aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.WebDashboard/Api/DashboardService.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.WebDashboard/Api/DashboardService.cs')
-rw-r--r--MediaBrowser.WebDashboard/Api/DashboardService.cs30
1 files changed, 18 insertions, 12 deletions
diff --git a/MediaBrowser.WebDashboard/Api/DashboardService.cs b/MediaBrowser.WebDashboard/Api/DashboardService.cs
index c6bbca672..47662b509 100644
--- a/MediaBrowser.WebDashboard/Api/DashboardService.cs
+++ b/MediaBrowser.WebDashboard/Api/DashboardService.cs
@@ -32,6 +32,7 @@ namespace MediaBrowser.WebDashboard.Api
/// </summary>
/// <value>The type of the page.</value>
public ConfigurationPageType? PageType { get; set; }
+ public bool? EnableInMainMenu { get; set; }
}
/// <summary>
@@ -47,13 +48,13 @@ namespace MediaBrowser.WebDashboard.Api
public string Name { get; set; }
}
- [Route("/web/Package", "GET")]
+ [Route("/web/Package", "GET", IsHidden = true)]
public class GetDashboardPackage
{
public string Mode { get; set; }
}
- [Route("/robots.txt", "GET")]
+ [Route("/robots.txt", "GET", IsHidden = true)]
public class GetRobotsTxt
{
}
@@ -61,7 +62,7 @@ namespace MediaBrowser.WebDashboard.Api
/// <summary>
/// Class GetDashboardResource
/// </summary>
- [Route("/web/{ResourceName*}", "GET")]
+ [Route("/web/{ResourceName*}", "GET", IsHidden = true)]
public class GetDashboardResource
{
/// <summary>
@@ -76,7 +77,7 @@ namespace MediaBrowser.WebDashboard.Api
public string V { get; set; }
}
- [Route("/favicon.ico", "GET")]
+ [Route("/favicon.ico", "GET", IsHidden = true)]
public class GetFavIcon
{
}
@@ -221,25 +222,20 @@ namespace MediaBrowser.WebDashboard.Api
/// <returns>System.Object.</returns>
public object Get(GetDashboardConfigurationPages request)
{
- const string unavilableMessage = "The server is still loading. Please try again momentarily.";
+ const string unavailableMessage = "The server is still loading. Please try again momentarily.";
var instance = ServerEntryPoint.Instance;
if (instance == null)
{
- throw new InvalidOperationException(unavilableMessage);
+ throw new InvalidOperationException(unavailableMessage);
}
var pages = instance.PluginConfigurationPages;
if (pages == null)
{
- throw new InvalidOperationException(unavilableMessage);
- }
-
- if (request.PageType.HasValue)
- {
- pages = pages.Where(p => p.ConfigurationPageType == request.PageType.Value).ToList();
+ throw new InvalidOperationException(unavailableMessage);
}
// Don't allow a failing plugin to fail them all
@@ -261,6 +257,16 @@ namespace MediaBrowser.WebDashboard.Api
configPages.AddRange(_appHost.Plugins.SelectMany(GetConfigPages));
+ if (request.PageType.HasValue)
+ {
+ configPages = configPages.Where(p => p.ConfigurationPageType == request.PageType.Value).ToList();
+ }
+
+ if (request.EnableInMainMenu.HasValue)
+ {
+ configPages = configPages.Where(p => p.EnableInMainMenu == request.EnableInMainMenu.Value).ToList();
+ }
+
return _resultFactory.GetOptimizedResult(Request, configPages);
}