Shell Environment Variables in config
Adding updated Nini and support to use shell environment variables in OpenSimulator configuration. Nini @ https://github.com/BlueWall/Nini-Deviar_mods
							parent
							
								
									b89c48b1be
								
							
						
					
					
						commit
						d4e3a7fe81
					
				|  | @ -70,7 +70,7 @@ namespace OpenSim | ||||||
|         /// <param name="networkInfo"></param> |         /// <param name="networkInfo"></param> | ||||||
|         /// <returns>A configuration that gets passed to modules</returns> |         /// <returns>A configuration that gets passed to modules</returns> | ||||||
|         public OpenSimConfigSource LoadConfigSettings( |         public OpenSimConfigSource LoadConfigSettings( | ||||||
|                 IConfigSource argvSource, out ConfigSettings configSettings, |                 IConfigSource argvSource, EnvConfigSource envConfigSource, out ConfigSettings configSettings, | ||||||
|                 out NetworkServersInfo networkInfo) |                 out NetworkServersInfo networkInfo) | ||||||
|         { |         { | ||||||
|             m_configSettings = configSettings = new ConfigSettings(); |             m_configSettings = configSettings = new ConfigSettings(); | ||||||
|  | @ -195,6 +195,24 @@ namespace OpenSim | ||||||
|             // Make sure command line options take precedence |             // Make sure command line options take precedence | ||||||
|             m_config.Source.Merge(argvSource); |             m_config.Source.Merge(argvSource); | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |             IConfig enVars = m_config.Source.Configs["Environment"]; | ||||||
|  | 
 | ||||||
|  |             if( enVars != null ) | ||||||
|  |             { | ||||||
|  |                 string[] env_keys = enVars.GetKeys(); | ||||||
|  | 
 | ||||||
|  |                 foreach ( string key in env_keys ) | ||||||
|  |                 { | ||||||
|  |                     envConfigSource.AddEnv(key, string.Empty); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 envConfigSource.LoadEnv(); | ||||||
|  |                 m_config.Source.Merge(envConfigSource); | ||||||
|  |                 m_config.Source.ExpandKeyValues(); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|             ReadConfigSettings(); |             ReadConfigSettings(); | ||||||
| 
 | 
 | ||||||
|             return m_config; |             return m_config; | ||||||
|  |  | ||||||
|  | @ -108,6 +108,13 @@ namespace OpenSim | ||||||
|             get { return m_clientServers; } |             get { return m_clientServers; } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         protected EnvConfigSource m_EnvConfigSource = new EnvConfigSource(); | ||||||
|  | 
 | ||||||
|  |         public EnvConfigSource envConfigSource | ||||||
|  |         { | ||||||
|  |             get { return m_EnvConfigSource; } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         protected List<IClientNetworkServer> m_clientServers = new List<IClientNetworkServer>(); |         protected List<IClientNetworkServer> m_clientServers = new List<IClientNetworkServer>(); | ||||||
|         |         | ||||||
|         public uint HttpServerPort |         public uint HttpServerPort | ||||||
|  | @ -142,7 +149,7 @@ namespace OpenSim | ||||||
|         protected virtual void LoadConfigSettings(IConfigSource configSource) |         protected virtual void LoadConfigSettings(IConfigSource configSource) | ||||||
|         { |         { | ||||||
|             m_configLoader = new ConfigurationLoader(); |             m_configLoader = new ConfigurationLoader(); | ||||||
|             m_config = m_configLoader.LoadConfigSettings(configSource, out m_configSettings, out m_networkServersInfo); |             m_config = m_configLoader.LoadConfigSettings(configSource, envConfigSource, out m_configSettings, out m_networkServersInfo); | ||||||
|             ReadExtraConfigSettings(); |             ReadExtraConfigSettings(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -109,11 +109,13 @@ namespace OpenSim.Tests | ||||||
|             // Prepare call to ConfigurationLoader.LoadConfigSettings() |             // Prepare call to ConfigurationLoader.LoadConfigSettings() | ||||||
|             ConfigurationLoader cl = new ConfigurationLoader(); |             ConfigurationLoader cl = new ConfigurationLoader(); | ||||||
|             IConfigSource argvSource = new IniConfigSource(); |             IConfigSource argvSource = new IniConfigSource(); | ||||||
|  |             EnvConfigSource envConfigSource = new EnvConfigSource(); | ||||||
|             argvSource.AddConfig("Startup").Set("inifile", mainIniFile); |             argvSource.AddConfig("Startup").Set("inifile", mainIniFile); | ||||||
|             ConfigSettings configSettings; |             ConfigSettings configSettings; | ||||||
|             NetworkServersInfo networkInfo; |             NetworkServersInfo networkInfo; | ||||||
| 
 | 
 | ||||||
|             OpenSimConfigSource source = cl.LoadConfigSettings(argvSource, out configSettings, out networkInfo); |             OpenSimConfigSource source = cl.LoadConfigSettings(argvSource, envConfigSource, | ||||||
|  |                 out configSettings, out networkInfo); | ||||||
| 
 | 
 | ||||||
|             // Remove default config |             // Remove default config | ||||||
|             config = source.Source.Configs["Startup"]; |             config = source.Source.Configs["Startup"]; | ||||||
|  |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								bin/Nini.dll
								
								
								
								
							
							
						
						
									
										
											BIN
										
									
								
								bin/Nini.dll
								
								
								
								
							
										
											Binary file not shown.
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	 BlueWall
						BlueWall