Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WCF / IdentityModel / System / IdentityModel / Tokens / SamlSubjectStatement.cs / 1305376 / SamlSubjectStatement.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Collections.Generic; using System.Collections.ObjectModel; using System.IdentityModel.Claims; using System.IdentityModel.Policy; using System.IdentityModel.Selectors; using System.Security.Principal; public abstract class SamlSubjectStatement : SamlStatement { SamlSubject subject; IAuthorizationPolicy policy; bool isReadOnly = false; protected SamlSubjectStatement() { } protected SamlSubjectStatement(SamlSubject samlSubject) { if (samlSubject == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("samlSubject")); this.subject = samlSubject; } public SamlSubject SamlSubject { get {return this.subject; } set { if (isReadOnly) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly))); if (value == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("value")); this.subject = value; } } public override bool IsReadOnly { get { return this.isReadOnly; } } public override void MakeReadOnly() { if (!this.isReadOnly) { subject.MakeReadOnly(); this.isReadOnly = true; } } public override IAuthorizationPolicy CreatePolicy(ClaimSet issuer, SamlSecurityTokenAuthenticator samlAuthenticator) { if (issuer == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("issuer"); // SupportingTokenAuthenticator collection can be null when the Subject does not // contain a key. if (this.policy == null) { ListclaimSets = new List (); ClaimSet subjectKeyClaimset = this.subject.ExtractSubjectKeyClaimSet(samlAuthenticator); if (subjectKeyClaimset != null) claimSets.Add(subjectKeyClaimset); List claims = new List (); ReadOnlyCollection subjectClaims = this.subject.ExtractClaims(); for (int i = 0; i < subjectClaims.Count; ++i) { claims.Add(subjectClaims[i]); } AddClaimsToList(claims); claimSets.Add(new DefaultClaimSet(issuer, claims)); this.policy = new UnconditionalPolicy(this.subject.Identity, claimSets.AsReadOnly(), SecurityUtils.MaxUtcDateTime); } return this.policy; } protected void SetSubject(SamlSubject samlSubject) { if (samlSubject == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("samlSubject")); this.subject = samlSubject; } protected abstract void AddClaimsToList(IList claims); } } // 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
- CreateUserWizardStep.cs
- Rotation3DKeyFrameCollection.cs
- CapabilitiesUse.cs
- RtfControlWordInfo.cs
- WebPartZoneBaseDesigner.cs
- SerializationObjectManager.cs
- ClosableStream.cs
- ColorDialog.cs
- ECDiffieHellmanCng.cs
- DrawListViewItemEventArgs.cs
- NetSectionGroup.cs
- documentsequencetextpointer.cs
- SqlParameterCollection.cs
- DBSqlParserTable.cs
- CodeCatchClause.cs
- BidirectionalDictionary.cs
- DispatcherHooks.cs
- LocalizationCodeDomSerializer.cs
- FormViewModeEventArgs.cs
- RunClient.cs
- BamlTreeMap.cs
- ContentTextAutomationPeer.cs
- XmlAttributeProperties.cs
- StylusEventArgs.cs
- ExpressionVisitorHelpers.cs
- RemoteWebConfigurationHostStream.cs
- BindingNavigator.cs
- XsdBuildProvider.cs
- PublisherMembershipCondition.cs
- ArrayWithOffset.cs
- UpWmlMobileTextWriter.cs
- SerializationInfo.cs
- ComplusEndpointConfigContainer.cs
- FillBehavior.cs
- PrintPreviewControl.cs
- RootBrowserWindowProxy.cs
- DBDataPermission.cs
- Function.cs
- PropertyHelper.cs
- QuotedPairReader.cs
- ObjectListComponentEditor.cs
- DataGridViewColumnTypeEditor.cs
- FixedSOMPageElement.cs
- SmiSettersStream.cs
- BamlLocalizerErrorNotifyEventArgs.cs
- CellConstantDomain.cs
- ComplexTypeEmitter.cs
- SplitterPanel.cs
- CompositeCollectionView.cs
- CommandLineParser.cs
- MatrixUtil.cs
- OleDbTransaction.cs
- SQLInt64Storage.cs
- ArrayConverter.cs
- StdRegProviderWrapper.cs
- EntitySetBaseCollection.cs
- ExecutionContext.cs
- ClientUrlResolverWrapper.cs
- SessionStateContainer.cs
- OleDbConnection.cs
- ECDiffieHellmanCngPublicKey.cs
- FileDetails.cs
- DateTimeConstantAttribute.cs
- EmptyReadOnlyDictionaryInternal.cs
- TypeSystem.cs
- GACIdentityPermission.cs
- MTConfigUtil.cs
- StaticContext.cs
- TrustLevelCollection.cs
- DataColumnMapping.cs
- IntSecurity.cs
- IdentitySection.cs
- ListBox.cs
- TrustLevel.cs
- WhitespaceSignificantCollectionAttribute.cs
- AddInBase.cs
- OutOfMemoryException.cs
- ConditionalAttribute.cs
- ErrorLog.cs
- ExtractedStateEntry.cs
- EditingCommands.cs
- DataKeyArray.cs
- StylusPlugin.cs
- DiagnosticSection.cs
- ModuleElement.cs
- Misc.cs
- VariableQuery.cs
- NullEntityWrapper.cs
- SiteMapNodeItem.cs
- AutomationPropertyInfo.cs
- MimeXmlReflector.cs
- Soap.cs
- NativeMethods.cs
- ObjectHelper.cs
- WSSecureConversationFeb2005.cs
- HttpPostedFileBase.cs
- AxisAngleRotation3D.cs
- XmlSchemaSimpleType.cs
- UnitySerializationHolder.cs
- ImageListStreamer.cs