You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			104 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| //------------------------------------------------------------------------------
 | |
| 
 | |
| namespace System.ServiceModel.Configuration
 | |
| {
 | |
|     using System;
 | |
|     using System.ServiceModel;
 | |
|     using System.Configuration;
 | |
|     using System.ServiceModel.Channels;
 | |
|     using System.ServiceModel.Security;
 | |
|     using System.Xml;
 | |
|     using System.Security.Cryptography.X509Certificates;
 | |
|     using System.IdentityModel.Selectors;
 | |
| 
 | |
|     public sealed partial class X509PeerCertificateAuthenticationElement : ConfigurationElement
 | |
|     {
 | |
|         public X509PeerCertificateAuthenticationElement()
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         [ConfigurationProperty(ConfigurationStrings.CustomCertificateValidatorType, DefaultValue = "")]
 | |
|         [StringValidator(MinLength = 0)]
 | |
|         public string CustomCertificateValidatorType
 | |
|         {
 | |
|             get { return (string)base[ConfigurationStrings.CustomCertificateValidatorType]; }
 | |
|             set
 | |
|             {
 | |
|                 if (String.IsNullOrEmpty(value))
 | |
|                 {
 | |
|                     value = String.Empty;
 | |
|                 }
 | |
|                 base[ConfigurationStrings.CustomCertificateValidatorType] = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         [ConfigurationProperty(ConfigurationStrings.CertificateValidationMode, DefaultValue = X509PeerCertificateAuthentication.DefaultCertificateValidationMode)]
 | |
|         [ServiceModelEnumValidator(typeof(X509CertificateValidationModeHelper))]
 | |
|         public X509CertificateValidationMode CertificateValidationMode
 | |
|         {
 | |
|             get { return (X509CertificateValidationMode)base[ConfigurationStrings.CertificateValidationMode]; }
 | |
|             set { base[ConfigurationStrings.CertificateValidationMode] = value; }
 | |
|         }
 | |
| 
 | |
|         [ConfigurationProperty(ConfigurationStrings.RevocationMode, DefaultValue = X509PeerCertificateAuthentication.DefaultRevocationMode)]
 | |
|         [StandardRuntimeEnumValidator(typeof(X509RevocationMode))]
 | |
|         public X509RevocationMode RevocationMode
 | |
|         {
 | |
|             get { return (X509RevocationMode)base[ConfigurationStrings.RevocationMode]; }
 | |
|             set { base[ConfigurationStrings.RevocationMode] = value; }
 | |
|         }
 | |
| 
 | |
|         [ConfigurationProperty(ConfigurationStrings.TrustedStoreLocation, DefaultValue = X509PeerCertificateAuthentication.DefaultTrustedStoreLocation)]
 | |
|         [StandardRuntimeEnumValidator(typeof(StoreLocation))]
 | |
|         public StoreLocation TrustedStoreLocation
 | |
|         {
 | |
|             get { return (StoreLocation)base[ConfigurationStrings.TrustedStoreLocation]; }
 | |
|             set { base[ConfigurationStrings.TrustedStoreLocation] = value; }
 | |
|         }
 | |
| 
 | |
|         public void Copy(X509PeerCertificateAuthenticationElement from)
 | |
|         {
 | |
|             if (this.IsReadOnly())
 | |
|             {
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(SR.GetString(SR.ConfigReadOnly)));
 | |
|             }
 | |
|             if (null == from)
 | |
|             {
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("from");
 | |
|             }
 | |
| 
 | |
|             this.CertificateValidationMode = from.CertificateValidationMode;
 | |
|             this.RevocationMode = from.RevocationMode;
 | |
|             this.TrustedStoreLocation = from.TrustedStoreLocation;
 | |
|             this.CustomCertificateValidatorType = from.CustomCertificateValidatorType;
 | |
|         }
 | |
| 
 | |
|         internal void ApplyConfiguration(X509PeerCertificateAuthentication cert)
 | |
|         {
 | |
|             if (cert == null)
 | |
|             {
 | |
|                 throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("cert");
 | |
|             }
 | |
| 
 | |
|             cert.CertificateValidationMode = this.CertificateValidationMode;
 | |
|             cert.RevocationMode = this.RevocationMode;
 | |
|             cert.TrustedStoreLocation = this.TrustedStoreLocation;
 | |
|             if (!string.IsNullOrEmpty(this.CustomCertificateValidatorType))
 | |
|             {
 | |
|                 Type validatorType = System.Type.GetType(this.CustomCertificateValidatorType, true);
 | |
|                 if (!typeof(X509CertificateValidator).IsAssignableFrom(validatorType))
 | |
|                 {
 | |
|                     throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(
 | |
|                         SR.GetString(SR.ConfigInvalidCertificateValidatorType, this.CustomCertificateValidatorType, typeof(X509CertificateValidator).ToString())));
 | |
|                 }
 | |
|                 cert.CustomCertificateValidator = (X509CertificateValidator)Activator.CreateInstance(validatorType);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 |