// // SamlAdvice.cs // // Author: // Atsushi Enomoto // // Copyright (C) 2005 Novell, Inc. http://www.novell.com // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System; using System.Collections.Generic; using System.Xml; using System.IdentityModel.Selectors; namespace System.IdentityModel.Tokens { public class SamlAdvice { List idrefs = new List (); List assertions = new List (); bool is_readonly; public SamlAdvice () { } public SamlAdvice (IEnumerable assertions) : this (new string [0], assertions) { } public SamlAdvice (IEnumerable references) : this (references, new SamlAssertion [0]) { } public SamlAdvice (IEnumerable references, IEnumerable assertions) { if (references == null) throw new ArgumentException ("references are null."); if (assertions == null) throw new ArgumentException ("assertions are null."); foreach (string r in references) { if (r == null) throw new ArgumentException ("references contain null item."); idrefs.Add (r); } foreach (SamlAssertion a in assertions) { if (a == null) throw new ArgumentException ("assertions contain null item."); this.assertions.Add (a); } } public bool IsReadOnly { get { return is_readonly; } } public IList Assertions { get { return assertions; } } public IList AssertionIdReferences { get { return idrefs; } } public void MakeReadOnly () { is_readonly = true; } public virtual void ReadXml (XmlDictionaryReader reader, SamlSerializer samlSerializer, SecurityTokenSerializer keyInfoTokenSerializer, SecurityTokenResolver outOfBandTokenResolver) { if (reader == null) throw new ArgumentNullException ("reader"); if (samlSerializer == null) throw new ArgumentNullException ("samlSerializer"); reader.ReadStartElement ("Advice", SamlConstants.Namespace); for (reader.MoveToContent (); reader.NodeType == XmlNodeType.Element; reader.MoveToContent ()) { if (reader.NamespaceURI != SamlConstants.Namespace) throw new SecurityTokenException (String.Format ("Invalid SAML Advice element: element '{0}' in namespace '{1}' is unexpected.", reader.LocalName, reader.NamespaceURI)); switch (reader.LocalName) { case "Assertion": SamlAssertion a = new SamlAssertion (); a.ReadXml (reader, samlSerializer, keyInfoTokenSerializer, outOfBandTokenResolver); assertions.Add (a); break; case "AssertionIDReference": idrefs.Add (reader.ReadElementContentAsString ()); break; default: throw new SecurityTokenException (String.Format ("Invalid SAML Advice element: SAML element '{0}' is unexpected.", reader.LocalName)); } } reader.ReadEndElement (); } public virtual void WriteXml (XmlDictionaryWriter writer, SamlSerializer samlSerializer, SecurityTokenSerializer keyInfoTokenSerializer) { if (writer == null) throw new ArgumentNullException ("writer"); if (samlSerializer == null) throw new ArgumentNullException ("samlSerializer"); writer.WriteStartElement ("saml", "Advice", SamlConstants.Namespace); foreach (string idref in AssertionIdReferences) writer.WriteElementString ("saml", "AssertionIDReference", SamlConstants.Namespace, idref); foreach (SamlAssertion assertion in Assertions) assertion.WriteXml (writer, samlSerializer, keyInfoTokenSerializer); writer.WriteEndElement (); } } }