2 // System.Configuration.InternalConfigurationHost.cs
5 // Lluis Sanchez Gual (lluis@novell.com)
7 // Permission is hereby granted, free of charge, to any person obtaining
8 // a copy of this software and associated documentation files (the
9 // "Software"), to deal in the Software without restriction, including
10 // without limitation the rights to use, copy, modify, merge, publish,
11 // distribute, sublicense, and/or sell copies of the Software, and to
12 // permit persons to whom the Software is furnished to do so, subject to
13 // the following conditions:
15 // The above copyright notice and this permission notice shall be
16 // included in all copies or substantial portions of the Software.
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
21 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
22 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
23 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
24 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 // Copyright (C) 2005 Novell, Inc (http://www.novell.com)
33 using System.Security;
34 using System.Configuration.Internal;
35 using System.Runtime.CompilerServices;
37 namespace System.Configuration
39 abstract class InternalConfigurationHost: IInternalConfigHost
41 public virtual object CreateConfigurationContext (string configPath, string locationSubPath)
46 public virtual object CreateDeprecatedConfigContext (string configPath)
51 public virtual void DeleteStream (string streamName)
53 File.Delete (streamName);
56 string IInternalConfigHost.DecryptSection (string encryptedXml, ProtectedConfigurationProvider protectionProvider, ProtectedConfigurationSection protectedSection)
58 return protectedSection.DecryptSection (encryptedXml, protectionProvider);
61 string IInternalConfigHost.EncryptSection (string clearXml, ProtectedConfigurationProvider protectionProvider, ProtectedConfigurationSection protectedSection)
63 return protectedSection.EncryptSection (clearXml, protectionProvider);
66 public virtual string GetConfigPathFromLocationSubPath (string configPath, string locationSubPath)
71 public virtual Type GetConfigType (string typeName, bool throwOnError)
73 Type type = Type.GetType (typeName);
74 if (type == null && throwOnError)
75 throw new ConfigurationErrorsException ("Type '" + typeName + "' not found.");
79 public virtual string GetConfigTypeName (Type t)
81 return t.AssemblyQualifiedName;
84 public virtual void GetRestrictedPermissions (IInternalConfigRecord configRecord, out PermissionSet permissionSet, out bool isHostReady)
86 throw new NotImplementedException ();
89 public abstract string GetStreamName (string configPath);
90 public abstract void Init (IInternalConfigRoot root, params object[] hostInitParams);
91 public abstract void InitForConfiguration (ref string locationSubPath, out string configPath, out string locationConfigPath, IInternalConfigRoot root, params object[] hostInitConfigurationParams);
93 [MonoNotSupported ("mono does not support remote configuration")]
94 public virtual string GetStreamNameForConfigSource (string streamName, string configSource)
96 throw new NotSupportedException ("mono does not support remote configuration");
99 public virtual object GetStreamVersion (string streamName)
101 throw new NotImplementedException ();
104 public virtual IDisposable Impersonate ()
106 throw new NotImplementedException ();
109 public virtual bool IsAboveApplication (string configPath)
111 throw new NotImplementedException ();
114 public virtual bool IsConfigRecordRequired (string configPath)
116 throw new NotImplementedException ();
119 public virtual bool IsDefinitionAllowed (string configPath, ConfigurationAllowDefinition allowDefinition, ConfigurationAllowExeDefinition allowExeDefinition)
121 switch (allowDefinition) {
122 case ConfigurationAllowDefinition.MachineOnly:
123 return configPath == "machine";
124 case ConfigurationAllowDefinition.MachineToApplication:
125 return configPath == "machine" || configPath == "exe";
131 public virtual bool IsFile (string streamName)
133 throw new NotImplementedException ();
136 public virtual bool IsFullTrustSectionWithoutAptcaAllowed (IInternalConfigRecord configRecord)
138 throw new NotImplementedException ();
141 public virtual bool IsInitDelayed (IInternalConfigRecord configRecord)
143 throw new NotImplementedException ();
146 public virtual bool IsLocationApplicable (string configPath)
148 throw new NotImplementedException ();
151 public virtual bool IsRemote {
153 throw new NotImplementedException ();
157 public virtual bool IsSecondaryRoot (string configPath)
159 throw new NotImplementedException ();
162 public virtual bool IsTrustedConfigPath (string configPath)
164 throw new NotImplementedException ();
167 [MethodImplAttribute(MethodImplOptions.InternalCall)]
168 extern private static string get_bundled_machine_config ();
170 [MethodImplAttribute(MethodImplOptions.InternalCall)]
171 extern private static string get_bundled_app_config ();
174 public virtual Stream OpenStreamForRead (string streamName)
176 if (String.CompareOrdinal (streamName, System.Runtime.InteropServices.RuntimeEnvironment.SystemConfigurationFile) == 0) {
178 return (Stream) vmw.common.IOUtils.getStreamForGHConfigs (streamName);
180 string bundle = get_bundled_machine_config ();
182 return new MemoryStream (System.Text.Encoding.UTF8.GetBytes (bundle));
186 if (String.CompareOrdinal (streamName, AppDomain.CurrentDomain.SetupInformation.ConfigurationFile) == 0) {
188 throw new NotImplementedException();
190 string bundle = get_bundled_app_config ();
192 return new MemoryStream (System.Text.Encoding.UTF8.GetBytes (bundle));
196 if (!File.Exists (streamName))
199 return new FileStream (streamName, FileMode.Open, FileAccess.Read);
202 public virtual Stream OpenStreamForRead (string streamName, bool assertPermissions)
204 throw new NotImplementedException ();
207 public virtual Stream OpenStreamForWrite (string streamName, string templateStreamName, ref object writeContext)
209 string dir = Path.GetDirectoryName (streamName);
210 if (!String.IsNullOrEmpty (dir) && !Directory.Exists (dir))
211 Directory.CreateDirectory (dir);
212 return new FileStream (streamName, FileMode.Create, FileAccess.Write);
215 public virtual Stream OpenStreamForWrite (string streamName, string templateStreamName, ref object writeContext, bool assertPermissions)
217 throw new NotImplementedException ();
220 public virtual bool PrefetchAll (string configPath, string streamName)
222 throw new NotImplementedException ();
225 public virtual bool PrefetchSection (string sectionGroupName, string sectionName)
227 throw new NotImplementedException ();
230 public virtual void RequireCompleteInit (IInternalConfigRecord configRecord)
232 throw new NotImplementedException ();
235 public virtual object StartMonitoringStreamForChanges (string streamName, StreamChangeCallback callback)
237 throw new NotImplementedException ();
240 public virtual void StopMonitoringStreamForChanges (string streamName, StreamChangeCallback callback)
242 throw new NotImplementedException ();
245 public virtual void VerifyDefinitionAllowed (string configPath, ConfigurationAllowDefinition allowDefinition, ConfigurationAllowExeDefinition allowExeDefinition, IConfigErrorInfo errorInfo)
247 if (!IsDefinitionAllowed (configPath, allowDefinition, allowExeDefinition))
248 throw new ConfigurationErrorsException ("The section can't be defined in this file (the allowed definition context is '" + allowDefinition + "').", errorInfo.Filename, errorInfo.LineNumber);
251 public virtual void WriteCompleted (string streamName, bool success, object writeContext)
255 public virtual void WriteCompleted (string streamName, bool success, object writeContext, bool assertPermissions)
259 public virtual bool SupportsChangeNotifications {
260 get { return false; }
263 public virtual bool SupportsLocation {
264 get { return false; }
267 public virtual bool SupportsPath {
268 get { return false; }
271 public virtual bool SupportsRefresh {
272 get { return false; }
276 class ExeConfigurationHost: InternalConfigurationHost
278 ExeConfigurationFileMap map;
279 ConfigurationUserLevel level;
281 public override void Init (IInternalConfigRoot root, params object[] hostInitParams)
283 map = (ExeConfigurationFileMap) hostInitParams [0];
284 level = (ConfigurationUserLevel) hostInitParams [1];
287 public override string GetStreamName (string configPath)
289 switch (configPath) {
290 case "exe": return map.ExeConfigFilename;
291 case "local": return map.LocalUserConfigFilename;
292 case "roaming": return map.RoamingUserConfigFilename;
293 case "machine": return map.MachineConfigFilename;
294 default://return map.ExeConfigFilename;
296 case ConfigurationUserLevel.None:
297 return map.ExeConfigFilename;
298 case ConfigurationUserLevel.PerUserRoaming:
299 return map.RoamingUserConfigFilename;
300 case ConfigurationUserLevel.PerUserRoamingAndLocal:
301 return map.LocalUserConfigFilename;
303 return map.MachineConfigFilename;
308 public override void InitForConfiguration (ref string locationSubPath, out string configPath, out string locationConfigPath, IInternalConfigRoot root, params object[] hostInitConfigurationParams)
310 map = (ExeConfigurationFileMap) hostInitConfigurationParams [0];
312 if (hostInitConfigurationParams.Length > 1 &&
313 hostInitConfigurationParams [1] is ConfigurationUserLevel)
314 level = (ConfigurationUserLevel) hostInitConfigurationParams [1];
315 if (locationSubPath == null)
317 case ConfigurationUserLevel.PerUserRoaming:
318 if (map.RoamingUserConfigFilename == null)
319 throw new ArgumentException ("RoamingUserConfigFilename must be set correctly");
320 locationSubPath = "roaming";
322 case ConfigurationUserLevel.PerUserRoamingAndLocal:
323 if (map.LocalUserConfigFilename == null)
324 throw new ArgumentException ("LocalUserConfigFilename must be set correctly");
325 locationSubPath = "local";
332 locationConfigPath = null;
334 if (locationSubPath == "exe" || locationSubPath == null && map.ExeConfigFilename != null) {
337 locationConfigPath = map.ExeConfigFilename;
340 if (locationSubPath == "local" && map.LocalUserConfigFilename != null) {
341 configPath = "local";
343 locationConfigPath = map.LocalUserConfigFilename;
346 if (locationSubPath == "roaming" && map.RoamingUserConfigFilename != null) {
347 configPath = "roaming";
349 locationConfigPath = map.RoamingUserConfigFilename;
352 if ((locationSubPath == "machine" || configPath == null) && map.MachineConfigFilename != null) {
353 configPath = "machine";
356 locationSubPath = next;
360 class MachineConfigurationHost: InternalConfigurationHost
362 ConfigurationFileMap map;
364 public override void Init (IInternalConfigRoot root, params object[] hostInitParams)
366 map = (ConfigurationFileMap) hostInitParams [0];
369 public override string GetStreamName (string configPath)
371 return map.MachineConfigFilename;
374 public override void InitForConfiguration (ref string locationSubPath, out string configPath, out string locationConfigPath, IInternalConfigRoot root, params object[] hostInitConfigurationParams)
376 map = (ConfigurationFileMap) hostInitConfigurationParams [0];
377 locationSubPath = null;
379 locationConfigPath = null;
382 public override bool IsDefinitionAllowed (string configPath, ConfigurationAllowDefinition allowDefinition, ConfigurationAllowExeDefinition allowExeDefinition)