From c8a38c139f2d7e854c8dfc9c38641e1ceeff6d9e Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Sat, 16 May 2015 15:09:02 -0400 Subject: lazy load scripts --- MediaBrowser.Api/PluginService.cs | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'MediaBrowser.Api/PluginService.cs') diff --git a/MediaBrowser.Api/PluginService.cs b/MediaBrowser.Api/PluginService.cs index 4bd78f1f5..2fbf65f3f 100644 --- a/MediaBrowser.Api/PluginService.cs +++ b/MediaBrowser.Api/PluginService.cs @@ -25,6 +25,7 @@ namespace MediaBrowser.Api [Authenticated] public class GetPlugins : IReturn> { + public bool? IsAppStoreEnabled { get; set; } } /// @@ -181,6 +182,7 @@ namespace MediaBrowser.Api public async Task Get(GetPlugins request) { var result = _appHost.Plugins.OrderBy(p => p.Name).Select(p => p.GetPluginInfo()).ToList(); + var requireAppStoreEnabled = request.IsAppStoreEnabled.HasValue && request.IsAppStoreEnabled.Value; // Don't fail just on account of image url's try @@ -197,10 +199,26 @@ namespace MediaBrowser.Api plugin.ImageUrl = pkg.thumbImage; } } + + if (requireAppStoreEnabled) + { + result = result + .Where(plugin => + { + var pkg = packages.FirstOrDefault(i => !string.IsNullOrWhiteSpace(i.guid) && new Guid(plugin.Id).Equals(new Guid(i.guid))); + return pkg != null && pkg.enableInAppStore; + + }) + .ToList(); + } } catch { - + // Play it safe here + if (requireAppStoreEnabled) + { + result = new List(); + } } return ToOptimizedSerializedResultUsingCache(result); -- cgit v1.2.3