pixel-react 1.15.21 → 1.15.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (208) hide show
  1. package/lib/_virtual/aesCipherSuites.js +4 -0
  2. package/lib/_virtual/aesCipherSuites.js.map +1 -0
  3. package/lib/_virtual/asn1-validator.js +4 -0
  4. package/lib/_virtual/asn1-validator.js.map +1 -0
  5. package/lib/_virtual/asn1.js +4 -0
  6. package/lib/_virtual/asn1.js.map +1 -0
  7. package/lib/_virtual/cipherModes.js +4 -0
  8. package/lib/_virtual/cipherModes.js.map +1 -0
  9. package/lib/_virtual/hmac.js +4 -0
  10. package/lib/_virtual/hmac.js.map +1 -0
  11. package/lib/_virtual/index11.js +2 -2
  12. package/lib/_virtual/index12.js +2 -2
  13. package/lib/_virtual/index13.js +2 -2
  14. package/lib/_virtual/index14.js +4 -0
  15. package/lib/_virtual/index14.js.map +1 -0
  16. package/lib/_virtual/index2.js +5 -3
  17. package/lib/_virtual/index2.js.map +1 -1
  18. package/lib/_virtual/index3.js +4 -2
  19. package/lib/_virtual/index3.js.map +1 -1
  20. package/lib/_virtual/index4.js +2 -4
  21. package/lib/_virtual/index4.js.map +1 -1
  22. package/lib/_virtual/index5.js +4 -2
  23. package/lib/_virtual/index5.js.map +1 -1
  24. package/lib/_virtual/index6.js +2 -2
  25. package/lib/_virtual/index7.js +2 -6
  26. package/lib/_virtual/index7.js.map +1 -1
  27. package/lib/_virtual/index8.js +6 -2
  28. package/lib/_virtual/index8.js.map +1 -1
  29. package/lib/_virtual/index9.js +2 -2
  30. package/lib/_virtual/md5.js +4 -0
  31. package/lib/_virtual/md5.js.map +1 -0
  32. package/lib/_virtual/mgf1.js +4 -0
  33. package/lib/_virtual/mgf1.js.map +1 -0
  34. package/lib/_virtual/oids.js +4 -0
  35. package/lib/_virtual/oids.js.map +1 -0
  36. package/lib/_virtual/pem.js +4 -0
  37. package/lib/_virtual/pem.js.map +1 -0
  38. package/lib/_virtual/pkcs1.js +4 -0
  39. package/lib/_virtual/pkcs1.js.map +1 -0
  40. package/lib/_virtual/pkcs12.js +4 -0
  41. package/lib/_virtual/pkcs12.js.map +1 -0
  42. package/lib/_virtual/pkcs7.js +4 -0
  43. package/lib/_virtual/pkcs7.js.map +1 -0
  44. package/lib/_virtual/pkcs7asn1.js +4 -0
  45. package/lib/_virtual/pkcs7asn1.js.map +1 -0
  46. package/lib/_virtual/pki.js +4 -0
  47. package/lib/_virtual/pki.js.map +1 -0
  48. package/lib/_virtual/prime.js +4 -0
  49. package/lib/_virtual/prime.js.map +1 -0
  50. package/lib/_virtual/prng.js +4 -0
  51. package/lib/_virtual/prng.js.map +1 -0
  52. package/lib/_virtual/pss.js +4 -0
  53. package/lib/_virtual/pss.js.map +1 -0
  54. package/lib/_virtual/random.js +4 -0
  55. package/lib/_virtual/random.js.map +1 -0
  56. package/lib/_virtual/sha1.js +4 -0
  57. package/lib/_virtual/sha1.js.map +1 -0
  58. package/lib/_virtual/sha256.js +4 -0
  59. package/lib/_virtual/sha256.js.map +1 -0
  60. package/lib/_virtual/sha512.js +4 -0
  61. package/lib/_virtual/sha512.js.map +1 -0
  62. package/lib/_virtual/ssh.js +4 -0
  63. package/lib/_virtual/ssh.js.map +1 -0
  64. package/lib/_virtual/util.js +4 -0
  65. package/lib/_virtual/util.js.map +1 -0
  66. package/lib/_virtual/x509.js +4 -0
  67. package/lib/_virtual/x509.js.map +1 -0
  68. package/lib/assets/icons/testify_icon.svg.js +6 -0
  69. package/lib/assets/icons/testify_icon.svg.js.map +1 -0
  70. package/lib/assets/icons/testify_loader.svg.js +6 -0
  71. package/lib/assets/icons/testify_loader.svg.js.map +1 -0
  72. package/lib/assets/icons/testify_logo_name.svg.js +6 -0
  73. package/lib/assets/icons/testify_logo_name.svg.js.map +1 -0
  74. package/lib/components/AllProjectsDropdown/AllProjectsDropdown.js +3 -1
  75. package/lib/components/AllProjectsDropdown/AllProjectsDropdown.js.map +1 -1
  76. package/lib/components/Charts/DashboardDonutChart/DashboardDonutChart.js +2 -9
  77. package/lib/components/Charts/DashboardDonutChart/DashboardDonutChart.js.map +1 -1
  78. package/lib/components/Charts/DashboardDonutChart/types.d.ts +1 -1
  79. package/lib/components/ConditionalDropdown/ConditionalDropdown.js +2 -9
  80. package/lib/components/ConditionalDropdown/ConditionalDropdown.js.map +1 -1
  81. package/lib/components/Editor/Editor.js +37 -17
  82. package/lib/components/Editor/Editor.js.map +1 -1
  83. package/lib/components/Icon/iconList.js +6 -0
  84. package/lib/components/Icon/iconList.js.map +1 -1
  85. package/lib/components/MultiSelect/MultiSelect.js +9 -10
  86. package/lib/components/MultiSelect/MultiSelect.js.map +1 -1
  87. package/lib/components/PhoneInput/PhoneInput.js +1 -0
  88. package/lib/components/PhoneInput/PhoneInput.js.map +1 -1
  89. package/lib/components/SessionDropdown/SessionDropdown.js +4 -2
  90. package/lib/components/SessionDropdown/SessionDropdown.js.map +1 -1
  91. package/lib/index.cjs +27423 -379
  92. package/lib/index.cjs.map +1 -1
  93. package/lib/index.d.ts +1 -1
  94. package/lib/node_modules/classnames/index.js +1 -1
  95. package/lib/node_modules/input-format/modules/react/Input.js +1 -1
  96. package/lib/node_modules/js-beautify/js/index.js +1 -1
  97. package/lib/node_modules/js-beautify/js/src/html/beautifier.js +1 -1
  98. package/lib/node_modules/js-beautify/js/src/html/index.js +1 -1
  99. package/lib/node_modules/js-beautify/js/src/html/options.js +1 -1
  100. package/lib/node_modules/js-beautify/js/src/html/tokenizer.js +1 -1
  101. package/lib/node_modules/js-beautify/js/src/index.js +1 -1
  102. package/lib/node_modules/js-beautify/js/src/javascript/beautifier.js +1 -1
  103. package/lib/node_modules/js-beautify/js/src/javascript/index.js +1 -1
  104. package/lib/node_modules/js-beautify/js/src/javascript/options.js +1 -1
  105. package/lib/node_modules/js-beautify/js/src/javascript/tokenizer.js +1 -1
  106. package/lib/node_modules/node-forge/lib/aes.js +1014 -0
  107. package/lib/node_modules/node-forge/lib/aes.js.map +1 -0
  108. package/lib/node_modules/node-forge/lib/aesCipherSuites.js +286 -0
  109. package/lib/node_modules/node-forge/lib/aesCipherSuites.js.map +1 -0
  110. package/lib/node_modules/node-forge/lib/asn1-validator.js +100 -0
  111. package/lib/node_modules/node-forge/lib/asn1-validator.js.map +1 -0
  112. package/lib/node_modules/node-forge/lib/asn1.js +1379 -0
  113. package/lib/node_modules/node-forge/lib/asn1.js.map +1 -0
  114. package/lib/node_modules/node-forge/lib/baseN.js +181 -0
  115. package/lib/node_modules/node-forge/lib/baseN.js.map +1 -0
  116. package/lib/node_modules/node-forge/lib/cipher.js +236 -0
  117. package/lib/node_modules/node-forge/lib/cipher.js.map +1 -0
  118. package/lib/node_modules/node-forge/lib/cipherModes.js +936 -0
  119. package/lib/node_modules/node-forge/lib/cipherModes.js.map +1 -0
  120. package/lib/node_modules/node-forge/lib/des.js +467 -0
  121. package/lib/node_modules/node-forge/lib/des.js.map +1 -0
  122. package/lib/node_modules/node-forge/lib/ed25519.js +1108 -0
  123. package/lib/node_modules/node-forge/lib/ed25519.js.map +1 -0
  124. package/lib/node_modules/node-forge/lib/forge.js +23 -0
  125. package/lib/node_modules/node-forge/lib/forge.js.map +1 -0
  126. package/lib/node_modules/node-forge/lib/hmac.js +158 -0
  127. package/lib/node_modules/node-forge/lib/hmac.js.map +1 -0
  128. package/lib/node_modules/node-forge/lib/index.js +70 -0
  129. package/lib/node_modules/node-forge/lib/index.js.map +1 -0
  130. package/lib/node_modules/node-forge/lib/jsbn.js +1481 -0
  131. package/lib/node_modules/node-forge/lib/jsbn.js.map +1 -0
  132. package/lib/node_modules/node-forge/lib/kem.js +178 -0
  133. package/lib/node_modules/node-forge/lib/kem.js.map +1 -0
  134. package/lib/node_modules/node-forge/lib/log.js +325 -0
  135. package/lib/node_modules/node-forge/lib/log.js.map +1 -0
  136. package/lib/node_modules/node-forge/lib/md.all.js +28 -0
  137. package/lib/node_modules/node-forge/lib/md.all.js.map +1 -0
  138. package/lib/node_modules/node-forge/lib/md.js +22 -0
  139. package/lib/node_modules/node-forge/lib/md.js.map +1 -0
  140. package/lib/node_modules/node-forge/lib/md5.js +288 -0
  141. package/lib/node_modules/node-forge/lib/md5.js.map +1 -0
  142. package/lib/node_modules/node-forge/lib/mgf.js +24 -0
  143. package/lib/node_modules/node-forge/lib/mgf.js.map +1 -0
  144. package/lib/node_modules/node-forge/lib/mgf1.js +68 -0
  145. package/lib/node_modules/node-forge/lib/mgf1.js.map +1 -0
  146. package/lib/node_modules/node-forge/lib/oids.js +185 -0
  147. package/lib/node_modules/node-forge/lib/oids.js.map +1 -0
  148. package/lib/node_modules/node-forge/lib/pbe.js +966 -0
  149. package/lib/node_modules/node-forge/lib/pbe.js.map +1 -0
  150. package/lib/node_modules/node-forge/lib/pbkdf2.js +209 -0
  151. package/lib/node_modules/node-forge/lib/pbkdf2.js.map +1 -0
  152. package/lib/node_modules/node-forge/lib/pem.js +250 -0
  153. package/lib/node_modules/node-forge/lib/pem.js.map +1 -0
  154. package/lib/node_modules/node-forge/lib/pkcs1.js +273 -0
  155. package/lib/node_modules/node-forge/lib/pkcs1.js.map +1 -0
  156. package/lib/node_modules/node-forge/lib/pkcs12.js +980 -0
  157. package/lib/node_modules/node-forge/lib/pkcs12.js.map +1 -0
  158. package/lib/node_modules/node-forge/lib/pkcs7.js +1073 -0
  159. package/lib/node_modules/node-forge/lib/pkcs7.js.map +1 -0
  160. package/lib/node_modules/node-forge/lib/pkcs7asn1.js +415 -0
  161. package/lib/node_modules/node-forge/lib/pkcs7asn1.js.map +1 -0
  162. package/lib/node_modules/node-forge/lib/pki.js +125 -0
  163. package/lib/node_modules/node-forge/lib/pki.js.map +1 -0
  164. package/lib/node_modules/node-forge/lib/prime.js +297 -0
  165. package/lib/node_modules/node-forge/lib/prime.js.map +1 -0
  166. package/lib/node_modules/node-forge/lib/prng.js +433 -0
  167. package/lib/node_modules/node-forge/lib/prng.js.map +1 -0
  168. package/lib/node_modules/node-forge/lib/pss.js +246 -0
  169. package/lib/node_modules/node-forge/lib/pss.js.map +1 -0
  170. package/lib/node_modules/node-forge/lib/random.js +191 -0
  171. package/lib/node_modules/node-forge/lib/random.js.map +1 -0
  172. package/lib/node_modules/node-forge/lib/rc2.js +382 -0
  173. package/lib/node_modules/node-forge/lib/rc2.js.map +1 -0
  174. package/lib/node_modules/node-forge/lib/rsa.js +1815 -0
  175. package/lib/node_modules/node-forge/lib/rsa.js.map +1 -0
  176. package/lib/node_modules/node-forge/lib/sha1.js +325 -0
  177. package/lib/node_modules/node-forge/lib/sha1.js.map +1 -0
  178. package/lib/node_modules/node-forge/lib/sha256.js +306 -0
  179. package/lib/node_modules/node-forge/lib/sha256.js.map +1 -0
  180. package/lib/node_modules/node-forge/lib/sha512.js +479 -0
  181. package/lib/node_modules/node-forge/lib/sha512.js.map +1 -0
  182. package/lib/node_modules/node-forge/lib/ssh.js +244 -0
  183. package/lib/node_modules/node-forge/lib/ssh.js.map +1 -0
  184. package/lib/node_modules/node-forge/lib/tls.js +4207 -0
  185. package/lib/node_modules/node-forge/lib/tls.js.map +1 -0
  186. package/lib/node_modules/node-forge/lib/util.js +2565 -0
  187. package/lib/node_modules/node-forge/lib/util.js.map +1 -0
  188. package/lib/node_modules/node-forge/lib/x509.js +2986 -0
  189. package/lib/node_modules/node-forge/lib/x509.js.map +1 -0
  190. package/lib/node_modules/prop-types/index.js +1 -1
  191. package/lib/node_modules/react-async-script/lib/esm/async-script-loader.js +1 -1
  192. package/lib/node_modules/react-google-recaptcha/lib/esm/recaptcha.js +1 -1
  193. package/lib/node_modules/react-is/index.js +1 -1
  194. package/lib/node_modules/react-phone-number-input/modules/CountryIcon.js +1 -1
  195. package/lib/node_modules/react-phone-number-input/modules/CountrySelect.js +1 -1
  196. package/lib/node_modules/react-phone-number-input/modules/Flag.js +1 -1
  197. package/lib/node_modules/react-phone-number-input/modules/InputBasic.js +1 -1
  198. package/lib/node_modules/react-phone-number-input/modules/InputSmart.js +1 -1
  199. package/lib/node_modules/react-phone-number-input/modules/InternationalIcon.js +1 -1
  200. package/lib/node_modules/react-phone-number-input/modules/PhoneInputWithCountry.js +1 -1
  201. package/lib/node_modules/react-phone-number-input/modules/PropTypes.js +1 -1
  202. package/lib/node_modules/scheduler/index.js +1 -1
  203. package/lib/node_modules/use-context-selector/dist/index.js +1 -1
  204. package/lib/styles.css +1 -1
  205. package/lib/styles.css.map +1 -1
  206. package/lib/utils/getEncryptedData/getEncryptedData.js +10 -13
  207. package/lib/utils/getEncryptedData/getEncryptedData.js.map +1 -1
  208. package/package.json +3 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pkcs7.js","sources":["../../../../node_modules/node-forge/lib/pkcs7.js"],"sourcesContent":["/**\n * Javascript implementation of PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n *\n * Currently this implementation only supports ContentType of EnvelopedData,\n * EncryptedData, or SignedData at the root level. The top level elements may\n * contain only a ContentInfo of ContentType Data, i.e. plain data. Further\n * nesting is not (yet) supported.\n *\n * The Forge validators for PKCS #7's ASN.1 structures are available from\n * a separate file pkcs7asn1.js, since those are referenced from other\n * PKCS standards like PKCS #12.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./oids');\nrequire('./pem');\nrequire('./pkcs7asn1');\nrequire('./random');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};\n\n/**\n * Converts a PKCS#7 message from PEM format.\n *\n * @param pem the PEM-formatted PKCS#7 message.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PKCS7') {\n var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +\n 'header type is not \"PKCS#7\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return p7.messageFromAsn1(obj);\n};\n\n/**\n * Converts a PKCS#7 message to PEM format.\n *\n * @param msg The PKCS#7 message object\n * @param maxline The maximum characters per line, defaults to 64.\n *\n * @return The PEM-formatted PKCS#7 message.\n */\np7.messageToPem = function(msg, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var pemObj = {\n type: 'PKCS7',\n body: asn1.toDer(msg.toAsn1()).getBytes()\n };\n return forge.pem.encode(pemObj, {maxline: maxline});\n};\n\n/**\n * Converts a PKCS#7 message from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a ContentInfo.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromAsn1 = function(obj) {\n // validate root level ContentInfo and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not an PKCS#7 ContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var contentType = asn1.derToOid(capture.contentType);\n var msg;\n\n switch(contentType) {\n case forge.pki.oids.envelopedData:\n msg = p7.createEnvelopedData();\n break;\n\n case forge.pki.oids.encryptedData:\n msg = p7.createEncryptedData();\n break;\n\n case forge.pki.oids.signedData:\n msg = p7.createSignedData();\n break;\n\n default:\n throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +\n contentType + ' is not (yet) supported.');\n }\n\n msg.fromAsn1(capture.content.value[0]);\n return msg;\n};\n\np7.createSignedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.signedData,\n version: 1,\n certificates: [],\n crls: [],\n // TODO: add json-formatted signer stuff here?\n signers: [],\n // populated during sign()\n digestAlgorithmIdentifiers: [],\n contentInfo: null,\n signerInfos: [],\n\n fromAsn1: function(obj) {\n // validate SignedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.signedDataValidator);\n msg.certificates = [];\n msg.crls = [];\n msg.digestAlgorithmIdentifiers = [];\n msg.contentInfo = null;\n msg.signerInfos = [];\n\n if(msg.rawCapture.certificates) {\n var certs = msg.rawCapture.certificates.value;\n for(var i = 0; i < certs.length; ++i) {\n msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));\n }\n }\n\n // TODO: parse crls\n },\n\n toAsn1: function() {\n // degenerate case with no content\n if(!msg.contentInfo) {\n msg.sign();\n }\n\n var certs = [];\n for(var i = 0; i < msg.certificates.length; ++i) {\n certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));\n }\n\n var crls = [];\n // TODO: implement CRLs\n\n // [0] SignedData\n var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // DigestAlgorithmIdentifiers\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.digestAlgorithmIdentifiers),\n // ContentInfo\n msg.contentInfo\n ])\n ]);\n if(certs.length > 0) {\n // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));\n }\n if(crls.length > 0) {\n // [1] IMPLICIT CertificateRevocationLists OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));\n }\n // SignerInfos\n signedData.value[0].value.push(\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.signerInfos));\n\n // ContentInfo\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] SignedData\n signedData\n ]);\n },\n\n /**\n * Add (another) entity to list of signers.\n *\n * Note: If authenticatedAttributes are provided, then, per RFC 2315,\n * they must include at least two attributes: content type and\n * message digest. The message digest attribute value will be\n * auto-calculated during signing and will be ignored if provided.\n *\n * Here's an example of providing these two attributes:\n *\n * forge.pkcs7.createSignedData();\n * p7.addSigner({\n * issuer: cert.issuer.attributes,\n * serialNumber: cert.serialNumber,\n * key: privateKey,\n * digestAlgorithm: forge.pki.oids.sha1,\n * authenticatedAttributes: [{\n * type: forge.pki.oids.contentType,\n * value: forge.pki.oids.data\n * }, {\n * type: forge.pki.oids.messageDigest\n * }]\n * });\n *\n * TODO: Support [subjectKeyIdentifier] as signer's ID.\n *\n * @param signer the signer information:\n * key the signer's private key.\n * [certificate] a certificate containing the public key\n * associated with the signer's private key; use this option as\n * an alternative to specifying signer.issuer and\n * signer.serialNumber.\n * [issuer] the issuer attributes (eg: cert.issuer.attributes).\n * [serialNumber] the signer's certificate's serial number in\n * hexadecimal (eg: cert.serialNumber).\n * [digestAlgorithm] the message digest OID, as a string, to use\n * (eg: forge.pki.oids.sha1).\n * [authenticatedAttributes] an optional array of attributes\n * to also sign along with the content.\n */\n addSigner: function(signer) {\n var issuer = signer.issuer;\n var serialNumber = signer.serialNumber;\n if(signer.certificate) {\n var cert = signer.certificate;\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n issuer = cert.issuer.attributes;\n serialNumber = cert.serialNumber;\n }\n var key = signer.key;\n if(!key) {\n throw new Error(\n 'Could not add PKCS#7 signer; no private key specified.');\n }\n if(typeof key === 'string') {\n key = forge.pki.privateKeyFromPem(key);\n }\n\n // ensure OID known for digest algorithm\n var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;\n switch(digestAlgorithm) {\n case forge.pki.oids.sha1:\n case forge.pki.oids.sha256:\n case forge.pki.oids.sha384:\n case forge.pki.oids.sha512:\n case forge.pki.oids.md5:\n break;\n default:\n throw new Error(\n 'Could not add PKCS#7 signer; unknown message digest algorithm: ' +\n digestAlgorithm);\n }\n\n // if authenticatedAttributes is present, then the attributes\n // must contain at least PKCS #9 content-type and message-digest\n var authenticatedAttributes = signer.authenticatedAttributes || [];\n if(authenticatedAttributes.length > 0) {\n var contentType = false;\n var messageDigest = false;\n for(var i = 0; i < authenticatedAttributes.length; ++i) {\n var attr = authenticatedAttributes[i];\n if(!contentType && attr.type === forge.pki.oids.contentType) {\n contentType = true;\n if(messageDigest) {\n break;\n }\n continue;\n }\n if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {\n messageDigest = true;\n if(contentType) {\n break;\n }\n continue;\n }\n }\n\n if(!contentType || !messageDigest) {\n throw new Error('Invalid signer.authenticatedAttributes. If ' +\n 'signer.authenticatedAttributes is specified, then it must ' +\n 'contain at least two attributes, PKCS #9 content-type and ' +\n 'PKCS #9 message-digest.');\n }\n }\n\n msg.signers.push({\n key: key,\n version: 1,\n issuer: issuer,\n serialNumber: serialNumber,\n digestAlgorithm: digestAlgorithm,\n signatureAlgorithm: forge.pki.oids.rsaEncryption,\n signature: null,\n authenticatedAttributes: authenticatedAttributes,\n unauthenticatedAttributes: []\n });\n },\n\n /**\n * Signs the content.\n * @param options Options to apply when signing:\n * [detached] boolean. If signing should be done in detached mode. Defaults to false.\n */\n sign: function(options) {\n options = options || {};\n // auto-generate content info\n if(typeof msg.content !== 'object' || msg.contentInfo === null) {\n // use Data ContentInfo\n msg.contentInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes())\n ]);\n\n // add actual content, if present\n if('content' in msg) {\n var content;\n if(msg.content instanceof forge.util.ByteBuffer) {\n content = msg.content.bytes();\n } else if(typeof msg.content === 'string') {\n content = forge.util.encodeUtf8(msg.content);\n }\n\n if (options.detached) {\n msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);\n } else {\n msg.contentInfo.value.push(\n // [0] EXPLICIT content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n content)\n ]));\n }\n }\n }\n\n // no signers, return early (degenerate case for certificate container)\n if(msg.signers.length === 0) {\n return;\n }\n\n // generate digest algorithm identifiers\n var mds = addDigestAlgorithmIds();\n\n // generate signerInfos\n addSignerInfos(mds);\n },\n\n verify: function() {\n throw new Error('PKCS#7 signature verification not yet implemented.');\n },\n\n /**\n * Add a certificate.\n *\n * @param cert the certificate to add.\n */\n addCertificate: function(cert) {\n // convert from PEM\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n msg.certificates.push(cert);\n },\n\n /**\n * Add a certificate revokation list.\n *\n * @param crl the certificate revokation list to add.\n */\n addCertificateRevokationList: function(crl) {\n throw new Error('PKCS#7 CRL support not yet implemented.');\n }\n };\n return msg;\n\n function addDigestAlgorithmIds() {\n var mds = {};\n\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n var oid = signer.digestAlgorithm;\n if(!(oid in mds)) {\n // content digest\n mds[oid] = forge.md[forge.pki.oids[oid]].create();\n }\n if(signer.authenticatedAttributes.length === 0) {\n // no custom attributes to digest; use content message digest\n signer.md = mds[oid];\n } else {\n // custom attributes to be digested; use own message digest\n // TODO: optimize to just copy message digest state if that\n // feature is ever supported with message digests\n signer.md = forge.md[forge.pki.oids[oid]].create();\n }\n }\n\n // add unique digest algorithm identifiers\n msg.digestAlgorithmIdentifiers = [];\n for(var oid in mds) {\n msg.digestAlgorithmIdentifiers.push(\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oid).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n\n return mds;\n }\n\n function addSignerInfos(mds) {\n var content;\n\n if (msg.detachedContent) {\n // Signature has been made in detached mode.\n content = msg.detachedContent;\n } else {\n // Note: ContentInfo is a SEQUENCE with 2 values, second value is\n // the content field and is optional for a ContentInfo but required here\n // since signers are present\n // get ContentInfo content\n content = msg.contentInfo.value[1];\n // skip [0] EXPLICIT content wrapper\n content = content.value[0];\n }\n\n if(!content) {\n throw new Error(\n 'Could not sign PKCS#7 message; there is no content to sign.');\n }\n\n // get ContentInfo content type\n var contentType = asn1.derToOid(msg.contentInfo.value[0].value);\n\n // serialize content\n var bytes = asn1.toDer(content);\n\n // skip identifier and length per RFC 2315 9.3\n // skip identifier (1 byte)\n bytes.getByte();\n // read and discard length bytes\n asn1.getBerValueLength(bytes);\n bytes = bytes.getBytes();\n\n // digest content DER value bytes\n for(var oid in mds) {\n mds[oid].start().update(bytes);\n }\n\n // sign content\n var signingTime = new Date();\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n\n if(signer.authenticatedAttributes.length === 0) {\n // if ContentInfo content type is not \"Data\", then\n // authenticatedAttributes must be present per RFC 2315\n if(contentType !== forge.pki.oids.data) {\n throw new Error(\n 'Invalid signer; authenticatedAttributes must be present ' +\n 'when the ContentInfo content type is not PKCS#7 Data.');\n }\n } else {\n // process authenticated attributes\n // [0] IMPLICIT\n signer.authenticatedAttributesAsn1 = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // per RFC 2315, attributes are to be digested using a SET container\n // not the above [0] IMPLICIT container\n var attrsAsn1 = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);\n\n for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {\n var attr = signer.authenticatedAttributes[ai];\n if(attr.type === forge.pki.oids.messageDigest) {\n // use content message digest as value\n attr.value = mds[signer.digestAlgorithm].digest();\n } else if(attr.type === forge.pki.oids.signingTime) {\n // auto-populate signing time if not already set\n if(!attr.value) {\n attr.value = signingTime;\n }\n }\n\n // convert to ASN.1 and push onto Attributes SET (for signing) and\n // onto authenticatedAttributesAsn1 to complete SignedData ASN.1\n // TODO: optimize away duplication\n attrsAsn1.value.push(_attributeToAsn1(attr));\n signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));\n }\n\n // DER-serialize and digest SET OF attributes only\n bytes = asn1.toDer(attrsAsn1).getBytes();\n signer.md.start().update(bytes);\n }\n\n // sign digest\n signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');\n }\n\n // add signer info\n msg.signerInfos = _signersToAsn1(msg.signers);\n }\n};\n\n/**\n * Creates an empty PKCS#7 message of type EncryptedData.\n *\n * @return the message.\n */\np7.createEncryptedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.encryptedData,\n version: 0,\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EncryptedData content block (in ASN.1 format)\n *\n * @param obj The ASN.1 representation of the EncryptedData content block\n */\n fromAsn1: function(obj) {\n // Validate EncryptedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);\n },\n\n /**\n * Decrypt encrypted content\n *\n * @param key The (symmetric) key as a byte buffer\n */\n decrypt: function(key) {\n if(key !== undefined) {\n msg.encryptedContent.key = key;\n }\n _decryptContent(msg);\n }\n };\n return msg;\n};\n\n/**\n * Creates an empty PKCS#7 message of type EnvelopedData.\n *\n * @return the message.\n */\np7.createEnvelopedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.envelopedData,\n version: 0,\n recipients: [],\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EnvelopedData content block (in ASN.1 format)\n *\n * @param obj the ASN.1 representation of the EnvelopedData content block.\n */\n fromAsn1: function(obj) {\n // validate EnvelopedData content block and capture data\n var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);\n msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);\n },\n\n toAsn1: function() {\n // ContentInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] EnvelopedData\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // RecipientInfos\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n _recipientsToAsn1(msg.recipients)),\n // EncryptedContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,\n _encryptedContentToAsn1(msg.encryptedContent))\n ])\n ])\n ]);\n },\n\n /**\n * Find recipient by X.509 certificate's issuer.\n *\n * @param cert the certificate with the issuer to look for.\n *\n * @return the recipient object.\n */\n findRecipient: function(cert) {\n var sAttr = cert.issuer.attributes;\n\n for(var i = 0; i < msg.recipients.length; ++i) {\n var r = msg.recipients[i];\n var rAttr = r.issuer;\n\n if(r.serialNumber !== cert.serialNumber) {\n continue;\n }\n\n if(rAttr.length !== sAttr.length) {\n continue;\n }\n\n var match = true;\n for(var j = 0; j < sAttr.length; ++j) {\n if(rAttr[j].type !== sAttr[j].type ||\n rAttr[j].value !== sAttr[j].value) {\n match = false;\n break;\n }\n }\n\n if(match) {\n return r;\n }\n }\n\n return null;\n },\n\n /**\n * Decrypt enveloped content\n *\n * @param recipient The recipient object related to the private key\n * @param privKey The (RSA) private key object\n */\n decrypt: function(recipient, privKey) {\n if(msg.encryptedContent.key === undefined && recipient !== undefined &&\n privKey !== undefined) {\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n case forge.pki.oids.desCBC:\n var key = privKey.decrypt(recipient.encryptedContent.content);\n msg.encryptedContent.key = forge.util.createBuffer(key);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, ' +\n 'OID ' + recipient.encryptedContent.algorithm);\n }\n }\n\n _decryptContent(msg);\n },\n\n /**\n * Add (another) entity to list of recipients.\n *\n * @param cert The certificate of the entity to add.\n */\n addRecipient: function(cert) {\n msg.recipients.push({\n version: 0,\n issuer: cert.issuer.attributes,\n serialNumber: cert.serialNumber,\n encryptedContent: {\n // We simply assume rsaEncryption here, since forge.pki only\n // supports RSA so far. If the PKI module supports other\n // ciphers one day, we need to modify this one as well.\n algorithm: forge.pki.oids.rsaEncryption,\n key: cert.publicKey\n }\n });\n },\n\n /**\n * Encrypt enveloped content.\n *\n * This function supports two optional arguments, cipher and key, which\n * can be used to influence symmetric encryption. Unless cipher is\n * provided, the cipher specified in encryptedContent.algorithm is used\n * (defaults to AES-256-CBC). If no key is provided, encryptedContent.key\n * is (re-)used. If that one's not set, a random key will be generated\n * automatically.\n *\n * @param [key] The key to be used for symmetric encryption.\n * @param [cipher] The OID of the symmetric cipher to use.\n */\n encrypt: function(key, cipher) {\n // Part 1: Symmetric encryption\n if(msg.encryptedContent.content === undefined) {\n cipher = cipher || msg.encryptedContent.algorithm;\n key = key || msg.encryptedContent.key;\n\n var keyLen, ivLen, ciphFn;\n switch(cipher) {\n case forge.pki.oids['aes128-CBC']:\n keyLen = 16;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes192-CBC']:\n keyLen = 24;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes256-CBC']:\n keyLen = 32;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['des-EDE3-CBC']:\n keyLen = 24;\n ivLen = 8;\n ciphFn = forge.des.createEncryptionCipher;\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' + cipher);\n }\n\n if(key === undefined) {\n key = forge.util.createBuffer(forge.random.getBytes(keyLen));\n } else if(key.length() != keyLen) {\n throw new Error('Symmetric key has wrong length; ' +\n 'got ' + key.length() + ' bytes, expected ' + keyLen + '.');\n }\n\n // Keep a copy of the key & IV in the object, so the caller can\n // use it for whatever reason.\n msg.encryptedContent.algorithm = cipher;\n msg.encryptedContent.key = key;\n msg.encryptedContent.parameter = forge.util.createBuffer(\n forge.random.getBytes(ivLen));\n\n var ciph = ciphFn(key);\n ciph.start(msg.encryptedContent.parameter.copy());\n ciph.update(msg.content);\n\n // The finish function does PKCS#7 padding by default, therefore\n // no action required by us.\n if(!ciph.finish()) {\n throw new Error('Symmetric encryption failed.');\n }\n\n msg.encryptedContent.content = ciph.output;\n }\n\n // Part 2: asymmetric encryption for each recipient\n for(var i = 0; i < msg.recipients.length; ++i) {\n var recipient = msg.recipients[i];\n\n // Nothing to do, encryption already done.\n if(recipient.encryptedContent.content !== undefined) {\n continue;\n }\n\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n recipient.encryptedContent.content =\n recipient.encryptedContent.key.encrypt(\n msg.encryptedContent.key.data);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, OID ' +\n recipient.encryptedContent.algorithm);\n }\n }\n }\n };\n return msg;\n};\n\n/**\n * Converts a single recipient from an ASN.1 object.\n *\n * @param obj the ASN.1 RecipientInfo.\n *\n * @return the recipient object.\n */\nfunction _recipientFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +\n 'ASN.1 object is not an PKCS#7 RecipientInfo.');\n error.errors = errors;\n throw error;\n }\n\n return {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n encryptedContent: {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: capture.encParameter ? capture.encParameter.value : undefined,\n content: capture.encKey\n }\n };\n}\n\n/**\n * Converts a single recipient object to an ASN.1 object.\n *\n * @param obj the recipient object.\n *\n * @return the ASN.1 RecipientInfo.\n */\nfunction _recipientToAsn1(obj) {\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // IssuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // Serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // KeyEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.encryptedContent.algorithm).getBytes()),\n // Parameter, force NULL, only RSA supported for now.\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // EncryptedKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n obj.encryptedContent.content)\n ]);\n}\n\n/**\n * Map a set of RecipientInfo ASN.1 objects to recipient objects.\n *\n * @param infos an array of ASN.1 representations RecipientInfo (i.e. SET OF).\n *\n * @return an array of recipient objects.\n */\nfunction _recipientsFromAsn1(infos) {\n var ret = [];\n for(var i = 0; i < infos.length; ++i) {\n ret.push(_recipientFromAsn1(infos[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of recipient objects to ASN.1 RecipientInfo objects.\n *\n * @param recipients an array of recipientInfo objects.\n *\n * @return an array of ASN.1 RecipientInfos.\n */\nfunction _recipientsToAsn1(recipients) {\n var ret = [];\n for(var i = 0; i < recipients.length; ++i) {\n ret.push(_recipientToAsn1(recipients[i]));\n }\n return ret;\n}\n\n/**\n * Converts a single signer from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a SignerInfo.\n *\n * @return the signer object.\n */\nfunction _signerFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.signerInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 SignerInfo. ' +\n 'ASN.1 object is not an PKCS#7 SignerInfo.');\n error.errors = errors;\n throw error;\n }\n\n var rval = {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n digestAlgorithm: asn1.derToOid(capture.digestAlgorithm),\n signatureAlgorithm: asn1.derToOid(capture.signatureAlgorithm),\n signature: capture.signature,\n authenticatedAttributes: [],\n unauthenticatedAttributes: []\n };\n\n // TODO: convert attributes\n var authenticatedAttributes = capture.authenticatedAttributes || [];\n var unauthenticatedAttributes = capture.unauthenticatedAttributes || [];\n\n return rval;\n}\n\n/**\n * Converts a single signerInfo object to an ASN.1 object.\n *\n * @param obj the signerInfo object.\n *\n * @return the ASN.1 representation of a SignerInfo.\n */\nfunction _signerToAsn1(obj) {\n // SignerInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // issuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // digestAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.digestAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]);\n\n // authenticatedAttributes (OPTIONAL)\n if(obj.authenticatedAttributesAsn1) {\n // add ASN.1 previously generated during signing\n rval.value.push(obj.authenticatedAttributesAsn1);\n }\n\n // digestEncryptionAlgorithm\n rval.value.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.signatureAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n\n // encryptedDigest\n rval.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, obj.signature));\n\n // unauthenticatedAttributes (OPTIONAL)\n if(obj.unauthenticatedAttributes.length > 0) {\n // [1] IMPLICIT\n var attrsAsn1 = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, []);\n for(var i = 0; i < obj.unauthenticatedAttributes.length; ++i) {\n var attr = obj.unauthenticatedAttributes[i];\n attrsAsn1.values.push(_attributeToAsn1(attr));\n }\n rval.value.push(attrsAsn1);\n }\n\n return rval;\n}\n\n/**\n * Map a set of SignerInfo ASN.1 objects to an array of signer objects.\n *\n * @param signerInfoAsn1s an array of ASN.1 SignerInfos (i.e. SET OF).\n *\n * @return an array of signers objects.\n */\nfunction _signersFromAsn1(signerInfoAsn1s) {\n var ret = [];\n for(var i = 0; i < signerInfoAsn1s.length; ++i) {\n ret.push(_signerFromAsn1(signerInfoAsn1s[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of signer objects to ASN.1 objects.\n *\n * @param signers an array of signer objects.\n *\n * @return an array of ASN.1 SignerInfos.\n */\nfunction _signersToAsn1(signers) {\n var ret = [];\n for(var i = 0; i < signers.length; ++i) {\n ret.push(_signerToAsn1(signers[i]));\n }\n return ret;\n}\n\n/**\n * Convert an attribute object to an ASN.1 Attribute.\n *\n * @param attr the attribute object.\n *\n * @return the ASN.1 Attribute.\n */\nfunction _attributeToAsn1(attr) {\n var value;\n\n // TODO: generalize to support more attributes\n if(attr.type === forge.pki.oids.contentType) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.value).getBytes());\n } else if(attr.type === forge.pki.oids.messageDigest) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n attr.value.bytes());\n } else if(attr.type === forge.pki.oids.signingTime) {\n /* Note per RFC 2985: Dates between 1 January 1950 and 31 December 2049\n (inclusive) MUST be encoded as UTCTime. Any dates with year values\n before 1950 or after 2049 MUST be encoded as GeneralizedTime. [Further,]\n UTCTime values MUST be expressed in Greenwich Mean Time (Zulu) and MUST\n include seconds (i.e., times are YYMMDDHHMMSSZ), even where the\n number of seconds is zero. Midnight (GMT) must be represented as\n \"YYMMDD000000Z\". */\n // TODO: make these module-level constants\n var jan_1_1950 = new Date('1950-01-01T00:00:00Z');\n var jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n var date = attr.value;\n if(typeof date === 'string') {\n // try to parse date\n var timestamp = Date.parse(date);\n if(!isNaN(timestamp)) {\n date = new Date(timestamp);\n } else if(date.length === 13) {\n // YYMMDDHHMMSSZ (13 chars for UTCTime)\n date = asn1.utcTimeToDate(date);\n } else {\n // assume generalized time\n date = asn1.generalizedTimeToDate(date);\n }\n }\n\n if(date >= jan_1_1950 && date < jan_1_2050) {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n }\n\n // TODO: expose as common API call\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n value\n ])\n ]);\n}\n\n/**\n * Map messages encrypted content to ASN.1 objects.\n *\n * @param ec The encryptedContent object of the message.\n *\n * @return ASN.1 representation of the encryptedContent object (SEQUENCE).\n */\nfunction _encryptedContentToAsn1(ec) {\n return [\n // ContentType, always Data for the moment\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes()),\n // ContentEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ec.algorithm).getBytes()),\n // Parameters (IV)\n !ec.parameter ?\n undefined :\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.parameter.getBytes())\n ]),\n // [0] EncryptedContent\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.content.getBytes())\n ])\n ];\n}\n\n/**\n * Reads the \"common part\" of an PKCS#7 content block (in ASN.1 format)\n *\n * This function reads the \"common part\" of the PKCS#7 content blocks\n * EncryptedData and EnvelopedData, i.e. version number and symmetrically\n * encrypted content block.\n *\n * The result of the ASN.1 validate and capture process is returned\n * to allow the caller to extract further data, e.g. the list of recipients\n * in case of a EnvelopedData object.\n *\n * @param msg the PKCS#7 object to read the data to.\n * @param obj the ASN.1 representation of the content block.\n * @param validator the ASN.1 structure validator object to use.\n *\n * @return the value map captured by validator object.\n */\nfunction _fromAsn1(msg, obj, validator) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, validator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not a supported PKCS#7 message.');\n error.errors = error;\n throw error;\n }\n\n // Check contentType, so far we only support (raw) Data.\n var contentType = asn1.derToOid(capture.contentType);\n if(contentType !== forge.pki.oids.data) {\n throw new Error('Unsupported PKCS#7 message. ' +\n 'Only wrapped ContentType Data supported.');\n }\n\n if(capture.encryptedContent) {\n var content = '';\n if(forge.util.isArray(capture.encryptedContent)) {\n for(var i = 0; i < capture.encryptedContent.length; ++i) {\n if(capture.encryptedContent[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting encrypted ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.encryptedContent[i].value;\n }\n } else {\n content = capture.encryptedContent;\n }\n msg.encryptedContent = {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: forge.util.createBuffer(capture.encParameter.value),\n content: forge.util.createBuffer(content)\n };\n }\n\n if(capture.content) {\n var content = '';\n if(forge.util.isArray(capture.content)) {\n for(var i = 0; i < capture.content.length; ++i) {\n if(capture.content[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.content[i].value;\n }\n } else {\n content = capture.content;\n }\n msg.content = forge.util.createBuffer(content);\n }\n\n msg.version = capture.version.charCodeAt(0);\n msg.rawCapture = capture;\n\n return capture;\n}\n\n/**\n * Decrypt the symmetrically encrypted content block of the PKCS#7 message.\n *\n * Decryption is skipped in case the PKCS#7 message object already has a\n * (decrypted) content attribute. The algorithm, key and cipher parameters\n * (probably the iv) are taken from the encryptedContent attribute of the\n * message object.\n *\n * @param The PKCS#7 message object.\n */\nfunction _decryptContent(msg) {\n if(msg.encryptedContent.key === undefined) {\n throw new Error('Symmetric key not available.');\n }\n\n if(msg.content === undefined) {\n var ciph;\n\n switch(msg.encryptedContent.algorithm) {\n case forge.pki.oids['aes128-CBC']:\n case forge.pki.oids['aes192-CBC']:\n case forge.pki.oids['aes256-CBC']:\n ciph = forge.aes.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n case forge.pki.oids['desCBC']:\n case forge.pki.oids['des-EDE3-CBC']:\n ciph = forge.des.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' +\n msg.encryptedContent.algorithm);\n }\n ciph.start(msg.encryptedContent.parameter);\n ciph.update(msg.encryptedContent.content);\n\n if(!ciph.finish()) {\n throw new Error('Symmetric decryption failed.');\n }\n\n msg.content = ciph.output;\n }\n}\n"],"names":["forge","require$$0","require$$1","require$$2","require$$3","require$$4","require$$5","require$$6","require$$7","require$$8","require$$9","asn1","p7","pkcs7Module","exports","pkcs7","messageFromPem","pem","msg","decode","type","error","Error","headerType","procType","obj","fromDer","body","messageFromAsn1","messageToPem","maxline","pemObj","toDer","toAsn1","getBytes","encode","capture","errors","validate","contentInfoValidator","contentType","derToOid","pki","oids","envelopedData","createEnvelopedData","encryptedData","createEncryptedData","signedData","createSignedData","fromAsn1","content","value","version","certificates","crls","signers","digestAlgorithmIdentifiers","contentInfo","signerInfos","_fromAsn1","signedDataValidator","rawCapture","certs","i","length","push","certificateFromAsn1","sign","certificateToAsn1","create","Class","CONTEXT_SPECIFIC","UNIVERSAL","Type","SEQUENCE","INTEGER","integerToDer","SET","OID","oidToDer","addSigner","signer","issuer","serialNumber","certificate","cert","certificateFromPem","attributes","key","privateKeyFromPem","digestAlgorithm","sha1","sha256","sha384","sha512","md5","authenticatedAttributes","messageDigest","attr","signatureAlgorithm","rsaEncryption","signature","unauthenticatedAttributes","options","data","util","ByteBuffer","bytes","encodeUtf8","detached","detachedContent","OCTETSTRING","mds","addDigestAlgorithmIds","addSignerInfos","verify","addCertificate","addCertificateRevokationList","crl","oid","md","NULL","getByte","getBerValueLength","start","update","signingTime","Date","authenticatedAttributesAsn1","attrsAsn1","ai","digest","_attributeToAsn1","_signersToAsn1","encryptedContent","algorithm","encryptedDataValidator","decrypt","undefined","_decryptContent","recipients","envelopedDataValidator","_recipientsFromAsn1","recipientInfos","_recipientsToAsn1","_encryptedContentToAsn1","findRecipient","sAttr","r","rAttr","match","j","recipient","privKey","desCBC","createBuffer","addRecipient","publicKey","encrypt","cipher","keyLen","ivLen","ciphFn","aes","createEncryptionCipher","des","random","parameter","ciph","copy","finish","output","_recipientFromAsn1","recipientInfoValidator","charCodeAt","RDNAttributesAsArray","serial","toHex","encAlgorithm","encParameter","encKey","_recipientToAsn1","distinguishedNameToAsn1","hexToBytes","infos","ret","_signerToAsn1","rval","values","jan_1_1950","jan_1_2050","date","timestamp","parse","isNaN","utcTimeToDate","generalizedTimeToDate","UTCTIME","dateToUtcTime","GENERALIZEDTIME","dateToGeneralizedTime","ec","validator","isArray","createDecryptionCipher"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkBA,EAAA,IAAIA,KAAK,GAAGC,YAAA,EAAkB;AAC9BC,EAAAA,UAAA,EAAgB;AAChBC,EAAAA,WAAA,EAAiB;AACjBC,EAAAA,UAAA,EAAgB;AAChBC,EAAAA,WAAA,EAAiB;AACjBC,EAAAA,UAAA,EAAgB;AAChBC,EAAAA,gBAAA,EAAsB;AACtBC,EAAAA,aAAA,EAAmB;AACnBC,EAAAA,WAAA,EAAiB;AACjBC,EAAAA,WAAA,EAAiB;;AAEjB;AACA,EAAA,IAAIC,IAAI,GAAGX,KAAK,CAACW,IAAI;;AAErB;AACA,EAAA,IAAIC,EAAE,GAAGC,KAAA,CAAAC,OAAc,GAAGd,KAAK,CAACe,KAAK,GAAGf,KAAK,CAACe,KAAK,IAAI,EAAE;;AAEzD;AACA;AACA;AACA;AACA;AACA;AACA;AACAH,EAAAA,EAAE,CAACI,cAAc,GAAG,UAASC,GAAG,EAAE;AAChC,IAAA,IAAIC,GAAG,GAAGlB,KAAK,CAACiB,GAAG,CAACE,MAAM,CAACF,GAAG,CAAC,CAAC,CAAC,CAAC;AAElC,IAAA,IAAGC,GAAG,CAACE,IAAI,KAAK,OAAO,EAAE;MACvB,IAAIC,KAAK,GAAG,IAAIC,KAAK,CAAC,iDAAiD,GACrE,8BAA8B,CAAC;AACjCD,MAAAA,KAAK,CAACE,UAAU,GAAGL,GAAG,CAACE,IAAI;AAC3B,MAAA,MAAMC,KAAK;AACf,IAAA;IACE,IAAGH,GAAG,CAACM,QAAQ,IAAIN,GAAG,CAACM,QAAQ,CAACJ,IAAI,KAAK,WAAW,EAAE;AACpD,MAAA,MAAM,IAAIE,KAAK,CAAC,8DAA8D,CAAC;AACnF,IAAA;;AAEA;IACE,IAAIG,GAAG,GAAGd,IAAI,CAACe,OAAO,CAACR,GAAG,CAACS,IAAI,CAAC;AAEhC,IAAA,OAAOf,EAAE,CAACgB,eAAe,CAACH,GAAG,CAAC;EAChC,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACAb,EAAAA,EAAE,CAACiB,YAAY,GAAG,UAASX,GAAG,EAAEY,OAAO,EAAE;AACzC;AACE,IAAA,IAAIC,MAAM,GAAG;AACXX,MAAAA,IAAI,EAAE,OAAO;AACbO,MAAAA,IAAI,EAAEhB,IAAI,CAACqB,KAAK,CAACd,GAAG,CAACe,MAAM,EAAE,CAAC,CAACC,QAAQ;KACxC;AACD,IAAA,OAAOlC,KAAK,CAACiB,GAAG,CAACkB,MAAM,CAACJ,MAAM,EAAE;AAACD,MAAAA,OAAO,EAAEA;AAAO,KAAC,CAAC;EACrD,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACAlB,EAAAA,EAAE,CAACgB,eAAe,GAAG,UAASH,GAAG,EAAE;AACnC;IACE,IAAIW,OAAO,GAAG,EAAE;IAChB,IAAIC,MAAM,GAAG,EAAE;AACf,IAAA,IAAG,CAAC1B,IAAI,CAAC2B,QAAQ,CAACb,GAAG,EAAEb,EAAE,CAACD,IAAI,CAAC4B,oBAAoB,EAAEH,OAAO,EAAEC,MAAM,CAAC,EAAE;MACrE,IAAIhB,KAAK,GAAG,IAAIC,KAAK,CAAC,8BAA8B,GAClD,4CAA4C,CAAC;MAC/CD,KAAK,CAACgB,MAAM,GAAGA,MAAM;AACrB,MAAA,MAAMhB,KAAK;AACf,IAAA;IAEE,IAAImB,WAAW,GAAG7B,IAAI,CAAC8B,QAAQ,CAACL,OAAO,CAACI,WAAW,CAAC;AACpD,IAAA,IAAItB,GAAG;AAEP,IAAA,QAAOsB,WAAW;AAChB,MAAA,KAAKxC,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACC,aAAa;AAC/B1B,QAAAA,GAAG,GAAGN,EAAE,CAACiC,mBAAmB,EAAE;AAC9B,QAAA;AAEF,MAAA,KAAK7C,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACG,aAAa;AAC/B5B,QAAAA,GAAG,GAAGN,EAAE,CAACmC,mBAAmB,EAAE;AAC9B,QAAA;AAEF,MAAA,KAAK/C,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACK,UAAU;AAC5B9B,QAAAA,GAAG,GAAGN,EAAE,CAACqC,gBAAgB,EAAE;AAC3B,QAAA;AAEF,MAAA;QACE,MAAM,IAAI3B,KAAK,CAAC,mDAAmD,GACjEkB,WAAW,GAAG,0BAA0B,CAAC;AACjD;IAEEtB,GAAG,CAACgC,QAAQ,CAACd,OAAO,CAACe,OAAO,CAACC,KAAK,CAAC,CAAC,CAAC,CAAC;AACtC,IAAA,OAAOlC,GAAG;EACZ,CAAC;EAEDN,EAAE,CAACqC,gBAAgB,GAAG,YAAW;IAC/B,IAAI/B,GAAG,GAAG,IAAI;AACdA,IAAAA,GAAG,GAAG;AACJE,MAAAA,IAAI,EAAEpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACK,UAAU;AAC/BK,MAAAA,OAAO,EAAE,CAAC;AACVC,MAAAA,YAAY,EAAE,EAAE;AAChBC,MAAAA,IAAI,EAAE,EAAE;AACZ;AACIC,MAAAA,OAAO,EAAE,EAAE;AACf;AACIC,MAAAA,0BAA0B,EAAE,EAAE;AAC9BC,MAAAA,WAAW,EAAE,IAAI;AACjBC,MAAAA,WAAW,EAAE,EAAE;AAEfT,MAAAA,QAAQ,EAAE,UAASzB,GAAG,EAAE;AAC5B;QACMmC,SAAS,CAAC1C,GAAG,EAAEO,GAAG,EAAEb,EAAE,CAACD,IAAI,CAACkD,mBAAmB,CAAC;QAChD3C,GAAG,CAACoC,YAAY,GAAG,EAAE;QACrBpC,GAAG,CAACqC,IAAI,GAAG,EAAE;QACbrC,GAAG,CAACuC,0BAA0B,GAAG,EAAE;QACnCvC,GAAG,CAACwC,WAAW,GAAG,IAAI;QACtBxC,GAAG,CAACyC,WAAW,GAAG,EAAE;AAEpB,QAAA,IAAGzC,GAAG,CAAC4C,UAAU,CAACR,YAAY,EAAE;UAC9B,IAAIS,KAAK,GAAG7C,GAAG,CAAC4C,UAAU,CAACR,YAAY,CAACF,KAAK;AAC7C,UAAA,KAAI,IAAIY,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGD,KAAK,CAACE,MAAM,EAAE,EAAED,CAAC,EAAE;AACpC9C,YAAAA,GAAG,CAACoC,YAAY,CAACY,IAAI,CAAClE,KAAK,CAAC0C,GAAG,CAACyB,mBAAmB,CAACJ,KAAK,CAACC,CAAC,CAAC,CAAC,CAAC;AACxE,UAAA;AACA,QAAA;;AAEA;MACA,CAAK;MAED/B,MAAM,EAAE,YAAW;AACvB;AACM,QAAA,IAAG,CAACf,GAAG,CAACwC,WAAW,EAAE;UACnBxC,GAAG,CAACkD,IAAI,EAAE;AAClB,QAAA;QAEM,IAAIL,KAAK,GAAG,EAAE;AACd,QAAA,KAAI,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG9C,GAAG,CAACoC,YAAY,CAACW,MAAM,EAAE,EAAED,CAAC,EAAE;AAC/CD,UAAAA,KAAK,CAACG,IAAI,CAAClE,KAAK,CAAC0C,GAAG,CAAC2B,iBAAiB,CAACnD,GAAG,CAACoC,YAAY,CAACU,CAAC,CAAC,CAAC,CAAC;AACpE,QAAA;QAEM,IAAIT,IAAI,GAAG,EAAE;AACnB;;AAEA;AACM,QAAA,IAAIP,UAAU,GAAGrC,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,CACjE7D,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACpE;AACUhE,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxDjE,IAAI,CAACkE,YAAY,CAAC3D,GAAG,CAACmC,OAAO,CAAC,CAACnB,QAAQ,EAAE,CAAC;AACtD;QACUvB,IAAI,CAAC2D,MAAM,CACT3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACI,GAAG,EAAE,IAAI,EACzC5D,GAAG,CAACuC,0BAA0B,CAAC;AAC3C;AACUvC,QAAAA,GAAG,CAACwC,WAAA,CACL,CAAA,CACF,CAAC;AACF,QAAA,IAAGK,KAAK,CAACE,MAAM,GAAG,CAAC,EAAE;AAC3B;UACQjB,UAAU,CAACI,KAAK,CAAC,CAAC,CAAC,CAACA,KAAK,CAACc,IAAI,CAC5BvD,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAET,KAAK,CAAC,CAAC;AACnE,QAAA;AACM,QAAA,IAAGR,IAAI,CAACU,MAAM,GAAG,CAAC,EAAE;AAC1B;UACQjB,UAAU,CAACI,KAAK,CAAC,CAAC,CAAC,CAACA,KAAK,CAACc,IAAI,CAC5BvD,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAEjB,IAAI,CAAC,CAAC;AAClE,QAAA;AACA;AACMP,QAAAA,UAAU,CAACI,KAAK,CAAC,CAAC,CAAC,CAACA,KAAK,CAACc,IAAI,CAC5BvD,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACI,GAAG,EAAE,IAAI,EACnD5D,GAAG,CAACyC,WAAW,CAAC,CAAC;;AAE3B;AACM,QAAA,OAAOhD,IAAI,CAAC2D,MAAM,CAChB3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACxD;AACUhE,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAAC9D,GAAG,CAACE,IAAI,CAAC,CAACc,QAAQ,EAAE,CAAC;AAC/C;AACUc,QAAAA,UAAA,CACD,CAAC;MACV,CAAK;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACIiC,MAAAA,SAAS,EAAE,UAASC,MAAM,EAAE;AAC1B,QAAA,IAAIC,MAAM,GAAGD,MAAM,CAACC,MAAM;AAC1B,QAAA,IAAIC,YAAY,GAAGF,MAAM,CAACE,YAAY;QACtC,IAAGF,MAAM,CAACG,WAAW,EAAE;AACrB,UAAA,IAAIC,IAAI,GAAGJ,MAAM,CAACG,WAAW;AAC7B,UAAA,IAAG,OAAOC,IAAI,KAAK,QAAQ,EAAE;YAC3BA,IAAI,GAAGtF,KAAK,CAAC0C,GAAG,CAAC6C,kBAAkB,CAACD,IAAI,CAAC;AACnD,UAAA;AACQH,UAAAA,MAAM,GAAGG,IAAI,CAACH,MAAM,CAACK,UAAU;UAC/BJ,YAAY,GAAGE,IAAI,CAACF,YAAY;AACxC,QAAA;AACM,QAAA,IAAIK,GAAG,GAAGP,MAAM,CAACO,GAAG;QACpB,IAAG,CAACA,GAAG,EAAE;AACP,UAAA,MAAM,IAAInE,KAAK,CACb,wDAAwD,CAAC;AACnE,QAAA;AACM,QAAA,IAAG,OAAOmE,GAAG,KAAK,QAAQ,EAAE;UAC1BA,GAAG,GAAGzF,KAAK,CAAC0C,GAAG,CAACgD,iBAAiB,CAACD,GAAG,CAAC;AAC9C,QAAA;;AAEA;AACM,QAAA,IAAIE,eAAe,GAAGT,MAAM,CAACS,eAAe,IAAI3F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACiD,IAAI;AACnE,QAAA,QAAOD,eAAe;AACtB,UAAA,KAAK3F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACiD,IAAI;AACxB,UAAA,KAAK5F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACkD,MAAM;AAC1B,UAAA,KAAK7F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACmD,MAAM;AAC1B,UAAA,KAAK9F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACoD,MAAM;AAC1B,UAAA,KAAK/F,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACqD,GAAG;AACrB,YAAA;AACF,UAAA;AACE,YAAA,MAAM,IAAI1E,KAAK,CACb,iEAAiE,GACjEqE,eAAe,CAAC;AAC1B;;AAEA;AACA;AACM,QAAA,IAAIM,uBAAuB,GAAGf,MAAM,CAACe,uBAAuB,IAAI,EAAE;AAClE,QAAA,IAAGA,uBAAuB,CAAChC,MAAM,GAAG,CAAC,EAAE;UACrC,IAAIzB,WAAW,GAAG,KAAK;UACvB,IAAI0D,aAAa,GAAG,KAAK;AACzB,UAAA,KAAI,IAAIlC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGiC,uBAAuB,CAAChC,MAAM,EAAE,EAAED,CAAC,EAAE;AACtD,YAAA,IAAImC,IAAI,GAAGF,uBAAuB,CAACjC,CAAC,CAAC;AACrC,YAAA,IAAG,CAACxB,WAAW,IAAI2D,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACH,WAAW,EAAE;AAC3DA,cAAAA,WAAW,GAAG,IAAI;AAClB,cAAA,IAAG0D,aAAa,EAAE;AAChB,gBAAA;AACd,cAAA;AACY,cAAA;AACZ,YAAA;AACU,YAAA,IAAG,CAACA,aAAa,IAAIC,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACuD,aAAa,EAAE;AAC/DA,cAAAA,aAAa,GAAG,IAAI;AACpB,cAAA,IAAG1D,WAAW,EAAE;AACd,gBAAA;AACd,cAAA;AACY,cAAA;AACZ,YAAA;AACA,UAAA;AAEQ,UAAA,IAAG,CAACA,WAAW,IAAI,CAAC0D,aAAa,EAAE;YACjC,MAAM,IAAI5E,KAAK,CAAC,6CAA6C,GAC3D,4DAA4D,GAC5D,4DAA4D,GAC5D,yBAAyB,CAAC;AACtC,UAAA;AACA,QAAA;AAEMJ,QAAAA,GAAG,CAACsC,OAAO,CAACU,IAAI,CAAC;AACfuB,UAAAA,GAAG,EAAEA,GAAG;AACRpC,UAAAA,OAAO,EAAE,CAAC;AACV8B,UAAAA,MAAM,EAAEA,MAAM;AACdC,UAAAA,YAAY,EAAEA,YAAY;AAC1BO,UAAAA,eAAe,EAAEA,eAAe;AAChCS,UAAAA,kBAAkB,EAAEpG,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC0D,aAAa;AAChDC,UAAAA,SAAS,EAAE,IAAI;AACfL,UAAAA,uBAAuB,EAAEA,uBAAuB;AAChDM,UAAAA,yBAAyB,EAAE;AACnC,SAAO,CAAC;MACR,CAAK;AAEL;AACA;AACA;AACA;AACA;AACInC,MAAAA,IAAI,EAAE,UAASoC,OAAO,EAAE;AACtBA,QAAAA,OAAO,GAAGA,OAAO,IAAI,EAAE;AAC7B;AACM,QAAA,IAAG,OAAOtF,GAAG,CAACiC,OAAO,KAAK,QAAQ,IAAIjC,GAAG,CAACwC,WAAW,KAAK,IAAI,EAAE;AACtE;UACQxC,GAAG,CAACwC,WAAW,GAAG/C,IAAI,CAAC2D,MAAM,CAC3B3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAC1D;AACYhE,UAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAAChF,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC8D,IAAI,CAAC,CAACvE,QAAQ,EAAE,CAAA,CAChD,CAAC;;AAEZ;UACQ,IAAG,SAAS,IAAIhB,GAAG,EAAE;AACnB,YAAA,IAAIiC,OAAO;YACX,IAAGjC,GAAG,CAACiC,OAAO,YAAYnD,KAAK,CAAC0G,IAAI,CAACC,UAAU,EAAE;AAC/CxD,cAAAA,OAAO,GAAGjC,GAAG,CAACiC,OAAO,CAACyD,KAAK,EAAE;YACzC,CAAW,MAAM,IAAG,OAAO1F,GAAG,CAACiC,OAAO,KAAK,QAAQ,EAAE;cACzCA,OAAO,GAAGnD,KAAK,CAAC0G,IAAI,CAACG,UAAU,CAAC3F,GAAG,CAACiC,OAAO,CAAC;AACxD,YAAA;YAEU,IAAIqD,OAAO,CAACM,QAAQ,EAAE;cACpB5F,GAAG,CAAC6F,eAAe,GAAGpG,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAAE7D,OAAO,CAAC;AAC1G,YAAA,CAAW,MAAM;AACLjC,cAAAA,GAAG,CAACwC,WAAW,CAACN,KAAK,CAACc,IAAI;AACtC;AACcvD,cAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,CAChD7D,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAC5D7D,OAAO,CAAA,CACV,CAAC,CAAC;AACjB,YAAA;AACA,UAAA;AACA,QAAA;;AAEA;AACM,QAAA,IAAGjC,GAAG,CAACsC,OAAO,CAACS,MAAM,KAAK,CAAC,EAAE;AAC3B,UAAA;AACR,QAAA;;AAEA;AACM,QAAA,IAAIgD,GAAG,GAAGC,qBAAqB,EAAE;;AAEvC;QACMC,cAAc,CAACF,GAAG,CAAC;MACzB,CAAK;MAEDG,MAAM,EAAE,YAAW;AACjB,QAAA,MAAM,IAAI9F,KAAK,CAAC,oDAAoD,CAAC;MAC3E,CAAK;AAEL;AACA;AACA;AACA;AACA;AACI+F,MAAAA,cAAc,EAAE,UAAS/B,IAAI,EAAE;AACnC;AACM,QAAA,IAAG,OAAOA,IAAI,KAAK,QAAQ,EAAE;UAC3BA,IAAI,GAAGtF,KAAK,CAAC0C,GAAG,CAAC6C,kBAAkB,CAACD,IAAI,CAAC;AACjD,QAAA;AACMpE,QAAAA,GAAG,CAACoC,YAAY,CAACY,IAAI,CAACoB,IAAI,CAAC;MACjC,CAAK;AAEL;AACA;AACA;AACA;AACA;AACIgC,MAAAA,4BAA4B,EAAE,UAASC,GAAG,EAAE;AAC1C,QAAA,MAAM,IAAIjG,KAAK,CAAC,yCAAyC,CAAC;AAChE,MAAA;KACG;AACD,IAAA,OAAOJ,GAAG;IAEV,SAASgG,qBAAqBA,GAAG;MAC/B,IAAID,GAAG,GAAG,EAAE;AAEZ,MAAA,KAAI,IAAIjD,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG9C,GAAG,CAACsC,OAAO,CAACS,MAAM,EAAE,EAAED,CAAC,EAAE;AAC1C,QAAA,IAAIkB,MAAM,GAAGhE,GAAG,CAACsC,OAAO,CAACQ,CAAC,CAAC;AAC3B,QAAA,IAAIwD,GAAG,GAAGtC,MAAM,CAACS,eAAe;AAChC,QAAA,IAAG,EAAE6B,GAAG,IAAIP,GAAG,CAAC,EAAE;AACxB;UACQA,GAAG,CAACO,GAAG,CAAC,GAAGxH,KAAK,CAACyH,EAAE,CAACzH,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC6E,GAAG,CAAC,CAAC,CAAClD,MAAM,EAAE;AACzD,QAAA;AACM,QAAA,IAAGY,MAAM,CAACe,uBAAuB,CAAChC,MAAM,KAAK,CAAC,EAAE;AACtD;AACQiB,UAAAA,MAAM,CAACuC,EAAE,GAAGR,GAAG,CAACO,GAAG,CAAC;AAC5B,QAAA,CAAO,MAAM;AACb;AACA;AACA;AACQtC,UAAAA,MAAM,CAACuC,EAAE,GAAGzH,KAAK,CAACyH,EAAE,CAACzH,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC6E,GAAG,CAAC,CAAC,CAAClD,MAAM,EAAE;AAC1D,QAAA;AACA,MAAA;;AAEA;MACIpD,GAAG,CAACuC,0BAA0B,GAAG,EAAE;AACnC,MAAA,KAAI,IAAI+D,GAAG,IAAIP,GAAG,EAAE;QAClB/F,GAAG,CAACuC,0BAA0B,CAACS,IAAI;AACzC;AACQvD,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACpE;QACUhE,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAACwC,GAAG,CAAC,CAACtF,QAAQ,EAAE,CAAC;AAC1C;QACUvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACgD,IAAI,EAAE,KAAK,EAAE,EAAE,CAAA,CAC5D,CAAC,CAAC;AACX,MAAA;AAEI,MAAA,OAAOT,GAAG;AACd,IAAA;IAEE,SAASE,cAAcA,CAACF,GAAG,EAAE;AAC3B,MAAA,IAAI9D,OAAO;MAEX,IAAIjC,GAAG,CAAC6F,eAAe,EAAE;AAC7B;QACM5D,OAAO,GAAGjC,GAAG,CAAC6F,eAAe;AACnC,MAAA,CAAK,MAAM;AACX;AACA;AACA;AACA;QACM5D,OAAO,GAAGjC,GAAG,CAACwC,WAAW,CAACN,KAAK,CAAC,CAAC,CAAC;AACxC;AACMD,QAAAA,OAAO,GAAGA,OAAO,CAACC,KAAK,CAAC,CAAC,CAAC;AAChC,MAAA;MAEI,IAAG,CAACD,OAAO,EAAE;AACX,QAAA,MAAM,IAAI7B,KAAK,CACb,6DAA6D,CAAC;AACtE,MAAA;;AAEA;AACI,MAAA,IAAIkB,WAAW,GAAG7B,IAAI,CAAC8B,QAAQ,CAACvB,GAAG,CAACwC,WAAW,CAACN,KAAK,CAAC,CAAC,CAAC,CAACA,KAAK,CAAC;;AAEnE;AACI,MAAA,IAAIwD,KAAK,GAAGjG,IAAI,CAACqB,KAAK,CAACmB,OAAO,CAAC;;AAEnC;AACA;MACIyD,KAAK,CAACe,OAAO,EAAE;AACnB;AACIhH,MAAAA,IAAI,CAACiH,iBAAiB,CAAChB,KAAK,CAAC;AAC7BA,MAAAA,KAAK,GAAGA,KAAK,CAAC1E,QAAQ,EAAE;;AAE5B;AACI,MAAA,KAAI,IAAIsF,GAAG,IAAIP,GAAG,EAAE;QAClBA,GAAG,CAACO,GAAG,CAAC,CAACK,KAAK,EAAE,CAACC,MAAM,CAAClB,KAAK,CAAC;AACpC,MAAA;;AAEA;AACI,MAAA,IAAImB,WAAW,GAAG,IAAIC,IAAI,EAAE;AAC5B,MAAA,KAAI,IAAIhE,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG9C,GAAG,CAACsC,OAAO,CAACS,MAAM,EAAE,EAAED,CAAC,EAAE;AAC1C,QAAA,IAAIkB,MAAM,GAAGhE,GAAG,CAACsC,OAAO,CAACQ,CAAC,CAAC;AAE3B,QAAA,IAAGkB,MAAM,CAACe,uBAAuB,CAAChC,MAAM,KAAK,CAAC,EAAE;AACtD;AACA;UACQ,IAAGzB,WAAW,KAAKxC,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC8D,IAAI,EAAE;AACtC,YAAA,MAAM,IAAInF,KAAK,CACb,0DAA0D,GAC1D,uDAAuD,CAAC;AACpE,UAAA;AACA,QAAA,CAAO,MAAM;AACb;AACA;AACQ4D,UAAAA,MAAM,CAAC+C,2BAA2B,GAAGtH,IAAI,CAAC2D,MAAM,CAC9C3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC;;AAEnD;AACA;UACQ,IAAI0D,SAAS,GAAGvH,IAAI,CAAC2D,MAAM,CACzB3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACI,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC;AAEhD,UAAA,KAAI,IAAIqD,EAAE,GAAG,CAAC,EAAEA,EAAE,GAAGjD,MAAM,CAACe,uBAAuB,CAAChC,MAAM,EAAE,EAAEkE,EAAE,EAAE;AAChE,YAAA,IAAIhC,IAAI,GAAGjB,MAAM,CAACe,uBAAuB,CAACkC,EAAE,CAAC;YAC7C,IAAGhC,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACuD,aAAa,EAAE;AACzD;AACYC,cAAAA,IAAI,CAAC/C,KAAK,GAAG6D,GAAG,CAAC/B,MAAM,CAACS,eAAe,CAAC,CAACyC,MAAM,EAAE;AAC7D,YAAA,CAAW,MAAM,IAAGjC,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACoF,WAAW,EAAE;AAC9D;AACY,cAAA,IAAG,CAAC5B,IAAI,CAAC/C,KAAK,EAAE;gBACd+C,IAAI,CAAC/C,KAAK,GAAG2E,WAAW;AACtC,cAAA;AACA,YAAA;;AAEA;AACA;AACA;YACUG,SAAS,CAAC9E,KAAK,CAACc,IAAI,CAACmE,gBAAgB,CAAClC,IAAI,CAAC,CAAC;YAC5CjB,MAAM,CAAC+C,2BAA2B,CAAC7E,KAAK,CAACc,IAAI,CAACmE,gBAAgB,CAAClC,IAAI,CAAC,CAAC;AAC/E,UAAA;;AAEA;UACQS,KAAK,GAAGjG,IAAI,CAACqB,KAAK,CAACkG,SAAS,CAAC,CAAChG,QAAQ,EAAE;UACxCgD,MAAM,CAACuC,EAAE,CAACI,KAAK,EAAE,CAACC,MAAM,CAAClB,KAAK,CAAC;AACvC,QAAA;;AAEA;AACM1B,QAAAA,MAAM,CAACoB,SAAS,GAAGpB,MAAM,CAACO,GAAG,CAACrB,IAAI,CAACc,MAAM,CAACuC,EAAE,EAAE,mBAAmB,CAAC;AACxE,MAAA;;AAEA;MACIvG,GAAG,CAACyC,WAAW,GAAG2E,cAAc,CAACpH,GAAG,CAACsC,OAAO,CAAC;AACjD,IAAA;EACA,CAAC;;AAED;AACA;AACA;AACA;AACA;EACA5C,EAAE,CAACmC,mBAAmB,GAAG,YAAW;IAClC,IAAI7B,GAAG,GAAG,IAAI;AACdA,IAAAA,GAAG,GAAG;AACJE,MAAAA,IAAI,EAAEpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACG,aAAa;AAClCO,MAAAA,OAAO,EAAE,CAAC;AACVkF,MAAAA,gBAAgB,EAAE;AAChBC,QAAAA,SAAS,EAAExI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY;OACvC;AAEL;AACA;AACA;AACA;AACA;AACIO,MAAAA,QAAQ,EAAE,UAASzB,GAAG,EAAE;AAC5B;QACMmC,SAAS,CAAC1C,GAAG,EAAEO,GAAG,EAAEb,EAAE,CAACD,IAAI,CAAC8H,sBAAsB,CAAC;MACzD,CAAK;AAEL;AACA;AACA;AACA;AACA;AACIC,MAAAA,OAAO,EAAE,UAASjD,GAAG,EAAE;QACrB,IAAGA,GAAG,KAAKkD,SAAS,EAAE;AACpBzH,UAAAA,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,GAAGA,GAAG;AACtC,QAAA;QACMmD,eAAe,CAAC1H,GAAG,CAAC;AAC1B,MAAA;KACG;AACD,IAAA,OAAOA,GAAG;EACZ,CAAC;;AAED;AACA;AACA;AACA;AACA;EACAN,EAAE,CAACiC,mBAAmB,GAAG,YAAW;IAClC,IAAI3B,GAAG,GAAG,IAAI;AACdA,IAAAA,GAAG,GAAG;AACJE,MAAAA,IAAI,EAAEpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACC,aAAa;AAClCS,MAAAA,OAAO,EAAE,CAAC;AACVwF,MAAAA,UAAU,EAAE,EAAE;AACdN,MAAAA,gBAAgB,EAAE;AAChBC,QAAAA,SAAS,EAAExI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY;OACvC;AAEL;AACA;AACA;AACA;AACA;AACIO,MAAAA,QAAQ,EAAE,UAASzB,GAAG,EAAE;AAC5B;AACM,QAAA,IAAIW,OAAO,GAAGwB,SAAS,CAAC1C,GAAG,EAAEO,GAAG,EAAEb,EAAE,CAACD,IAAI,CAACmI,sBAAsB,CAAC;QACjE5H,GAAG,CAAC2H,UAAU,GAAGE,mBAAmB,CAAC3G,OAAO,CAAC4G,cAAc,CAAC5F,KAAK,CAAC;MACxE,CAAK;MAEDnB,MAAM,EAAE,YAAW;AACvB;AACM,QAAA,OAAOtB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACzE;AACQhE,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAAC9D,GAAG,CAACE,IAAI,CAAC,CAACc,QAAQ,EAAE,CAAC;AAC7C;AACQvB,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,CAChD7D,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACtE;AACYhE,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxDjE,IAAI,CAACkE,YAAY,CAAC3D,GAAG,CAACmC,OAAO,CAAC,CAACnB,QAAQ,EAAE,CAAC;AACxD;QACYvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACI,GAAG,EAAE,IAAI,EACnDmE,iBAAiB,CAAC/H,GAAG,CAAC2H,UAAU,CAAC,CAAC;AAChD;AACYlI,QAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EACxDuE,uBAAuB,CAAChI,GAAG,CAACqH,gBAAgB,CAAC,CAAA,CAChD,CAAA,CACF,CAAA,CACF,CAAC;MACR,CAAK;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACIY,MAAAA,aAAa,EAAE,UAAS7D,IAAI,EAAE;AAC5B,QAAA,IAAI8D,KAAK,GAAG9D,IAAI,CAACH,MAAM,CAACK,UAAU;AAElC,QAAA,KAAI,IAAIxB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG9C,GAAG,CAAC2H,UAAU,CAAC5E,MAAM,EAAE,EAAED,CAAC,EAAE;AAC7C,UAAA,IAAIqF,CAAC,GAAGnI,GAAG,CAAC2H,UAAU,CAAC7E,CAAC,CAAC;AACzB,UAAA,IAAIsF,KAAK,GAAGD,CAAC,CAAClE,MAAM;AAEpB,UAAA,IAAGkE,CAAC,CAACjE,YAAY,KAAKE,IAAI,CAACF,YAAY,EAAE;AACvC,YAAA;AACV,UAAA;AAEQ,UAAA,IAAGkE,KAAK,CAACrF,MAAM,KAAKmF,KAAK,CAACnF,MAAM,EAAE;AAChC,YAAA;AACV,UAAA;UAEQ,IAAIsF,KAAK,GAAG,IAAI;AAChB,UAAA,KAAI,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGJ,KAAK,CAACnF,MAAM,EAAE,EAAEuF,CAAC,EAAE;YACpC,IAAGF,KAAK,CAACE,CAAC,CAAC,CAACpI,IAAI,KAAKgI,KAAK,CAACI,CAAC,CAAC,CAACpI,IAAI,IAChCkI,KAAK,CAACE,CAAC,CAAC,CAACpG,KAAK,KAAKgG,KAAK,CAACI,CAAC,CAAC,CAACpG,KAAK,EAAE;AACnCmG,cAAAA,KAAK,GAAG,KAAK;AACb,cAAA;AACZ,YAAA;AACA,UAAA;AAEQ,UAAA,IAAGA,KAAK,EAAE;AACR,YAAA,OAAOF,CAAC;AAClB,UAAA;AACA,QAAA;AAEM,QAAA,OAAO,IAAI;MACjB,CAAK;AAEL;AACA;AACA;AACA;AACA;AACA;AACIX,MAAAA,OAAO,EAAE,UAASe,SAAS,EAAEC,OAAO,EAAE;AACpC,QAAA,IAAGxI,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,KAAKkD,SAAS,IAAIc,SAAS,KAAKd,SAAS,IAClEe,OAAO,KAAKf,SAAS,EAAE;AACvB,UAAA,QAAOc,SAAS,CAAClB,gBAAgB,CAACC,SAAS;AACzC,YAAA,KAAKxI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC0D,aAAa;AACjC,YAAA,KAAKrG,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACgH,MAAM;cACxB,IAAIlE,GAAG,GAAGiE,OAAO,CAAChB,OAAO,CAACe,SAAS,CAAClB,gBAAgB,CAACpF,OAAO,CAAC;AAC7DjC,cAAAA,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,GAAGzF,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAACnE,GAAG,CAAC;AACvD,cAAA;AAEF,YAAA;AACE,cAAA,MAAM,IAAInE,KAAK,CAAC,iCAAiC,GAC/C,MAAM,GAAGmI,SAAS,CAAClB,gBAAgB,CAACC,SAAS,CAAC;AAC5D;AACA,QAAA;QAEMI,eAAe,CAAC1H,GAAG,CAAC;MAC1B,CAAK;AAEL;AACA;AACA;AACA;AACA;AACI2I,MAAAA,YAAY,EAAE,UAASvE,IAAI,EAAE;AAC3BpE,QAAAA,GAAG,CAAC2H,UAAU,CAAC3E,IAAI,CAAC;AAClBb,UAAAA,OAAO,EAAE,CAAC;AACV8B,UAAAA,MAAM,EAAEG,IAAI,CAACH,MAAM,CAACK,UAAU;UAC9BJ,YAAY,EAAEE,IAAI,CAACF,YAAY;AAC/BmD,UAAAA,gBAAgB,EAAE;AAC1B;AACA;AACA;AACUC,YAAAA,SAAS,EAAExI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC0D,aAAa;YACvCZ,GAAG,EAAEH,IAAI,CAACwE;AACpB;AACA,SAAO,CAAC;MACR,CAAK;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACIC,MAAAA,OAAO,EAAE,UAAStE,GAAG,EAAEuE,MAAM,EAAE;AACnC;AACM,QAAA,IAAG9I,GAAG,CAACqH,gBAAgB,CAACpF,OAAO,KAAKwF,SAAS,EAAE;AAC7CqB,UAAAA,MAAM,GAAGA,MAAM,IAAI9I,GAAG,CAACqH,gBAAgB,CAACC,SAAS;AACjD/C,UAAAA,GAAG,GAAGA,GAAG,IAAIvE,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG;AAErC,UAAA,IAAIwE,MAAM,EAAEC,KAAK,EAAEC,MAAM;AACzB,UAAA,QAAOH,MAAM;AACX,YAAA,KAAKhK,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AAC/BsH,cAAAA,MAAM,GAAG,EAAE;AACXC,cAAAA,KAAK,GAAG,EAAE;AACVC,cAAAA,MAAM,GAAGnK,KAAK,CAACoK,GAAG,CAACC,sBAAsB;AACzC,cAAA;AAEF,YAAA,KAAKrK,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AAC/BsH,cAAAA,MAAM,GAAG,EAAE;AACXC,cAAAA,KAAK,GAAG,EAAE;AACVC,cAAAA,MAAM,GAAGnK,KAAK,CAACoK,GAAG,CAACC,sBAAsB;AACzC,cAAA;AAEF,YAAA,KAAKrK,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AAC/BsH,cAAAA,MAAM,GAAG,EAAE;AACXC,cAAAA,KAAK,GAAG,EAAE;AACVC,cAAAA,MAAM,GAAGnK,KAAK,CAACoK,GAAG,CAACC,sBAAsB;AACzC,cAAA;AAEF,YAAA,KAAKrK,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,cAAc,CAAC;AACjCsH,cAAAA,MAAM,GAAG,EAAE;AACXC,cAAAA,KAAK,GAAG,CAAC;AACTC,cAAAA,MAAM,GAAGnK,KAAK,CAACsK,GAAG,CAACD,sBAAsB;AACzC,cAAA;AAEF,YAAA;AACE,cAAA,MAAM,IAAI/I,KAAK,CAAC,oCAAoC,GAAG0I,MAAM,CAAC;AAC1E;UAEQ,IAAGvE,GAAG,KAAKkD,SAAS,EAAE;AACpBlD,YAAAA,GAAG,GAAGzF,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAAC5J,KAAK,CAACuK,MAAM,CAACrI,QAAQ,CAAC+H,MAAM,CAAC,CAAC;UACtE,CAAS,MAAM,IAAGxE,GAAG,CAACxB,MAAM,EAAE,IAAIgG,MAAM,EAAE;AAChC,YAAA,MAAM,IAAI3I,KAAK,CAAC,kCAAkC,GAChD,MAAM,GAAGmE,GAAG,CAACxB,MAAM,EAAE,GAAG,mBAAmB,GAAGgG,MAAM,GAAG,GAAG,CAAC;AACvE,UAAA;;AAEA;AACA;AACQ/I,UAAAA,GAAG,CAACqH,gBAAgB,CAACC,SAAS,GAAGwB,MAAM;AACvC9I,UAAAA,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,GAAGA,GAAG;AAC9BvE,UAAAA,GAAG,CAACqH,gBAAgB,CAACiC,SAAS,GAAGxK,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CACtD5J,KAAK,CAACuK,MAAM,CAACrI,QAAQ,CAACgI,KAAK,CAAC,CAAC;AAE/B,UAAA,IAAIO,IAAI,GAAGN,MAAM,CAAC1E,GAAG,CAAC;AACtBgF,UAAAA,IAAI,CAAC5C,KAAK,CAAC3G,GAAG,CAACqH,gBAAgB,CAACiC,SAAS,CAACE,IAAI,EAAE,CAAC;AACjDD,UAAAA,IAAI,CAAC3C,MAAM,CAAC5G,GAAG,CAACiC,OAAO,CAAC;;AAEhC;AACA;AACQ,UAAA,IAAG,CAACsH,IAAI,CAACE,MAAM,EAAE,EAAE;AACjB,YAAA,MAAM,IAAIrJ,KAAK,CAAC,8BAA8B,CAAC;AACzD,UAAA;AAEQJ,UAAAA,GAAG,CAACqH,gBAAgB,CAACpF,OAAO,GAAGsH,IAAI,CAACG,MAAM;AAClD,QAAA;;AAEA;AACM,QAAA,KAAI,IAAI5G,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG9C,GAAG,CAAC2H,UAAU,CAAC5E,MAAM,EAAE,EAAED,CAAC,EAAE;AAC7C,UAAA,IAAIyF,SAAS,GAAGvI,GAAG,CAAC2H,UAAU,CAAC7E,CAAC,CAAC;;AAEzC;AACQ,UAAA,IAAGyF,SAAS,CAAClB,gBAAgB,CAACpF,OAAO,KAAKwF,SAAS,EAAE;AACnD,YAAA;AACV,UAAA;AAEQ,UAAA,QAAOc,SAAS,CAAClB,gBAAgB,CAACC,SAAS;AACzC,YAAA,KAAKxI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC0D,aAAa;cAC/BoD,SAAS,CAAClB,gBAAgB,CAACpF,OAAO,GAChCsG,SAAS,CAAClB,gBAAgB,CAAC9C,GAAG,CAACsE,OAAO,CACpC7I,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,CAACgB,IAAI,CAAC;AAClC,cAAA;AAEF,YAAA;cACE,MAAM,IAAInF,KAAK,CAAC,qCAAqC,GACnDmI,SAAS,CAAClB,gBAAgB,CAACC,SAAS,CAAC;AACnD;AACA,QAAA;AACA,MAAA;KACG;AACD,IAAA,OAAOtH,GAAG;EACZ,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAAS2J,kBAAkBA,CAACpJ,GAAG,EAAE;AACjC;IACE,IAAIW,OAAO,GAAG,EAAE;IAChB,IAAIC,MAAM,GAAG,EAAE;AACf,IAAA,IAAG,CAAC1B,IAAI,CAAC2B,QAAQ,CAACb,GAAG,EAAEb,EAAE,CAACD,IAAI,CAACmK,sBAAsB,EAAE1I,OAAO,EAAEC,MAAM,CAAC,EAAE;MACvE,IAAIhB,KAAK,GAAG,IAAIC,KAAK,CAAC,oCAAoC,GACxD,8CAA8C,CAAC;MACjDD,KAAK,CAACgB,MAAM,GAAGA,MAAM;AACrB,MAAA,MAAMhB,KAAK;AACf,IAAA;IAEE,OAAO;MACLgC,OAAO,EAAEjB,OAAO,CAACiB,OAAO,CAAC0H,UAAU,CAAC,CAAC,CAAC;MACtC5F,MAAM,EAAEnF,KAAK,CAAC0C,GAAG,CAACsI,oBAAoB,CAAC5I,OAAO,CAAC+C,MAAM,CAAC;AACtDC,MAAAA,YAAY,EAAEpF,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAACxH,OAAO,CAAC6I,MAAM,CAAC,CAACC,KAAK,EAAE;AAC7D3C,MAAAA,gBAAgB,EAAE;QAChBC,SAAS,EAAE7H,IAAI,CAAC8B,QAAQ,CAACL,OAAO,CAAC+I,YAAY,CAAC;QAC9CX,SAAS,EAAEpI,OAAO,CAACgJ,YAAY,GAAGhJ,OAAO,CAACgJ,YAAY,CAAChI,KAAK,GAAGuF,SAAS;QACxExF,OAAO,EAAEf,OAAO,CAACiJ;AACvB;KACG;AACH,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASC,gBAAgBA,CAAC7J,GAAG,EAAE;AAC7B,IAAA,OAAOd,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACrE;AACIhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxDjE,IAAI,CAACkE,YAAY,CAACpD,GAAG,CAAC4B,OAAO,CAAC,CAACnB,QAAQ,EAAE,CAAC;AAChD;AACIvB,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAChE;AACM3E,IAAAA,KAAK,CAAC0C,GAAG,CAAC6I,uBAAuB,CAAC;MAAC/F,UAAU,EAAE/D,GAAG,CAAC0D;AAAM,KAAC,CAAC;AACjE;AACMxE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxD5E,KAAK,CAAC0G,IAAI,CAAC8E,UAAU,CAAC/J,GAAG,CAAC2D,YAAY,CAAC,CAAA,CAC1C,CAAC;AACN;AACIzE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAChE;AACMhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAACvD,GAAG,CAAC8G,gBAAgB,CAACC,SAAS,CAAC,CAACtG,QAAQ,EAAE,CAAC;AACjE;IACMvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACgD,IAAI,EAAE,KAAK,EAAE,EAAE,CAAA,CAC5D,CAAC;AACN;IACI/G,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAC5DvF,GAAG,CAAC8G,gBAAgB,CAACpF,OAAO,CAAA,CAC/B,CAAC;AACJ,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAAS4F,mBAAmBA,CAAC0C,KAAK,EAAE;IAClC,IAAIC,GAAG,GAAG,EAAE;AACZ,IAAA,KAAI,IAAI1H,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGyH,KAAK,CAACxH,MAAM,EAAE,EAAED,CAAC,EAAE;MACpC0H,GAAG,CAACxH,IAAI,CAAC2G,kBAAkB,CAACY,KAAK,CAACzH,CAAC,CAAC,CAAC,CAAC;AAC1C,IAAA;AACE,IAAA,OAAO0H,GAAG;AACZ,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASzC,iBAAiBA,CAACJ,UAAU,EAAE;IACrC,IAAI6C,GAAG,GAAG,EAAE;AACZ,IAAA,KAAI,IAAI1H,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG6E,UAAU,CAAC5E,MAAM,EAAE,EAAED,CAAC,EAAE;MACzC0H,GAAG,CAACxH,IAAI,CAACoH,gBAAgB,CAACzC,UAAU,CAAC7E,CAAC,CAAC,CAAC,CAAC;AAC7C,IAAA;AACE,IAAA,OAAO0H,GAAG;AACZ,EAAA;;AAsCA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASC,aAAaA,CAAClK,GAAG,EAAE;AAC5B;AACE,IAAA,IAAImK,IAAI,GAAGjL,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACzE;AACIhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxDjE,IAAI,CAACkE,YAAY,CAACpD,GAAG,CAAC4B,OAAO,CAAC,CAACnB,QAAQ,EAAE,CAAC;AAChD;AACIvB,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAChE;AACM3E,IAAAA,KAAK,CAAC0C,GAAG,CAAC6I,uBAAuB,CAAC;MAAC/F,UAAU,EAAE/D,GAAG,CAAC0D;AAAM,KAAC,CAAC;AACjE;AACMxE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACE,OAAO,EAAE,KAAK,EACxD5E,KAAK,CAAC0G,IAAI,CAAC8E,UAAU,CAAC/J,GAAG,CAAC2D,YAAY,CAAC,CAAA,CAC1C,CAAC;AACN;AACIzE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAChE;AACMhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAACvD,GAAG,CAACkE,eAAe,CAAC,CAACzD,QAAQ,EAAE,CAAC;AACtD;IACMvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACgD,IAAI,EAAE,KAAK,EAAE,EAAE,CAAA,CAC5D,CAAA,CACF,CAAC;;AAEJ;IACE,IAAGjG,GAAG,CAACwG,2BAA2B,EAAE;AACtC;MACI2D,IAAI,CAACxI,KAAK,CAACc,IAAI,CAACzC,GAAG,CAACwG,2BAA2B,CAAC;AACpD,IAAA;;AAEA;IACE2D,IAAI,CAACxI,KAAK,CAACc,IAAI,CAACvD,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAC9E;AACIhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAACvD,GAAG,CAAC2E,kBAAkB,CAAC,CAAClE,QAAQ,EAAE,CAAC;AACvD;IACIvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACgD,IAAI,EAAE,KAAK,EAAE,EAAE,CAAA,CAC5D,CAAC,CAAC;;AAEL;IACEkE,IAAI,CAACxI,KAAK,CAACc,IAAI,CAACvD,IAAI,CAAC2D,MAAM,CACzB3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAAEvF,GAAG,CAAC6E,SAAS,CAAC,CAAC;;AAEvE;AACE,IAAA,IAAG7E,GAAG,CAAC8E,yBAAyB,CAACtC,MAAM,GAAG,CAAC,EAAE;AAC/C;AACI,MAAA,IAAIiE,SAAS,GAAGvH,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC;AACrE,MAAA,KAAI,IAAIR,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGvC,GAAG,CAAC8E,yBAAyB,CAACtC,MAAM,EAAE,EAAED,CAAC,EAAE;AAC5D,QAAA,IAAImC,IAAI,GAAG1E,GAAG,CAAC8E,yBAAyB,CAACvC,CAAC,CAAC;QAC3CkE,SAAS,CAAC2D,MAAM,CAAC3H,IAAI,CAACmE,gBAAgB,CAAClC,IAAI,CAAC,CAAC;AACnD,MAAA;AACIyF,MAAAA,IAAI,CAACxI,KAAK,CAACc,IAAI,CAACgE,SAAS,CAAC;AAC9B,IAAA;AAEE,IAAA,OAAO0D,IAAI;AACb,EAAA;;AAiBA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAAStD,cAAcA,CAAC9E,OAAO,EAAE;IAC/B,IAAIkI,GAAG,GAAG,EAAE;AACZ,IAAA,KAAI,IAAI1H,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGR,OAAO,CAACS,MAAM,EAAE,EAAED,CAAC,EAAE;MACtC0H,GAAG,CAACxH,IAAI,CAACyH,aAAa,CAACnI,OAAO,CAACQ,CAAC,CAAC,CAAC,CAAC;AACvC,IAAA;AACE,IAAA,OAAO0H,GAAG;AACZ,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASrD,gBAAgBA,CAAClC,IAAI,EAAE;AAC9B,IAAA,IAAI/C,KAAK;;AAEX;IACE,IAAG+C,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACH,WAAW,EAAE;AAC3CY,MAAAA,KAAK,GAAGzC,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EAC5DpE,IAAI,CAACqE,QAAQ,CAACmB,IAAI,CAAC/C,KAAK,CAAC,CAAClB,QAAQ,EAAE,CAAC;AAC3C,IAAA,CAAG,MAAM,IAAGiE,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACuD,aAAa,EAAE;MACpD9C,KAAK,GAAGzC,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EACpEb,IAAI,CAAC/C,KAAK,CAACwD,KAAK,EAAE,CAAC;AACzB,IAAA,CAAG,MAAM,IAAGT,IAAI,CAAC/E,IAAI,KAAKpB,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAACoF,WAAW,EAAE;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACI,MAAA,IAAI+D,UAAU,GAAG,IAAI9D,IAAI,CAAC,sBAAsB,CAAC;AACjD,MAAA,IAAI+D,UAAU,GAAG,IAAI/D,IAAI,CAAC,sBAAsB,CAAC;AACjD,MAAA,IAAIgE,IAAI,GAAG7F,IAAI,CAAC/C,KAAK;AACrB,MAAA,IAAG,OAAO4I,IAAI,KAAK,QAAQ,EAAE;AACjC;AACM,QAAA,IAAIC,SAAS,GAAGjE,IAAI,CAACkE,KAAK,CAACF,IAAI,CAAC;AAChC,QAAA,IAAG,CAACG,KAAK,CAACF,SAAS,CAAC,EAAE;AACpBD,UAAAA,IAAI,GAAG,IAAIhE,IAAI,CAACiE,SAAS,CAAC;AAClC,QAAA,CAAO,MAAM,IAAGD,IAAI,CAAC/H,MAAM,KAAK,EAAE,EAAE;AACpC;AACQ+H,UAAAA,IAAI,GAAGrL,IAAI,CAACyL,aAAa,CAACJ,IAAI,CAAC;AACvC,QAAA,CAAO,MAAM;AACb;AACQA,UAAAA,IAAI,GAAGrL,IAAI,CAAC0L,qBAAqB,CAACL,IAAI,CAAC;AAC/C,QAAA;AACA,MAAA;AAEI,MAAA,IAAGA,IAAI,IAAIF,UAAU,IAAIE,IAAI,GAAGD,UAAU,EAAE;QAC1C3I,KAAK,GAAGzC,IAAI,CAAC2D,MAAM,CACjB3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAAC4H,OAAO,EAAE,KAAK,EAC9C3L,IAAI,CAAC4L,aAAa,CAACP,IAAI,CAAC,CAAC;AACjC,MAAA,CAAK,MAAM;QACL5I,KAAK,GAAGzC,IAAI,CAAC2D,MAAM,CACjB3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAAC8H,eAAe,EAAE,KAAK,EACtD7L,IAAI,CAAC8L,qBAAqB,CAACT,IAAI,CAAC,CAAC;AACzC,MAAA;AACA,IAAA;;AAEA;AACA;AACA;AACA;AACE,IAAA,OAAOrL,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AACrE;IACIhE,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAACmB,IAAI,CAAC/E,IAAI,CAAC,CAACc,QAAQ,EAAE,CAAC,EACtCvB,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACI,GAAG,EAAE,IAAI,EAAE;AAC3D;IACM1B,KAAA,CACD,CAAA,CACF,CAAC;AACJ,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAAS8F,uBAAuBA,CAACwD,EAAE,EAAE;IACnC,OAAO;AACT;AACI/L,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAAChF,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC8D,IAAI,CAAC,CAACvE,QAAQ,EAAE,CAAC;AACpD;AACIvB,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACC,QAAQ,EAAE,IAAI,EAAE;AAChE;AACMhE,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACK,GAAG,EAAE,KAAK,EACpDpE,IAAI,CAACqE,QAAQ,CAAC0H,EAAE,CAAClE,SAAS,CAAC,CAACtG,QAAQ,EAAE,CAAC;AAC/C;AACM,IAAA,CAACwK,EAAE,CAAClC,SAAS,GACX7B,SAAS,GACThI,IAAI,CAAC2D,MAAM,CACT3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAClD0F,EAAE,CAAClC,SAAS,CAACtI,QAAQ,EAAE,CAAA,CAC5B,CAAC;AACN;AACIvB,IAAAA,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACC,gBAAgB,EAAE,CAAC,EAAE,IAAI,EAAE,CAChD7D,IAAI,CAAC2D,MAAM,CAAC3D,IAAI,CAAC4D,KAAK,CAACE,SAAS,EAAE9D,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE,KAAK,EAC5D0F,EAAE,CAACvJ,OAAO,CAACjB,QAAQ,EAAE,CAAA,CACxB,CAAA,CACF;AACH,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAA,SAAS0B,SAASA,CAAC1C,GAAG,EAAEO,GAAG,EAAEkL,SAAS,EAAE;IACtC,IAAIvK,OAAO,GAAG,EAAE;IAChB,IAAIC,MAAM,GAAG,EAAE;AACf,IAAA,IAAG,CAAC1B,IAAI,CAAC2B,QAAQ,CAACb,GAAG,EAAEkL,SAAS,EAAEvK,OAAO,EAAEC,MAAM,CAAC,EAAE;MAClD,IAAIhB,KAAK,GAAG,IAAIC,KAAK,CAAC,8BAA8B,GAClD,iDAAiD,CAAC;MACpDD,KAAK,CAACgB,MAAM,GAAGhB,KAAK;AACpB,MAAA,MAAMA,KAAK;AACf,IAAA;;AAEA;IACE,IAAImB,WAAW,GAAG7B,IAAI,CAAC8B,QAAQ,CAACL,OAAO,CAACI,WAAW,CAAC;IACpD,IAAGA,WAAW,KAAKxC,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC8D,IAAI,EAAE;AACtC,MAAA,MAAM,IAAInF,KAAK,CAAC,8BAA8B,GAC5C,0CAA0C,CAAC;AACjD,IAAA;IAEE,IAAGc,OAAO,CAACmG,gBAAgB,EAAE;MAC3B,IAAIpF,OAAO,GAAG,EAAE;MAChB,IAAGnD,KAAK,CAAC0G,IAAI,CAACkG,OAAO,CAACxK,OAAO,CAACmG,gBAAgB,CAAC,EAAE;AAC/C,QAAA,KAAI,IAAIvE,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG5B,OAAO,CAACmG,gBAAgB,CAACtE,MAAM,EAAE,EAAED,CAAC,EAAE;AACvD,UAAA,IAAG5B,OAAO,CAACmG,gBAAgB,CAACvE,CAAC,CAAC,CAAC5C,IAAI,KAAKT,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE;AAC7D,YAAA,MAAM,IAAI1F,KAAK,CAAC,gDAAgD,GAC9D,mDAAmD,CAAC;AAChE,UAAA;UACQ6B,OAAO,IAAIf,OAAO,CAACmG,gBAAgB,CAACvE,CAAC,CAAC,CAACZ,KAAK;AACpD,QAAA;AACA,MAAA,CAAK,MAAM;QACLD,OAAO,GAAGf,OAAO,CAACmG,gBAAgB;AACxC,MAAA;MACIrH,GAAG,CAACqH,gBAAgB,GAAG;QACrBC,SAAS,EAAE7H,IAAI,CAAC8B,QAAQ,CAACL,OAAO,CAAC+I,YAAY,CAAC;AAC9CX,QAAAA,SAAS,EAAExK,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAACxH,OAAO,CAACgJ,YAAY,CAAChI,KAAK,CAAC;AAC9DD,QAAAA,OAAO,EAAEnD,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAACzG,OAAO;OACzC;AACL,IAAA;IAEE,IAAGf,OAAO,CAACe,OAAO,EAAE;MAClB,IAAIA,OAAO,GAAG,EAAE;MAChB,IAAGnD,KAAK,CAAC0G,IAAI,CAACkG,OAAO,CAACxK,OAAO,CAACe,OAAO,CAAC,EAAE;AACtC,QAAA,KAAI,IAAIa,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG5B,OAAO,CAACe,OAAO,CAACc,MAAM,EAAE,EAAED,CAAC,EAAE;AAC9C,UAAA,IAAG5B,OAAO,CAACe,OAAO,CAACa,CAAC,CAAC,CAAC5C,IAAI,KAAKT,IAAI,CAAC+D,IAAI,CAACsC,WAAW,EAAE;AACpD,YAAA,MAAM,IAAI1F,KAAK,CAAC,sCAAsC,GACpD,mDAAmD,CAAC;AAChE,UAAA;UACQ6B,OAAO,IAAIf,OAAO,CAACe,OAAO,CAACa,CAAC,CAAC,CAACZ,KAAK;AAC3C,QAAA;AACA,MAAA,CAAK,MAAM;QACLD,OAAO,GAAGf,OAAO,CAACe,OAAO;AAC/B,MAAA;MACIjC,GAAG,CAACiC,OAAO,GAAGnD,KAAK,CAAC0G,IAAI,CAACkD,YAAY,CAACzG,OAAO,CAAC;AAClD,IAAA;IAEEjC,GAAG,CAACmC,OAAO,GAAGjB,OAAO,CAACiB,OAAO,CAAC0H,UAAU,CAAC,CAAC,CAAC;IAC3C7J,GAAG,CAAC4C,UAAU,GAAG1B,OAAO;AAExB,IAAA,OAAOA,OAAO;AAChB,EAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASwG,eAAeA,CAAC1H,GAAG,EAAE;AAC5B,IAAA,IAAGA,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,KAAKkD,SAAS,EAAE;AACzC,MAAA,MAAM,IAAIrH,KAAK,CAAC,8BAA8B,CAAC;AACnD,IAAA;AAEE,IAAA,IAAGJ,GAAG,CAACiC,OAAO,KAAKwF,SAAS,EAAE;AAC5B,MAAA,IAAI8B,IAAI;AAER,MAAA,QAAOvJ,GAAG,CAACqH,gBAAgB,CAACC,SAAS;AACnC,QAAA,KAAKxI,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AACjC,QAAA,KAAK3C,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AACjC,QAAA,KAAK3C,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,YAAY,CAAC;AAC/B8H,UAAAA,IAAI,GAAGzK,KAAK,CAACoK,GAAG,CAACyC,sBAAsB,CAAC3L,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,CAAC;AACjE,UAAA;AAEF,QAAA,KAAKzF,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,QAAQ,CAAC;AAC7B,QAAA,KAAK3C,KAAK,CAAC0C,GAAG,CAACC,IAAI,CAAC,cAAc,CAAC;AACjC8H,UAAAA,IAAI,GAAGzK,KAAK,CAACsK,GAAG,CAACuC,sBAAsB,CAAC3L,GAAG,CAACqH,gBAAgB,CAAC9C,GAAG,CAAC;AACjE,UAAA;AAEF,QAAA;UACE,MAAM,IAAInE,KAAK,CAAC,oCAAoC,GAClDJ,GAAG,CAACqH,gBAAgB,CAACC,SAAS,CAAC;AACzC;MACIiC,IAAI,CAAC5C,KAAK,CAAC3G,GAAG,CAACqH,gBAAgB,CAACiC,SAAS,CAAC;MAC1CC,IAAI,CAAC3C,MAAM,CAAC5G,GAAG,CAACqH,gBAAgB,CAACpF,OAAO,CAAC;AAEzC,MAAA,IAAG,CAACsH,IAAI,CAACE,MAAM,EAAE,EAAE;AACjB,QAAA,MAAM,IAAIrJ,KAAK,CAAC,8BAA8B,CAAC;AACrD,MAAA;AAEIJ,MAAAA,GAAG,CAACiC,OAAO,GAAGsH,IAAI,CAACG,MAAM;AAC7B,IAAA;AACA,EAAA;;;;;;","x_google_ignoreList":[0]}
@@ -0,0 +1,415 @@
1
+ import { __module as pkcs7asn1 } from '../../../_virtual/pkcs7asn1.js';
2
+ import { __require as requireForge } from './forge.js';
3
+ import { __require as requireAsn1 } from './asn1.js';
4
+ import { __require as requireUtil } from './util.js';
5
+
6
+ /**
7
+ * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.
8
+ *
9
+ * @author Dave Longley
10
+ * @author Stefan Siegl
11
+ *
12
+ * Copyright (c) 2012-2015 Digital Bazaar, Inc.
13
+ * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>
14
+ *
15
+ * The ASN.1 representation of PKCS#7 is as follows
16
+ * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):
17
+ *
18
+ * A PKCS#7 message consists of a ContentInfo on root level, which may
19
+ * contain any number of further ContentInfo nested into it.
20
+ *
21
+ * ContentInfo ::= SEQUENCE {
22
+ * contentType ContentType,
23
+ * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL
24
+ * }
25
+ *
26
+ * ContentType ::= OBJECT IDENTIFIER
27
+ *
28
+ * EnvelopedData ::= SEQUENCE {
29
+ * version Version,
30
+ * recipientInfos RecipientInfos,
31
+ * encryptedContentInfo EncryptedContentInfo
32
+ * }
33
+ *
34
+ * EncryptedData ::= SEQUENCE {
35
+ * version Version,
36
+ * encryptedContentInfo EncryptedContentInfo
37
+ * }
38
+ *
39
+ * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)
40
+ * us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }
41
+ *
42
+ * SignedData ::= SEQUENCE {
43
+ * version INTEGER,
44
+ * digestAlgorithms DigestAlgorithmIdentifiers,
45
+ * contentInfo ContentInfo,
46
+ * certificates [0] IMPLICIT Certificates OPTIONAL,
47
+ * crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
48
+ * signerInfos SignerInfos
49
+ * }
50
+ *
51
+ * SignerInfos ::= SET OF SignerInfo
52
+ *
53
+ * SignerInfo ::= SEQUENCE {
54
+ * version Version,
55
+ * issuerAndSerialNumber IssuerAndSerialNumber,
56
+ * digestAlgorithm DigestAlgorithmIdentifier,
57
+ * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
58
+ * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
59
+ * encryptedDigest EncryptedDigest,
60
+ * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
61
+ * }
62
+ *
63
+ * EncryptedDigest ::= OCTET STRING
64
+ *
65
+ * Attributes ::= SET OF Attribute
66
+ *
67
+ * Attribute ::= SEQUENCE {
68
+ * attrType OBJECT IDENTIFIER,
69
+ * attrValues SET OF AttributeValue
70
+ * }
71
+ *
72
+ * AttributeValue ::= ANY
73
+ *
74
+ * Version ::= INTEGER
75
+ *
76
+ * RecipientInfos ::= SET OF RecipientInfo
77
+ *
78
+ * EncryptedContentInfo ::= SEQUENCE {
79
+ * contentType ContentType,
80
+ * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
81
+ * encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
82
+ * }
83
+ *
84
+ * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
85
+ *
86
+ * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters
87
+ * for the algorithm, if any. In the case of AES and DES3, there is only one,
88
+ * the IV.
89
+ *
90
+ * AlgorithmIdentifer ::= SEQUENCE {
91
+ * algorithm OBJECT IDENTIFIER,
92
+ * parameters ANY DEFINED BY algorithm OPTIONAL
93
+ * }
94
+ *
95
+ * EncryptedContent ::= OCTET STRING
96
+ *
97
+ * RecipientInfo ::= SEQUENCE {
98
+ * version Version,
99
+ * issuerAndSerialNumber IssuerAndSerialNumber,
100
+ * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
101
+ * encryptedKey EncryptedKey
102
+ * }
103
+ *
104
+ * IssuerAndSerialNumber ::= SEQUENCE {
105
+ * issuer Name,
106
+ * serialNumber CertificateSerialNumber
107
+ * }
108
+ *
109
+ * CertificateSerialNumber ::= INTEGER
110
+ *
111
+ * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
112
+ *
113
+ * EncryptedKey ::= OCTET STRING
114
+ */
115
+ var hasRequiredPkcs7asn1;
116
+ function requirePkcs7asn1() {
117
+ if (hasRequiredPkcs7asn1) return pkcs7asn1.exports;
118
+ hasRequiredPkcs7asn1 = 1;
119
+ var forge = requireForge();
120
+ requireAsn1();
121
+ requireUtil();
122
+
123
+ // shortcut for ASN.1 API
124
+ var asn1 = forge.asn1;
125
+
126
+ // shortcut for PKCS#7 API
127
+ var p7v = pkcs7asn1.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};
128
+ forge.pkcs7 = forge.pkcs7 || {};
129
+ forge.pkcs7.asn1 = p7v;
130
+ var contentInfoValidator = {
131
+ name: 'ContentInfo',
132
+ tagClass: asn1.Class.UNIVERSAL,
133
+ type: asn1.Type.SEQUENCE,
134
+ constructed: true,
135
+ value: [{
136
+ name: 'ContentInfo.ContentType',
137
+ tagClass: asn1.Class.UNIVERSAL,
138
+ type: asn1.Type.OID,
139
+ constructed: false,
140
+ capture: 'contentType'
141
+ }, {
142
+ name: 'ContentInfo.content',
143
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
144
+ type: 0,
145
+ constructed: true,
146
+ optional: true,
147
+ captureAsn1: 'content'
148
+ }]
149
+ };
150
+ p7v.contentInfoValidator = contentInfoValidator;
151
+ var encryptedContentInfoValidator = {
152
+ name: 'EncryptedContentInfo',
153
+ tagClass: asn1.Class.UNIVERSAL,
154
+ type: asn1.Type.SEQUENCE,
155
+ constructed: true,
156
+ value: [{
157
+ name: 'EncryptedContentInfo.contentType',
158
+ tagClass: asn1.Class.UNIVERSAL,
159
+ type: asn1.Type.OID,
160
+ constructed: false,
161
+ capture: 'contentType'
162
+ }, {
163
+ name: 'EncryptedContentInfo.contentEncryptionAlgorithm',
164
+ tagClass: asn1.Class.UNIVERSAL,
165
+ type: asn1.Type.SEQUENCE,
166
+ constructed: true,
167
+ value: [{
168
+ name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',
169
+ tagClass: asn1.Class.UNIVERSAL,
170
+ type: asn1.Type.OID,
171
+ constructed: false,
172
+ capture: 'encAlgorithm'
173
+ }, {
174
+ name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',
175
+ tagClass: asn1.Class.UNIVERSAL,
176
+ captureAsn1: 'encParameter'
177
+ }]
178
+ }, {
179
+ name: 'EncryptedContentInfo.encryptedContent',
180
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
181
+ type: 0,
182
+ /* The PKCS#7 structure output by OpenSSL somewhat differs from what
183
+ * other implementations do generate.
184
+ *
185
+ * OpenSSL generates a structure like this:
186
+ * SEQUENCE {
187
+ * ...
188
+ * [0]
189
+ * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38
190
+ * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45
191
+ * ...
192
+ * }
193
+ *
194
+ * Whereas other implementations (and this PKCS#7 module) generate:
195
+ * SEQUENCE {
196
+ * ...
197
+ * [0] {
198
+ * OCTET STRING
199
+ * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38
200
+ * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45
201
+ * ...
202
+ * }
203
+ * }
204
+ *
205
+ * In order to support both, we just capture the context specific
206
+ * field here. The OCTET STRING bit is removed below.
207
+ */
208
+ capture: 'encryptedContent',
209
+ captureAsn1: 'encryptedContentAsn1'
210
+ }]
211
+ };
212
+ p7v.envelopedDataValidator = {
213
+ name: 'EnvelopedData',
214
+ tagClass: asn1.Class.UNIVERSAL,
215
+ type: asn1.Type.SEQUENCE,
216
+ constructed: true,
217
+ value: [{
218
+ name: 'EnvelopedData.Version',
219
+ tagClass: asn1.Class.UNIVERSAL,
220
+ type: asn1.Type.INTEGER,
221
+ constructed: false,
222
+ capture: 'version'
223
+ }, {
224
+ name: 'EnvelopedData.RecipientInfos',
225
+ tagClass: asn1.Class.UNIVERSAL,
226
+ type: asn1.Type.SET,
227
+ constructed: true,
228
+ captureAsn1: 'recipientInfos'
229
+ }].concat(encryptedContentInfoValidator)
230
+ };
231
+ p7v.encryptedDataValidator = {
232
+ name: 'EncryptedData',
233
+ tagClass: asn1.Class.UNIVERSAL,
234
+ type: asn1.Type.SEQUENCE,
235
+ constructed: true,
236
+ value: [{
237
+ name: 'EncryptedData.Version',
238
+ tagClass: asn1.Class.UNIVERSAL,
239
+ type: asn1.Type.INTEGER,
240
+ constructed: false,
241
+ capture: 'version'
242
+ }].concat(encryptedContentInfoValidator)
243
+ };
244
+ var signerValidator = {
245
+ name: 'SignerInfo',
246
+ tagClass: asn1.Class.UNIVERSAL,
247
+ type: asn1.Type.SEQUENCE,
248
+ constructed: true,
249
+ value: [{
250
+ name: 'SignerInfo.version',
251
+ tagClass: asn1.Class.UNIVERSAL,
252
+ type: asn1.Type.INTEGER,
253
+ constructed: false
254
+ }, {
255
+ name: 'SignerInfo.issuerAndSerialNumber',
256
+ tagClass: asn1.Class.UNIVERSAL,
257
+ type: asn1.Type.SEQUENCE,
258
+ constructed: true,
259
+ value: [{
260
+ name: 'SignerInfo.issuerAndSerialNumber.issuer',
261
+ tagClass: asn1.Class.UNIVERSAL,
262
+ type: asn1.Type.SEQUENCE,
263
+ constructed: true,
264
+ captureAsn1: 'issuer'
265
+ }, {
266
+ name: 'SignerInfo.issuerAndSerialNumber.serialNumber',
267
+ tagClass: asn1.Class.UNIVERSAL,
268
+ type: asn1.Type.INTEGER,
269
+ constructed: false,
270
+ capture: 'serial'
271
+ }]
272
+ }, {
273
+ name: 'SignerInfo.digestAlgorithm',
274
+ tagClass: asn1.Class.UNIVERSAL,
275
+ type: asn1.Type.SEQUENCE,
276
+ constructed: true,
277
+ value: [{
278
+ name: 'SignerInfo.digestAlgorithm.algorithm',
279
+ tagClass: asn1.Class.UNIVERSAL,
280
+ type: asn1.Type.OID,
281
+ constructed: false,
282
+ capture: 'digestAlgorithm'
283
+ }, {
284
+ name: 'SignerInfo.digestAlgorithm.parameter',
285
+ tagClass: asn1.Class.UNIVERSAL,
286
+ constructed: false,
287
+ captureAsn1: 'digestParameter',
288
+ optional: true
289
+ }]
290
+ }, {
291
+ name: 'SignerInfo.authenticatedAttributes',
292
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
293
+ type: 0,
294
+ constructed: true,
295
+ optional: true,
296
+ capture: 'authenticatedAttributes'
297
+ }, {
298
+ name: 'SignerInfo.digestEncryptionAlgorithm',
299
+ tagClass: asn1.Class.UNIVERSAL,
300
+ type: asn1.Type.SEQUENCE,
301
+ constructed: true,
302
+ capture: 'signatureAlgorithm'
303
+ }, {
304
+ name: 'SignerInfo.encryptedDigest',
305
+ tagClass: asn1.Class.UNIVERSAL,
306
+ type: asn1.Type.OCTETSTRING,
307
+ constructed: false,
308
+ capture: 'signature'
309
+ }, {
310
+ name: 'SignerInfo.unauthenticatedAttributes',
311
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
312
+ type: 1,
313
+ constructed: true,
314
+ optional: true,
315
+ capture: 'unauthenticatedAttributes'
316
+ }]
317
+ };
318
+ p7v.signedDataValidator = {
319
+ name: 'SignedData',
320
+ tagClass: asn1.Class.UNIVERSAL,
321
+ type: asn1.Type.SEQUENCE,
322
+ constructed: true,
323
+ value: [{
324
+ name: 'SignedData.Version',
325
+ tagClass: asn1.Class.UNIVERSAL,
326
+ type: asn1.Type.INTEGER,
327
+ constructed: false,
328
+ capture: 'version'
329
+ }, {
330
+ name: 'SignedData.DigestAlgorithms',
331
+ tagClass: asn1.Class.UNIVERSAL,
332
+ type: asn1.Type.SET,
333
+ constructed: true,
334
+ captureAsn1: 'digestAlgorithms'
335
+ }, contentInfoValidator, {
336
+ name: 'SignedData.Certificates',
337
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
338
+ type: 0,
339
+ optional: true,
340
+ captureAsn1: 'certificates'
341
+ }, {
342
+ name: 'SignedData.CertificateRevocationLists',
343
+ tagClass: asn1.Class.CONTEXT_SPECIFIC,
344
+ type: 1,
345
+ optional: true,
346
+ captureAsn1: 'crls'
347
+ }, {
348
+ name: 'SignedData.SignerInfos',
349
+ tagClass: asn1.Class.UNIVERSAL,
350
+ type: asn1.Type.SET,
351
+ capture: 'signerInfos',
352
+ optional: true,
353
+ value: [signerValidator]
354
+ }]
355
+ };
356
+ p7v.recipientInfoValidator = {
357
+ name: 'RecipientInfo',
358
+ tagClass: asn1.Class.UNIVERSAL,
359
+ type: asn1.Type.SEQUENCE,
360
+ constructed: true,
361
+ value: [{
362
+ name: 'RecipientInfo.version',
363
+ tagClass: asn1.Class.UNIVERSAL,
364
+ type: asn1.Type.INTEGER,
365
+ constructed: false,
366
+ capture: 'version'
367
+ }, {
368
+ name: 'RecipientInfo.issuerAndSerial',
369
+ tagClass: asn1.Class.UNIVERSAL,
370
+ type: asn1.Type.SEQUENCE,
371
+ constructed: true,
372
+ value: [{
373
+ name: 'RecipientInfo.issuerAndSerial.issuer',
374
+ tagClass: asn1.Class.UNIVERSAL,
375
+ type: asn1.Type.SEQUENCE,
376
+ constructed: true,
377
+ captureAsn1: 'issuer'
378
+ }, {
379
+ name: 'RecipientInfo.issuerAndSerial.serialNumber',
380
+ tagClass: asn1.Class.UNIVERSAL,
381
+ type: asn1.Type.INTEGER,
382
+ constructed: false,
383
+ capture: 'serial'
384
+ }]
385
+ }, {
386
+ name: 'RecipientInfo.keyEncryptionAlgorithm',
387
+ tagClass: asn1.Class.UNIVERSAL,
388
+ type: asn1.Type.SEQUENCE,
389
+ constructed: true,
390
+ value: [{
391
+ name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',
392
+ tagClass: asn1.Class.UNIVERSAL,
393
+ type: asn1.Type.OID,
394
+ constructed: false,
395
+ capture: 'encAlgorithm'
396
+ }, {
397
+ name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',
398
+ tagClass: asn1.Class.UNIVERSAL,
399
+ constructed: false,
400
+ captureAsn1: 'encParameter',
401
+ optional: true
402
+ }]
403
+ }, {
404
+ name: 'RecipientInfo.encryptedKey',
405
+ tagClass: asn1.Class.UNIVERSAL,
406
+ type: asn1.Type.OCTETSTRING,
407
+ constructed: false,
408
+ capture: 'encKey'
409
+ }]
410
+ };
411
+ return pkcs7asn1.exports;
412
+ }
413
+
414
+ export { requirePkcs7asn1 as __require };
415
+ //# sourceMappingURL=pkcs7asn1.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pkcs7asn1.js","sources":["../../../../node_modules/node-forge/lib/pkcs7asn1.js"],"sourcesContent":["/**\n * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.\n *\n * @author Dave Longley\n * @author Stefan Siegl\n *\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#7 is as follows\n * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):\n *\n * A PKCS#7 message consists of a ContentInfo on root level, which may\n * contain any number of further ContentInfo nested into it.\n *\n * ContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * EnvelopedData ::= SEQUENCE {\n * version Version,\n * recipientInfos RecipientInfos,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * EncryptedData ::= SEQUENCE {\n * version Version,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)\n * us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }\n *\n * SignedData ::= SEQUENCE {\n * version INTEGER,\n * digestAlgorithms DigestAlgorithmIdentifiers,\n * contentInfo ContentInfo,\n * certificates [0] IMPLICIT Certificates OPTIONAL,\n * crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,\n * signerInfos SignerInfos\n * }\n *\n * SignerInfos ::= SET OF SignerInfo\n *\n * SignerInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * digestAlgorithm DigestAlgorithmIdentifier,\n * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,\n * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,\n * encryptedDigest EncryptedDigest,\n * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL\n * }\n *\n * EncryptedDigest ::= OCTET STRING\n *\n * Attributes ::= SET OF Attribute\n *\n * Attribute ::= SEQUENCE {\n * attrType OBJECT IDENTIFIER,\n * attrValues SET OF AttributeValue\n * }\n *\n * AttributeValue ::= ANY\n *\n * Version ::= INTEGER\n *\n * RecipientInfos ::= SET OF RecipientInfo\n *\n * EncryptedContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,\n * encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL\n * }\n *\n * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of AES and DES3, there is only one,\n * the IV.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * EncryptedContent ::= OCTET STRING\n *\n * RecipientInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,\n * encryptedKey EncryptedKey\n * }\n *\n * IssuerAndSerialNumber ::= SEQUENCE {\n * issuer Name,\n * serialNumber CertificateSerialNumber\n * }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedKey ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./util');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7v = module.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};\nforge.pkcs7 = forge.pkcs7 || {};\nforge.pkcs7.asn1 = p7v;\n\nvar contentInfoValidator = {\n name: 'ContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'ContentInfo.ContentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'ContentInfo.content',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n captureAsn1: 'content'\n }]\n};\np7v.contentInfoValidator = contentInfoValidator;\n\nvar encryptedContentInfoValidator = {\n name: 'EncryptedContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'EncryptedContentInfo.encryptedContent',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n /* The PKCS#7 structure output by OpenSSL somewhat differs from what\n * other implementations do generate.\n *\n * OpenSSL generates a structure like this:\n * SEQUENCE {\n * ...\n * [0]\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n *\n * Whereas other implementations (and this PKCS#7 module) generate:\n * SEQUENCE {\n * ...\n * [0] {\n * OCTET STRING\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n * }\n *\n * In order to support both, we just capture the context specific\n * field here. The OCTET STRING bit is removed below.\n */\n capture: 'encryptedContent',\n captureAsn1: 'encryptedContentAsn1'\n }]\n};\n\np7v.envelopedDataValidator = {\n name: 'EnvelopedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EnvelopedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'EnvelopedData.RecipientInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'recipientInfos'\n }].concat(encryptedContentInfoValidator)\n};\n\np7v.encryptedDataValidator = {\n name: 'EncryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }].concat(encryptedContentInfoValidator)\n};\n\nvar signerValidator = {\n name: 'SignerInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false\n }, {\n name: 'SignerInfo.issuerAndSerialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.issuerAndSerialNumber.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'SignerInfo.issuerAndSerialNumber.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'SignerInfo.digestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.digestAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'digestAlgorithm'\n }, {\n name: 'SignerInfo.digestAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'digestParameter',\n optional: true\n }]\n }, {\n name: 'SignerInfo.authenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'authenticatedAttributes'\n }, {\n name: 'SignerInfo.digestEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n capture: 'signatureAlgorithm'\n }, {\n name: 'SignerInfo.encryptedDigest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'signature'\n }, {\n name: 'SignerInfo.unauthenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n capture: 'unauthenticatedAttributes'\n }]\n};\n\np7v.signedDataValidator = {\n name: 'SignedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'SignedData.DigestAlgorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'digestAlgorithms'\n },\n contentInfoValidator,\n {\n name: 'SignedData.Certificates',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n optional: true,\n captureAsn1: 'certificates'\n }, {\n name: 'SignedData.CertificateRevocationLists',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n optional: true,\n captureAsn1: 'crls'\n }, {\n name: 'SignedData.SignerInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n capture: 'signerInfos',\n optional: true,\n value: [signerValidator]\n }]\n};\n\np7v.recipientInfoValidator = {\n name: 'RecipientInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'RecipientInfo.issuerAndSerial',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.issuerAndSerial.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'RecipientInfo.issuerAndSerial.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'encParameter',\n optional: true\n }]\n }, {\n name: 'RecipientInfo.encryptedKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encKey'\n }]\n};\n"],"names":["forge","require$$0","require$$1","require$$2","asn1","p7v","pkcs7asn1Module","exports","pkcs7asn1","pkcs7","contentInfoValidator","name","tagClass","Class","UNIVERSAL","type","Type","SEQUENCE","constructed","value","OID","capture","CONTEXT_SPECIFIC","optional","captureAsn1","encryptedContentInfoValidator","envelopedDataValidator","INTEGER","SET","concat","encryptedDataValidator","signerValidator","OCTETSTRING","signedDataValidator","recipientInfoValidator"],"mappings":"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","x_google_ignoreList":[0]}