|
@@ -51,7 +51,6 @@ namespace Jellyfin.Api.Controllers
|
|
|
/// Gets the configuration pages.
|
|
|
/// </summary>
|
|
|
/// <param name="enableInMainMenu">Whether to enable in the main menu.</param>
|
|
|
- /// <param name="pageType">The <see cref="ConfigurationPageInfo"/>.</param>
|
|
|
/// <response code="200">ConfigurationPages returned.</response>
|
|
|
/// <response code="404">Server still loading.</response>
|
|
|
/// <returns>An <see cref="IEnumerable{ConfigurationPageInfo}"/> with infos about the plugins.</returns>
|
|
@@ -59,40 +58,9 @@ namespace Jellyfin.Api.Controllers
|
|
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
|
|
[ProducesResponseType(StatusCodes.Status404NotFound)]
|
|
|
public ActionResult<IEnumerable<ConfigurationPageInfo?>> GetConfigurationPages(
|
|
|
- [FromQuery] bool? enableInMainMenu,
|
|
|
- [FromQuery] ConfigurationPageType? pageType)
|
|
|
+ [FromQuery] bool? enableInMainMenu)
|
|
|
{
|
|
|
- const string unavailableMessage = "The server is still loading. Please try again momentarily.";
|
|
|
-
|
|
|
- var pages = _appHost.GetExports<IPluginConfigurationPage>().ToList();
|
|
|
-
|
|
|
- if (pages == null)
|
|
|
- {
|
|
|
- return NotFound(unavailableMessage);
|
|
|
- }
|
|
|
-
|
|
|
- // Don't allow a failing plugin to fail them all
|
|
|
- var configPages = pages.Select(p =>
|
|
|
- {
|
|
|
- try
|
|
|
- {
|
|
|
- return new ConfigurationPageInfo(p);
|
|
|
- }
|
|
|
- catch (Exception ex)
|
|
|
- {
|
|
|
- _logger.LogError(ex, "Error getting plugin information from {Plugin}", p.GetType().Name);
|
|
|
- return null;
|
|
|
- }
|
|
|
- })
|
|
|
- .Where(i => i != null)
|
|
|
- .ToList();
|
|
|
-
|
|
|
- configPages.AddRange(_pluginManager.Plugins.SelectMany(GetConfigPages));
|
|
|
-
|
|
|
- if (pageType.HasValue)
|
|
|
- {
|
|
|
- configPages = configPages.Where(p => p!.ConfigurationPageType == pageType).ToList();
|
|
|
- }
|
|
|
+ var configPages = _pluginManager.Plugins.SelectMany(GetConfigPages).ToList();
|
|
|
|
|
|
if (enableInMainMenu.HasValue)
|
|
|
{
|
|
@@ -121,24 +89,14 @@ namespace Jellyfin.Api.Controllers
|
|
|
var isJs = false;
|
|
|
var isTemplate = false;
|
|
|
|
|
|
- var page = _appHost.GetExports<IPluginConfigurationPage>().FirstOrDefault(p => string.Equals(p.Name, name, StringComparison.OrdinalIgnoreCase));
|
|
|
- if (page != null)
|
|
|
- {
|
|
|
- plugin = page.Plugin;
|
|
|
- stream = page.GetHtmlStream();
|
|
|
- }
|
|
|
-
|
|
|
- if (plugin == null)
|
|
|
+ var altPage = GetPluginPages().FirstOrDefault(p => string.Equals(p.Item1.Name, name, StringComparison.OrdinalIgnoreCase));
|
|
|
+ if (altPage != null)
|
|
|
{
|
|
|
- var altPage = GetPluginPages().FirstOrDefault(p => string.Equals(p.Item1.Name, name, StringComparison.OrdinalIgnoreCase));
|
|
|
- if (altPage != null)
|
|
|
- {
|
|
|
- plugin = altPage.Item2;
|
|
|
- stream = plugin.GetType().Assembly.GetManifestResourceStream(altPage.Item1.EmbeddedResourcePath);
|
|
|
+ plugin = altPage.Item2;
|
|
|
+ stream = plugin.GetType().Assembly.GetManifestResourceStream(altPage.Item1.EmbeddedResourcePath);
|
|
|
|
|
|
- isJs = string.Equals(Path.GetExtension(altPage.Item1.EmbeddedResourcePath), ".js", StringComparison.OrdinalIgnoreCase);
|
|
|
- isTemplate = altPage.Item1.EmbeddedResourcePath.EndsWith(".template.html", StringComparison.Ordinal);
|
|
|
- }
|
|
|
+ isJs = string.Equals(Path.GetExtension(altPage.Item1.EmbeddedResourcePath), ".js", StringComparison.OrdinalIgnoreCase);
|
|
|
+ isTemplate = altPage.Item1.EmbeddedResourcePath.EndsWith(".template.html", StringComparison.Ordinal);
|
|
|
}
|
|
|
|
|
|
if (plugin != null && stream != null)
|