TimeStampReq.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
  5. using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
  6. namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Tsp
  7. {
  8. public class TimeStampReq
  9. : Asn1Encodable
  10. {
  11. private readonly DerInteger version;
  12. private readonly MessageImprint messageImprint;
  13. private readonly DerObjectIdentifier tsaPolicy;
  14. private readonly DerInteger nonce;
  15. private readonly DerBoolean certReq;
  16. private readonly X509Extensions extensions;
  17. public static TimeStampReq GetInstance(object obj)
  18. {
  19. if (obj is TimeStampReq)
  20. return (TimeStampReq)obj;
  21. if (obj == null)
  22. return null;
  23. return new TimeStampReq(Asn1Sequence.GetInstance(obj));
  24. }
  25. private TimeStampReq(
  26. Asn1Sequence seq)
  27. {
  28. int nbObjects = seq.Count;
  29. int seqStart = 0;
  30. // version
  31. version = DerInteger.GetInstance(seq[seqStart++]);
  32. // messageImprint
  33. messageImprint = MessageImprint.GetInstance(seq[seqStart++]);
  34. for (int opt = seqStart; opt < nbObjects; opt++)
  35. {
  36. // tsaPolicy
  37. if (seq[opt] is DerObjectIdentifier)
  38. {
  39. tsaPolicy = DerObjectIdentifier.GetInstance(seq[opt]);
  40. }
  41. // nonce
  42. else if (seq[opt] is DerInteger)
  43. {
  44. nonce = DerInteger.GetInstance(seq[opt]);
  45. }
  46. // certReq
  47. else if (seq[opt] is DerBoolean)
  48. {
  49. certReq = DerBoolean.GetInstance(seq[opt]);
  50. }
  51. // extensions
  52. else if (seq[opt] is Asn1TaggedObject)
  53. {
  54. Asn1TaggedObject tagged = (Asn1TaggedObject) seq[opt];
  55. if (tagged.TagNo == 0)
  56. {
  57. extensions = X509Extensions.GetInstance(tagged, false);
  58. }
  59. }
  60. }
  61. }
  62. public TimeStampReq(
  63. MessageImprint messageImprint,
  64. DerObjectIdentifier tsaPolicy,
  65. DerInteger nonce,
  66. DerBoolean certReq,
  67. X509Extensions extensions)
  68. {
  69. // default
  70. this.version = new DerInteger(1);
  71. this.messageImprint = messageImprint;
  72. this.tsaPolicy = tsaPolicy;
  73. this.nonce = nonce;
  74. this.certReq = certReq;
  75. this.extensions = extensions;
  76. }
  77. public DerInteger Version
  78. {
  79. get { return version; }
  80. }
  81. public MessageImprint MessageImprint
  82. {
  83. get { return messageImprint; }
  84. }
  85. public DerObjectIdentifier ReqPolicy
  86. {
  87. get { return tsaPolicy; }
  88. }
  89. public DerInteger Nonce
  90. {
  91. get { return nonce; }
  92. }
  93. public DerBoolean CertReq
  94. {
  95. get { return certReq; }
  96. }
  97. public X509Extensions Extensions
  98. {
  99. get { return extensions; }
  100. }
  101. /**
  102. * <pre>
  103. * TimeStampReq ::= SEQUENCE {
  104. * version INTEGER { v1(1) },
  105. * messageImprint MessageImprint,
  106. * --a hash algorithm OID and the hash value of the data to be
  107. * --time-stamped
  108. * reqPolicy TSAPolicyId OPTIONAL,
  109. * nonce INTEGER OPTIONAL,
  110. * certReq BOOLEAN DEFAULT FALSE,
  111. * extensions [0] IMPLICIT Extensions OPTIONAL
  112. * }
  113. * </pre>
  114. */
  115. public override Asn1Object ToAsn1Object()
  116. {
  117. Asn1EncodableVector v = new Asn1EncodableVector(version, messageImprint);
  118. v.AddOptional(tsaPolicy, nonce);
  119. if (certReq != null && certReq.IsTrue)
  120. {
  121. v.Add(certReq);
  122. }
  123. v.AddOptionalTagged(false, 0, extensions);
  124. return new DerSequence(v);
  125. }
  126. }
  127. }
  128. #pragma warning restore
  129. #endif