//------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //------------------------------------------------------------------------------ using System; using System.Xml; using System.Diagnostics; using System.Configuration; using System.Globalization; using System.Web; using System.Web.Configuration; using System.Collections.Specialized; using System.Security.Permissions; namespace System.Web.UI.MobileControls { // Mobile Controls Configuration class. // Includes Mobile Web Forms-specific settings, including a set // of device configurations, that can be used to decide what set of // adapters to use for a given device. [Obsolete("The System.Web.Mobile.dll assembly has been deprecated and should no longer be used. For information about how to develop ASP.NET mobile applications, see http://go.microsoft.com/fwlink/?LinkId=157231.")] internal class ControlsConfig { private readonly ControlsConfig _parent; private readonly StringDictionary _settings = new StringDictionary(); private readonly ListDictionary _deviceConfigs = new ListDictionary(); [ConfigurationPermission(SecurityAction.Assert, Unrestricted=true)] internal static ControlsConfig GetFromContext(HttpContext context) { // VSWhidbey 372365: Use MobileControlsSection if it is being returned Object config = context.GetSection("system.web/mobileControls"); MobileControlsSection controlSection = config as MobileControlsSection; if (controlSection != null) { return controlSection.GetControlsConfig(); } return (ControlsConfig)config; } internal ControlsConfig(ControlsConfig parent) { _parent = parent; } // Return false if a device of the same name has already been added. internal /*public*/ bool AddDeviceConfig(String configName, IndividualDeviceConfig deviceConfig) { // Note that GetDeviceConfig also walks the parents configs if (GetDeviceConfig(configName) != null) { return false; } else { _deviceConfigs[configName] = deviceConfig; return true; } } internal /*public*/ IndividualDeviceConfig GetDeviceConfig(HttpContext context) { IndividualDeviceConfig deviceConfig = null; #if DEBUG if (context.Session != null) { String var = "AdapterOverride"; bool saveInSession = true; String adapterOverride = (String)context.Session[var]; if (adapterOverride == null) { saveInSession = false; adapterOverride = (String)context.Request.QueryString[var]; } if (adapterOverride != null && (deviceConfig = GetDeviceConfig(adapterOverride)) != null) { if (saveInSession) { context.Session[var] = adapterOverride; } return deviceConfig; } } #endif foreach (IndividualDeviceConfig candidate in _deviceConfigs.Values) { if (candidate.DeviceQualifies(context)) { deviceConfig = candidate; break; } } if (deviceConfig == null && _parent != null) { deviceConfig = _parent.GetDeviceConfig (context); } if (deviceConfig == null) { throw new Exception( SR.GetString(SR.ControlsConfig_NoDeviceConfigRegistered, context.Request.UserAgent)); } return deviceConfig; } internal /*public*/ IndividualDeviceConfig GetDeviceConfig(String configName) { IndividualDeviceConfig deviceConfig = (IndividualDeviceConfig)_deviceConfigs[configName]; if (deviceConfig == null && _parent != null) { deviceConfig = _parent.GetDeviceConfig (configName); } return deviceConfig; } // Call this after all the device configs have been entered. This will // resolve the names of the parent classes to inherit from actual // classes, and flag an error if there isn't one. This is done as a // second-pass because devices earlier in web.config may inherit from // items later in the web.config. That flexibility is required to get // the right behavior for device predicates being evaluated in the order // they appear. internal void FixupDeviceConfigInheritance(XmlNode configNode) { foreach (IndividualDeviceConfig config in _deviceConfigs.Values) { config.FixupInheritance(null, configNode); } } internal /*public*/ String this[String key] { get { String s = _settings[key]; if (s == null && _parent != null) { s = _parent[key]; } return s; } set { _settings[key] = value; } } internal /*public*/ int SessionStateHistorySize { get { String sizeString = this["sessionStateHistorySize"]; int size = Constants.DefaultSessionsStateHistorySize; if (sizeString != null) { // Enclose in case a numerical value wasn't provided. In // which case just return the default. try { size = Int32.Parse(sizeString, CultureInfo.InvariantCulture); } catch { } } return size; } } internal /*public*/ Type CookielessDataDictionaryType { get { Type cookielessDataType = null; String typeString = this["cookielessDataDictionaryType"]; if (!String.IsNullOrEmpty(typeString)) { cookielessDataType = Type.GetType(typeString); } return cookielessDataType; } } internal /*public*/ bool AllowCustomAttributes { get { String allow = this["allowCustomAttributes"]; return String.Compare(allow, "true", StringComparison.OrdinalIgnoreCase) == 0; } } } }