SignerInfo.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
  5. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Utilities;
  6. namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.Pkcs
  7. {
  8. /**
  9. * a Pkcs#7 signer info object.
  10. */
  11. public class SignerInfo
  12. : Asn1Encodable
  13. {
  14. private DerInteger version;
  15. private IssuerAndSerialNumber issuerAndSerialNumber;
  16. private AlgorithmIdentifier digAlgorithm;
  17. private Asn1Set authenticatedAttributes;
  18. private AlgorithmIdentifier digEncryptionAlgorithm;
  19. private Asn1OctetString encryptedDigest;
  20. private Asn1Set unauthenticatedAttributes;
  21. public static SignerInfo GetInstance(
  22. object obj)
  23. {
  24. if (obj is SignerInfo)
  25. {
  26. return (SignerInfo) obj;
  27. }
  28. if (obj is Asn1Sequence)
  29. {
  30. return new SignerInfo((Asn1Sequence) obj);
  31. }
  32. throw new ArgumentException("Unknown object in factory: " + Org.BouncyCastle.Utilities.Platform.GetTypeName(obj), "obj");
  33. }
  34. public SignerInfo(
  35. DerInteger version,
  36. IssuerAndSerialNumber issuerAndSerialNumber,
  37. AlgorithmIdentifier digAlgorithm,
  38. Asn1Set authenticatedAttributes,
  39. AlgorithmIdentifier digEncryptionAlgorithm,
  40. Asn1OctetString encryptedDigest,
  41. Asn1Set unauthenticatedAttributes)
  42. {
  43. this.version = version;
  44. this.issuerAndSerialNumber = issuerAndSerialNumber;
  45. this.digAlgorithm = digAlgorithm;
  46. this.authenticatedAttributes = authenticatedAttributes;
  47. this.digEncryptionAlgorithm = digEncryptionAlgorithm;
  48. this.encryptedDigest = encryptedDigest;
  49. this.unauthenticatedAttributes = unauthenticatedAttributes;
  50. }
  51. public SignerInfo(
  52. Asn1Sequence seq)
  53. {
  54. var e = seq.GetEnumerator();
  55. e.MoveNext();
  56. version = (DerInteger) e.Current;
  57. e.MoveNext();
  58. issuerAndSerialNumber = IssuerAndSerialNumber.GetInstance(e.Current);
  59. e.MoveNext();
  60. digAlgorithm = AlgorithmIdentifier.GetInstance(e.Current);
  61. e.MoveNext();
  62. var obj = e.Current;
  63. if (obj is Asn1TaggedObject tagged)
  64. {
  65. authenticatedAttributes = Asn1Set.GetInstance(tagged, false);
  66. e.MoveNext();
  67. digEncryptionAlgorithm = AlgorithmIdentifier.GetInstance(e.Current);
  68. }
  69. else
  70. {
  71. authenticatedAttributes = null;
  72. digEncryptionAlgorithm = AlgorithmIdentifier.GetInstance(obj);
  73. }
  74. e.MoveNext();
  75. encryptedDigest = DerOctetString.GetInstance(e.Current);
  76. if (e.MoveNext())
  77. {
  78. unauthenticatedAttributes = Asn1Set.GetInstance((Asn1TaggedObject)e.Current, false);
  79. }
  80. else
  81. {
  82. unauthenticatedAttributes = null;
  83. }
  84. }
  85. public DerInteger Version { get { return version; } }
  86. public IssuerAndSerialNumber IssuerAndSerialNumber { get { return issuerAndSerialNumber; } }
  87. public Asn1Set AuthenticatedAttributes { get { return authenticatedAttributes; } }
  88. public AlgorithmIdentifier DigestAlgorithm { get { return digAlgorithm; } }
  89. public Asn1OctetString EncryptedDigest { get { return encryptedDigest; } }
  90. public AlgorithmIdentifier DigestEncryptionAlgorithm { get { return digEncryptionAlgorithm; } }
  91. public Asn1Set UnauthenticatedAttributes { get { return unauthenticatedAttributes; } }
  92. /**
  93. * Produce an object suitable for an Asn1OutputStream.
  94. * <pre>
  95. * SignerInfo ::= Sequence {
  96. * version Version,
  97. * issuerAndSerialNumber IssuerAndSerialNumber,
  98. * digestAlgorithm DigestAlgorithmIdentifier,
  99. * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
  100. * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
  101. * encryptedDigest EncryptedDigest,
  102. * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
  103. * }
  104. *
  105. * EncryptedDigest ::= OCTET STRING
  106. *
  107. * DigestAlgorithmIdentifier ::= AlgorithmIdentifier
  108. *
  109. * DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
  110. * </pre>
  111. */
  112. public override Asn1Object ToAsn1Object()
  113. {
  114. Asn1EncodableVector v = new Asn1EncodableVector(version, issuerAndSerialNumber, digAlgorithm);
  115. v.AddOptionalTagged(false, 0, authenticatedAttributes);
  116. v.Add(digEncryptionAlgorithm, encryptedDigest);
  117. v.AddOptionalTagged(false, 1, unauthenticatedAttributes);
  118. return new DerSequence(v);
  119. }
  120. }
  121. }
  122. #pragma warning restore
  123. #endif