KeyRecRepContent.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cmp
  5. {
  6. public class KeyRecRepContent
  7. : Asn1Encodable
  8. {
  9. public static KeyRecRepContent GetInstance(object obj)
  10. {
  11. if (obj is KeyRecRepContent keyRecRepContent)
  12. return keyRecRepContent;
  13. if (obj != null)
  14. return new KeyRecRepContent(Asn1Sequence.GetInstance(obj));
  15. return null;
  16. }
  17. private readonly PkiStatusInfo m_status;
  18. private readonly CmpCertificate m_newSigCert;
  19. private readonly Asn1Sequence m_caCerts;
  20. private readonly Asn1Sequence m_keyPairHist;
  21. private KeyRecRepContent(Asn1Sequence seq)
  22. {
  23. m_status = PkiStatusInfo.GetInstance(seq[0]);
  24. for (int pos = 1; pos < seq.Count; ++pos)
  25. {
  26. Asn1TaggedObject tObj = Asn1TaggedObject.GetInstance(seq[pos]);
  27. switch (tObj.TagNo)
  28. {
  29. case 0:
  30. m_newSigCert = CmpCertificate.GetInstance(tObj.GetObject());
  31. break;
  32. case 1:
  33. m_caCerts = Asn1Sequence.GetInstance(tObj.GetObject());
  34. break;
  35. case 2:
  36. m_keyPairHist = Asn1Sequence.GetInstance(tObj.GetObject());
  37. break;
  38. default:
  39. throw new ArgumentException("unknown tag number: " + tObj.TagNo, "seq");
  40. }
  41. }
  42. }
  43. public virtual PkiStatusInfo Status => m_status;
  44. public virtual CmpCertificate NewSigCert => m_newSigCert;
  45. public virtual CmpCertificate[] GetCACerts()
  46. {
  47. if (m_caCerts == null)
  48. return null;
  49. return m_caCerts.MapElements(CmpCertificate.GetInstance);
  50. }
  51. public virtual CertifiedKeyPair[] GetKeyPairHist()
  52. {
  53. if (m_keyPairHist == null)
  54. return null;
  55. return m_keyPairHist.MapElements(CertifiedKeyPair.GetInstance);
  56. }
  57. /**
  58. * <pre>
  59. * KeyRecRepContent ::= SEQUENCE {
  60. * status PKIStatusInfo,
  61. * newSigCert [0] CMPCertificate OPTIONAL,
  62. * caCerts [1] SEQUENCE SIZE (1..MAX) OF
  63. * CMPCertificate OPTIONAL,
  64. * keyPairHist [2] SEQUENCE SIZE (1..MAX) OF
  65. * CertifiedKeyPair OPTIONAL
  66. * }
  67. * </pre>
  68. * @return a basic ASN.1 object representation.
  69. */
  70. public override Asn1Object ToAsn1Object()
  71. {
  72. Asn1EncodableVector v = new Asn1EncodableVector(m_status);
  73. v.AddOptionalTagged(true, 0, m_newSigCert);
  74. v.AddOptionalTagged(true, 1, m_caCerts);
  75. v.AddOptionalTagged(true, 2, m_keyPairHist);
  76. return new DerSequence(v);
  77. }
  78. }
  79. }
  80. #pragma warning restore
  81. #endif