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
- NestedContainer.cs
- TimeoutException.cs
- ConnectionConsumerAttribute.cs
- SymmetricAlgorithm.cs
- SymmetricCryptoHandle.cs
- CustomErrorsSection.cs
- ExtendedProperty.cs
- ComponentDispatcher.cs
- HostedHttpRequestAsyncResult.cs
- DictionaryEntry.cs
- ConfigurationManagerHelperFactory.cs
- WebHttpSecurityModeHelper.cs
- WorkflowRuntimeService.cs
- DataGridViewSelectedCellsAccessibleObject.cs
- ErrorProvider.cs
- MessageQueuePermission.cs
- RSAProtectedConfigurationProvider.cs
- SecurityKeyIdentifierClause.cs
- IsolatedStorageException.cs
- ProxyHelper.cs
- Msec.cs
- ListControlConvertEventArgs.cs
- ColorConvertedBitmapExtension.cs
- ReverseInheritProperty.cs
- UnionCqlBlock.cs
- BindingList.cs
- HtmlTableRowCollection.cs
- ReadOnlyTernaryTree.cs
- DoWorkEventArgs.cs
- DrawingContextWalker.cs
- FontUnitConverter.cs
- DataGridViewComboBoxColumn.cs
- CompilerErrorCollection.cs
- OptionalColumn.cs
- EditorPart.cs
- ExpressionWriter.cs
- BinaryObjectReader.cs
- DetailsViewRowCollection.cs
- DataControlPagerLinkButton.cs
- SqlXml.cs
- QilParameter.cs
- InstanceNormalEvent.cs
- CodePageUtils.cs
- CodeIdentifiers.cs
- ParameterCollectionEditorForm.cs
- ProfilePropertySettingsCollection.cs
- NativeMethods.cs
- DataGridTable.cs
- HMACRIPEMD160.cs
- Button.cs
- DesignerDataView.cs
- ContextMarshalException.cs
- RedistVersionInfo.cs
- ArithmeticException.cs
- ListBase.cs
- RegularExpressionValidator.cs
- ProcessModelSection.cs
- TextTreeDeleteContentUndoUnit.cs
- DataGridViewCellStyleConverter.cs
- SessionStateContainer.cs
- MoveSizeWinEventHandler.cs
- SettingsPropertyIsReadOnlyException.cs
- DesignerForm.cs
- StreamGeometry.cs
- LifetimeServices.cs
- RightNameExpirationInfoPair.cs
- ProfessionalColorTable.cs
- NumericExpr.cs
- Exceptions.cs
- MediaElement.cs
- MatrixAnimationUsingPath.cs
- ExpressionServices.cs
- WebServiceFaultDesigner.cs
- ColorAnimationBase.cs
- ProxyWebPartConnectionCollection.cs
- BindToObject.cs
- Translator.cs
- GeneralTransform3DCollection.cs
- Encoding.cs
- ProtocolsSection.cs
- SecurityTokenAuthenticator.cs
- CallContext.cs
- PingReply.cs
- Logging.cs
- XmlParser.cs
- LocalBuilder.cs
- PointCollection.cs
- WindowsUpDown.cs
- SHA256Managed.cs
- ResourceCollectionInfo.cs
- IndexingContentUnit.cs
- SQLInt16Storage.cs
- DbReferenceCollection.cs
- Debugger.cs
- VideoDrawing.cs
- FloatMinMaxAggregationOperator.cs
- DesignTimeParseData.cs
- TextServicesLoader.cs
- LoadGrammarCompletedEventArgs.cs
- CompiledAction.cs