| 123456789101112131415161718192021222324252627282930313233343536373839404142 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- using System;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Tls;
- namespace Org.BouncyCastle.Crypto.Tls2
- {
- public interface IClientCredentialsProvider
- {
- TlsCredentials GetClientCredentials(TlsContext context, CertificateRequest certificateRequest);
- }
- /// <summary>
- /// A temporary class to wrap old CertificateVerifyer stuff for new TlsAuthentication.
- /// </summary>
- public class LegacyTlsAuthentication : TlsAuthentication
- {
- protected ICertificateVerifyer verifyer;
- protected IClientCredentialsProvider credProvider;
- protected Uri TargetUri;
- public LegacyTlsAuthentication(Uri targetUri, ICertificateVerifyer verifyer, IClientCredentialsProvider prov)
- {
- this.TargetUri = targetUri;
- this.verifyer = verifyer;
- this.credProvider = prov;
- }
- public virtual void NotifyServerCertificate(Certificate serverCertificate)
- {
- if (!this.verifyer.IsValid(this.TargetUri, serverCertificate.GetCertificateList()))
- throw new TlsFatalAlert(AlertDescription.user_canceled);
- }
- public virtual TlsCredentials GetClientCredentials(TlsContext context, CertificateRequest certificateRequest)
- {
- return credProvider == null ? null : credProvider.GetClientCredentials(context, certificateRequest);
- }
- }
- }
- #endif
|