You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			156 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			156 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------ | ||
|  | // Copyright (c) Microsoft Corporation.  All rights reserved. | ||
|  | //------------------------------------------------------------ | ||
|  | 
 | ||
|  | using System; | ||
|  | using System.Collections.Generic; | ||
|  | using System.IdentityModel.Selectors; | ||
|  | using System.IdentityModel.Tokens; | ||
|  | using System.Runtime; | ||
|  | using System.Security.Cryptography; | ||
|  | using System.Security.Authentication.ExtendedProtection; | ||
|  | using System.ServiceModel.Diagnostics; | ||
|  | 
 | ||
|  | namespace System.ServiceModel.Security.Tokens | ||
|  | { | ||
|  |     /// <summary> | ||
|  |     /// The ProviderBackedSecurityToken was added for the ChannelBindingToken work for Win7.   | ||
|  |     /// It is used to delay the resolution of a token until it is needed.   | ||
|  |     /// For the CBT, this delay is necessary as the CBT is not available until SecurityAppliedMessage.OnWriteMessage is called. | ||
|  |     /// The CBT binds a token to the  | ||
|  |     /// </summary> | ||
|  |     internal class ProviderBackedSecurityToken : SecurityToken | ||
|  |     { | ||
|  |         SecurityTokenProvider _tokenProvider; | ||
|  | 
 | ||
|  |         // Double-checked locking pattern requires volatile for read/write synchronization | ||
|  |         volatile SecurityToken _securityToken; | ||
|  |         TimeSpan _timeout; | ||
|  |         ChannelBinding _channelBinding; | ||
|  | 
 | ||
|  |         object _lock; | ||
|  | 
 | ||
|  |         /// <summary> | ||
|  |         /// Constructor to create an instance of this class. | ||
|  |         /// </summary> | ||
|  |         /// <param name="securityToken">SecurityToken that represents the SecurityTokenElement element.</param> | ||
|  |         public ProviderBackedSecurityToken( SecurityTokenProvider tokenProvider, TimeSpan timeout ) | ||
|  |         { | ||
|  |             _lock = new object(); | ||
|  | 
 | ||
|  |             if ( tokenProvider == null ) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("tokenProvider")); | ||
|  |             } | ||
|  | 
 | ||
|  |             _tokenProvider = tokenProvider; | ||
|  |             _timeout = timeout; | ||
|  |         } | ||
|  | 
 | ||
|  |         public SecurityTokenProvider TokenProvider | ||
|  |         { | ||
|  |             get { return _tokenProvider; } | ||
|  |         } | ||
|  | 
 | ||
|  |         public ChannelBinding ChannelBinding | ||
|  |         { | ||
|  |             set { _channelBinding = value; } | ||
|  |         } | ||
|  | 
 | ||
|  |         void ResolveSecurityToken() | ||
|  |         { | ||
|  |             if ( _securityToken == null ) | ||
|  |             { | ||
|  |                 lock ( _lock ) | ||
|  |                 { | ||
|  |                     if ( _securityToken == null ) | ||
|  |                     { | ||
|  |                         ClientCredentialsSecurityTokenManager.KerberosSecurityTokenProviderWrapper kerbTokenProvider = _tokenProvider  | ||
|  |                                                         as ClientCredentialsSecurityTokenManager.KerberosSecurityTokenProviderWrapper; | ||
|  |                         if (kerbTokenProvider != null) | ||
|  |                         { | ||
|  |                             _securityToken = kerbTokenProvider.GetToken((new TimeoutHelper(_timeout)).RemainingTime(), _channelBinding); | ||
|  |                         } | ||
|  |                         else | ||
|  |                         { | ||
|  |                             _securityToken = _tokenProvider.GetToken((new TimeoutHelper(_timeout)).RemainingTime()); | ||
|  |                         } | ||
|  |                     } | ||
|  |                 } | ||
|  |             } | ||
|  | 
 | ||
|  |             if ( _securityToken == null ) | ||
|  |             { | ||
|  |                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError( new SecurityTokenException( SR.GetString( SR.SecurityTokenNotResolved, _tokenProvider.GetType().ToString() ) ) ); | ||
|  |             } | ||
|  | 
 | ||
|  |             return; | ||
|  |         } | ||
|  | 
 | ||
|  |         public SecurityToken Token | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 if ( _securityToken == null ) | ||
|  |                 { | ||
|  |                     ResolveSecurityToken(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 return _securityToken; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override string Id | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 if ( _securityToken == null ) | ||
|  |                 { | ||
|  |                     ResolveSecurityToken(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 return _securityToken.Id; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override System.Collections.ObjectModel.ReadOnlyCollection<SecurityKey> SecurityKeys | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 if ( _securityToken == null ) | ||
|  |                 { | ||
|  |                     ResolveSecurityToken(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 return _securityToken.SecurityKeys; | ||
|  |             }    | ||
|  |         } | ||
|  | 
 | ||
|  |         public override DateTime ValidFrom | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 if ( _securityToken == null ) | ||
|  |                 { | ||
|  |                     ResolveSecurityToken(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 return _securityToken.ValidFrom; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override DateTime ValidTo | ||
|  |         { | ||
|  |             get | ||
|  |             { | ||
|  |                 if ( _securityToken == null ) | ||
|  |                 { | ||
|  |                     ResolveSecurityToken(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 return _securityToken.ValidTo; | ||
|  |             }    | ||
|  |         } | ||
|  |     } | ||
|  | } |