You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			64 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //----------------------------------------------------------
 | |
| // Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| //------------------------------------------------------------
 | |
| 
 | |
| namespace System.ServiceModel.Security
 | |
| {
 | |
|     using System.IdentityModel.Tokens;
 | |
|     using System.Security.Cryptography;
 | |
|     using System.ServiceModel;
 | |
|     using System.ServiceModel.Channels;
 | |
|     using System.ServiceModel.Description;
 | |
|     using System.ServiceModel.Security.Tokens;
 | |
|     using System.Xml;
 | |
| 
 | |
|     class WSSecurityOneDotOneReceiveSecurityHeader : WSSecurityOneDotZeroReceiveSecurityHeader
 | |
|     {
 | |
|         public WSSecurityOneDotOneReceiveSecurityHeader(Message message, string actor, bool mustUnderstand, bool relay,
 | |
|             SecurityStandardsManager standardsManager,
 | |
|             SecurityAlgorithmSuite algorithmSuite,
 | |
|             int headerIndex, MessageDirection direction)
 | |
|             : base(message, actor, mustUnderstand, relay, standardsManager, algorithmSuite, headerIndex, direction)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         protected override DecryptedHeader DecryptHeader(XmlDictionaryReader reader, WrappedKeySecurityToken wrappedKeyToken)
 | |
|         {
 | |
|             // If it is the client, then we may need to read the GenericXmlSecurityKeyIdentoifoer clause while reading EncryptedData. 
 | |
|             EncryptedHeaderXml headerXml = new EncryptedHeaderXml(this.Version, this.MessageDirection == MessageDirection.Output);
 | |
|             headerXml.SecurityTokenSerializer = this.StandardsManager.SecurityTokenSerializer;
 | |
|             headerXml.ReadFrom(reader, MaxReceivedMessageSize);
 | |
| 
 | |
|             // The Encrypted Headers MustUnderstand, Relay and Actor attributes should match the
 | |
|             // Security Headers value.
 | |
|             if (headerXml.MustUnderstand != this.MustUnderstand)
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new MessageSecurityException(SR.GetString(SR.EncryptedHeaderAttributeMismatch, XD.MessageDictionary.MustUnderstand.Value, headerXml.MustUnderstand, this.MustUnderstand)));
 | |
| 
 | |
|             if (headerXml.Relay != this.Relay)
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new MessageSecurityException(SR.GetString(SR.EncryptedHeaderAttributeMismatch, XD.Message12Dictionary.Relay.Value, headerXml.Relay, this.Relay)));
 | |
| 
 | |
|             if (headerXml.Actor != this.Actor)
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new MessageSecurityException(SR.GetString(SR.EncryptedHeaderAttributeMismatch, this.Version.Envelope.DictionaryActor, headerXml.Actor, this.Actor)));
 | |
|             
 | |
|             SecurityToken token;
 | |
|             if (wrappedKeyToken == null)
 | |
|             {
 | |
|                 token = ResolveKeyIdentifier(headerXml.KeyIdentifier, this.CombinedPrimaryTokenResolver, false);
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 token = wrappedKeyToken;
 | |
|             }
 | |
|             RecordEncryptionToken(token);
 | |
|             using (SymmetricAlgorithm algorithm = CreateDecryptionAlgorithm(token, headerXml.EncryptionMethod, this.AlgorithmSuite))
 | |
|             {
 | |
|                 headerXml.SetUpDecryption(algorithm);
 | |
|                 return new DecryptedHeader(
 | |
|                     headerXml.GetDecryptedBuffer(),
 | |
|                     this.SecurityVerifiedMessage.GetEnvelopeAttributes(), this.SecurityVerifiedMessage.GetHeaderAttributes(),
 | |
|                     this.Version, this.StandardsManager.IdManager, this.ReaderQuotas);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |