You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			254 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			254 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------ | ||
|  | // Copyright (c) Microsoft Corporation.  All rights reserved. | ||
|  | //------------------------------------------------------------ | ||
|  | 
 | ||
|  | namespace System.ServiceModel.Security | ||
|  | { | ||
|  |     using System.Collections.Generic; | ||
|  |     using System.ServiceModel.Channels; | ||
|  |     using System.Collections.ObjectModel; | ||
|  |     using System.Globalization; | ||
|  |     using System.ServiceModel; | ||
|  |     using System.Xml; | ||
|  |     using System.IdentityModel.Selectors; | ||
|  |     using System.ServiceModel.Diagnostics; | ||
|  | 
 | ||
|  |     sealed class IssuedTokensHeader : MessageHeader | ||
|  |     { | ||
|  |         ReadOnlyCollection<RequestSecurityTokenResponse> tokenIssuances; | ||
|  |         SecurityStandardsManager standardsManager; | ||
|  |         string actor; | ||
|  |         bool mustUnderstand; | ||
|  |         bool relay; | ||
|  |         bool isRefParam; | ||
|  | 
 | ||
|  |         public IssuedTokensHeader(RequestSecurityTokenResponse tokenIssuance, MessageSecurityVersion version, SecurityTokenSerializer tokenSerializer) | ||
|  |             : this(tokenIssuance, new SecurityStandardsManager(version, tokenSerializer)) | ||
|  |         { | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         public IssuedTokensHeader(RequestSecurityTokenResponse tokenIssuance, SecurityStandardsManager standardsManager) | ||
|  |             : base() | ||
|  |         { | ||
|  |             if (tokenIssuance == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("tokenIssuance"); | ||
|  |             } | ||
|  |             Collection<RequestSecurityTokenResponse> coll = new Collection<RequestSecurityTokenResponse>(); | ||
|  |             coll.Add(tokenIssuance); | ||
|  |             Initialize(coll, standardsManager); | ||
|  |         } | ||
|  | 
 | ||
|  |         public IssuedTokensHeader(IEnumerable<RequestSecurityTokenResponse> tokenIssuances, SecurityStandardsManager standardsManager) | ||
|  |             : base() | ||
|  |         { | ||
|  |             if (tokenIssuances == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("tokenIssuances"); | ||
|  |             } | ||
|  |             int index = 0; | ||
|  |             Collection<RequestSecurityTokenResponse> coll = new Collection<RequestSecurityTokenResponse>(); | ||
|  |             foreach (RequestSecurityTokenResponse rstr in tokenIssuances) | ||
|  |             { | ||
|  |                 if (rstr == null) | ||
|  |                 { | ||
|  |                     throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull(String.Format(CultureInfo.InvariantCulture, "tokenIssuances[{0}]", index)); | ||
|  |                 } | ||
|  |                 coll.Add(rstr); | ||
|  |                 ++index; | ||
|  |             } | ||
|  |             Initialize(coll, standardsManager); | ||
|  |         } | ||
|  | 
 | ||
|  |         void Initialize(Collection<RequestSecurityTokenResponse> coll, SecurityStandardsManager standardsManager) | ||
|  |         { | ||
|  |             if (standardsManager == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("standardsManager")); | ||
|  |             } | ||
|  |             this.standardsManager = standardsManager; | ||
|  |             this.tokenIssuances = new ReadOnlyCollection<RequestSecurityTokenResponse>(coll); | ||
|  |             this.actor = base.Actor; | ||
|  |             this.mustUnderstand = base.MustUnderstand; | ||
|  |             this.relay = base.Relay; | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         public IssuedTokensHeader(XmlReader xmlReader, MessageVersion version, SecurityStandardsManager standardsManager) | ||
|  |             : base() | ||
|  |         { | ||
|  |             if (xmlReader == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("xmlReader"); | ||
|  |             } | ||
|  |             if (standardsManager == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("standardsManager")); | ||
|  |             } | ||
|  |             this.standardsManager = standardsManager; | ||
|  |             XmlDictionaryReader reader = XmlDictionaryReader.CreateDictionaryReader(xmlReader); | ||
|  |             MessageHeader.GetHeaderAttributes(reader, version, out this.actor, out this.mustUnderstand, out this.relay, out this.isRefParam); | ||
|  |             reader.ReadStartElement(this.Name, this.Namespace); | ||
|  |             Collection<RequestSecurityTokenResponse> coll = new Collection<RequestSecurityTokenResponse>(); | ||
|  |             if (this.standardsManager.TrustDriver.IsAtRequestSecurityTokenResponseCollection(reader)) | ||
|  |             { | ||
|  |                 RequestSecurityTokenResponseCollection rstrColl = this.standardsManager.TrustDriver.CreateRequestSecurityTokenResponseCollection(reader); | ||
|  |                 foreach (RequestSecurityTokenResponse rstr in rstrColl.RstrCollection) | ||
|  |                 { | ||
|  |                     coll.Add(rstr); | ||
|  |                 } | ||
|  |             } | ||
|  |             else | ||
|  |             { | ||
|  |                 RequestSecurityTokenResponse rstr = this.standardsManager.TrustDriver.CreateRequestSecurityTokenResponse(reader); | ||
|  |                 coll.Add(rstr); | ||
|  |             } | ||
|  |             this.tokenIssuances = new ReadOnlyCollection<RequestSecurityTokenResponse>(coll); | ||
|  |             reader.ReadEndElement(); | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         public ReadOnlyCollection<RequestSecurityTokenResponse> TokenIssuances | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 return this.tokenIssuances; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override string Actor | ||
|  |         { | ||
|  |             get  | ||
|  |             { | ||
|  |                 return this.actor; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override bool IsReferenceParameter | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 return this.isRefParam; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override bool MustUnderstand | ||
|  |         { | ||
|  |             get  | ||
|  |             {  | ||
|  |                 return this.mustUnderstand;  | ||
|  |             } | ||
|  | 
 | ||
|  |         } | ||
|  | 
 | ||
|  |         public override bool Relay | ||
|  |         { | ||
|  |             get  | ||
|  |             {  | ||
|  |                 return this.relay;  | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         public override string Name | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 return this.standardsManager.TrustDriver.IssuedTokensHeaderName; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override string Namespace | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 return this.standardsManager.TrustDriver.IssuedTokensHeaderNamespace; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         protected override void OnWriteHeaderContents(XmlDictionaryWriter writer, MessageVersion messageVersion) | ||
|  |         { | ||
|  |             if (this.tokenIssuances.Count == 1) | ||
|  |             { | ||
|  |                 this.standardsManager.TrustDriver.WriteRequestSecurityTokenResponse(this.tokenIssuances[0], writer); | ||
|  |             } | ||
|  |             else | ||
|  |             { | ||
|  |                 RequestSecurityTokenResponseCollection rstrCollection = new RequestSecurityTokenResponseCollection(this.tokenIssuances, this.standardsManager); | ||
|  |                 rstrCollection.WriteTo(writer); | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         internal static Collection<RequestSecurityTokenResponse> ExtractIssuances(Message message, MessageSecurityVersion version, WSSecurityTokenSerializer tokenSerializer, string[] actors, XmlQualifiedName expectedAppliesToQName) | ||
|  |         { | ||
|  |             return ExtractIssuances(message, new SecurityStandardsManager(version, tokenSerializer), actors, expectedAppliesToQName); | ||
|  |         } | ||
|  | 
 | ||
|  |         // if expectedAppliesToQName is null all issuances matching the actors are returned. | ||
|  |         internal static Collection<RequestSecurityTokenResponse> ExtractIssuances(Message message, SecurityStandardsManager standardsManager, string[] actors, XmlQualifiedName expectedAppliesToQName) | ||
|  |         { | ||
|  |             if (message == null) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("message"); | ||
|  |             } | ||
|  |             if (standardsManager == null) | ||
|  |             { | ||
|  |                 standardsManager = SecurityStandardsManager.DefaultInstance; | ||
|  |             } | ||
|  |             if (actors == null) | ||
|  |             { | ||
|  |                 throw TraceUtility.ThrowHelperArgumentNull("actors", message); | ||
|  |             } | ||
|  |             Collection<RequestSecurityTokenResponse> issuances = new Collection<RequestSecurityTokenResponse>(); | ||
|  |             for (int i = 0; i < message.Headers.Count; ++i) | ||
|  |             { | ||
|  |                 if (message.Headers[i].Name == standardsManager.TrustDriver.IssuedTokensHeaderName && message.Headers[i].Namespace == standardsManager.TrustDriver.IssuedTokensHeaderNamespace) | ||
|  |                 { | ||
|  |                     bool isValidActor = false; | ||
|  |                     for (int j = 0; j < actors.Length; ++j) | ||
|  |                     { | ||
|  |                         if (actors[j] == message.Headers[i].Actor) | ||
|  |                         { | ||
|  |                             isValidActor = true; | ||
|  |                             break; | ||
|  |                         } | ||
|  |                     } | ||
|  |                     if (!isValidActor) | ||
|  |                     { | ||
|  |                         continue; | ||
|  |                     } | ||
|  |                     IssuedTokensHeader issuedTokensHeader = new IssuedTokensHeader(message.Headers.GetReaderAtHeader(i), message.Version, standardsManager); | ||
|  |                     for (int k = 0; k < issuedTokensHeader.TokenIssuances.Count; ++k) | ||
|  |                     { | ||
|  |                         bool isMatch; | ||
|  |                         if (expectedAppliesToQName != null) | ||
|  |                         { | ||
|  |                             string issuanceAppliesToName; | ||
|  |                             string issuanceAppliesToNs; | ||
|  |                             issuedTokensHeader.TokenIssuances[k].GetAppliesToQName(out issuanceAppliesToName, out issuanceAppliesToNs); | ||
|  |                             if (issuanceAppliesToName == expectedAppliesToQName.Name && issuanceAppliesToNs == expectedAppliesToQName.Namespace) | ||
|  |                             { | ||
|  |                                 isMatch = true; | ||
|  |                             } | ||
|  |                             else | ||
|  |                             { | ||
|  |                                 isMatch = false; | ||
|  |                             } | ||
|  |                         } | ||
|  |                         else | ||
|  |                         { | ||
|  |                             isMatch = true; | ||
|  |                         } | ||
|  |                         if (isMatch) | ||
|  |                         { | ||
|  |                             issuances.Add(issuedTokensHeader.TokenIssuances[k]); | ||
|  |                         } | ||
|  |                     } | ||
|  |                 } | ||
|  |             } | ||
|  |             return issuances; | ||
|  |         } | ||
|  |     } | ||
|  | } |