Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / IdentityModel / System / IdentityModel / Tokens / SamlAuthenticationStatement.cs / 1 / SamlAuthenticationStatement.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Collections.Generic; using System.Collections.ObjectModel; using System.Globalization; using System.IdentityModel; using System.IdentityModel.Claims; using System.IdentityModel.Selectors; using System.Runtime.Serialization; using System.Xml.Serialization; using System.Xml; public class SamlAuthenticationStatement : SamlSubjectStatement { DateTime authenticationInstant = DateTime.UtcNow.ToUniversalTime(); string authenticationMethod = XD.SamlDictionary.UnspecifiedAuthenticationMethod.Value; readonly ImmutableCollectionauthorityBindings = new ImmutableCollection (); string dnsAddress; string ipAddress; bool isReadOnly = false; public SamlAuthenticationStatement() { } public SamlAuthenticationStatement(SamlSubject samlSubject, string authenticationMethod, DateTime authenticationInstant, string dnsAddress, string ipAddress, IEnumerable authorityBindings) : base(samlSubject) { if (String.IsNullOrEmpty(authenticationMethod)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument("authenticationMethod", SR.GetString(SR.SAMLAuthenticationStatementMissingAuthenticationMethod)); this.authenticationMethod = authenticationMethod; this.authenticationInstant = authenticationInstant.ToUniversalTime(); this.dnsAddress = dnsAddress; this.ipAddress = ipAddress; if (authorityBindings != null) { foreach (SamlAuthorityBinding binding in authorityBindings) { if (binding == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.Assertion.Value)); this.authorityBindings.Add(binding); } } CheckObjectValidity(); } public DateTime AuthenticationInstant { get {return this.authenticationInstant; } set { if (isReadOnly) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly))); this.authenticationInstant = value; } } public string AuthenticationMethod { get {return this.authenticationMethod; } set { if (isReadOnly) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly))); if (String.IsNullOrEmpty(value)) this.authenticationMethod = XD.SamlDictionary.UnspecifiedAuthenticationMethod.Value; else this.authenticationMethod = value; } } public static string ClaimType { get { return ClaimTypes.Authentication; } } public IList AuthorityBindings { get {return this.authorityBindings; } } public string DnsAddress { get { return this.dnsAddress; } set { if (isReadOnly) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly))); this.dnsAddress = value; } } public string IPAddress { get {return this.ipAddress; } set { if (isReadOnly) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly))); this.ipAddress = value; } } public override bool IsReadOnly { get { return this.isReadOnly; } } public override void MakeReadOnly() { if (!this.isReadOnly) { foreach (SamlAuthorityBinding binding in this.authorityBindings) { binding.MakeReadOnly(); } this.authorityBindings.MakeReadOnly(); this.isReadOnly = true; } } protected override void AddClaimsToList(IList claims) { if (claims == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("claims"); claims.Add(new Claim(ClaimTypes.Authentication, new SamlAuthenticationClaimResource(this.authenticationInstant, this.authenticationMethod, this.dnsAddress, this.ipAddress, this.authorityBindings), Rights.PossessProperty)); } void CheckObjectValidity() { if (this.SamlSubject == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLSubjectStatementRequiresSubject))); // Authenticaton instant is required. We will throw an exception if it is not present while // deserializing a SAML Authentication statement. When creating a new Authentication statement // we set this value to UtcNow. if (String.IsNullOrEmpty(this.authenticationMethod)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLAuthenticationStatementMissingAuthenticationMethod))); } public override void ReadXml(XmlDictionaryReader reader, SamlSerializer samlSerializer, SecurityTokenSerializer keyInfoSerializer, SecurityTokenResolver outOfBandTokenResolver) { if (reader == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("reader")); if (samlSerializer == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("samlSerializer")); #pragma warning suppress 56506 // samlSerializer.DictionaryManager is never null. SamlDictionary dictionary = samlSerializer.DictionaryManager.SamlDictionary; string authInstance = reader.GetAttribute(dictionary.AuthenticationInstant, null); if (String.IsNullOrEmpty(authInstance)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLAuthenticationStatementMissingAuthenticationInstanceOnRead))); this.authenticationInstant = DateTime.ParseExact( authInstance, SamlConstants.AcceptedDateTimeFormats, DateTimeFormatInfo.InvariantInfo, DateTimeStyles.None).ToUniversalTime(); this.authenticationMethod = reader.GetAttribute(dictionary.AuthenticationMethod, null); if (String.IsNullOrEmpty(this.authenticationMethod)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLAuthenticationStatementMissingAuthenticationMethodOnRead))); reader.MoveToContent(); reader.Read(); if (reader.IsStartElement(dictionary.Subject, dictionary.Namespace)) { SamlSubject subject = new SamlSubject(); subject.ReadXml(reader, samlSerializer, keyInfoSerializer, outOfBandTokenResolver); base.SamlSubject = subject; } else { // Subject is a required element for a Authentication Statement clause. throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLAuthenticationStatementMissingSubject))); } if (reader.IsStartElement(dictionary.SubjectLocality, dictionary.Namespace)) { this.dnsAddress = reader.GetAttribute(dictionary.SubjectLocalityDNSAddress, null); this.ipAddress = reader.GetAttribute(dictionary.SubjectLocalityIPAddress, null); if (reader.IsEmptyElement) { reader.MoveToContent(); reader.Read(); } else { reader.MoveToContent(); reader.Read(); reader.ReadEndElement(); } } while (reader.IsStartElement()) { if (reader.IsStartElement(dictionary.AuthorityBinding, dictionary.Namespace)) { SamlAuthorityBinding binding = new SamlAuthorityBinding(); binding.ReadXml(reader, samlSerializer, keyInfoSerializer, outOfBandTokenResolver); this.authorityBindings.Add(binding); } else { // We do not understand this element. throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLBadSchema, dictionary.AuthenticationStatement))); } } reader.MoveToContent(); reader.ReadEndElement(); } public override void WriteXml(XmlDictionaryWriter writer, SamlSerializer samlSerializer, SecurityTokenSerializer keyInfoSerializer) { CheckObjectValidity(); if (writer == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("writer")); if (samlSerializer == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("samlSerializer")); #pragma warning suppress 56506 // samlSerializer.DictionaryManager is never null. SamlDictionary dictionary = samlSerializer.DictionaryManager.SamlDictionary; writer.WriteStartElement(dictionary.PreferredPrefix.Value, dictionary.AuthenticationStatement, dictionary.Namespace); writer.WriteStartAttribute(dictionary.AuthenticationMethod, null); writer.WriteString(this.authenticationMethod); writer.WriteEndAttribute(); writer.WriteStartAttribute(dictionary.AuthenticationInstant, null); writer.WriteString(this.authenticationInstant.ToString(SamlConstants.GeneratedDateTimeFormat, CultureInfo.InvariantCulture)); writer.WriteEndAttribute(); this.SamlSubject.WriteXml(writer, samlSerializer, keyInfoSerializer); if ((this.ipAddress != null) || (this.dnsAddress != null)) { writer.WriteStartElement(dictionary.PreferredPrefix.Value, dictionary.SubjectLocality, dictionary.Namespace); if (this.ipAddress != null) { writer.WriteStartAttribute(dictionary.SubjectLocalityIPAddress, null); writer.WriteString(this.ipAddress); writer.WriteEndAttribute(); } if (this.dnsAddress != null) { writer.WriteStartAttribute(dictionary.SubjectLocalityDNSAddress, null); writer.WriteString(this.dnsAddress); writer.WriteEndAttribute(); } writer.WriteEndElement(); } for (int i = 0; i < this.authorityBindings.Count; i++) { this.authorityBindings[i].WriteXml(writer, samlSerializer, keyInfoSerializer); } writer.WriteEndElement(); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ControlBuilder.cs
- TextBoxBaseDesigner.cs
- EntryIndex.cs
- SecurityCriticalDataForSet.cs
- Globals.cs
- PersistChildrenAttribute.cs
- LinkButton.cs
- ObjectStateFormatter.cs
- XmlILIndex.cs
- recordstatefactory.cs
- MustUnderstandSoapException.cs
- Environment.cs
- StringUtil.cs
- BooleanConverter.cs
- ColumnBinding.cs
- AngleUtil.cs
- TableItemStyle.cs
- ConfigXmlComment.cs
- DataBindingList.cs
- ReflectionHelper.cs
- SpeechUI.cs
- WebConfigurationManager.cs
- IdentifierService.cs
- AttributeCollection.cs
- AssociationTypeEmitter.cs
- XmlUtil.cs
- RemotingException.cs
- FormatterConverter.cs
- AuthenticatedStream.cs
- ContextMenuService.cs
- EventsTab.cs
- SourceCollection.cs
- CodeComment.cs
- LinearKeyFrames.cs
- SqlTypesSchemaImporter.cs
- RemotingAttributes.cs
- StateItem.cs
- WorkflowApplicationCompletedException.cs
- HijriCalendar.cs
- indexingfiltermarshaler.cs
- RegistryConfigurationProvider.cs
- EmptyElement.cs
- RSAPKCS1KeyExchangeDeformatter.cs
- IdleTimeoutMonitor.cs
- Point4D.cs
- ProjectionCamera.cs
- HeaderCollection.cs
- xdrvalidator.cs
- XmlCharType.cs
- Timer.cs
- CacheEntry.cs
- XmlStringTable.cs
- JsonDeserializer.cs
- EncodingStreamWrapper.cs
- DynamicQueryableWrapper.cs
- RegexGroup.cs
- filewebrequest.cs
- XmlAttribute.cs
- ValidateNames.cs
- UriTemplate.cs
- WpfSharedXamlSchemaContext.cs
- InteropBitmapSource.cs
- ExpandCollapseProviderWrapper.cs
- XComponentModel.cs
- MobileControlsSectionHandler.cs
- FormsAuthenticationCredentials.cs
- RemoteWebConfigurationHost.cs
- SoapFormatterSinks.cs
- OutKeywords.cs
- GeneralTransform2DTo3DTo2D.cs
- Regex.cs
- CodeFieldReferenceExpression.cs
- OutputCacheProfileCollection.cs
- ListChangedEventArgs.cs
- DragAssistanceManager.cs
- ApplicationGesture.cs
- GetWinFXPath.cs
- SafeNativeMethods.cs
- FolderBrowserDialog.cs
- Exceptions.cs
- EventListener.cs
- MobileControlsSectionHelper.cs
- IconBitmapDecoder.cs
- RSAOAEPKeyExchangeFormatter.cs
- ISAPIApplicationHost.cs
- AutoGeneratedFieldProperties.cs
- TreeViewImageKeyConverter.cs
- DiscreteKeyFrames.cs
- IEnumerable.cs
- XpsColorContext.cs
- StateBag.cs
- BeginEvent.cs
- StorageRoot.cs
- ApplicationActivator.cs
- XmlSchemaException.cs
- GenericPrincipal.cs
- BinaryReader.cs
- SmiMetaDataProperty.cs
- WebResourceUtil.cs
- SiteMapPath.cs