|
|
@@ -0,0 +1,317 @@
|
|
|
+//
|
|
|
+// System.Web.Configuration.WebConfigurationHost.cs
|
|
|
+//
|
|
|
+// Authors:
|
|
|
+// Lluis Sanchez Gual ([email protected])
|
|
|
+//
|
|
|
+// Permission is hereby granted, free of charge, to any person obtaining
|
|
|
+// a copy of this software and associated documentation files (the
|
|
|
+// "Software"), to deal in the Software without restriction, including
|
|
|
+// without limitation the rights to use, copy, modify, merge, publish,
|
|
|
+// distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
+// permit persons to whom the Software is furnished to do so, subject to
|
|
|
+// the following conditions:
|
|
|
+//
|
|
|
+// The above copyright notice and this permission notice shall be
|
|
|
+// included in all copies or substantial portions of the Software.
|
|
|
+//
|
|
|
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
|
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
|
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
+//
|
|
|
+// Copyright (C) 2005 Novell, Inc (http://www.novell.com)
|
|
|
+//
|
|
|
+
|
|
|
+#if NET_2_0
|
|
|
+
|
|
|
+using System;
|
|
|
+using System.IO;
|
|
|
+using System.Security;
|
|
|
+using System.Configuration;
|
|
|
+using System.Configuration.Internal;
|
|
|
+using System.Web.Util;
|
|
|
+
|
|
|
+namespace System.Web.Configuration
|
|
|
+{
|
|
|
+ class WebConfigurationHost: IInternalConfigHost
|
|
|
+ {
|
|
|
+ WebConfigurationFileMap map;
|
|
|
+ const string MachinePath = "machine:";
|
|
|
+
|
|
|
+ public virtual object CreateConfigurationContext (string configPath, string locationSubPath)
|
|
|
+ {
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual object CreateDeprecatedConfigContext (string configPath)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string DecryptSection (string encryptedXml, ProtectedConfigurationProvider protectionProvider, ProtectedConfigurationSection protectedSection)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void DeleteStream (string streamName)
|
|
|
+ {
|
|
|
+ File.Delete (streamName);
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string EncryptSection (string encryptedXml, ProtectedConfigurationProvider protectionProvider, ProtectedConfigurationSection protectedSection)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string GetConfigPathFromLocationSubPath (string configPath, string locatinSubPath)
|
|
|
+ {
|
|
|
+ return configPath + "/" + locatinSubPath;
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual Type GetConfigType (string typeName, bool throwOnError)
|
|
|
+ {
|
|
|
+ Type type = Type.GetType (typeName);
|
|
|
+ if (type == null && throwOnError)
|
|
|
+ throw new ConfigurationErrorsException ("Type not found: '" + typeName + "'");
|
|
|
+ return type;
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string GetConfigTypeName (Type t)
|
|
|
+ {
|
|
|
+ return t.AssemblyQualifiedName;
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void GetRestrictedPermissions (IInternalConfigRecord configRecord, out PermissionSet permissionSet, out bool isHostReady)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string GetStreamName (string configPath)
|
|
|
+ {
|
|
|
+ if (configPath == MachinePath) {
|
|
|
+ if (map == null)
|
|
|
+ return System.Runtime.InteropServices.RuntimeEnvironment.SystemConfigurationFile;
|
|
|
+ else
|
|
|
+ return map.MachineConfigFilename;
|
|
|
+ }
|
|
|
+
|
|
|
+ string dir = MapPath (configPath);
|
|
|
+ return GetWebConfigFileName (dir);
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual string GetStreamNameForConfigSource (string streamName, string configSource)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual object GetStreamVersion (string streamName)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual IDisposable Impersonate ()
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void Init (IInternalConfigRoot root, params object[] hostInitParams)
|
|
|
+ {
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void InitForConfiguration (ref string locationSubPath, out string configPath, out string locationConfigPath, IInternalConfigRoot root, params object[] hostInitConfigurationParams)
|
|
|
+ {
|
|
|
+ string fullPath = (string) hostInitConfigurationParams [1];
|
|
|
+
|
|
|
+ map = (WebConfigurationFileMap) hostInitConfigurationParams [0];
|
|
|
+
|
|
|
+ if (locationSubPath == MachinePath) {
|
|
|
+ locationSubPath = null;
|
|
|
+ configPath = MachinePath;
|
|
|
+ locationConfigPath = null;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ int i;
|
|
|
+ if (locationSubPath == null) {
|
|
|
+ configPath = fullPath;
|
|
|
+ i = fullPath.LastIndexOf ("/");
|
|
|
+ } else {
|
|
|
+ configPath = locationSubPath;
|
|
|
+ if (locationSubPath != "/")
|
|
|
+ i = locationSubPath.LastIndexOf ('/');
|
|
|
+ else
|
|
|
+ i = -1;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (i != -1) {
|
|
|
+ locationConfigPath = configPath.Substring (i+1);
|
|
|
+
|
|
|
+ if (i == 0)
|
|
|
+ locationSubPath = "/";
|
|
|
+ else
|
|
|
+ locationSubPath = fullPath.Substring (0, i);
|
|
|
+
|
|
|
+ string dir = MapPath (configPath);
|
|
|
+ if (GetWebConfigFileName (dir) == null) {
|
|
|
+ InitForConfiguration (ref locationSubPath, out configPath, out locationConfigPath, root, hostInitConfigurationParams);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ locationSubPath = MachinePath;
|
|
|
+ locationConfigPath = null;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ public string MapPath (string virtualPath)
|
|
|
+ {
|
|
|
+ if (map != null)
|
|
|
+ return MapPathFromMapper (virtualPath);
|
|
|
+ else
|
|
|
+ return HttpContext.Current.Request.MapPath (virtualPath);
|
|
|
+ }
|
|
|
+
|
|
|
+ public string NormalizeVirtualPath (string virtualPath)
|
|
|
+ {
|
|
|
+ if (virtualPath == null || virtualPath.Length == 0)
|
|
|
+ virtualPath = ".";
|
|
|
+ else
|
|
|
+ virtualPath = virtualPath.Trim ();
|
|
|
+
|
|
|
+ if (virtualPath [0] == '~' && virtualPath.Length > 2 && virtualPath [1] == '/')
|
|
|
+ virtualPath = virtualPath.Substring (1);
|
|
|
+
|
|
|
+ if (System.IO.Path.DirectorySeparatorChar != '/')
|
|
|
+ virtualPath = virtualPath.Replace (System.IO.Path.DirectorySeparatorChar, '/');
|
|
|
+
|
|
|
+ if (UrlUtils.IsRooted (virtualPath)) {
|
|
|
+ virtualPath = UrlUtils.Reduce (virtualPath);
|
|
|
+ } else {
|
|
|
+ if (map.VirtualDirectories.Count > 0) {
|
|
|
+ string root = map.VirtualDirectories [0].VirtualDirectory;
|
|
|
+ virtualPath = UrlUtils.Combine (root, virtualPath);
|
|
|
+ virtualPath = UrlUtils.Reduce (virtualPath);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return virtualPath;
|
|
|
+ }
|
|
|
+
|
|
|
+ public string MapPathFromMapper (string virtualPath)
|
|
|
+ {
|
|
|
+ string path = NormalizeVirtualPath (virtualPath);
|
|
|
+
|
|
|
+ foreach (VirtualDirectoryMapping mapping in map.VirtualDirectories) {
|
|
|
+ if (path.StartsWith (mapping.VirtualDirectory)) {
|
|
|
+ int i = mapping.VirtualDirectory.Length;
|
|
|
+ if (path.Length == i) {
|
|
|
+ return mapping.PhysicalDirectory;
|
|
|
+ }
|
|
|
+ else if (path [i] == '/') {
|
|
|
+ string pathPart = path.Substring (i + 1).Replace ('/', Path.DirectorySeparatorChar);
|
|
|
+ return Path.Combine (mapping.PhysicalDirectory, pathPart);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ throw new HttpException ("Invalid virtual directory: " + virtualPath);
|
|
|
+ }
|
|
|
+
|
|
|
+ string GetWebConfigFileName (string dir)
|
|
|
+ {
|
|
|
+ string file = Path.Combine (dir, "Web.config");
|
|
|
+ if (File.Exists (file))
|
|
|
+ return file;
|
|
|
+ file = Path.Combine (dir, "web.config");
|
|
|
+ if (File.Exists (file))
|
|
|
+ return file;
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool IsAboveApplication (string configPath)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool IsConfigRecordRequired (string configPath)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool IsDefinitionAllowed (string configPath, ConfigurationAllowDefinition allowDefinition, ConfigurationAllowExeDefinition allowExeDefinition)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool IsFile (string streamName)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool IsLocationApplicable (string configPath)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual Stream OpenStreamForRead (string streamName)
|
|
|
+ {
|
|
|
+ if (!File.Exists (streamName))
|
|
|
+ throw new ConfigurationException ("File '" + streamName + "' not found");
|
|
|
+
|
|
|
+ return new FileStream (streamName, FileMode.Open, FileAccess.Read);
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual Stream OpenStreamForWrite (string streamName, string templateStreamName, ref object writeContext)
|
|
|
+ {
|
|
|
+ return new FileStream (streamName, FileMode.Create, FileAccess.Write);
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool PrefetchAll (string configPath, string streamName)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool PrefetchSection (string sectionGroupName, string sectionName)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual object StartMonitoringStreamForChanges (string streamName, StreamChangeCallback callback)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void StopMonitoringStreamForChanges (string streamName, StreamChangeCallback callback)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void VerifyDefinitionAllowed (string configPath, ConfigurationAllowDefinition allowDefinition, ConfigurationAllowExeDefinition allowExeDefinition, IConfigErrorInfo errorInfo)
|
|
|
+ {
|
|
|
+ throw new NotImplementedException ();
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual void WriteCompleted (string streamName, bool success, object writeContext)
|
|
|
+ {
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool SupportsChangeNotifications {
|
|
|
+ get { return false; }
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool SupportsLocation {
|
|
|
+ get { return false; }
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool SupportsPath {
|
|
|
+ get { return false; }
|
|
|
+ }
|
|
|
+
|
|
|
+ public virtual bool SupportsRefresh {
|
|
|
+ get { return false; }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+#endif
|