aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common/Plugins/PluginController.cs
diff options
context:
space:
mode:
authorLukePulverenti Luke Pulverenti luke pulverenti <LukePulverenti Luke Pulverenti luke.pulverenti@gmail.com>2012-07-24 10:54:34 -0400
committerLukePulverenti Luke Pulverenti luke pulverenti <LukePulverenti Luke Pulverenti luke.pulverenti@gmail.com>2012-07-24 10:54:34 -0400
commit84af205572e6ab9ca3e10f6de33cbce278e01335 (patch)
tree0cb89ab3a9d3ff67f85894096e592a959c3ff9b0 /MediaBrowser.Common/Plugins/PluginController.cs
parent6c7175e33d258ff2e65735f68cb05f110a8d2306 (diff)
Added new api handlers to get plugin information
Diffstat (limited to 'MediaBrowser.Common/Plugins/PluginController.cs')
-rw-r--r--MediaBrowser.Common/Plugins/PluginController.cs38
1 files changed, 28 insertions, 10 deletions
diff --git a/MediaBrowser.Common/Plugins/PluginController.cs b/MediaBrowser.Common/Plugins/PluginController.cs
index 1f83d485b..c26275436 100644
--- a/MediaBrowser.Common/Plugins/PluginController.cs
+++ b/MediaBrowser.Common/Plugins/PluginController.cs
@@ -18,7 +18,7 @@ namespace MediaBrowser.Common.Plugins
/// <summary>
/// Gets the list of currently loaded plugins
/// </summary>
- public IEnumerable<IPlugin> Plugins { get; private set; }
+ public IEnumerable<BasePlugin> Plugins { get; private set; }
/// <summary>
/// Initializes the controller
@@ -32,7 +32,21 @@ namespace MediaBrowser.Common.Plugins
Parallel.For(0, Plugins.Count(), i =>
{
- Plugins.ElementAt(i).Init();
+ var plugin = Plugins.ElementAt(i);
+
+ plugin.ReloadConfiguration();
+
+ if (plugin.Enabled)
+ {
+ if (context == KernelContext.Server)
+ {
+ plugin.InitInServer();
+ }
+ else
+ {
+ plugin.InitInUI();
+ }
+ }
});
}
@@ -40,18 +54,18 @@ namespace MediaBrowser.Common.Plugins
/// Gets all plugins within PluginsPath
/// </summary>
/// <returns></returns>
- private IEnumerable<IPlugin> GetAllPlugins()
+ private IEnumerable<BasePlugin> GetAllPlugins()
{
if (!Directory.Exists(PluginsPath))
{
Directory.CreateDirectory(PluginsPath);
}
- List<IPlugin> plugins = new List<IPlugin>();
+ List<BasePlugin> plugins = new List<BasePlugin>();
foreach (string folder in Directory.GetDirectories(PluginsPath, "*", SearchOption.TopDirectoryOnly))
{
- IPlugin plugin = GetPluginFromDirectory(folder);
+ BasePlugin plugin = GetPluginFromDirectory(folder);
plugin.Path = folder;
@@ -64,7 +78,7 @@ namespace MediaBrowser.Common.Plugins
return plugins;
}
- private IPlugin GetPluginFromDirectory(string path)
+ private BasePlugin GetPluginFromDirectory(string path)
{
string dll = Directory.GetFiles(path, "*.dll", SearchOption.TopDirectoryOnly).FirstOrDefault();
@@ -76,18 +90,22 @@ namespace MediaBrowser.Common.Plugins
return null;
}
- private IPlugin GetPluginFromDll(string path)
+ private BasePlugin GetPluginFromDll(string path)
{
return GetPluginFromDll(Assembly.Load(File.ReadAllBytes(path)));
}
- private IPlugin GetPluginFromDll(Assembly assembly)
+ private BasePlugin GetPluginFromDll(Assembly assembly)
{
- var plugin = assembly.GetTypes().Where(type => typeof(IPlugin).IsAssignableFrom(type)).FirstOrDefault();
+ var plugin = assembly.GetTypes().Where(type => typeof(BasePlugin).IsAssignableFrom(type)).FirstOrDefault();
if (plugin != null)
{
- return plugin.GetConstructor(Type.EmptyTypes).Invoke(null) as IPlugin;
+ BasePlugin instance = plugin.GetConstructor(Type.EmptyTypes).Invoke(null) as BasePlugin;
+
+ instance.Version = assembly.GetName().Version;
+
+ return instance;
}
return null;