BcVerifyingStreamSigner.cs 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using System.IO;
  5. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto;
  6. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.IO;
  7. using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.IO;
  8. namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Tls.Crypto.Impl.BC
  9. {
  10. internal sealed class BcVerifyingStreamSigner
  11. : TlsStreamSigner
  12. {
  13. private readonly ISigner m_signer;
  14. private readonly ISigner m_verifier;
  15. private readonly TeeOutputStream m_output;
  16. internal BcVerifyingStreamSigner(ISigner signer, ISigner verifier)
  17. {
  18. Stream outputSigner = new SignerSink(signer);
  19. Stream outputVerifier = new SignerSink(verifier);
  20. this.m_signer = signer;
  21. this.m_verifier = verifier;
  22. this.m_output = new TeeOutputStream(outputSigner, outputVerifier);
  23. }
  24. public Stream GetOutputStream()
  25. {
  26. return m_output;
  27. }
  28. public byte[] GetSignature()
  29. {
  30. try
  31. {
  32. byte[] signature = m_signer.GenerateSignature();
  33. if (m_verifier.VerifySignature(signature))
  34. return signature;
  35. }
  36. catch (CryptoException e)
  37. {
  38. throw new TlsFatalAlert(AlertDescription.internal_error, e);
  39. }
  40. throw new TlsFatalAlert(AlertDescription.internal_error);
  41. }
  42. }
  43. }
  44. #pragma warning restore
  45. #endif