From f6d50c411f0008497f95e6e7e31eb7f04eb2c360 Mon Sep 17 00:00:00 2001 From: Bond_009 Date: Sat, 5 Jan 2019 21:16:47 +0100 Subject: [PATCH] Add env vars JELLYFIN_CONFIG_DIR and JELLYFIN_DATA_PATH --- Jellyfin.Server/Program.cs | 72 +++++++++++++++++++++----------------- 1 file changed, 39 insertions(+), 33 deletions(-) diff --git a/Jellyfin.Server/Program.cs b/Jellyfin.Server/Program.cs index 53eaacad09..eedc9f9ce6 100644 --- a/Jellyfin.Server/Program.cs +++ b/Jellyfin.Server/Program.cs @@ -102,56 +102,62 @@ namespace Jellyfin.Server private static ServerApplicationPaths createApplicationPaths(StartupOptions options) { - string programDataPath; - if (options.ContainsOption("-programdata")) + string programDataPath = Environment.GetEnvironmentVariable("JELLYFIN_DATA_PATH"); + if (string.IsNullOrEmpty(programDataPath)) { - programDataPath = options.GetOption("-programdata"); - } - else - { - if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)) + if (options.ContainsOption("-programdata")) { - programDataPath = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); + programDataPath = options.GetOption("-programdata"); } else { - // $XDG_DATA_HOME defines the base directory relative to which user specific data files should be stored. - programDataPath = Environment.GetEnvironmentVariable("XDG_DATA_HOME"); - // If $XDG_DATA_HOME is either not set or empty, $HOME/.local/share should be used. - if (string.IsNullOrEmpty(programDataPath)) + if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)) { - programDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share"); + programDataPath = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); } + else + { + // $XDG_DATA_HOME defines the base directory relative to which user specific data files should be stored. + programDataPath = Environment.GetEnvironmentVariable("XDG_DATA_HOME"); + // If $XDG_DATA_HOME is either not set or empty, $HOME/.local/share should be used. + if (string.IsNullOrEmpty(programDataPath)) + { + programDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share"); + } + } + programDataPath = Path.Combine(programDataPath, "jellyfin"); + // Ensure the dir exists + Directory.CreateDirectory(programDataPath); } - programDataPath = Path.Combine(programDataPath, "jellyfin"); - // Ensure the dir exists - Directory.CreateDirectory(programDataPath); } - string configPath; - if (options.ContainsOption("-configdir")) + string configDir = Environment.GetEnvironmentVariable("JELLYFIN_CONFIG_DIR"); + if (string.IsNullOrEmpty(configDir)) { - configPath = options.GetOption("-configdir"); - } - else - { - if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)) + if (options.ContainsOption("-configdir")) { - configPath = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); + configDir = options.GetOption("-configdir"); } else { - // $XDG_CONFIG_HOME defines the base directory relative to which user specific configuration files should be stored. - configPath = Environment.GetEnvironmentVariable("XDG_CONFIG_HOME"); - // If $XDG_CONFIG_HOME is either not set or empty, $HOME/.config should be used. - if (string.IsNullOrEmpty(configPath)) + if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)) { - configPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share"); + configDir = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); } + else + { + // $XDG_CONFIG_HOME defines the base directory relative to which user specific configuration files should be stored. + configDir = Environment.GetEnvironmentVariable("XDG_CONFIG_HOME"); + // If $XDG_CONFIG_HOME is either not set or empty, $HOME/.config should be used. + if (string.IsNullOrEmpty(configDir)) + { + configDir = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share"); + } + } + configDir = Path.Combine(configDir, "jellyfin"); + // Ensure the dir exists + Directory.CreateDirectory(configDir); } - configPath = Path.Combine(configPath, "jellyfin"); - // Ensure the dir exists - Directory.CreateDirectory(configPath); } string logDir = Environment.GetEnvironmentVariable("JELLYFIN_LOG_DIR"); @@ -173,7 +179,7 @@ namespace Jellyfin.Server string appPath = AppContext.BaseDirectory; - return new ServerApplicationPaths(programDataPath, appPath, appPath, logDir, configPath); + return new ServerApplicationPaths(programDataPath, appPath, appPath, logDir, configDir); } private static async Task createLogger(IApplicationPaths appPaths)