e79aa3c0ed
Former-commit-id: a2155e9bd80020e49e72e86c44da02a8ac0e57a4
79 lines
2.6 KiB
C#
79 lines
2.6 KiB
C#
//-----------------------------------------------------------------------------
|
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
namespace System.ServiceModel.Security
|
|
{
|
|
using System.Security.Cryptography.X509Certificates;
|
|
using System.ServiceModel;
|
|
|
|
public sealed class X509CertificateRecipientServiceCredential
|
|
{
|
|
X509Certificate2 certificate;
|
|
internal const StoreLocation DefaultStoreLocation = StoreLocation.LocalMachine;
|
|
internal const StoreName DefaultStoreName = StoreName.My;
|
|
internal const X509FindType DefaultFindType = X509FindType.FindBySubjectDistinguishedName;
|
|
bool isReadOnly;
|
|
|
|
internal X509CertificateRecipientServiceCredential()
|
|
{
|
|
}
|
|
|
|
internal X509CertificateRecipientServiceCredential(X509CertificateRecipientServiceCredential other)
|
|
{
|
|
this.certificate = other.certificate;
|
|
this.isReadOnly = other.isReadOnly;
|
|
}
|
|
|
|
public X509Certificate2 Certificate
|
|
{
|
|
get
|
|
{
|
|
return this.certificate;
|
|
}
|
|
set
|
|
{
|
|
ThrowIfImmutable();
|
|
this.certificate = value;
|
|
}
|
|
}
|
|
|
|
public void SetCertificate(string subjectName)
|
|
{
|
|
this.SetCertificate(subjectName, DefaultStoreLocation, DefaultStoreName);
|
|
}
|
|
|
|
public void SetCertificate(string subjectName, StoreLocation storeLocation, StoreName storeName)
|
|
{
|
|
if (subjectName == null)
|
|
{
|
|
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("subjectName");
|
|
}
|
|
this.SetCertificate(storeLocation, storeName, DefaultFindType, subjectName);
|
|
}
|
|
|
|
public void SetCertificate(StoreLocation storeLocation, StoreName storeName, X509FindType findType, object findValue)
|
|
{
|
|
if (findValue == null)
|
|
{
|
|
throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("findValue");
|
|
}
|
|
ThrowIfImmutable();
|
|
this.certificate = SecurityUtils.GetCertificateFromStore(storeName, storeLocation, findType, findValue, null);
|
|
}
|
|
|
|
internal void MakeReadOnly()
|
|
{
|
|
this.isReadOnly = true;
|
|
}
|
|
|
|
void ThrowIfImmutable()
|
|
{
|
|
if (this.isReadOnly)
|
|
{
|
|
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.ObjectIsReadOnly)));
|
|
}
|
|
}
|
|
}
|
|
}
|