mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-04 03:27:21 -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());
 | 
					                Console.WriteLine(version.ToString());
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            ServerApplicationPaths appPaths = createApplicationPaths(options);
 | 
					            ServerApplicationPaths appPaths = CreateApplicationPaths(options);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            // $JELLYFIN_LOG_DIR needs to be set for the logger configuration manager
 | 
					            // $JELLYFIN_LOG_DIR needs to be set for the logger configuration manager
 | 
				
			||||||
            Environment.SetEnvironmentVariable("JELLYFIN_LOG_DIR", appPaths.LogDirectoryPath);
 | 
					            Environment.SetEnvironmentVariable("JELLYFIN_LOG_DIR", appPaths.LogDirectoryPath);
 | 
				
			||||||
            await createLogger(appPaths);
 | 
					            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");
 | 
					            string programDataPath = Environment.GetEnvironmentVariable("JELLYFIN_DATA_PATH");
 | 
				
			||||||
            if (string.IsNullOrEmpty(programDataPath))
 | 
					            if (string.IsNullOrEmpty(programDataPath))
 | 
				
			||||||
@ -155,12 +156,21 @@ namespace Jellyfin.Server
 | 
				
			|||||||
                            programDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share");
 | 
					                            programDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local", "share");
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                    programDataPath = Path.Combine(programDataPath, "jellyfin");
 | 
					                    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");
 | 
					            string configDir = Environment.GetEnvironmentVariable("JELLYFIN_CONFIG_DIR");
 | 
				
			||||||
            if (string.IsNullOrEmpty(configDir))
 | 
					            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");
 | 
					            string logDir = Environment.GetEnvironmentVariable("JELLYFIN_LOG_DIR");
 | 
				
			||||||
            if (string.IsNullOrEmpty(logDir))
 | 
					            if (string.IsNullOrEmpty(logDir))
 | 
				
			||||||
            {
 | 
					            {
 | 
				
			||||||
@ -189,6 +204,11 @@ namespace Jellyfin.Server
 | 
				
			|||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if (string.IsNullOrEmpty(logDir))
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                Directory.CreateDirectory(logDir);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            string appPath = AppContext.BaseDirectory;
 | 
					            string appPath = AppContext.BaseDirectory;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            return new ServerApplicationPaths(programDataPath, appPath, appPath, logDir, configDir);
 | 
					            return new ServerApplicationPaths(programDataPath, appPath, appPath, logDir, configDir);
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user