BcTlsSrp6Server.cs 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto;
  5. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Agreement.Srp;
  6. using BestHTTP.SecureProtocol.Org.BouncyCastle.Math;
  7. namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Tls.Crypto.Impl.BC
  8. {
  9. internal sealed class BcTlsSrp6Server
  10. : TlsSrp6Server
  11. {
  12. private readonly Srp6Server m_srp6Server;
  13. internal BcTlsSrp6Server(Srp6Server srp6Server)
  14. {
  15. this.m_srp6Server = srp6Server;
  16. }
  17. public BigInteger GenerateServerCredentials()
  18. {
  19. return m_srp6Server.GenerateServerCredentials();
  20. }
  21. public BigInteger CalculateSecret(BigInteger clientA)
  22. {
  23. try
  24. {
  25. return m_srp6Server.CalculateSecret(clientA);
  26. }
  27. catch (CryptoException e)
  28. {
  29. throw new TlsFatalAlert(AlertDescription.illegal_parameter, e);
  30. }
  31. }
  32. }
  33. }
  34. #pragma warning restore
  35. #endif