191 lines
8.2 KiB
C#
191 lines
8.2 KiB
C#
|
//------------------------------------------------------------------------------
|
||
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
namespace System.ServiceModel.Configuration
|
||
|
{
|
||
|
using System.Configuration;
|
||
|
using System.Globalization;
|
||
|
using System.IdentityModel.Configuration;
|
||
|
using System.Net.Security;
|
||
|
using System.Security.Cryptography.X509Certificates;
|
||
|
using System.ServiceModel;
|
||
|
using System.ServiceModel.Description;
|
||
|
using System.ServiceModel.Security;
|
||
|
|
||
|
public partial class ServiceCredentialsElement : BehaviorExtensionElement
|
||
|
{
|
||
|
public ServiceCredentialsElement()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.Type, DefaultValue = "")]
|
||
|
[StringValidator(MinLength = 0)]
|
||
|
public string Type
|
||
|
{
|
||
|
get { return (string)base[ConfigurationStrings.Type]; }
|
||
|
set
|
||
|
{
|
||
|
if (String.IsNullOrEmpty(value))
|
||
|
{
|
||
|
value = String.Empty;
|
||
|
}
|
||
|
base[ConfigurationStrings.Type] = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.ClientCertificate)]
|
||
|
public X509InitiatorCertificateServiceElement ClientCertificate
|
||
|
{
|
||
|
get { return (X509InitiatorCertificateServiceElement)base[ConfigurationStrings.ClientCertificate]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.ServiceCertificate)]
|
||
|
public X509RecipientCertificateServiceElement ServiceCertificate
|
||
|
{
|
||
|
get { return (X509RecipientCertificateServiceElement)base[ConfigurationStrings.ServiceCertificate]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.UserNameAuthentication)]
|
||
|
public UserNameServiceElement UserNameAuthentication
|
||
|
{
|
||
|
get { return (UserNameServiceElement)base[ConfigurationStrings.UserNameAuthentication]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty( ConfigurationStrings.UseIdentityConfiguration, DefaultValue = false, IsRequired = false )]
|
||
|
public bool UseIdentityConfiguration
|
||
|
{
|
||
|
get { return (bool)base[ConfigurationStrings.UseIdentityConfiguration]; }
|
||
|
set { base[ConfigurationStrings.UseIdentityConfiguration] = value; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.IdentityConfiguration, IsRequired = false, DefaultValue = System.IdentityModel.Configuration.ConfigurationStrings.DefaultServiceName)]
|
||
|
[StringValidator(MinLength = 0)]
|
||
|
public string IdentityConfiguration
|
||
|
{
|
||
|
get { return (string)base[ConfigurationStrings.IdentityConfiguration]; }
|
||
|
set { base[ConfigurationStrings.IdentityConfiguration] = value; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.WindowsAuthentication)]
|
||
|
public WindowsServiceElement WindowsAuthentication
|
||
|
{
|
||
|
get { return (WindowsServiceElement)base[ConfigurationStrings.WindowsAuthentication]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.Peer)]
|
||
|
public PeerCredentialElement Peer
|
||
|
{
|
||
|
get { return (PeerCredentialElement)base[ConfigurationStrings.Peer]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.IssuedTokenAuthentication)]
|
||
|
public IssuedTokenServiceElement IssuedTokenAuthentication
|
||
|
{
|
||
|
get { return (IssuedTokenServiceElement)base[ConfigurationStrings.IssuedTokenAuthentication]; }
|
||
|
}
|
||
|
|
||
|
[ConfigurationProperty(ConfigurationStrings.SecureConversationAuthentication)]
|
||
|
public SecureConversationServiceElement SecureConversationAuthentication
|
||
|
{
|
||
|
get { return (SecureConversationServiceElement)base[ConfigurationStrings.SecureConversationAuthentication]; }
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
public override void CopyFrom(ServiceModelExtensionElement from)
|
||
|
{
|
||
|
base.CopyFrom(from);
|
||
|
|
||
|
ServiceCredentialsElement source = (ServiceCredentialsElement)from;
|
||
|
#pragma warning suppress 56506 //[....]; base.CopyFrom() checks for 'from' being null
|
||
|
this.ClientCertificate.Copy(source.ClientCertificate);
|
||
|
this.ServiceCertificate.Copy(source.ServiceCertificate);
|
||
|
this.UserNameAuthentication.Copy(source.UserNameAuthentication);
|
||
|
this.WindowsAuthentication.Copy(source.WindowsAuthentication);
|
||
|
this.Peer.Copy(source.Peer);
|
||
|
this.IssuedTokenAuthentication.Copy(source.IssuedTokenAuthentication);
|
||
|
this.SecureConversationAuthentication.Copy(source.SecureConversationAuthentication);
|
||
|
this.Type = source.Type;
|
||
|
this.UseIdentityConfiguration = source.UseIdentityConfiguration;
|
||
|
this.IdentityConfiguration = source.IdentityConfiguration;
|
||
|
}
|
||
|
|
||
|
protected internal override object CreateBehavior()
|
||
|
{
|
||
|
ServiceCredentials behavior;
|
||
|
if (string.IsNullOrEmpty(this.Type))
|
||
|
{
|
||
|
behavior = new ServiceCredentials();
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Type credentialsType = System.Type.GetType(this.Type, true);
|
||
|
if (!typeof(ServiceCredentials).IsAssignableFrom(credentialsType))
|
||
|
{
|
||
|
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(
|
||
|
SR.GetString(SR.ConfigInvalidServiceCredentialsType, this.Type, credentialsType.AssemblyQualifiedName)));
|
||
|
}
|
||
|
behavior = (ServiceCredentials)Activator.CreateInstance(credentialsType);
|
||
|
}
|
||
|
ApplyConfiguration(behavior);
|
||
|
|
||
|
return behavior;
|
||
|
}
|
||
|
|
||
|
protected internal void ApplyConfiguration(ServiceCredentials behavior)
|
||
|
{
|
||
|
if (behavior == null)
|
||
|
{
|
||
|
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("behavior");
|
||
|
}
|
||
|
|
||
|
PropertyInformationCollection propertyInfo = this.ElementInformation.Properties;
|
||
|
if (propertyInfo[ConfigurationStrings.UserNameAuthentication].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.UserNameAuthentication.ApplyConfiguration(behavior.UserNameAuthentication);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.WindowsAuthentication].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.WindowsAuthentication.ApplyConfiguration(behavior.WindowsAuthentication);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.ClientCertificate].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.ClientCertificate.ApplyConfiguration(behavior.ClientCertificate);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.ServiceCertificate].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.ServiceCertificate.ApplyConfiguration(behavior.ServiceCertificate);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.Peer].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.Peer.ApplyConfiguration(behavior.Peer);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.IssuedTokenAuthentication].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.IssuedTokenAuthentication.ApplyConfiguration(behavior.IssuedTokenAuthentication);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.SecureConversationAuthentication].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
this.SecureConversationAuthentication.ApplyConfiguration(behavior.SecureConversationAuthentication);
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.UseIdentityConfiguration].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
behavior.UseIdentityConfiguration = this.UseIdentityConfiguration;
|
||
|
}
|
||
|
if (propertyInfo[ConfigurationStrings.IdentityConfiguration].ValueOrigin != PropertyValueOrigin.Default)
|
||
|
{
|
||
|
behavior.IdentityConfiguration = new IdentityConfiguration( IdentityConfiguration );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public override Type BehaviorType
|
||
|
{
|
||
|
get { return typeof(ServiceCredentials); }
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|