ESSCertIDv2.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Nist;
  5. using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
  6. using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
  7. namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Ess
  8. {
  9. public class EssCertIDv2
  10. : Asn1Encodable
  11. {
  12. private readonly AlgorithmIdentifier hashAlgorithm;
  13. private readonly byte[] certHash;
  14. private readonly IssuerSerial issuerSerial;
  15. private static readonly AlgorithmIdentifier DefaultAlgID = new AlgorithmIdentifier(
  16. NistObjectIdentifiers.IdSha256);
  17. public static EssCertIDv2 GetInstance(object obj)
  18. {
  19. if (obj == null)
  20. return null;
  21. EssCertIDv2 existing = obj as EssCertIDv2;
  22. if (existing != null)
  23. return existing;
  24. return new EssCertIDv2(Asn1Sequence.GetInstance(obj));
  25. }
  26. private EssCertIDv2(
  27. Asn1Sequence seq)
  28. {
  29. if (seq.Count > 3)
  30. throw new ArgumentException("Bad sequence size: " + seq.Count, "seq");
  31. int count = 0;
  32. if (seq[0] is Asn1OctetString)
  33. {
  34. // Default value
  35. this.hashAlgorithm = DefaultAlgID;
  36. }
  37. else
  38. {
  39. this.hashAlgorithm = AlgorithmIdentifier.GetInstance(seq[count++].ToAsn1Object());
  40. }
  41. this.certHash = Asn1OctetString.GetInstance(seq[count++].ToAsn1Object()).GetOctets();
  42. if (seq.Count > count)
  43. {
  44. this.issuerSerial = IssuerSerial.GetInstance(
  45. Asn1Sequence.GetInstance(seq[count].ToAsn1Object()));
  46. }
  47. }
  48. public EssCertIDv2(byte[] certHash)
  49. : this(null, certHash, null)
  50. {
  51. }
  52. public EssCertIDv2(
  53. AlgorithmIdentifier algId,
  54. byte[] certHash)
  55. : this(algId, certHash, null)
  56. {
  57. }
  58. public EssCertIDv2(
  59. byte[] certHash,
  60. IssuerSerial issuerSerial)
  61. : this(null, certHash, issuerSerial)
  62. {
  63. }
  64. public EssCertIDv2(
  65. AlgorithmIdentifier algId,
  66. byte[] certHash,
  67. IssuerSerial issuerSerial)
  68. {
  69. if (algId == null)
  70. {
  71. // Default value
  72. this.hashAlgorithm = DefaultAlgID;
  73. }
  74. else
  75. {
  76. this.hashAlgorithm = algId;
  77. }
  78. this.certHash = certHash;
  79. this.issuerSerial = issuerSerial;
  80. }
  81. public AlgorithmIdentifier HashAlgorithm
  82. {
  83. get { return this.hashAlgorithm; }
  84. }
  85. public byte[] GetCertHash()
  86. {
  87. return Arrays.Clone(certHash);
  88. }
  89. public IssuerSerial IssuerSerial
  90. {
  91. get { return issuerSerial; }
  92. }
  93. /**
  94. * <pre>
  95. * EssCertIDv2 ::= SEQUENCE {
  96. * hashAlgorithm AlgorithmIdentifier
  97. * DEFAULT {algorithm id-sha256},
  98. * certHash Hash,
  99. * issuerSerial IssuerSerial OPTIONAL
  100. * }
  101. *
  102. * Hash ::= OCTET STRING
  103. *
  104. * IssuerSerial ::= SEQUENCE {
  105. * issuer GeneralNames,
  106. * serialNumber CertificateSerialNumber
  107. * }
  108. * </pre>
  109. */
  110. public override Asn1Object ToAsn1Object()
  111. {
  112. Asn1EncodableVector v = new Asn1EncodableVector();
  113. if (!hashAlgorithm.Equals(DefaultAlgID))
  114. {
  115. v.Add(hashAlgorithm);
  116. }
  117. v.Add(new DerOctetString(certHash).ToAsn1Object());
  118. v.AddOptional(issuerSerial);
  119. return new DerSequence(v);
  120. }
  121. }
  122. }
  123. #pragma warning restore
  124. #endif