CertReqTemplateContent.cs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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.Crmf;
  5. namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cmp
  6. {
  7. /**
  8. * GenMsg: {id-it 19}, < absent >
  9. * GenRep: {id-it 19}, CertReqTemplateContent | < absent >
  10. * <p>
  11. * CertReqTemplateValue ::= CertReqTemplateContent
  12. * </p><p>
  13. * CertReqTemplateContent ::= SEQUENCE {
  14. * certTemplate CertTemplate,
  15. * keySpec Controls OPTIONAL }
  16. * </p><p>
  17. * Controls ::= SEQUENCE SIZE (1..MAX) OF AttributeTypeAndValue
  18. * </p>
  19. */
  20. public class CertReqTemplateContent
  21. : Asn1Encodable
  22. {
  23. public static CertReqTemplateContent GetInstance(object obj)
  24. {
  25. if (obj is CertReqTemplateContent certReqTemplateContent)
  26. return certReqTemplateContent;
  27. if (obj != null)
  28. return new CertReqTemplateContent(Asn1Sequence.GetInstance(obj));
  29. return null;
  30. }
  31. private readonly CertTemplate m_certTemplate;
  32. private readonly Asn1Sequence m_keySpec;
  33. private CertReqTemplateContent(Asn1Sequence seq)
  34. {
  35. if (seq.Count != 1 && seq.Count != 2)
  36. throw new ArgumentException("expected sequence size of 1 or 2");
  37. m_certTemplate = CertTemplate.GetInstance(seq[0]);
  38. if (seq.Count > 1)
  39. {
  40. m_keySpec = Asn1Sequence.GetInstance(seq[1]);
  41. }
  42. }
  43. public CertReqTemplateContent(CertTemplate certTemplate, Asn1Sequence keySpec)
  44. {
  45. m_certTemplate = certTemplate;
  46. m_keySpec = keySpec;
  47. }
  48. public virtual CertTemplate CertTemplate => m_certTemplate;
  49. public virtual Asn1Sequence KeySpec => m_keySpec;
  50. public override Asn1Object ToAsn1Object()
  51. {
  52. Asn1EncodableVector v = new Asn1EncodableVector(m_certTemplate);
  53. v.AddOptional(m_keySpec);
  54. return new DerSequence(v);
  55. }
  56. }
  57. }
  58. #pragma warning restore
  59. #endif