TlsRsaKeyExchange.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using System.Collections;
  5. using System.IO;
  6. using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1;
  7. using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
  8. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Encodings;
  9. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Engines;
  10. using BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Parameters;
  11. using BestHTTP.SecureProtocol.Org.BouncyCastle.Security;
  12. using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.IO;
  13. namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Crypto.Tls
  14. {
  15. /// <summary>(D)TLS and SSLv3 RSA key exchange.</summary>
  16. public class TlsRsaKeyExchange
  17. : AbstractTlsKeyExchange
  18. {
  19. protected AsymmetricKeyParameter mServerPublicKey = null;
  20. protected RsaKeyParameters mRsaServerPublicKey = null;
  21. protected TlsEncryptionCredentials mServerCredentials = null;
  22. protected byte[] mPremasterSecret;
  23. public TlsRsaKeyExchange(IList supportedSignatureAlgorithms)
  24. : base(KeyExchangeAlgorithm.RSA, supportedSignatureAlgorithms)
  25. {
  26. }
  27. public override void SkipServerCredentials()
  28. {
  29. throw new TlsFatalAlert(AlertDescription.unexpected_message);
  30. }
  31. public override void ProcessServerCredentials(TlsCredentials serverCredentials)
  32. {
  33. if (!(serverCredentials is TlsEncryptionCredentials))
  34. throw new TlsFatalAlert(AlertDescription.internal_error);
  35. ProcessServerCertificate(serverCredentials.Certificate);
  36. this.mServerCredentials = (TlsEncryptionCredentials)serverCredentials;
  37. }
  38. public override void ProcessServerCertificate(Certificate serverCertificate)
  39. {
  40. if (serverCertificate.IsEmpty)
  41. throw new TlsFatalAlert(AlertDescription.bad_certificate);
  42. X509CertificateStructure x509Cert = serverCertificate.GetCertificateAt(0);
  43. SubjectPublicKeyInfo keyInfo = x509Cert.SubjectPublicKeyInfo;
  44. try
  45. {
  46. this.mServerPublicKey = PublicKeyFactory.CreateKey(keyInfo);
  47. }
  48. catch (Exception e)
  49. {
  50. throw new TlsFatalAlert(AlertDescription.unsupported_certificate, e);
  51. }
  52. // Sanity check the PublicKeyFactory
  53. if (this.mServerPublicKey.IsPrivate)
  54. throw new TlsFatalAlert(AlertDescription.internal_error);
  55. this.mRsaServerPublicKey = ValidateRsaPublicKey((RsaKeyParameters)this.mServerPublicKey);
  56. TlsUtilities.ValidateKeyUsage(x509Cert, KeyUsage.KeyEncipherment);
  57. base.ProcessServerCertificate(serverCertificate);
  58. }
  59. public override void ValidateCertificateRequest(CertificateRequest certificateRequest)
  60. {
  61. byte[] types = certificateRequest.CertificateTypes;
  62. for (int i = 0; i < types.Length; ++i)
  63. {
  64. switch (types[i])
  65. {
  66. case ClientCertificateType.rsa_sign:
  67. case ClientCertificateType.dss_sign:
  68. case ClientCertificateType.ecdsa_sign:
  69. break;
  70. default:
  71. throw new TlsFatalAlert(AlertDescription.illegal_parameter);
  72. }
  73. }
  74. }
  75. public override void ProcessClientCredentials(TlsCredentials clientCredentials)
  76. {
  77. if (!(clientCredentials is TlsSignerCredentials))
  78. throw new TlsFatalAlert(AlertDescription.internal_error);
  79. }
  80. public override void GenerateClientKeyExchange(Stream output)
  81. {
  82. this.mPremasterSecret = TlsRsaUtilities.GenerateEncryptedPreMasterSecret(mContext, mRsaServerPublicKey, output);
  83. }
  84. public override void ProcessClientKeyExchange(Stream input)
  85. {
  86. byte[] encryptedPreMasterSecret;
  87. if (TlsUtilities.IsSsl(mContext))
  88. {
  89. // TODO Do any SSLv3 clients actually include the length?
  90. encryptedPreMasterSecret = Streams.ReadAll(input);
  91. }
  92. else
  93. {
  94. encryptedPreMasterSecret = TlsUtilities.ReadOpaque16(input);
  95. }
  96. this.mPremasterSecret = mServerCredentials.DecryptPreMasterSecret(encryptedPreMasterSecret);
  97. }
  98. public override byte[] GeneratePremasterSecret()
  99. {
  100. if (this.mPremasterSecret == null)
  101. throw new TlsFatalAlert(AlertDescription.internal_error);
  102. byte[] tmp = this.mPremasterSecret;
  103. this.mPremasterSecret = null;
  104. return tmp;
  105. }
  106. protected virtual RsaKeyParameters ValidateRsaPublicKey(RsaKeyParameters key)
  107. {
  108. // TODO What is the minimum bit length required?
  109. // key.Modulus.BitLength;
  110. if (!key.Exponent.IsProbablePrime(2))
  111. throw new TlsFatalAlert(AlertDescription.illegal_parameter);
  112. return key;
  113. }
  114. }
  115. }
  116. #pragma warning restore
  117. #endif