Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Configuration / System / Configuration / TypeUtil.cs / 1 / TypeUtil.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Configuration.Internal; using System.Reflection; using System.Security; using System.Security.Permissions; namespace System.Configuration { internal static class TypeUtil { // // Since the config APIs were originally implemented in System.dll, // references to types without assembly names could be resolved to // System.dll in Everett. Emulate that behavior by trying to get the // type from System.dll // static private Type GetLegacyType(string typeString) { Type type = null; // // Ignore all exceptions, otherwise callers will get unexpected // exceptions not related to the original failure to load the // desired type. // try { Assembly systemAssembly = typeof(ConfigurationException).Assembly; type = systemAssembly.GetType(typeString, false); } catch { } return type; } // // Get the type specified by typeString. If it fails, try to retrieve it // as a type from System.dll. If that fails, return null or throw the original // exception as indicated by throwOnError. // static private Type GetTypeImpl(string typeString, bool throwOnError) { Type type = null; Exception originalException = null; try { type = Type.GetType(typeString, throwOnError); } catch (Exception e) { originalException = e; } if (type == null) { type = GetLegacyType(typeString); if (type == null && originalException != null) { throw originalException; } } return type; } // // Ask the host to get the type specified by typeString. If it fails, try to retrieve it // as a type from System.dll. If that fails, return null or throw the original // exception as indicated by throwOnError. // [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal Type GetTypeWithReflectionPermission(IInternalConfigHost host, string typeString, bool throwOnError) { Type type = null; Exception originalException = null; try { type = host.GetConfigType(typeString, throwOnError); } catch (Exception e) { originalException = e; } if (type == null) { type = GetLegacyType(typeString); if (type == null && originalException != null) { throw originalException; } } return type; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal Type GetTypeWithReflectionPermission(string typeString, bool throwOnError) { return GetTypeImpl(typeString, throwOnError); } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object CreateInstanceWithReflectionPermission(string typeString) { Type type = GetTypeImpl(typeString, true); // catch the errors and report them object result = Activator.CreateInstance(type, true); // create non-public types return result; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object CreateInstanceWithReflectionPermission(Type type) { object result = Activator.CreateInstance(type, true); // create non-public types return result; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal ConstructorInfo GetConstructorWithReflectionPermission(Type type, Type baseType, bool throwOnError) { type = VerifyAssignableType(baseType, type, throwOnError); if (type == null) { return null; } BindingFlags bindingFlags = BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic; ConstructorInfo ctor = type.GetConstructor(bindingFlags, null, CallingConventions.HasThis, Type.EmptyTypes, null); if (ctor == null && throwOnError) { throw new TypeLoadException(SR.GetString(SR.TypeNotPublic, type.AssemblyQualifiedName)); } return ctor; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object InvokeCtorWithReflectionPermission(ConstructorInfo ctor) { return ctor.Invoke(null); } static internal bool IsTypeFromTrustedAssemblyWithoutAptca(Type type) { Assembly assembly = type.Assembly; return assembly.GlobalAssemblyCache && !HasAptcaBit(assembly); } static internal Type VerifyAssignableType(Type baseType, Type type, bool throwOnError) { if (baseType.IsAssignableFrom(type)) { return type; } if (throwOnError) { throw new TypeLoadException( SR.GetString(SR.Config_type_doesnt_inherit_from_type, type.FullName, baseType.FullName)); } return null; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] private static bool HasAptcaBit(Assembly assembly) { Object[] attrs = assembly.GetCustomAttributes( typeof(System.Security.AllowPartiallyTrustedCallersAttribute), /*inherit*/ false); return (attrs != null && attrs.Length > 0); } static private PermissionSet s_fullTrustPermissionSet; // Check if the caller is fully trusted static internal bool IsCallerFullTrust { get { bool isFullTrust = false; try { if (s_fullTrustPermissionSet == null) { s_fullTrustPermissionSet = new PermissionSet(PermissionState.Unrestricted); } s_fullTrustPermissionSet.Demand(); isFullTrust = true; } catch { } return isFullTrust; } } // Check if the type is allowed to be used in config by checking the APTCA bit internal static bool IsTypeAllowedInConfig(Type t) { // Note: // This code is copied from HttpRuntime.IsTypeAllowedInConfig, but modified in // how it checks for fulltrust this can be called from non-ASP.NET apps. // Allow everything in full trust if (IsCallerFullTrust) { return true; } // The APTCA bit is only relevant for assemblies living in the GAC, since the rest runs // under partial trust (VSWhidbey 422183) Assembly assembly = t.Assembly; if (!assembly.GlobalAssemblyCache) return true; // If it has the APTCA bit, allow it if (HasAptcaBit(assembly)) return true; // It's a GAC type without APTCA in partial trust scenario: block it return false; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Configuration.Internal; using System.Reflection; using System.Security; using System.Security.Permissions; namespace System.Configuration { internal static class TypeUtil { // // Since the config APIs were originally implemented in System.dll, // references to types without assembly names could be resolved to // System.dll in Everett. Emulate that behavior by trying to get the // type from System.dll // static private Type GetLegacyType(string typeString) { Type type = null; // // Ignore all exceptions, otherwise callers will get unexpected // exceptions not related to the original failure to load the // desired type. // try { Assembly systemAssembly = typeof(ConfigurationException).Assembly; type = systemAssembly.GetType(typeString, false); } catch { } return type; } // // Get the type specified by typeString. If it fails, try to retrieve it // as a type from System.dll. If that fails, return null or throw the original // exception as indicated by throwOnError. // static private Type GetTypeImpl(string typeString, bool throwOnError) { Type type = null; Exception originalException = null; try { type = Type.GetType(typeString, throwOnError); } catch (Exception e) { originalException = e; } if (type == null) { type = GetLegacyType(typeString); if (type == null && originalException != null) { throw originalException; } } return type; } // // Ask the host to get the type specified by typeString. If it fails, try to retrieve it // as a type from System.dll. If that fails, return null or throw the original // exception as indicated by throwOnError. // [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal Type GetTypeWithReflectionPermission(IInternalConfigHost host, string typeString, bool throwOnError) { Type type = null; Exception originalException = null; try { type = host.GetConfigType(typeString, throwOnError); } catch (Exception e) { originalException = e; } if (type == null) { type = GetLegacyType(typeString); if (type == null && originalException != null) { throw originalException; } } return type; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal Type GetTypeWithReflectionPermission(string typeString, bool throwOnError) { return GetTypeImpl(typeString, throwOnError); } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object CreateInstanceWithReflectionPermission(string typeString) { Type type = GetTypeImpl(typeString, true); // catch the errors and report them object result = Activator.CreateInstance(type, true); // create non-public types return result; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object CreateInstanceWithReflectionPermission(Type type) { object result = Activator.CreateInstance(type, true); // create non-public types return result; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation)] static internal ConstructorInfo GetConstructorWithReflectionPermission(Type type, Type baseType, bool throwOnError) { type = VerifyAssignableType(baseType, type, throwOnError); if (type == null) { return null; } BindingFlags bindingFlags = BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic; ConstructorInfo ctor = type.GetConstructor(bindingFlags, null, CallingConventions.HasThis, Type.EmptyTypes, null); if (ctor == null && throwOnError) { throw new TypeLoadException(SR.GetString(SR.TypeNotPublic, type.AssemblyQualifiedName)); } return ctor; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] static internal object InvokeCtorWithReflectionPermission(ConstructorInfo ctor) { return ctor.Invoke(null); } static internal bool IsTypeFromTrustedAssemblyWithoutAptca(Type type) { Assembly assembly = type.Assembly; return assembly.GlobalAssemblyCache && !HasAptcaBit(assembly); } static internal Type VerifyAssignableType(Type baseType, Type type, bool throwOnError) { if (baseType.IsAssignableFrom(type)) { return type; } if (throwOnError) { throw new TypeLoadException( SR.GetString(SR.Config_type_doesnt_inherit_from_type, type.FullName, baseType.FullName)); } return null; } [ReflectionPermission(SecurityAction.Assert, Flags=ReflectionPermissionFlag.TypeInformation | ReflectionPermissionFlag.MemberAccess)] private static bool HasAptcaBit(Assembly assembly) { Object[] attrs = assembly.GetCustomAttributes( typeof(System.Security.AllowPartiallyTrustedCallersAttribute), /*inherit*/ false); return (attrs != null && attrs.Length > 0); } static private PermissionSet s_fullTrustPermissionSet; // Check if the caller is fully trusted static internal bool IsCallerFullTrust { get { bool isFullTrust = false; try { if (s_fullTrustPermissionSet == null) { s_fullTrustPermissionSet = new PermissionSet(PermissionState.Unrestricted); } s_fullTrustPermissionSet.Demand(); isFullTrust = true; } catch { } return isFullTrust; } } // Check if the type is allowed to be used in config by checking the APTCA bit internal static bool IsTypeAllowedInConfig(Type t) { // Note: // This code is copied from HttpRuntime.IsTypeAllowedInConfig, but modified in // how it checks for fulltrust this can be called from non-ASP.NET apps. // Allow everything in full trust if (IsCallerFullTrust) { return true; } // The APTCA bit is only relevant for assemblies living in the GAC, since the rest runs // under partial trust (VSWhidbey 422183) Assembly assembly = t.Assembly; if (!assembly.GlobalAssemblyCache) return true; // If it has the APTCA bit, allow it if (HasAptcaBit(assembly)) return true; // It's a GAC type without APTCA in partial trust scenario: block it return false; } } } // 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
- SystemEvents.cs
- RefType.cs
- CodeGroup.cs
- CodeMemberProperty.cs
- ScopelessEnumAttribute.cs
- Italic.cs
- ImageMap.cs
- InlineUIContainer.cs
- DataObjectPastingEventArgs.cs
- FileInfo.cs
- TogglePattern.cs
- QilXmlWriter.cs
- CompilerHelpers.cs
- MouseCaptureWithinProperty.cs
- SafeNativeMethodsOther.cs
- NativeRecognizer.cs
- DrawingContextFlattener.cs
- TriggerCollection.cs
- ControlFilterExpression.cs
- WorkflowDataContext.cs
- DataViewManager.cs
- DependentList.cs
- DesignerVerbCollection.cs
- SoapFormatter.cs
- Vector3DCollectionValueSerializer.cs
- HyperLinkStyle.cs
- ListViewCancelEventArgs.cs
- Inflater.cs
- BulletedList.cs
- DesignerProperties.cs
- DynamicMetaObject.cs
- RangeValidator.cs
- ToolstripProfessionalRenderer.cs
- RubberbandSelector.cs
- EditableTreeList.cs
- ArgumentOutOfRangeException.cs
- StyleXamlParser.cs
- TreeNodeStyleCollection.cs
- DeploymentSection.cs
- QilIterator.cs
- SHA256Managed.cs
- ValidationPropertyAttribute.cs
- TrackingProvider.cs
- _ConnectStream.cs
- URLString.cs
- TaskHelper.cs
- ExtenderProviderService.cs
- TextParaClient.cs
- ClockGroup.cs
- DocumentViewerBaseAutomationPeer.cs
- CharStorage.cs
- EntityModelBuildProvider.cs
- CodeGeneratorOptions.cs
- DeferredTextReference.cs
- GeometryCombineModeValidation.cs
- SmtpNetworkElement.cs
- DelayedRegex.cs
- DashStyle.cs
- StrongNamePublicKeyBlob.cs
- DynamicControlParameter.cs
- infer.cs
- XsltOutput.cs
- Double.cs
- VariableAction.cs
- StaticTextPointer.cs
- MULTI_QI.cs
- TextRange.cs
- XPathScanner.cs
- DataGridViewRowsRemovedEventArgs.cs
- HealthMonitoringSectionHelper.cs
- PropertyStore.cs
- WebPartCollection.cs
- SingleKeyFrameCollection.cs
- ParallelTimeline.cs
- BufferedWebEventProvider.cs
- DockingAttribute.cs
- DateTimeOffsetConverter.cs
- InputScopeNameConverter.cs
- UriTemplateTable.cs
- PenThreadWorker.cs
- WebPartTransformer.cs
- ServiceModelEnumValidator.cs
- ActiveDocumentEvent.cs
- EmptyStringExpandableObjectConverter.cs
- ActivityBuilderXamlWriter.cs
- LayoutTable.cs
- EDesignUtil.cs
- XPathSelectionIterator.cs
- HMACSHA1.cs
- TransformerConfigurationWizardBase.cs
- StatusBarDrawItemEvent.cs
- ServiceAuthorizationElement.cs
- Privilege.cs
- DataGridColumnCollection.cs
- CommonProperties.cs
- PageBuildProvider.cs
- CodeDomSerializationProvider.cs
- PropertyGrid.cs
- RootBuilder.cs
- UICuesEvent.cs