SignerInfo.cs 5.0 KB

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