Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WCF / IdentityModel / System / IdentityModel / Tokens / SamlEvidence.cs / 1305376 / SamlEvidence.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Xml; using System.Xml.Serialization; using System.Runtime.Serialization; using System.IdentityModel.Selectors; public class SamlEvidence { readonly ImmutableCollectionassertionIdReferences = new ImmutableCollection (); readonly ImmutableCollection assertions = new ImmutableCollection (); bool isReadOnly = false; public SamlEvidence(IEnumerable assertionIdReferences) : this(assertionIdReferences, null) { } public SamlEvidence(IEnumerable assertions) : this(null, assertions) { } public SamlEvidence(IEnumerable assertionIdReferences, IEnumerable assertions) { if (assertionIdReferences == null && assertions == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertion)); if (assertionIdReferences != null) { foreach (string idReference in assertionIdReferences) { if (String.IsNullOrEmpty(idReference)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.AssertionIdReference.Value)); this.assertionIdReferences.Add(idReference); } } if (assertions != null) { foreach (SamlAssertion assertion in assertions) { if (assertion == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.Assertion.Value)); this.assertions.Add(assertion); } } } public SamlEvidence() { } public IList AssertionIdReferences { get {return this.assertionIdReferences; } } public IList Assertions { get {return this.assertions; } } public bool IsReadOnly { get { return this.isReadOnly; } } public void MakeReadOnly() { if (!this.isReadOnly) { foreach (SamlAssertion assertion in this.assertions) { assertion.MakeReadOnly(); } this.assertionIdReferences.MakeReadOnly(); this.assertions.MakeReadOnly(); this.isReadOnly = true; } } void CheckObjectValidity() { if ((this.assertions.Count == 0) && (this.assertionIdReferences.Count == 0)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertion))); } public virtual 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; reader.MoveToContent(); reader.Read(); while (reader.IsStartElement()) { if (reader.IsStartElement(dictionary.AssertionIdReference, dictionary.Namespace)) { reader.MoveToContent(); this.assertionIdReferences.Add(reader.ReadString()); reader.ReadEndElement(); } else if (reader.IsStartElement(dictionary.Assertion, dictionary.Namespace)) { SamlAssertion assertion = new SamlAssertion(); assertion.ReadXml(reader, samlSerializer, keyInfoSerializer, outOfBandTokenResolver); this.assertions.Add(assertion); } else throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLBadSchema, dictionary.Evidence.Value))); } if ((this.assertionIdReferences.Count == 0) && (this.assertions.Count == 0)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertionOnRead))); reader.MoveToContent(); reader.ReadEndElement(); } public virtual 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.Evidence.Value, dictionary.Namespace.Value); for (int i = 0; i < this.assertionIdReferences.Count; i++) { writer.WriteStartElement(dictionary.PreferredPrefix.Value, dictionary.AssertionIdReference, dictionary.Namespace); writer.WriteString(this.assertionIdReferences[i]); writer.WriteEndElement(); } for (int i = 0; i < this.assertions.Count; i++) { this.assertions[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. //----------------------------------------------------------------------------- namespace System.IdentityModel.Tokens { using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Xml; using System.Xml.Serialization; using System.Runtime.Serialization; using System.IdentityModel.Selectors; public class SamlEvidence { readonly ImmutableCollection assertionIdReferences = new ImmutableCollection (); readonly ImmutableCollection assertions = new ImmutableCollection (); bool isReadOnly = false; public SamlEvidence(IEnumerable assertionIdReferences) : this(assertionIdReferences, null) { } public SamlEvidence(IEnumerable assertions) : this(null, assertions) { } public SamlEvidence(IEnumerable assertionIdReferences, IEnumerable assertions) { if (assertionIdReferences == null && assertions == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertion)); if (assertionIdReferences != null) { foreach (string idReference in assertionIdReferences) { if (String.IsNullOrEmpty(idReference)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.AssertionIdReference.Value)); this.assertionIdReferences.Add(idReference); } } if (assertions != null) { foreach (SamlAssertion assertion in assertions) { if (assertion == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.Assertion.Value)); this.assertions.Add(assertion); } } } public SamlEvidence() { } public IList AssertionIdReferences { get {return this.assertionIdReferences; } } public IList Assertions { get {return this.assertions; } } public bool IsReadOnly { get { return this.isReadOnly; } } public void MakeReadOnly() { if (!this.isReadOnly) { foreach (SamlAssertion assertion in this.assertions) { assertion.MakeReadOnly(); } this.assertionIdReferences.MakeReadOnly(); this.assertions.MakeReadOnly(); this.isReadOnly = true; } } void CheckObjectValidity() { if ((this.assertions.Count == 0) && (this.assertionIdReferences.Count == 0)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertion))); } public virtual 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; reader.MoveToContent(); reader.Read(); while (reader.IsStartElement()) { if (reader.IsStartElement(dictionary.AssertionIdReference, dictionary.Namespace)) { reader.MoveToContent(); this.assertionIdReferences.Add(reader.ReadString()); reader.ReadEndElement(); } else if (reader.IsStartElement(dictionary.Assertion, dictionary.Namespace)) { SamlAssertion assertion = new SamlAssertion(); assertion.ReadXml(reader, samlSerializer, keyInfoSerializer, outOfBandTokenResolver); this.assertions.Add(assertion); } else throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLBadSchema, dictionary.Evidence.Value))); } if ((this.assertionIdReferences.Count == 0) && (this.assertions.Count == 0)) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLEvidenceShouldHaveOneAssertionOnRead))); reader.MoveToContent(); reader.ReadEndElement(); } public virtual 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.Evidence.Value, dictionary.Namespace.Value); for (int i = 0; i < this.assertionIdReferences.Count; i++) { writer.WriteStartElement(dictionary.PreferredPrefix.Value, dictionary.AssertionIdReference, dictionary.Namespace); writer.WriteString(this.assertionIdReferences[i]); writer.WriteEndElement(); } for (int i = 0; i < this.assertions.Count; i++) { this.assertions[i].WriteXml(writer, samlSerializer, keyInfoSerializer); } writer.WriteEndElement(); } } } // 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
- RNGCryptoServiceProvider.cs
- MultilineStringEditor.cs
- XmlArrayAttribute.cs
- DataServiceRequest.cs
- BitmapPalette.cs
- Delegate.cs
- VirtualPathProvider.cs
- WCFModelStrings.Designer.cs
- ImageDrawing.cs
- StreamReader.cs
- WsatTransactionFormatter.cs
- CodeActivityContext.cs
- InstalledVoice.cs
- Bitmap.cs
- AttributeProviderAttribute.cs
- ServiceHostingEnvironmentSection.cs
- StrongTypingException.cs
- DictionaryContent.cs
- FrugalList.cs
- ControlBuilderAttribute.cs
- HwndKeyboardInputProvider.cs
- Module.cs
- DataSourceHelper.cs
- ToolboxItemFilterAttribute.cs
- EdmType.cs
- UIPropertyMetadata.cs
- GetPageNumberCompletedEventArgs.cs
- EventLogPermissionHolder.cs
- InkCanvasInnerCanvas.cs
- ValidatingPropertiesEventArgs.cs
- ISFTagAndGuidCache.cs
- XXXOnTypeBuilderInstantiation.cs
- X509ChainElement.cs
- ExceptionHelpers.cs
- WeakEventTable.cs
- TextDecorationLocationValidation.cs
- Overlapped.cs
- SecurityListenerSettingsLifetimeManager.cs
- SystemUdpStatistics.cs
- NumberFormatter.cs
- ButtonBaseAutomationPeer.cs
- TextEffect.cs
- RegexRunnerFactory.cs
- ValueTable.cs
- ReadOnlyMetadataCollection.cs
- BigInt.cs
- SyndicationPerson.cs
- HandlerFactoryCache.cs
- ISFClipboardData.cs
- HostedHttpTransportManager.cs
- ReferenceSchema.cs
- PrePrepareMethodAttribute.cs
- RawUIStateInputReport.cs
- DesignerToolboxInfo.cs
- CssClassPropertyAttribute.cs
- Empty.cs
- PipelineModuleStepContainer.cs
- DocumentsTrace.cs
- storepermission.cs
- MailDefinition.cs
- FormViewCommandEventArgs.cs
- CategoryNameCollection.cs
- GetPageNumberCompletedEventArgs.cs
- View.cs
- ThumbButtonInfo.cs
- NavigationExpr.cs
- DbParameterCollectionHelper.cs
- HttpWrapper.cs
- CollectionMarkupSerializer.cs
- BamlReader.cs
- SiteMapDataSourceView.cs
- JapaneseCalendar.cs
- TimeStampChecker.cs
- CompressEmulationStream.cs
- DbParameterCollectionHelper.cs
- KeySpline.cs
- AttributeParameterInfo.cs
- StreamGeometry.cs
- XmlSchemaObjectTable.cs
- InkCollectionBehavior.cs
- Model3DCollection.cs
- TextWriterEngine.cs
- TimeoutValidationAttribute.cs
- Types.cs
- PassportAuthenticationModule.cs
- FreezableCollection.cs
- SqlVisitor.cs
- Calendar.cs
- VirtualPathUtility.cs
- EncodingInfo.cs
- XomlCompilerHelpers.cs
- ByeMessageCD1.cs
- ToolBar.cs
- BindingsCollection.cs
- MetafileHeaderWmf.cs
- GlyphRunDrawing.cs
- FileRecordSequenceHelper.cs
- wgx_render.cs
- PackageProperties.cs
- PersonalizationStateInfoCollection.cs