You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			184 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //-----------------------------------------------------------------------------
 | |
| // 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.Serialization;
 | |
|     using System.Xml;
 | |
|     using System.Runtime.Serialization;
 | |
|     using System.Globalization;
 | |
|     using System.IdentityModel.Selectors;
 | |
| 
 | |
|     public class SamlConditions
 | |
|     {
 | |
|         readonly ImmutableCollection<SamlCondition> conditions = new ImmutableCollection<SamlCondition>();
 | |
|         bool isReadOnly = false;
 | |
| 
 | |
|         // Calculate once
 | |
|         DateTime notBefore = SecurityUtils.MinUtcDateTime;
 | |
|         DateTime notOnOrAfter = SecurityUtils.MaxUtcDateTime;
 | |
| 
 | |
|         public SamlConditions()
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public SamlConditions(DateTime notBefore, DateTime notOnOrAfter)
 | |
|             : this(notBefore, notOnOrAfter, null)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public SamlConditions(DateTime notBefore, DateTime notOnOrAfter,
 | |
|             IEnumerable<SamlCondition> conditions
 | |
|             )
 | |
|         {
 | |
|             this.notBefore = notBefore.ToUniversalTime();
 | |
|             this.notOnOrAfter = notOnOrAfter.ToUniversalTime();
 | |
| 
 | |
|             if (conditions != null)
 | |
|             {
 | |
|                 foreach (SamlCondition condition in conditions)
 | |
|                 {
 | |
|                     if (condition == null)
 | |
|                         throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument(SR.GetString(SR.SAMLEntityCannotBeNullOrEmpty, XD.SamlDictionary.Condition.Value));
 | |
| 
 | |
|                     this.conditions.Add(condition);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public IList<SamlCondition> Conditions
 | |
|         {
 | |
|             get { return this.conditions; }
 | |
|         }
 | |
| 
 | |
|         public DateTime NotBefore
 | |
|         {
 | |
|             get { return this.notBefore; }
 | |
|             set
 | |
|             {
 | |
|                 if (isReadOnly)
 | |
|                     throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly)));
 | |
| 
 | |
|                 this.notBefore = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public DateTime NotOnOrAfter
 | |
|         {
 | |
|             get { return this.notOnOrAfter; }
 | |
|             set
 | |
|             {
 | |
|                 if (isReadOnly)
 | |
|                     throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly)));
 | |
| 
 | |
|                 this.notOnOrAfter = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public bool IsReadOnly
 | |
|         {
 | |
|             get { return this.isReadOnly; }
 | |
|         }
 | |
| 
 | |
|         public void MakeReadOnly()
 | |
|         {
 | |
|             if (!this.isReadOnly)
 | |
|             {
 | |
|                 this.conditions.MakeReadOnly();
 | |
| 
 | |
|                 foreach (SamlCondition condition in this.conditions)
 | |
|                 {
 | |
|                     condition.MakeReadOnly();
 | |
|                 }
 | |
| 
 | |
|                 this.isReadOnly = true;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         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;
 | |
| 
 | |
|             string time = reader.GetAttribute(dictionary.NotBefore, null);
 | |
|             if (!string.IsNullOrEmpty(time))
 | |
|                 this.notBefore = DateTime.ParseExact(
 | |
|                     time, SamlConstants.AcceptedDateTimeFormats, DateTimeFormatInfo.InvariantInfo, DateTimeStyles.None).ToUniversalTime();
 | |
| 
 | |
|             time = reader.GetAttribute(dictionary.NotOnOrAfter, null);
 | |
|             if (!string.IsNullOrEmpty(time))
 | |
|                 this.notOnOrAfter = DateTime.ParseExact(
 | |
|                     time, SamlConstants.AcceptedDateTimeFormats, DateTimeFormatInfo.InvariantInfo, DateTimeStyles.None).ToUniversalTime();
 | |
| 
 | |
|             // Saml Conditions element is an optional element and all its child element
 | |
|             // are optional as well. So we can have a empty <saml:Conditions /> element
 | |
|             // in a valid Saml token.
 | |
|             if (reader.IsEmptyElement)
 | |
|             {
 | |
|                 // Just issue a read to read the Empty element.
 | |
|                 reader.MoveToContent();
 | |
|                 reader.Read();
 | |
|                 return;
 | |
|             }
 | |
| 
 | |
|             reader.MoveToContent();
 | |
|             reader.Read();
 | |
|             while (reader.IsStartElement())
 | |
|             {
 | |
|                 SamlCondition condition = samlSerializer.LoadCondition(reader, keyInfoSerializer, outOfBandTokenResolver);
 | |
|                 if (condition == null)
 | |
|                     throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new SecurityTokenException(SR.GetString(SR.SAMLUnableToLoadCondtion)));
 | |
|                 this.conditions.Add(condition);
 | |
|             }
 | |
|             reader.MoveToContent();
 | |
|             reader.ReadEndElement();
 | |
|         }
 | |
| 
 | |
|         public virtual void WriteXml(XmlDictionaryWriter writer, SamlSerializer samlSerializer, SecurityTokenSerializer keyInfoSerializer)
 | |
|         {
 | |
|             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.Conditions, dictionary.Namespace);
 | |
| 
 | |
|             if (this.notBefore != SecurityUtils.MinUtcDateTime)
 | |
|             {
 | |
|                 writer.WriteStartAttribute(dictionary.NotBefore, null);
 | |
|                 writer.WriteString(this.notBefore.ToString(SamlConstants.GeneratedDateTimeFormat, DateTimeFormatInfo.InvariantInfo));
 | |
|                 writer.WriteEndAttribute();
 | |
|             }
 | |
| 
 | |
|             if (this.notOnOrAfter != SecurityUtils.MaxUtcDateTime)
 | |
|             {
 | |
|                 writer.WriteStartAttribute(dictionary.NotOnOrAfter, null);
 | |
|                 writer.WriteString(this.notOnOrAfter.ToString(SamlConstants.GeneratedDateTimeFormat, DateTimeFormatInfo.InvariantInfo));
 | |
|                 writer.WriteEndAttribute();
 | |
|             }
 | |
| 
 | |
|             for (int i = 0; i < this.conditions.Count; i++)
 | |
|             {
 | |
|                 this.conditions[i].WriteXml(writer, samlSerializer, keyInfoSerializer);
 | |
|             }
 | |
| 
 | |
|             writer.WriteEndElement();
 | |
|         }
 | |
|     }
 | |
| 
 | |
| }
 |