Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / clr / src / BCL / System / Security / Policy / FirstMatchCodeGroup.cs / 2 / 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
- BulletedListEventArgs.cs
- DesignerAttributeInfo.cs
- SubclassTypeValidatorAttribute.cs
- ResXResourceReader.cs
- ReliableChannelFactory.cs
- DynamicDataRoute.cs
- EmbeddedMailObject.cs
- Sorting.cs
- ReflectionPermission.cs
- QuadraticBezierSegment.cs
- LineSegment.cs
- OSEnvironmentHelper.cs
- DesignerObjectListAdapter.cs
- CompositeCollectionView.cs
- X509Certificate2Collection.cs
- EntityCodeGenerator.cs
- Serializer.cs
- ErrorTableItemStyle.cs
- ListViewItemEventArgs.cs
- DataGridViewTopLeftHeaderCell.cs
- ConditionalDesigner.cs
- ProviderConnectionPointCollection.cs
- Merger.cs
- SqlExpander.cs
- XmlDataSource.cs
- BaseDataBoundControl.cs
- TransformerTypeCollection.cs
- RadioButtonStandardAdapter.cs
- ConfigXmlElement.cs
- ItemDragEvent.cs
- BindToObject.cs
- _WinHttpWebProxyDataBuilder.cs
- ObjectManager.cs
- ToolZone.cs
- EdmProviderManifest.cs
- WsatProxy.cs
- WorkflowServiceAttributes.cs
- ExtensionWindow.cs
- NodeInfo.cs
- ThicknessAnimation.cs
- SqlBooleanMismatchVisitor.cs
- XmlSerializationReader.cs
- RadioButtonBaseAdapter.cs
- PerfCounters.cs
- NameTable.cs
- ValidationResults.cs
- SqlDataReaderSmi.cs
- FloaterBaseParagraph.cs
- OdbcConnectionOpen.cs
- DesignerWithHeader.cs
- DynamicUpdateCommand.cs
- EncodingInfo.cs
- CounterSample.cs
- ScriptResourceDefinition.cs
- MimeWriter.cs
- MatrixTransform3D.cs
- PageBuildProvider.cs
- WebHeaderCollection.cs
- ExtensionWindowHeader.cs
- MatrixTransform3D.cs
- ThreadPool.cs
- Rect3DConverter.cs
- StickyNote.cs
- DataGridViewCheckBoxColumn.cs
- Publisher.cs
- PartialCachingControl.cs
- ManifestSignedXml.cs
- EditingCoordinator.cs
- DataTransferEventArgs.cs
- IsolatedStorageException.cs
- Trace.cs
- TraceHelpers.cs
- WebPageTraceListener.cs
- PatternMatcher.cs
- WebControl.cs
- QuaternionRotation3D.cs
- Separator.cs
- XslUrlEditor.cs
- COM2TypeInfoProcessor.cs
- RouteItem.cs
- ParseNumbers.cs
- DBSchemaTable.cs
- ServiceCredentials.cs
- TextTreeObjectNode.cs
- WebPartVerbsEventArgs.cs
- MessageSecurityVersion.cs
- RTLAwareMessageBox.cs
- CompiledIdentityConstraint.cs
- UriWriter.cs
- DataControlImageButton.cs
- OraclePermission.cs
- Vector3DValueSerializer.cs
- mansign.cs
- PropertyGeneratedEventArgs.cs
- EventInfo.cs
- XmlComment.cs
- DependencyPropertyKind.cs
- EncoderReplacementFallback.cs
- _emptywebproxy.cs
- OrderedDictionary.cs