Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Security / Policy / AppDomainEvidenceFactory.cs / 1305376 / AppDomainEvidenceFactory.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== using System; using System.Collections.Generic; using System.Diagnostics.Contracts; using System.Reflection; namespace System.Security.Policy { ////// Factory class which creates evidence on demand for an AppDomain /// internal sealed class AppDomainEvidenceFactory : IRuntimeEvidenceFactory { private AppDomain m_targetDomain; private Evidence m_entryPointEvidence; internal AppDomainEvidenceFactory(AppDomain target) { Contract.Assert(target != null); Contract.Assert(target == AppDomain.CurrentDomain, "AppDomainEvidenceFactory should not be used across domains."); m_targetDomain = target; } ////// AppDomain this factory generates evidence for /// public IEvidenceFactory Target { get { return m_targetDomain; } } ////// Return any evidence supplied by the AppDomain itself /// public IEnumerableGetFactorySuppliedEvidence() { // AppDomains do not contain serialized evidence return new EvidenceBase[] { }; } /// /// Generate evidence on demand for an AppDomain /// [SecuritySafeCritical] public EvidenceBase GenerateEvidence(Type evidenceType) { // For v1.x compatibility, the default AppDomain has the same evidence as the entry point // assembly. Since other AppDomains inherit their evidence from the default AppDomain by // default, they also use the entry point assembly. BCLDebug.Assert(m_targetDomain == AppDomain.CurrentDomain, "AppDomainEvidenceFactory should not be used across domains."); if (m_targetDomain.IsDefaultAppDomain()) { // If we don't already know the evidence for the entry point assembly, get that now. If we // have a RuntimeAssembly go directly to its EvidenceNoDemand property to avoid the full // demand that it will do on access to its Evidence property. if (m_entryPointEvidence == null) { Assembly entryAssembly = Assembly.GetEntryAssembly(); RuntimeAssembly entryRuntimeAssembly = entryAssembly as RuntimeAssembly; if (entryRuntimeAssembly != null) { m_entryPointEvidence = entryRuntimeAssembly.EvidenceNoDemand.Clone(); } else if (entryAssembly != null) { m_entryPointEvidence = entryAssembly.Evidence; } } // If the entry point assembly provided evidence, then we use that for the AppDomain if (m_entryPointEvidence != null) { return m_entryPointEvidence.GetHostEvidence(evidenceType); } } else { // If we're not the default domain, then we should inherit our evidence from the default // domain -- so ask it what evidence it has of this type. AppDomain defaultDomain = AppDomain.GetDefaultDomain(); return defaultDomain.GetHostEvidence(evidenceType); } // AppDomains do not generate any evidence on demand return null; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== using System; using System.Collections.Generic; using System.Diagnostics.Contracts; using System.Reflection; namespace System.Security.Policy { ////// Factory class which creates evidence on demand for an AppDomain /// internal sealed class AppDomainEvidenceFactory : IRuntimeEvidenceFactory { private AppDomain m_targetDomain; private Evidence m_entryPointEvidence; internal AppDomainEvidenceFactory(AppDomain target) { Contract.Assert(target != null); Contract.Assert(target == AppDomain.CurrentDomain, "AppDomainEvidenceFactory should not be used across domains."); m_targetDomain = target; } ////// AppDomain this factory generates evidence for /// public IEvidenceFactory Target { get { return m_targetDomain; } } ////// Return any evidence supplied by the AppDomain itself /// public IEnumerableGetFactorySuppliedEvidence() { // AppDomains do not contain serialized evidence return new EvidenceBase[] { }; } /// /// Generate evidence on demand for an AppDomain /// [SecuritySafeCritical] public EvidenceBase GenerateEvidence(Type evidenceType) { // For v1.x compatibility, the default AppDomain has the same evidence as the entry point // assembly. Since other AppDomains inherit their evidence from the default AppDomain by // default, they also use the entry point assembly. BCLDebug.Assert(m_targetDomain == AppDomain.CurrentDomain, "AppDomainEvidenceFactory should not be used across domains."); if (m_targetDomain.IsDefaultAppDomain()) { // If we don't already know the evidence for the entry point assembly, get that now. If we // have a RuntimeAssembly go directly to its EvidenceNoDemand property to avoid the full // demand that it will do on access to its Evidence property. if (m_entryPointEvidence == null) { Assembly entryAssembly = Assembly.GetEntryAssembly(); RuntimeAssembly entryRuntimeAssembly = entryAssembly as RuntimeAssembly; if (entryRuntimeAssembly != null) { m_entryPointEvidence = entryRuntimeAssembly.EvidenceNoDemand.Clone(); } else if (entryAssembly != null) { m_entryPointEvidence = entryAssembly.Evidence; } } // If the entry point assembly provided evidence, then we use that for the AppDomain if (m_entryPointEvidence != null) { return m_entryPointEvidence.GetHostEvidence(evidenceType); } } else { // If we're not the default domain, then we should inherit our evidence from the default // domain -- so ask it what evidence it has of this type. AppDomain defaultDomain = AppDomain.GetDefaultDomain(); return defaultDomain.GetHostEvidence(evidenceType); } // AppDomains do not generate any evidence on demand return null; } } } // 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
- DataGridViewColumnEventArgs.cs
- Memoizer.cs
- SchemaImporterExtension.cs
- DataServiceHost.cs
- Compensation.cs
- PartialArray.cs
- GridErrorDlg.cs
- CompilationSection.cs
- BuildProvidersCompiler.cs
- BinaryFormatterWriter.cs
- DataGridCell.cs
- AutomationElement.cs
- TableLayoutSettings.cs
- ToolStripDropDownMenu.cs
- LocalClientSecuritySettingsElement.cs
- SqlExpressionNullability.cs
- OdbcDataAdapter.cs
- GraphicsContext.cs
- CodeAttachEventStatement.cs
- SequentialOutput.cs
- ObjectHandle.cs
- WebPartConnectionsCloseVerb.cs
- HttpRuntime.cs
- ResourceAssociationSet.cs
- DataServiceQuery.cs
- WindowsFormsLinkLabel.cs
- SecurityChannelListener.cs
- DetailsViewDeletedEventArgs.cs
- GridViewEditEventArgs.cs
- RuleInfoComparer.cs
- OleDbError.cs
- State.cs
- _DisconnectOverlappedAsyncResult.cs
- _FtpDataStream.cs
- XmlException.cs
- IDispatchConstantAttribute.cs
- TextSpanModifier.cs
- OverloadGroupAttribute.cs
- TextTreeRootTextBlock.cs
- MsmqIntegrationReceiveParameters.cs
- EffectiveValueEntry.cs
- HyperLinkStyle.cs
- PropertyMapper.cs
- SinglePageViewer.cs
- TraceUtility.cs
- CodeTypeMember.cs
- TypeDescriptorFilterService.cs
- JoinElimination.cs
- IncrementalReadDecoders.cs
- IPEndPoint.cs
- ProtocolsSection.cs
- TreeWalker.cs
- ClientClassGenerator.cs
- DataObjectAttribute.cs
- x509utils.cs
- Transform3DGroup.cs
- userdatakeys.cs
- DynamicDataResources.Designer.cs
- SpeakProgressEventArgs.cs
- RuntimeWrappedException.cs
- Sql8ConformanceChecker.cs
- RuntimeConfig.cs
- DesignTimeParseData.cs
- SiteMapSection.cs
- TypeExtension.cs
- AuthenticationService.cs
- FindProgressChangedEventArgs.cs
- SeekStoryboard.cs
- MultiByteCodec.cs
- TimeSpanMinutesConverter.cs
- MemberProjectedSlot.cs
- BulletChrome.cs
- MissingMethodException.cs
- PriorityBinding.cs
- NullRuntimeConfig.cs
- XmlSchemaSimpleContent.cs
- SessionIDManager.cs
- MultiSelector.cs
- AtomEntry.cs
- HighContrastHelper.cs
- ValidatingReaderNodeData.cs
- XmlSchemaAnnotated.cs
- ProxyHelper.cs
- EntitySqlQueryState.cs
- WsdlInspector.cs
- OleDbFactory.cs
- FlowStep.cs
- ScriptingScriptResourceHandlerSection.cs
- AnnotationComponentManager.cs
- DeadCharTextComposition.cs
- ColorTransformHelper.cs
- WsatAdminException.cs
- ImageButton.cs
- PagePropertiesChangingEventArgs.cs
- GregorianCalendarHelper.cs
- ContextQuery.cs
- JoinTreeNode.cs
- RijndaelCryptoServiceProvider.cs
- Timer.cs
- ErrorFormatter.cs