aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Common/Plugins/BasePlugin.cs
diff options
context:
space:
mode:
authorAndrew Rabert <ar@nullsum.net>2018-12-27 18:27:57 -0500
committerAndrew Rabert <ar@nullsum.net>2018-12-27 18:27:57 -0500
commita86b71899ec52c44ddc6c3018e8cc5e9d7ff4d62 (patch)
treea74f6ea4a8abfa1664a605d31d48bc38245ccf58 /MediaBrowser.Common/Plugins/BasePlugin.cs
parent9bac3ac616b01f67db98381feb09d34ebe821f9a (diff)
Add GPL modules
Diffstat (limited to 'MediaBrowser.Common/Plugins/BasePlugin.cs')
-rw-r--r--MediaBrowser.Common/Plugins/BasePlugin.cs276
1 files changed, 276 insertions, 0 deletions
diff --git a/MediaBrowser.Common/Plugins/BasePlugin.cs b/MediaBrowser.Common/Plugins/BasePlugin.cs
new file mode 100644
index 000000000..82eb6ba4b
--- /dev/null
+++ b/MediaBrowser.Common/Plugins/BasePlugin.cs
@@ -0,0 +1,276 @@
+using MediaBrowser.Common.Configuration;
+using MediaBrowser.Model.Plugins;
+using MediaBrowser.Model.Serialization;
+using System;
+using System.IO;
+
+namespace MediaBrowser.Common.Plugins
+{
+ public abstract class BasePlugin : IPlugin, IPluginAssembly
+ {
+ /// <summary>
+ /// Gets the name of the plugin
+ /// </summary>
+ /// <value>The name.</value>
+ public abstract string Name { get; }
+
+ /// <summary>
+ /// Gets the description.
+ /// </summary>
+ /// <value>The description.</value>
+ public virtual string Description
+ {
+ get { return string.Empty; }
+ }
+
+ /// <summary>
+ /// Gets the unique id.
+ /// </summary>
+ /// <value>The unique id.</value>
+ public virtual Guid Id { get; private set; }
+
+ /// <summary>
+ /// Gets the plugin version
+ /// </summary>
+ /// <value>The version.</value>
+ public Version Version { get; private set; }
+
+ /// <summary>
+ /// Gets the path to the assembly file
+ /// </summary>
+ /// <value>The assembly file path.</value>
+ public string AssemblyFilePath { get; private set; }
+
+ /// <summary>
+ /// Gets the plugin info.
+ /// </summary>
+ /// <returns>PluginInfo.</returns>
+ public virtual PluginInfo GetPluginInfo()
+ {
+ var info = new PluginInfo
+ {
+ Name = Name,
+ Version = Version.ToString(),
+ Description = Description,
+ Id = Id.ToString()
+ };
+
+ return info;
+ }
+
+ /// <summary>
+ /// Called when just before the plugin is uninstalled from the server.
+ /// </summary>
+ public virtual void OnUninstalling()
+ {
+
+ }
+
+ public void SetAttributes(string assemblyFilePath, string dataFolderPath, Version assemblyVersion)
+ {
+ AssemblyFilePath = assemblyFilePath;
+ DataFolderPath = dataFolderPath;
+ Version = assemblyVersion;
+ }
+
+ public void SetId(Guid assemblyId)
+ {
+ Id = assemblyId;
+ }
+
+ /// <summary>
+ /// Gets the full path to the data folder, where the plugin can store any miscellaneous files needed
+ /// </summary>
+ /// <value>The data folder path.</value>
+ public string DataFolderPath { get; private set; }
+ }
+
+ /// <summary>
+ /// Provides a common base class for all plugins
+ /// </summary>
+ /// <typeparam name="TConfigurationType">The type of the T configuration type.</typeparam>
+ public abstract class BasePlugin<TConfigurationType> : BasePlugin, IHasPluginConfiguration
+ where TConfigurationType : BasePluginConfiguration
+ {
+ /// <summary>
+ /// Gets the application paths.
+ /// </summary>
+ /// <value>The application paths.</value>
+ protected IApplicationPaths ApplicationPaths { get; private set; }
+
+ /// <summary>
+ /// Gets the XML serializer.
+ /// </summary>
+ /// <value>The XML serializer.</value>
+ protected IXmlSerializer XmlSerializer { get; private set; }
+
+ /// <summary>
+ /// Gets the type of configuration this plugin uses
+ /// </summary>
+ /// <value>The type of the configuration.</value>
+ public Type ConfigurationType
+ {
+ get { return typeof(TConfigurationType); }
+ }
+
+ private Action<string> _directoryCreateFn;
+ public void SetStartupInfo(Action<string> directoryCreateFn)
+ {
+ // hack alert, until the .net core transition is complete
+ _directoryCreateFn = directoryCreateFn;
+ }
+
+ /// <summary>
+ /// Gets the name the assembly file
+ /// </summary>
+ /// <value>The name of the assembly file.</value>
+ protected string AssemblyFileName
+ {
+ get
+ {
+ return Path.GetFileName(AssemblyFilePath);
+ }
+ }
+
+ /// <summary>
+ /// The _configuration sync lock
+ /// </summary>
+ private readonly object _configurationSyncLock = new object();
+ /// <summary>
+ /// The _configuration
+ /// </summary>
+ private TConfigurationType _configuration;
+ /// <summary>
+ /// Gets the plugin's configuration
+ /// </summary>
+ /// <value>The configuration.</value>
+ public TConfigurationType Configuration
+ {
+ get
+ {
+ // Lazy load
+ if (_configuration == null)
+ {
+ lock (_configurationSyncLock)
+ {
+ if (_configuration == null)
+ {
+ _configuration = LoadConfiguration();
+ }
+ }
+ }
+ return _configuration;
+ }
+ protected set
+ {
+ _configuration = value;
+ }
+ }
+
+ private TConfigurationType LoadConfiguration()
+ {
+ var path = ConfigurationFilePath;
+
+ try
+ {
+ return (TConfigurationType)XmlSerializer.DeserializeFromFile(typeof(TConfigurationType), path);
+ }
+ catch
+ {
+ return (TConfigurationType)Activator.CreateInstance(typeof(TConfigurationType));
+ }
+ }
+
+ /// <summary>
+ /// Gets the name of the configuration file. Subclasses should override
+ /// </summary>
+ /// <value>The name of the configuration file.</value>
+ public virtual string ConfigurationFileName
+ {
+ get { return Path.ChangeExtension(AssemblyFileName, ".xml"); }
+ }
+
+ /// <summary>
+ /// Gets the full path to the configuration file
+ /// </summary>
+ /// <value>The configuration file path.</value>
+ public string ConfigurationFilePath
+ {
+ get
+ {
+ return Path.Combine(ApplicationPaths.PluginConfigurationsPath, ConfigurationFileName);
+ }
+ }
+
+ /// <summary>
+ /// Initializes a new instance of the <see cref="BasePlugin{TConfigurationType}" /> class.
+ /// </summary>
+ /// <param name="applicationPaths">The application paths.</param>
+ /// <param name="xmlSerializer">The XML serializer.</param>
+ protected BasePlugin(IApplicationPaths applicationPaths, IXmlSerializer xmlSerializer)
+ {
+ ApplicationPaths = applicationPaths;
+ XmlSerializer = xmlSerializer;
+ }
+
+ /// <summary>
+ /// The _save lock
+ /// </summary>
+ private readonly object _configurationSaveLock = new object();
+
+ /// <summary>
+ /// Saves the current configuration to the file system
+ /// </summary>
+ public virtual void SaveConfiguration()
+ {
+ lock (_configurationSaveLock)
+ {
+ _directoryCreateFn(Path.GetDirectoryName(ConfigurationFilePath));
+
+ XmlSerializer.SerializeToFile(Configuration, ConfigurationFilePath);
+ }
+ }
+
+ /// <summary>
+ /// Completely overwrites the current configuration with a new copy
+ /// Returns true or false indicating success or failure
+ /// </summary>
+ /// <param name="configuration">The configuration.</param>
+ /// <exception cref="System.ArgumentNullException">configuration</exception>
+ public virtual void UpdateConfiguration(BasePluginConfiguration configuration)
+ {
+ if (configuration == null)
+ {
+ throw new ArgumentNullException("configuration");
+ }
+
+ Configuration = (TConfigurationType)configuration;
+
+ SaveConfiguration();
+ }
+
+ /// <summary>
+ /// Gets the plugin's configuration
+ /// </summary>
+ /// <value>The configuration.</value>
+ BasePluginConfiguration IHasPluginConfiguration.Configuration
+ {
+ get { return Configuration; }
+ }
+
+ public override PluginInfo GetPluginInfo()
+ {
+ var info = base.GetPluginInfo();
+
+ info.ConfigurationFileName = ConfigurationFileName;
+
+ return info;
+ }
+ }
+
+ public interface IPluginAssembly
+ {
+ void SetAttributes(string assemblyFilePath, string dataFolderPath, Version assemblyVersion);
+ void SetId(Guid assemblyId);
+ }
+}