Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / xsp / System / Web / Configuration / HandlerBase.cs / 1 / HandlerBase.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HandlerBase contains static helper functions for consistent XML parsing * behavior and error messages. * * Copyright (c) 1998 Microsoft Corporation */ namespace System.Web.Configuration { using System.Collections; using System.Collections.Specialized; using System.Configuration; using System.Globalization; using System.Text; using System.Web.Hosting; using System.Web.Util; using System.Xml; using System.Web.Compilation; static internal class HandlerBase { // // XML Attribute Helpers // private static XmlNode GetAndRemoveAttribute(XmlNode node, string attrib, bool fRequired) { XmlNode a = node.Attributes.RemoveNamedItem(attrib); // If the attribute is required and was not present, throw if (fRequired && a == null) { throw new ConfigurationErrorsException( SR.GetString(SR.Missing_required_attribute, attrib, node.Name), node); } return a; } private static XmlNode GetAndRemoveStringAttributeInternal(XmlNode node, string attrib, bool fRequired, ref string val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { val = a.Value; } return a; } internal static XmlNode GetAndRemoveStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveStringAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveRequiredStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveStringAttributeInternal(node, attrib, true /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveNonEmptyStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveNonEmptyStringAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveRequiredNonEmptyStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveNonEmptyStringAttributeInternal(node, attrib, true /*fRequired*/, ref val); } private static XmlNode GetAndRemoveNonEmptyStringAttributeInternal(XmlNode node, string attrib, bool fRequired, ref string val) { XmlNode a = GetAndRemoveStringAttributeInternal(node, attrib, fRequired, ref val); if (a != null && val.Length == 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Empty_attribute, attrib), a); } return a; } // input.Xml cursor must be at a true/false XML attribute private static XmlNode GetAndRemoveBooleanAttributeInternal(XmlNode node, string attrib, bool fRequired, ref bool val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { if (a.Value == "true") { val = true; } else if (a.Value == "false") { val = false; } else { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_boolean_attribute, a.Name), a); } } return a; } internal static XmlNode GetAndRemoveBooleanAttribute(XmlNode node, string attrib, ref bool val) { return GetAndRemoveBooleanAttributeInternal(node, attrib, false /*fRequired*/, ref val); } private static XmlNode GetAndRemoveIntegerAttributeInternal(XmlNode node, string attrib, bool fRequired, ref int val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { if (a.Value.Trim() != a.Value) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_integer_attribute, a.Name), a); } try { val = int.Parse(a.Value, CultureInfo.InvariantCulture); } catch (Exception e) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_integer_attribute, a.Name), e, a); } } return a; } private static XmlNode GetAndRemovePositiveAttributeInternal(XmlNode node, string attrib, bool fRequired, ref int val) { XmlNode a = GetAndRemoveIntegerAttributeInternal(node, attrib, fRequired, ref val); if (a != null && val <= 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_positive_integer_attribute, attrib), a); } return a; } internal static XmlNode GetAndRemovePositiveIntegerAttribute(XmlNode node, string attrib, ref int val) { return GetAndRemovePositiveAttributeInternal(node, attrib, false /*fRequired*/, ref val); } #if UNUSED_CODE internal static XmlNode GetAndRemoveRequiredPositiveIntegerAttribute(XmlNode node, string attrib, ref int val) { return GetAndRemovePositiveAttributeInternal(node, attrib, true /*fRequired*/, ref val); } #endif private static XmlNode GetAndRemoveTypeAttributeInternal(XmlNode node, string attrib, bool fRequired, ref Type val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { val = ConfigUtil.GetType(a.Value, a); } return a; } internal static XmlNode GetAndRemoveTypeAttribute(XmlNode node, string attrib, ref Type val) { return GetAndRemoveTypeAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static void CheckForbiddenAttribute(XmlNode node, string attrib) { XmlAttribute attr = node.Attributes[attrib]; if (attr != null) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_attribute, attrib), attr); } } internal static void CheckForUnrecognizedAttributes(XmlNode node) { if (node.Attributes.Count != 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_attribute, node.Attributes[0].Name), node.Attributes[0]); } } #if UNUSED_CODE // Throw an exception complaining that a line is duplicated (ASURT 93151) internal static void ThrowDuplicateLineException(XmlNode node) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_duplicate_line), node); } #endif // // Obsolete XML Attribute Helpers // // if attribute not found return null internal static string RemoveAttribute(XmlNode node, string name) { XmlNode attribute = node.Attributes.RemoveNamedItem(name); if (attribute != null) { return attribute.Value; } return null; } // if attr not found throw standard message - "attribute x required" internal static string RemoveRequiredAttribute(XmlNode node, string name) { return RemoveRequiredAttribute(node, name, false); } internal static string RemoveRequiredAttribute(XmlNode node, string name, bool allowEmpty) { XmlNode attribute = node.Attributes.RemoveNamedItem(name); if (attribute == null) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_required_attribute_missing, name), node); } if (attribute.Value.Length == 0 && !allowEmpty) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_required_attribute_empty, name), node); } return attribute.Value; } // // XML Element Helpers // internal static void CheckForNonCommentChildNodes(XmlNode node) { foreach (XmlNode childNode in node.ChildNodes) { if (childNode.NodeType != XmlNodeType.Comment) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_no_child_nodes), childNode); } } } internal static void ThrowUnrecognizedElement(XmlNode node) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_element), node); } internal static void CheckAssignableType(XmlNode node, Type baseType, Type type) { if (!baseType.IsAssignableFrom(type)) { throw new ConfigurationErrorsException( SR.GetString(SR.Type_doesnt_inherit_from_type, type.FullName, baseType.FullName), node); } } internal static void CheckAssignableType(string filename, int lineNumber, Type baseType, Type type) { if (!baseType.IsAssignableFrom(type)) { throw new ConfigurationErrorsException( SR.GetString(SR.Type_doesnt_inherit_from_type, type.FullName, baseType.FullName), filename, lineNumber); } } // Section handlers can run in client mode through: // ConfigurationManager.GetSection("sectionName") // See ASURT 123738 internal static bool IsServerConfiguration(object context) { return context is HttpConfigurationContext; } internal static bool CheckAndReadRegistryValue(ref string value, bool throwIfError) { if (value == null) { return true; } if (!StringUtil.StringStartsWithIgnoreCase(value, "registry:")) { // Not a registry value. It's not an error. return true; } const int size = 1024; StringBuilder str = new StringBuilder(size); int iRet = UnsafeNativeMethods.GetCredentialFromRegistry(value, str, size); if (iRet == 0) { value = str.ToString(); return true; } else { if (throwIfError) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_registry_config)); } else { return false; } } } internal static bool CheckAndReadConnectionString(ref string connectionString, bool throwIfError) { ConnectionStringSettings connObj = RuntimeConfig.GetConfig().ConnectionStrings.ConnectionStrings[connectionString]; if (connObj != null && connObj.ConnectionString != null && connObj.ConnectionString.Length > 0) connectionString = connObj.ConnectionString; return CheckAndReadRegistryValue(ref connectionString, throwIfError); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HandlerBase contains static helper functions for consistent XML parsing * behavior and error messages. * * Copyright (c) 1998 Microsoft Corporation */ namespace System.Web.Configuration { using System.Collections; using System.Collections.Specialized; using System.Configuration; using System.Globalization; using System.Text; using System.Web.Hosting; using System.Web.Util; using System.Xml; using System.Web.Compilation; static internal class HandlerBase { // // XML Attribute Helpers // private static XmlNode GetAndRemoveAttribute(XmlNode node, string attrib, bool fRequired) { XmlNode a = node.Attributes.RemoveNamedItem(attrib); // If the attribute is required and was not present, throw if (fRequired && a == null) { throw new ConfigurationErrorsException( SR.GetString(SR.Missing_required_attribute, attrib, node.Name), node); } return a; } private static XmlNode GetAndRemoveStringAttributeInternal(XmlNode node, string attrib, bool fRequired, ref string val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { val = a.Value; } return a; } internal static XmlNode GetAndRemoveStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveStringAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveRequiredStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveStringAttributeInternal(node, attrib, true /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveNonEmptyStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveNonEmptyStringAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static XmlNode GetAndRemoveRequiredNonEmptyStringAttribute(XmlNode node, string attrib, ref string val) { return GetAndRemoveNonEmptyStringAttributeInternal(node, attrib, true /*fRequired*/, ref val); } private static XmlNode GetAndRemoveNonEmptyStringAttributeInternal(XmlNode node, string attrib, bool fRequired, ref string val) { XmlNode a = GetAndRemoveStringAttributeInternal(node, attrib, fRequired, ref val); if (a != null && val.Length == 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Empty_attribute, attrib), a); } return a; } // input.Xml cursor must be at a true/false XML attribute private static XmlNode GetAndRemoveBooleanAttributeInternal(XmlNode node, string attrib, bool fRequired, ref bool val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { if (a.Value == "true") { val = true; } else if (a.Value == "false") { val = false; } else { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_boolean_attribute, a.Name), a); } } return a; } internal static XmlNode GetAndRemoveBooleanAttribute(XmlNode node, string attrib, ref bool val) { return GetAndRemoveBooleanAttributeInternal(node, attrib, false /*fRequired*/, ref val); } private static XmlNode GetAndRemoveIntegerAttributeInternal(XmlNode node, string attrib, bool fRequired, ref int val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { if (a.Value.Trim() != a.Value) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_integer_attribute, a.Name), a); } try { val = int.Parse(a.Value, CultureInfo.InvariantCulture); } catch (Exception e) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_integer_attribute, a.Name), e, a); } } return a; } private static XmlNode GetAndRemovePositiveAttributeInternal(XmlNode node, string attrib, bool fRequired, ref int val) { XmlNode a = GetAndRemoveIntegerAttributeInternal(node, attrib, fRequired, ref val); if (a != null && val <= 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_positive_integer_attribute, attrib), a); } return a; } internal static XmlNode GetAndRemovePositiveIntegerAttribute(XmlNode node, string attrib, ref int val) { return GetAndRemovePositiveAttributeInternal(node, attrib, false /*fRequired*/, ref val); } #if UNUSED_CODE internal static XmlNode GetAndRemoveRequiredPositiveIntegerAttribute(XmlNode node, string attrib, ref int val) { return GetAndRemovePositiveAttributeInternal(node, attrib, true /*fRequired*/, ref val); } #endif private static XmlNode GetAndRemoveTypeAttributeInternal(XmlNode node, string attrib, bool fRequired, ref Type val) { XmlNode a = GetAndRemoveAttribute(node, attrib, fRequired); if (a != null) { val = ConfigUtil.GetType(a.Value, a); } return a; } internal static XmlNode GetAndRemoveTypeAttribute(XmlNode node, string attrib, ref Type val) { return GetAndRemoveTypeAttributeInternal(node, attrib, false /*fRequired*/, ref val); } internal static void CheckForbiddenAttribute(XmlNode node, string attrib) { XmlAttribute attr = node.Attributes[attrib]; if (attr != null) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_attribute, attrib), attr); } } internal static void CheckForUnrecognizedAttributes(XmlNode node) { if (node.Attributes.Count != 0) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_attribute, node.Attributes[0].Name), node.Attributes[0]); } } #if UNUSED_CODE // Throw an exception complaining that a line is duplicated (ASURT 93151) internal static void ThrowDuplicateLineException(XmlNode node) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_duplicate_line), node); } #endif // // Obsolete XML Attribute Helpers // // if attribute not found return null internal static string RemoveAttribute(XmlNode node, string name) { XmlNode attribute = node.Attributes.RemoveNamedItem(name); if (attribute != null) { return attribute.Value; } return null; } // if attr not found throw standard message - "attribute x required" internal static string RemoveRequiredAttribute(XmlNode node, string name) { return RemoveRequiredAttribute(node, name, false); } internal static string RemoveRequiredAttribute(XmlNode node, string name, bool allowEmpty) { XmlNode attribute = node.Attributes.RemoveNamedItem(name); if (attribute == null) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_required_attribute_missing, name), node); } if (attribute.Value.Length == 0 && !allowEmpty) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_required_attribute_empty, name), node); } return attribute.Value; } // // XML Element Helpers // internal static void CheckForNonCommentChildNodes(XmlNode node) { foreach (XmlNode childNode in node.ChildNodes) { if (childNode.NodeType != XmlNodeType.Comment) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_no_child_nodes), childNode); } } } internal static void ThrowUnrecognizedElement(XmlNode node) { throw new ConfigurationErrorsException( SR.GetString(SR.Config_base_unrecognized_element), node); } internal static void CheckAssignableType(XmlNode node, Type baseType, Type type) { if (!baseType.IsAssignableFrom(type)) { throw new ConfigurationErrorsException( SR.GetString(SR.Type_doesnt_inherit_from_type, type.FullName, baseType.FullName), node); } } internal static void CheckAssignableType(string filename, int lineNumber, Type baseType, Type type) { if (!baseType.IsAssignableFrom(type)) { throw new ConfigurationErrorsException( SR.GetString(SR.Type_doesnt_inherit_from_type, type.FullName, baseType.FullName), filename, lineNumber); } } // Section handlers can run in client mode through: // ConfigurationManager.GetSection("sectionName") // See ASURT 123738 internal static bool IsServerConfiguration(object context) { return context is HttpConfigurationContext; } internal static bool CheckAndReadRegistryValue(ref string value, bool throwIfError) { if (value == null) { return true; } if (!StringUtil.StringStartsWithIgnoreCase(value, "registry:")) { // Not a registry value. It's not an error. return true; } const int size = 1024; StringBuilder str = new StringBuilder(size); int iRet = UnsafeNativeMethods.GetCredentialFromRegistry(value, str, size); if (iRet == 0) { value = str.ToString(); return true; } else { if (throwIfError) { throw new ConfigurationErrorsException( SR.GetString(SR.Invalid_registry_config)); } else { return false; } } } internal static bool CheckAndReadConnectionString(ref string connectionString, bool throwIfError) { ConnectionStringSettings connObj = RuntimeConfig.GetConfig().ConnectionStrings.ConnectionStrings[connectionString]; if (connObj != null && connObj.ConnectionString != null && connObj.ConnectionString.Length > 0) connectionString = connObj.ConnectionString; return CheckAndReadRegistryValue(ref connectionString, throwIfError); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ParallelActivityDesigner.cs
- ViewGenResults.cs
- Timeline.cs
- BinaryNode.cs
- DesignerActionMethodItem.cs
- CalendarDesigner.cs
- Size.cs
- SafeCertificateStore.cs
- ArrangedElementCollection.cs
- VScrollBar.cs
- Int32AnimationUsingKeyFrames.cs
- BlockCollection.cs
- ObjectAnimationUsingKeyFrames.cs
- RuleSettings.cs
- XmlNamespaceManager.cs
- OlePropertyStructs.cs
- FormClosedEvent.cs
- XamlPathDataSerializer.cs
- ToolStripOverflowButton.cs
- RelatedView.cs
- PrintDialog.cs
- EncoderNLS.cs
- ValidationResult.cs
- EntitySqlQueryState.cs
- FieldBuilder.cs
- RoleManagerEventArgs.cs
- InfocardChannelParameter.cs
- IConvertible.cs
- EndPoint.cs
- DataColumnPropertyDescriptor.cs
- Substitution.cs
- AuthenticationServiceManager.cs
- LinqDataSourceInsertEventArgs.cs
- StackOverflowException.cs
- TypeViewSchema.cs
- Sql8ConformanceChecker.cs
- XPathNodeInfoAtom.cs
- ClientConvert.cs
- ListMarkerLine.cs
- KeysConverter.cs
- ContextBase.cs
- ConvertEvent.cs
- TabPanel.cs
- ItemsChangedEventArgs.cs
- Win32NamedPipes.cs
- metrodevice.cs
- CompilationUnit.cs
- HierarchicalDataBoundControlAdapter.cs
- HitTestResult.cs
- DictationGrammar.cs
- FieldAccessException.cs
- ParallelQuery.cs
- RoutedEventHandlerInfo.cs
- FileStream.cs
- XmlReflectionImporter.cs
- ClientTarget.cs
- HtmlEmptyTagControlBuilder.cs
- TextCharacters.cs
- PackageRelationshipCollection.cs
- Identifier.cs
- HebrewCalendar.cs
- SafeHGlobalHandleCritical.cs
- ThemeDirectoryCompiler.cs
- SequenceQuery.cs
- TextHintingModeValidation.cs
- Mapping.cs
- Soap.cs
- XmlUtf8RawTextWriter.cs
- OdbcException.cs
- ActivityTypeDesigner.xaml.cs
- TextFormatterHost.cs
- BorderGapMaskConverter.cs
- TabRenderer.cs
- ObjectNotFoundException.cs
- EventLogLink.cs
- SecurityTokenException.cs
- HMACSHA1.cs
- PageSetupDialog.cs
- FloatAverageAggregationOperator.cs
- SessionIDManager.cs
- SapiAttributeParser.cs
- WebPartZone.cs
- MenuCommand.cs
- MenuAdapter.cs
- RuleSettings.cs
- PrimaryKeyTypeConverter.cs
- DataServiceQueryOfT.cs
- WebPartsPersonalizationAuthorization.cs
- IPGlobalProperties.cs
- CheckableControlBaseAdapter.cs
- ISAPIWorkerRequest.cs
- BaseProcessor.cs
- _NegoState.cs
- BuildDependencySet.cs
- UndoEngine.cs
- EntityDataSourceViewSchema.cs
- ListSourceHelper.cs
- FormDesigner.cs
- TextRunCacheImp.cs
- GeneralTransform3DGroup.cs