CertificateRequestMessageBuilder.cs 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using System.Collections.Generic;
  5. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1;
  6. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.Crmf;
  7. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
  8. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Crypto;
  9. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Math;
  10. namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Crmf
  11. {
  12. public class CertificateRequestMessageBuilder
  13. {
  14. private readonly BigInteger _certReqId;
  15. private X509ExtensionsGenerator _extGenerator;
  16. private CertTemplateBuilder _templateBuilder;
  17. private IList<IControl> m_controls = new List<IControl>();
  18. private ISignatureFactory _popSigner;
  19. private PKMacBuilder _pkMacBuilder;
  20. private char[] _password;
  21. private GeneralName _sender;
  22. private int _popoType = ProofOfPossession.TYPE_KEY_ENCIPHERMENT;
  23. private PopoPrivKey _popoPrivKey;
  24. private Asn1Null _popRaVerified;
  25. private PKMacValue _agreeMac;
  26. public CertificateRequestMessageBuilder(BigInteger certReqId)
  27. {
  28. this._certReqId = certReqId;
  29. this._extGenerator = new X509ExtensionsGenerator();
  30. this._templateBuilder = new CertTemplateBuilder();
  31. }
  32. public CertificateRequestMessageBuilder SetPublicKey(SubjectPublicKeyInfo publicKeyInfo)
  33. {
  34. if (publicKeyInfo != null)
  35. {
  36. _templateBuilder.SetPublicKey(publicKeyInfo);
  37. }
  38. return this;
  39. }
  40. public CertificateRequestMessageBuilder SetIssuer(X509Name issuer)
  41. {
  42. if (issuer != null)
  43. {
  44. _templateBuilder.SetIssuer(issuer);
  45. }
  46. return this;
  47. }
  48. public CertificateRequestMessageBuilder SetSubject(X509Name subject)
  49. {
  50. if (subject != null)
  51. {
  52. _templateBuilder.SetSubject(subject);
  53. }
  54. return this;
  55. }
  56. public CertificateRequestMessageBuilder SetSerialNumber(BigInteger serialNumber)
  57. {
  58. if (serialNumber != null)
  59. {
  60. _templateBuilder.SetSerialNumber(new DerInteger(serialNumber));
  61. }
  62. return this;
  63. }
  64. public CertificateRequestMessageBuilder SetValidity(DateTime? notBefore, DateTime? notAfter)
  65. {
  66. _templateBuilder.SetValidity(new OptionalValidity(CreateTime(notBefore), CreateTime(notAfter)));
  67. return this;
  68. }
  69. public CertificateRequestMessageBuilder AddExtension(DerObjectIdentifier oid, bool critical,
  70. Asn1Encodable value)
  71. {
  72. _extGenerator.AddExtension(oid, critical, value);
  73. return this;
  74. }
  75. public CertificateRequestMessageBuilder AddExtension(DerObjectIdentifier oid, bool critical,
  76. byte[] value)
  77. {
  78. _extGenerator.AddExtension(oid, critical, value);
  79. return this;
  80. }
  81. public CertificateRequestMessageBuilder AddControl(IControl control)
  82. {
  83. m_controls.Add(control);
  84. return this;
  85. }
  86. public CertificateRequestMessageBuilder SetProofOfPossessionSignKeySigner(ISignatureFactory popoSignatureFactory)
  87. {
  88. if (_popoPrivKey != null || _popRaVerified != null || _agreeMac != null)
  89. {
  90. throw new InvalidOperationException("only one proof of possession is allowed.");
  91. }
  92. this._popSigner = popoSignatureFactory;
  93. return this;
  94. }
  95. public CertificateRequestMessageBuilder SetProofOfPossessionSubsequentMessage(SubsequentMessage msg)
  96. {
  97. if (_popoPrivKey != null || _popRaVerified != null || _agreeMac != null)
  98. {
  99. throw new InvalidOperationException("only one proof of possession is allowed.");
  100. }
  101. this._popoType = ProofOfPossession.TYPE_KEY_ENCIPHERMENT;
  102. this._popoPrivKey = new PopoPrivKey(msg);
  103. return this;
  104. }
  105. public CertificateRequestMessageBuilder SetProofOfPossessionSubsequentMessage(int type, SubsequentMessage msg)
  106. {
  107. if (_popoPrivKey != null || _popRaVerified != null || _agreeMac != null)
  108. {
  109. throw new InvalidOperationException("only one proof of possession is allowed.");
  110. }
  111. if (type != ProofOfPossession.TYPE_KEY_ENCIPHERMENT && type != ProofOfPossession.TYPE_KEY_AGREEMENT)
  112. {
  113. throw new ArgumentException("type must be ProofOfPossession.TYPE_KEY_ENCIPHERMENT || ProofOfPossession.TYPE_KEY_AGREEMENT");
  114. }
  115. this._popoType = type;
  116. this._popoPrivKey = new PopoPrivKey(msg);
  117. return this;
  118. }
  119. public CertificateRequestMessageBuilder SetProofOfPossessionAgreeMac(PKMacValue macValue)
  120. {
  121. if (_popSigner != null || _popRaVerified != null || _popoPrivKey != null)
  122. {
  123. throw new InvalidOperationException("only one proof of possession allowed");
  124. }
  125. this._agreeMac = macValue;
  126. return this;
  127. }
  128. public CertificateRequestMessageBuilder SetProofOfPossessionRaVerified()
  129. {
  130. if (_popSigner != null || _popoPrivKey != null)
  131. {
  132. throw new InvalidOperationException("only one proof of possession allowed");
  133. }
  134. this._popRaVerified = DerNull.Instance;
  135. return this;
  136. }
  137. public CertificateRequestMessageBuilder SetAuthInfoPKMAC(PKMacBuilder pkmacFactory, char[] password)
  138. {
  139. this._pkMacBuilder = pkmacFactory;
  140. this._password = password;
  141. return this;
  142. }
  143. public CertificateRequestMessageBuilder SetAuthInfoSender(X509Name sender)
  144. {
  145. return SetAuthInfoSender(new GeneralName(sender));
  146. }
  147. public CertificateRequestMessageBuilder SetAuthInfoSender(GeneralName sender)
  148. {
  149. this._sender = sender;
  150. return this;
  151. }
  152. public CertificateRequestMessage Build()
  153. {
  154. Asn1EncodableVector v = new Asn1EncodableVector(new DerInteger(this._certReqId));
  155. if (!this._extGenerator.IsEmpty)
  156. {
  157. this._templateBuilder.SetExtensions(_extGenerator.Generate());
  158. }
  159. v.Add(_templateBuilder.Build());
  160. if (m_controls.Count > 0)
  161. {
  162. Asn1EncodableVector controlV = new Asn1EncodableVector();
  163. foreach (var control in m_controls)
  164. {
  165. controlV.Add(new AttributeTypeAndValue(control.Type, control.Value));
  166. }
  167. v.Add(new DerSequence(controlV));
  168. }
  169. CertRequest request = CertRequest.GetInstance(new DerSequence(v));
  170. v = new Asn1EncodableVector(request);
  171. if (_popSigner != null)
  172. {
  173. CertTemplate template = request.CertTemplate;
  174. if (template.Subject == null || template.PublicKey == null)
  175. {
  176. SubjectPublicKeyInfo pubKeyInfo = request.CertTemplate.PublicKey;
  177. ProofOfPossessionSigningKeyBuilder builder = new ProofOfPossessionSigningKeyBuilder(pubKeyInfo);
  178. if (_sender != null)
  179. {
  180. builder.SetSender(_sender);
  181. }
  182. else
  183. {
  184. //PKMACValueGenerator pkmacGenerator = new PKMACValueGenerator(_pkmacBuilder);
  185. builder.SetPublicKeyMac(_pkMacBuilder, _password);
  186. }
  187. v.Add(new ProofOfPossession(builder.Build(_popSigner)));
  188. }
  189. else
  190. {
  191. ProofOfPossessionSigningKeyBuilder builder = new ProofOfPossessionSigningKeyBuilder(request);
  192. v.Add(new ProofOfPossession(builder.Build(_popSigner)));
  193. }
  194. }
  195. else if (_popoPrivKey != null)
  196. {
  197. v.Add(new ProofOfPossession(_popoType, _popoPrivKey));
  198. }
  199. else if (_agreeMac != null)
  200. {
  201. v.Add(new ProofOfPossession(ProofOfPossession.TYPE_KEY_AGREEMENT,
  202. PopoPrivKey.GetInstance(new DerTaggedObject(false, PopoPrivKey.agreeMAC, _agreeMac), true)));
  203. }
  204. else if (_popRaVerified != null)
  205. {
  206. v.Add(new ProofOfPossession());
  207. }
  208. return new CertificateRequestMessage(CertReqMsg.GetInstance(new DerSequence(v)));
  209. }
  210. private static Time CreateTime(DateTime? dateTime)
  211. {
  212. return dateTime == null ? null : new Time(dateTime.Value);
  213. }
  214. }
  215. }
  216. #pragma warning restore
  217. #endif