File: System\ServiceModel\Configuration\HttpDigestClientElement.cs
Project: ndp\cdf\src\WCF\ServiceModel\System.ServiceModel.csproj (System.ServiceModel)
//------------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation.  All rights reserved.
//------------------------------------------------------------------------------
 
namespace System.ServiceModel.Configuration
{
    using System;
    using System.ServiceModel;
    using System.Configuration;
    using System.ServiceModel.Security;
    using System.ServiceModel.Channels;
    using System.Xml;
    using System.Security.Principal;
    using System.Security.Cryptography.X509Certificates;
 
    public sealed partial class HttpDigestClientElement : ConfigurationElement
    {
        public HttpDigestClientElement()
        {
        }
 
        [ConfigurationProperty(ConfigurationStrings.ImpersonationLevel, DefaultValue = WindowsClientCredential.DefaultImpersonationLevel)]
        [ServiceModelEnumValidator(typeof(TokenImpersonationLevelHelper))]
        public TokenImpersonationLevel ImpersonationLevel
        {
            get { return (TokenImpersonationLevel)base[ConfigurationStrings.ImpersonationLevel]; }
            set { base[ConfigurationStrings.ImpersonationLevel] = value; }
        }
 
        public void Copy(HttpDigestClientElement from)
        {
            if (this.IsReadOnly())
            {
                throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(SR.GetString(SR.ConfigReadOnly)));
            }
            if (null == from)
            {
                throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("from");
            }
 
            this.ImpersonationLevel = from.ImpersonationLevel;
        }
 
        internal void ApplyConfiguration(HttpDigestClientCredential digest)
        {
            if (digest == null)
            {
                throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("digest");
            }
            digest.AllowedImpersonationLevel = this.ImpersonationLevel;
        }
    }
}