|
// 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.IdentityModel.Selectors;
using System.IdentityModel.Tokens;
namespace System.ServiceModel.Security.Tokens
{
public class UserNameSecurityTokenParameters : SecurityTokenParameters
{
protected UserNameSecurityTokenParameters(UserNameSecurityTokenParameters other)
: base(other)
{
base.RequireDerivedKeys = false;
}
public UserNameSecurityTokenParameters()
: base()
{
base.RequireDerivedKeys = false;
}
internal protected override bool HasAsymmetricKey { get { return false; } }
internal protected override bool SupportsClientAuthentication { get { return true; } }
internal protected override bool SupportsServerAuthentication { get { return false; } }
internal protected override bool SupportsClientWindowsIdentity { get { return true; } }
protected override SecurityTokenParameters CloneCore()
{
return new UserNameSecurityTokenParameters(this);
}
internal protected override SecurityKeyIdentifierClause CreateKeyIdentifierClause(SecurityToken token, SecurityTokenReferenceStyle referenceStyle)
{
return CreateKeyIdentifierClause<SecurityKeyIdentifierClause, LocalIdKeyIdentifierClause>(token, referenceStyle);
}
protected internal override void InitializeSecurityTokenRequirement(SecurityTokenRequirement requirement)
{
requirement.TokenType = SecurityTokenTypes.UserName;
requirement.RequireCryptographicToken = false;
}
}
}
|