Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Security / Policy / FirstMatchCodeGroup.cs / 1 / FirstMatchCodeGroup.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // FirstMatchCodeGroup.cs // // Representation for code groups used for the policy mechanism // namespace System.Security.Policy { using System; using System.Security; using System.Security.Util; using System.Collections; [Serializable] [System.Runtime.InteropServices.ComVisible(true)] sealed public class FirstMatchCodeGroup : CodeGroup { internal FirstMatchCodeGroup() : base() { } public FirstMatchCodeGroup( IMembershipCondition membershipCondition, PolicyStatement policy ) : base( membershipCondition, policy ) { } public override PolicyStatement Resolve( Evidence evidence ) { if (evidence == null) throw new ArgumentNullException("evidence"); object usedEvidence = null; if (PolicyManager.CheckMembershipCondition(MembershipCondition, evidence, out usedEvidence)) { PolicyStatement childPolicy = null; IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { childPolicy = PolicyManager.ResolveCodeGroup(enumerator.Current as CodeGroup, evidence); // If the child has a policy, we are done. if (childPolicy != null) { break; } } // If any delay-evidence was used to generate this grant set, then we need to keep track of // that for potentially later forcing it to be verified. IDelayEvaluatedEvidence delayEvidence = usedEvidence as IDelayEvaluatedEvidence; bool delayEvidenceNeedsVerification = delayEvidence != null && !delayEvidence.IsVerified; PolicyStatement thisPolicy = this.PolicyStatement; // PolicyStatement getter makes a copy for us if (thisPolicy == null) { // We didn't add any permissions, but we enabled our children to be evaluated, and // therefore its grant set is dependent on any of our delay evidence. if (delayEvidenceNeedsVerification) { childPolicy = childPolicy.Copy(); childPolicy.AddDependentEvidence(delayEvidence); } return childPolicy; } else if (childPolicy != null) { // Combine the child and this policy and return it. PolicyStatement combined = thisPolicy.Copy(); if (delayEvidenceNeedsVerification) { combined.AddDependentEvidence(delayEvidence); } combined.InplaceUnion(childPolicy); return combined; } else { // Otherwise we just copy the this policy. if (delayEvidenceNeedsVerification) { thisPolicy.AddDependentEvidence(delayEvidence); } return thisPolicy; } } else { return null; } } public override CodeGroup ResolveMatchingCodeGroups( Evidence evidence ) { if (evidence == null) throw new ArgumentNullException("evidence"); if (this.MembershipCondition.Check( evidence )) { CodeGroup retGroup = this.Copy(); retGroup.Children = new ArrayList(); IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { CodeGroup matchingGroups = ((CodeGroup)enumerator.Current).ResolveMatchingCodeGroups( evidence ); // If the child has a policy, we are done. if (matchingGroups != null) { retGroup.AddChild( matchingGroups ); break; } } return retGroup; } else { return null; } } public override CodeGroup Copy() { FirstMatchCodeGroup group = new FirstMatchCodeGroup(); group.MembershipCondition = this.MembershipCondition; group.PolicyStatement = this.PolicyStatement; group.Name = this.Name; group.Description = this.Description; IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { group.AddChild( (CodeGroup)enumerator.Current ); } return group; } public override String MergeLogic { get { return Environment.GetResourceString( "MergeLogic_FirstMatch" ); } } internal override String GetTypeName() { return "System.Security.Policy.FirstMatchCodeGroup"; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== // FirstMatchCodeGroup.cs // // Representation for code groups used for the policy mechanism // namespace System.Security.Policy { using System; using System.Security; using System.Security.Util; using System.Collections; [Serializable] [System.Runtime.InteropServices.ComVisible(true)] sealed public class FirstMatchCodeGroup : CodeGroup { internal FirstMatchCodeGroup() : base() { } public FirstMatchCodeGroup( IMembershipCondition membershipCondition, PolicyStatement policy ) : base( membershipCondition, policy ) { } public override PolicyStatement Resolve( Evidence evidence ) { if (evidence == null) throw new ArgumentNullException("evidence"); object usedEvidence = null; if (PolicyManager.CheckMembershipCondition(MembershipCondition, evidence, out usedEvidence)) { PolicyStatement childPolicy = null; IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { childPolicy = PolicyManager.ResolveCodeGroup(enumerator.Current as CodeGroup, evidence); // If the child has a policy, we are done. if (childPolicy != null) { break; } } // If any delay-evidence was used to generate this grant set, then we need to keep track of // that for potentially later forcing it to be verified. IDelayEvaluatedEvidence delayEvidence = usedEvidence as IDelayEvaluatedEvidence; bool delayEvidenceNeedsVerification = delayEvidence != null && !delayEvidence.IsVerified; PolicyStatement thisPolicy = this.PolicyStatement; // PolicyStatement getter makes a copy for us if (thisPolicy == null) { // We didn't add any permissions, but we enabled our children to be evaluated, and // therefore its grant set is dependent on any of our delay evidence. if (delayEvidenceNeedsVerification) { childPolicy = childPolicy.Copy(); childPolicy.AddDependentEvidence(delayEvidence); } return childPolicy; } else if (childPolicy != null) { // Combine the child and this policy and return it. PolicyStatement combined = thisPolicy.Copy(); if (delayEvidenceNeedsVerification) { combined.AddDependentEvidence(delayEvidence); } combined.InplaceUnion(childPolicy); return combined; } else { // Otherwise we just copy the this policy. if (delayEvidenceNeedsVerification) { thisPolicy.AddDependentEvidence(delayEvidence); } return thisPolicy; } } else { return null; } } public override CodeGroup ResolveMatchingCodeGroups( Evidence evidence ) { if (evidence == null) throw new ArgumentNullException("evidence"); if (this.MembershipCondition.Check( evidence )) { CodeGroup retGroup = this.Copy(); retGroup.Children = new ArrayList(); IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { CodeGroup matchingGroups = ((CodeGroup)enumerator.Current).ResolveMatchingCodeGroups( evidence ); // If the child has a policy, we are done. if (matchingGroups != null) { retGroup.AddChild( matchingGroups ); break; } } return retGroup; } else { return null; } } public override CodeGroup Copy() { FirstMatchCodeGroup group = new FirstMatchCodeGroup(); group.MembershipCondition = this.MembershipCondition; group.PolicyStatement = this.PolicyStatement; group.Name = this.Name; group.Description = this.Description; IEnumerator enumerator = this.Children.GetEnumerator(); while (enumerator.MoveNext()) { group.AddChild( (CodeGroup)enumerator.Current ); } return group; } public override String MergeLogic { get { return Environment.GetResourceString( "MergeLogic_FirstMatch" ); } } internal override String GetTypeName() { return "System.Security.Policy.FirstMatchCodeGroup"; } } } // 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
- TypeValidationEventArgs.cs
- safex509handles.cs
- mactripleDES.cs
- CompoundFileDeflateTransform.cs
- BackStopAuthenticationModule.cs
- CommonProperties.cs
- ObjectDataSourceStatusEventArgs.cs
- sitestring.cs
- ToolStripSplitButton.cs
- ChannelManager.cs
- WebPartRestoreVerb.cs
- SafeBuffer.cs
- ComponentEvent.cs
- ValueType.cs
- EncryptedData.cs
- ControlPropertyNameConverter.cs
- PrimitiveDataContract.cs
- WebServiceHostFactory.cs
- XmlIgnoreAttribute.cs
- ToolBarDesigner.cs
- QilTargetType.cs
- DefaultTraceListener.cs
- ResizingMessageFilter.cs
- XmlSerializationGeneratedCode.cs
- NamedPermissionSet.cs
- DbConnectionPoolGroupProviderInfo.cs
- NonSerializedAttribute.cs
- PseudoWebRequest.cs
- XamlWriter.cs
- ButtonBaseAdapter.cs
- __FastResourceComparer.cs
- InertiaRotationBehavior.cs
- WindowsListViewItemStartMenu.cs
- FormViewInsertEventArgs.cs
- TraceLog.cs
- HelpProvider.cs
- ColorAnimation.cs
- WebPageTraceListener.cs
- InputBinding.cs
- ReflectionPermission.cs
- TreeNodeCollectionEditor.cs
- SHA256.cs
- OleDbReferenceCollection.cs
- XPathException.cs
- _NestedSingleAsyncResult.cs
- MarshalDirectiveException.cs
- Bookmark.cs
- DefaultMemberAttribute.cs
- DataSourceControlBuilder.cs
- HttpListenerException.cs
- MouseDevice.cs
- DecimalMinMaxAggregationOperator.cs
- DiscoveryProxy.cs
- SynchronizedDispatch.cs
- SqlServer2KCompatibilityCheck.cs
- PrimaryKeyTypeConverter.cs
- EventlogProvider.cs
- SchemaTypeEmitter.cs
- PerformanceCounterLib.cs
- DefaultBinder.cs
- InnerItemCollectionView.cs
- EditorPartChrome.cs
- TransactionScopeDesigner.cs
- FixUpCollection.cs
- ObfuscationAttribute.cs
- SessionIDManager.cs
- StatusBarPanel.cs
- EventHandlerList.cs
- XmlDataCollection.cs
- IMembershipProvider.cs
- HitTestParameters3D.cs
- WindowsListViewSubItem.cs
- PerformanceCounters.cs
- CodeDomSerializationProvider.cs
- SecurityKeyIdentifierClause.cs
- WpfWebRequestHelper.cs
- StateWorkerRequest.cs
- ToolStripEditorManager.cs
- UpDownEvent.cs
- FieldMetadata.cs
- ExcCanonicalXml.cs
- GridViewHeaderRowPresenterAutomationPeer.cs
- EventRoute.cs
- AdapterSwitches.cs
- Matrix.cs
- __ComObject.cs
- XmlQueryRuntime.cs
- ScaleTransform3D.cs
- AssemblyInfo.cs
- WrappedIUnknown.cs
- DataGridViewCellPaintingEventArgs.cs
- OrderedDictionaryStateHelper.cs
- CAGDesigner.cs
- _PooledStream.cs
- ReceiveSecurityHeaderElementManager.cs
- CredentialCache.cs
- ListViewInsertionMark.cs
- RectangleConverter.cs
- WorkItem.cs
- DataGridViewCellToolTipTextNeededEventArgs.cs