|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
using System.Net.Security;
namespace System.ServiceModel.Channels
{
public class SecurityCapabilities : ISecurityCapabilities
{
internal bool supportsServerAuth;
internal bool supportsClientAuth;
internal bool supportsClientWindowsIdentity;
internal ProtectionLevel requestProtectionLevel;
internal ProtectionLevel responseProtectionLevel;
public SecurityCapabilities(bool supportsClientAuth, bool supportsServerAuth, bool supportsClientWindowsIdentity,
ProtectionLevel requestProtectionLevel, ProtectionLevel responseProtectionLevel)
{
this.supportsClientAuth = supportsClientAuth;
this.supportsServerAuth = supportsServerAuth;
this.supportsClientWindowsIdentity = supportsClientWindowsIdentity;
this.requestProtectionLevel = requestProtectionLevel;
this.responseProtectionLevel = responseProtectionLevel;
}
public ProtectionLevel SupportedRequestProtectionLevel { get { return requestProtectionLevel; } }
public ProtectionLevel SupportedResponseProtectionLevel { get { return responseProtectionLevel; } }
public bool SupportsClientAuthentication { get { return supportsClientAuth; } }
public bool SupportsClientWindowsIdentity { get { return supportsClientWindowsIdentity; } }
public bool SupportsServerAuthentication { get { return supportsServerAuth; } }
public static SecurityCapabilities None
{
get { return new SecurityCapabilities(false, false, false, ProtectionLevel.None, ProtectionLevel.None); }
}
public static bool IsEqual(ISecurityCapabilities capabilities1, ISecurityCapabilities capabilities2)
{
if (capabilities1 == null)
{
capabilities1 = SecurityCapabilities.None;
}
if (capabilities2 == null)
{
capabilities2 = SecurityCapabilities.None;
}
if (capabilities1.SupportedRequestProtectionLevel != capabilities2.SupportedRequestProtectionLevel)
{
return false;
}
if (capabilities1.SupportedResponseProtectionLevel != capabilities2.SupportedResponseProtectionLevel)
{
return false;
}
if (capabilities1.SupportsClientAuthentication != capabilities2.SupportsClientAuthentication)
{
return false;
}
if (capabilities1.SupportsClientWindowsIdentity != capabilities2.SupportsClientWindowsIdentity)
{
return false;
}
if (capabilities1.SupportsServerAuthentication != capabilities2.SupportsServerAuthentication)
{
return false;
}
return true;
}
}
}
|