mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-03 19:17:24 -05:00 
			
		
		
		
	Ensure all folders are created before running app
This commit is contained in:
		
							parent
							
								
									7aa975325a
								
							
						
					
					
						commit
						04d03c5cf9
					
				@ -45,7 +45,8 @@ namespace Jellyfin.Server
 | 
			
		||||
                Console.WriteLine(version.ToString());
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            ServerApplicationPaths appPaths = createApplicationPaths(options);
 | 
			
		||||
            ServerApplicationPaths appPaths = CreateApplicationPaths(options);
 | 
			
		||||
 | 
			
		||||
            // $JELLYFIN_LOG_DIR needs to be set for the logger configuration manager
 | 
			
		||||
            Environment.SetEnvironmentVariable("JELLYFIN_LOG_DIR", appPaths.LogDirectoryPath);
 | 
			
		||||
            await createLogger(appPaths);
 | 
			
		||||
@ -130,7 +131,7 @@ namespace Jellyfin.Server
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        private static ServerApplicationPaths createApplicationPaths(StartupOptions options)
 | 
			
		||||
        private static ServerApplicationPaths CreateApplicationPaths(StartupOptions options)
 | 
			
		||||
        {
 | 
			
		||||
            string programDataPath = Environment.GetEnvironmentVariable("JELLYFIN_DATA_PATH");
 | 
			
		||||
            if (string.IsNullOrEmpty(programDataPath))
 | 
			
		||||
@ -155,12 +156,21 @@ namespace Jellyfin.Server
 | 
			
		||||
                            programDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share");
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    programDataPath = Path.Combine(programDataPath, "jellyfin");
 | 
			
		||||
                    // Ensure the dir exists
 | 
			
		||||
                    Directory.CreateDirectory(programDataPath);
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (string.IsNullOrEmpty(programDataPath))
 | 
			
		||||
            {
 | 
			
		||||
                Console.WriteLine("Cannot continue without path to program data folder (try -programdata)");
 | 
			
		||||
                Environment.Exit(1);
 | 
			
		||||
            }
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                Directory.CreateDirectory(programDataPath);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            string configDir = Environment.GetEnvironmentVariable("JELLYFIN_CONFIG_DIR");
 | 
			
		||||
            if (string.IsNullOrEmpty(configDir))
 | 
			
		||||
            {
 | 
			
		||||
@ -175,6 +185,11 @@ namespace Jellyfin.Server
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (string.IsNullOrEmpty(configDir))
 | 
			
		||||
            {
 | 
			
		||||
                Directory.CreateDirectory(configDir);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            string logDir = Environment.GetEnvironmentVariable("JELLYFIN_LOG_DIR");
 | 
			
		||||
            if (string.IsNullOrEmpty(logDir))
 | 
			
		||||
            {
 | 
			
		||||
@ -189,6 +204,11 @@ namespace Jellyfin.Server
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (string.IsNullOrEmpty(logDir))
 | 
			
		||||
            {
 | 
			
		||||
                Directory.CreateDirectory(logDir);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            string appPath = AppContext.BaseDirectory;
 | 
			
		||||
 | 
			
		||||
            return new ServerApplicationPaths(programDataPath, appPath, appPath, logDir, configDir);
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user