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
- __ComObject.cs
- InputLanguageSource.cs
- OrderedHashRepartitionStream.cs
- ContextStack.cs
- QueryAccessibilityHelpEvent.cs
- SqlDataRecord.cs
- StatusBarItemAutomationPeer.cs
- SHA256.cs
- DesignerProperties.cs
- DesignerDataConnection.cs
- TextViewBase.cs
- StorageAssociationTypeMapping.cs
- OutputCacheSettingsSection.cs
- OleDbParameter.cs
- DiagnosticStrings.cs
- CompiledELinqQueryState.cs
- ComplexObject.cs
- DataErrorValidationRule.cs
- DesignerActionKeyboardBehavior.cs
- SessionState.cs
- Executor.cs
- TargetInvocationException.cs
- SessionPageStateSection.cs
- RegexStringValidatorAttribute.cs
- VScrollBar.cs
- FontNamesConverter.cs
- VisualStyleInformation.cs
- HtmlElement.cs
- SelectionPatternIdentifiers.cs
- XmlValidatingReader.cs
- ComplexLine.cs
- WebPartMovingEventArgs.cs
- InvokeSchedule.cs
- HtmlSelect.cs
- WsatTransactionFormatter.cs
- EventData.cs
- DbConnectionPoolGroup.cs
- ReachDocumentReferenceSerializerAsync.cs
- SelectionGlyphBase.cs
- UnhandledExceptionEventArgs.cs
- documentsequencetextview.cs
- PrefixQName.cs
- SafeNativeMemoryHandle.cs
- MappingSource.cs
- GradientBrush.cs
- XmlSyndicationContent.cs
- StrokeNodeOperations2.cs
- DataServiceStreamProviderWrapper.cs
- DBSqlParserTable.cs
- CompressEmulationStream.cs
- ContentElementCollection.cs
- DataServiceStreamProviderWrapper.cs
- XmlAttribute.cs
- Configuration.cs
- TextEndOfParagraph.cs
- ADMembershipUser.cs
- SchemaConstraints.cs
- PropertyGridCommands.cs
- GenericRootAutomationPeer.cs
- DateTimeSerializationSection.cs
- ObjectStateManager.cs
- ServiceReference.cs
- XPathSelfQuery.cs
- TypeConvertions.cs
- HttpChannelBindingToken.cs
- XmlEnumAttribute.cs
- HtmlControl.cs
- EditCommandColumn.cs
- StreamResourceInfo.cs
- AnalyzedTree.cs
- EndPoint.cs
- BindingElement.cs
- XmlParser.cs
- Vector3dCollection.cs
- DockPatternIdentifiers.cs
- WinFormsUtils.cs
- XhtmlBasicControlAdapter.cs
- ExpressionQuoter.cs
- Typeface.cs
- StatusBar.cs
- InputBindingCollection.cs
- InstanceDescriptor.cs
- XmlQueryType.cs
- ISCIIEncoding.cs
- SystemColorTracker.cs
- WebResourceUtil.cs
- ProcessHost.cs
- HtmlWindow.cs
- Lease.cs
- PrintDocument.cs
- ValuePattern.cs
- SqlStatistics.cs
- IsolatedStorage.cs
- BuildManager.cs
- COM2TypeInfoProcessor.cs
- TextEncodedRawTextWriter.cs
- SecurityUniqueId.cs
- MaterialCollection.cs
- HttpModuleAction.cs
- ClientScriptManager.cs