You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------
 | |
| // Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| //------------------------------------------------------------
 | |
| 
 | |
| using System.Collections.Generic;
 | |
| using System.Collections.ObjectModel;
 | |
| using System.IdentityModel.Policy;
 | |
| using System.IdentityModel.Selectors;
 | |
| using System.IdentityModel.Tokens;
 | |
| using System.Security.Claims;
 | |
| 
 | |
| namespace System.ServiceModel.Security
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Wraps a RsaSecurityTokenHandler. Delegates the token authentication call to
 | |
|     /// this wrapped tokenAuthenticator. Wraps the returned ClaimsIdentities into
 | |
|     /// an IAuthorizationPolicy.
 | |
|     /// </summary>
 | |
|     internal class WrappedRsaSecurityTokenAuthenticator : RsaSecurityTokenAuthenticator
 | |
|     {
 | |
|         RsaSecurityTokenHandler _wrappedRsaSecurityTokenHandler;
 | |
|         ExceptionMapper _exceptionMapper;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Initializes an instance of <see cref="WrappedRsaSecurityTokenAuthenticator"/>
 | |
|         /// </summary>
 | |
|         /// <param name="wrappedRsaSecurityTokenHandler">The RsaSecurityTokenHandler to wrap.</param>
 | |
|         /// <param name="exceptionMapper">Converts token validation exceptions to SOAP faults.</param>
 | |
|         public WrappedRsaSecurityTokenAuthenticator( 
 | |
|             RsaSecurityTokenHandler wrappedRsaSecurityTokenHandler, 
 | |
|             ExceptionMapper exceptionMapper )
 | |
|             : base()
 | |
|         {
 | |
|             if ( wrappedRsaSecurityTokenHandler == null )
 | |
|             {
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull( "wrappedRsaSecurityTokenHandler" );
 | |
|             }
 | |
| 
 | |
|             if ( exceptionMapper == null )
 | |
|             {
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull( "exceptionMapper" );
 | |
|             }
 | |
| 
 | |
|             _wrappedRsaSecurityTokenHandler = wrappedRsaSecurityTokenHandler;
 | |
|             _exceptionMapper = exceptionMapper;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Validates the token using the wrapped token handler and generates IAuthorizationPolicy
 | |
|         /// wrapping the returned ClaimsIdentities.
 | |
|         /// </summary>
 | |
|         /// <param name="token">Token to be validated.</param>
 | |
|         /// <returns>Read-only collection of IAuthorizationPolicy</returns>
 | |
|         protected override ReadOnlyCollection<IAuthorizationPolicy> ValidateTokenCore( SecurityToken token )
 | |
|         {
 | |
|             IEnumerable<ClaimsIdentity> identities = null;
 | |
|             try
 | |
|             {
 | |
|                 identities = _wrappedRsaSecurityTokenHandler.ValidateToken( token );
 | |
|             }
 | |
|             catch ( Exception ex )
 | |
|             {
 | |
|                 if ( !_exceptionMapper.HandleSecurityTokenProcessingException( ex ) )
 | |
|                 {
 | |
|                     throw;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             List<IAuthorizationPolicy> policies = new List<IAuthorizationPolicy>(1);
 | |
|             policies.Add(new AuthorizationPolicy(identities));
 | |
| 
 | |
|             return policies.AsReadOnly();
 | |
|         }
 | |
|     }
 | |
| }
 |