diff options
| author | dkanada <dkanada@users.noreply.github.com> | 2020-06-22 22:08:43 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-06-22 22:08:43 +0900 |
| commit | 552a358c9c0e8787cf40fca17b0c8d1b41c92093 (patch) | |
| tree | 865a78811d669449e52525c4c88bc17650261756 /Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs | |
| parent | c3349038c4270c65caa46b148ef6802f083e5e19 (diff) | |
| parent | 3d65cbdf0794c71fe488564c782e6ca099db5312 (diff) | |
Merge pull request #3244 from jellyfin/custom-repos
Initial implementation for custom plugin repositories
Diffstat (limited to 'Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs')
| -rw-r--r-- | Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs b/Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs new file mode 100644 index 000000000..a9d5ad16a --- /dev/null +++ b/Jellyfin.Server/Migrations/Routines/AddDefaultPluginRepository.cs @@ -0,0 +1,42 @@ +using System; +using MediaBrowser.Controller.Configuration; +using MediaBrowser.Model.Updates; + +namespace Jellyfin.Server.Migrations.Routines +{ + /// <summary> + /// Migration to initialize system configuration with the default plugin repository. + /// </summary> + public class AddDefaultPluginRepository : IMigrationRoutine + { + private readonly IServerConfigurationManager _serverConfigurationManager; + + private readonly RepositoryInfo _defaultRepositoryInfo = new RepositoryInfo + { + Name = "Jellyfin Stable", + Url = "https://repo.jellyfin.org/releases/plugin/manifest-stable.json" + }; + + /// <summary> + /// Initializes a new instance of the <see cref="AddDefaultPluginRepository"/> class. + /// </summary> + /// <param name="serverConfigurationManager">Instance of the <see cref="IServerConfigurationManager"/> interface.</param> + public AddDefaultPluginRepository(IServerConfigurationManager serverConfigurationManager) + { + _serverConfigurationManager = serverConfigurationManager; + } + + /// <inheritdoc/> + public Guid Id => Guid.Parse("EB58EBEE-9514-4B9B-8225-12E1A40020DF"); + + /// <inheritdoc/> + public string Name => "AddDefaultPluginRepository"; + + /// <inheritdoc/> + public void Perform() + { + _serverConfigurationManager.Configuration.PluginRepositories.Add(_defaultRepositoryInfo); + _serverConfigurationManager.SaveConfiguration(); + } + } +} |
