Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / Configuration / HandlerBase.cs / 2 / 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. //------------------------------------------------------------------------------ //// 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.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TextEditorTables.cs
- EdgeProfileValidation.cs
- ZipIOExtraFieldElement.cs
- InstanceDataCollection.cs
- HotSpot.cs
- HtmlInputImage.cs
- SpanIndex.cs
- SkewTransform.cs
- BasePropertyDescriptor.cs
- DesignTimeVisibleAttribute.cs
- Schema.cs
- TextEndOfParagraph.cs
- TextWriter.cs
- GroupBox.cs
- WebPartMenu.cs
- EnumValidator.cs
- OdbcTransaction.cs
- ExpressionEditorAttribute.cs
- FrugalMap.cs
- ContentDisposition.cs
- InProcStateClientManager.cs
- StatusBarItem.cs
- GlobalAclOperationRequirement.cs
- SessionStateSection.cs
- WebBrowserPermission.cs
- DoubleCollection.cs
- OdbcDataReader.cs
- MailWriter.cs
- Rule.cs
- DataSetUtil.cs
- CollectionBuilder.cs
- Span.cs
- Color.cs
- MenuScrollingVisibilityConverter.cs
- SqlError.cs
- MiniModule.cs
- DataGridItem.cs
- CommandValueSerializer.cs
- DebugView.cs
- WebPartZoneBaseDesigner.cs
- MemberExpressionHelper.cs
- Message.cs
- CommonProperties.cs
- ArrayExtension.cs
- PriorityBinding.cs
- WorkflowLayouts.cs
- BaseProcessor.cs
- LocalizedNameDescriptionPair.cs
- GradientStop.cs
- SynchronizedPool.cs
- HtmlFormParameterReader.cs
- AutomationPropertyChangedEventArgs.cs
- DataBoundControlAdapter.cs
- FileIOPermission.cs
- UserPersonalizationStateInfo.cs
- PointLight.cs
- ConstrainedDataObject.cs
- GorillaCodec.cs
- RuntimeConfigurationRecord.cs
- GridItemProviderWrapper.cs
- BitmapMetadataBlob.cs
- ToolTipService.cs
- OpenTypeCommon.cs
- AutoResetEvent.cs
- EntityContainerEmitter.cs
- TargetException.cs
- _LoggingObject.cs
- SafeNativeMethodsCLR.cs
- WebBrowserPermission.cs
- TextParagraphProperties.cs
- GenericIdentity.cs
- OptionUsage.cs
- ManualResetEvent.cs
- MetadataUtilsSmi.cs
- KeySpline.cs
- __Filters.cs
- Guid.cs
- PanelDesigner.cs
- ComponentChangingEvent.cs
- Misc.cs
- SharedDp.cs
- ThumbAutomationPeer.cs
- ResourceIDHelper.cs
- FlowLayoutPanel.cs
- XsltException.cs
- ExpressionBuilderCollection.cs
- SpoolingTask.cs
- BrowsableAttribute.cs
- SortQuery.cs
- SqlDataSourceQueryEditor.cs
- MeasureData.cs
- ResourceReferenceExpression.cs
- ListControlConvertEventArgs.cs
- ObjectListDataBindEventArgs.cs
- EntitySqlQueryBuilder.cs
- SqlNamer.cs
- WebContext.cs
- ViewManager.cs
- TypedRowHandler.cs
- FlatButtonAppearance.cs