node-opcua-crypto 4.2.0 → 4.3.1
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.
- package/LICENSE +1 -1
- package/README.md +1 -1
- package/dist/chunk-5NV4OKIV.mjs +1 -0
- package/dist/chunk-KPKFYTZJ.mjs +173 -0
- package/dist/chunk-QSSIRHMR.mjs +6243 -0
- package/dist/index.js +6521 -0
- package/dist/index.mjs +224 -0
- package/dist/source/index.js +6346 -0
- package/dist/source/index.mjs +192 -0
- package/dist/source/index_web.js +6346 -0
- package/dist/source/index_web.mjs +191 -0
- package/dist/source_nodejs/index.js +4170 -0
- package/dist/source_nodejs/index.mjs +37 -0
- package/dist-types/index.d.ts +2 -0
- package/dist-types/source/common.d.ts +21 -1
- package/dist-types/source/crypto_utils2.d.ts +2 -3
- package/dist-types/source/make_private_key_from_pem.d.ts +1 -1
- package/dist-types/source/x509/coerce_private_key.d.ts +5 -3
- package/dist-types/source/x509/create_key_pair.d.ts +6 -0
- package/dist-types/source/x509/create_self_signed_certificate.d.ts +4 -0
- package/dist-types/source_nodejs/read.d.ts +1 -0
- package/node-opcua-crypto-4.2.0.tgz +0 -0
- package/package.json +84 -91
- package/dist-cjs/source/asn1.js +0 -304
- package/dist-cjs/source/asn1.js.map +0 -1
- package/dist-cjs/source/buffer_utils.js +0 -9
- package/dist-cjs/source/buffer_utils.js.map +0 -1
- package/dist-cjs/source/common.js +0 -11
- package/dist-cjs/source/common.js.map +0 -1
- package/dist-cjs/source/crypto_explore_certificate.js +0 -367
- package/dist-cjs/source/crypto_explore_certificate.js.map +0 -1
- package/dist-cjs/source/crypto_utils.js +0 -200
- package/dist-cjs/source/crypto_utils.js.map +0 -1
- package/dist-cjs/source/crypto_utils2.js +0 -71
- package/dist-cjs/source/crypto_utils2.js.map +0 -1
- package/dist-cjs/source/derived_keys.js +0 -133
- package/dist-cjs/source/derived_keys.js.map +0 -1
- package/dist-cjs/source/explore_certificate.js +0 -37
- package/dist-cjs/source/explore_certificate.js.map +0 -1
- package/dist-cjs/source/explore_certificate_revocation_list.js +0 -69
- package/dist-cjs/source/explore_certificate_revocation_list.js.map +0 -1
- package/dist-cjs/source/explore_certificate_signing_request.js +0 -45
- package/dist-cjs/source/explore_certificate_signing_request.js.map +0 -1
- package/dist-cjs/source/explore_private_key.js +0 -77
- package/dist-cjs/source/explore_private_key.js.map +0 -1
- package/dist-cjs/source/index.js +0 -38
- package/dist-cjs/source/index.js.map +0 -1
- package/dist-cjs/source/make_private_key_from_pem.js +0 -8
- package/dist-cjs/source/make_private_key_from_pem.js.map +0 -1
- package/dist-cjs/source/oid_map.js +0 -300
- package/dist-cjs/source/oid_map.js.map +0 -1
- package/dist-cjs/source/public_private_match.js +0 -32
- package/dist-cjs/source/public_private_match.js.map +0 -1
- package/dist-cjs/source/subject.js +0 -92
- package/dist-cjs/source/subject.js.map +0 -1
- package/dist-cjs/source/verify_certificate_signature.js +0 -117
- package/dist-cjs/source/verify_certificate_signature.js.map +0 -1
- package/dist-cjs/source/x509/_build_public_key.js +0 -69
- package/dist-cjs/source/x509/_build_public_key.js.map +0 -1
- package/dist-cjs/source/x509/_crypto.js +0 -52
- package/dist-cjs/source/x509/_crypto.js.map +0 -1
- package/dist-cjs/source/x509/_get_attributes.js +0 -39
- package/dist-cjs/source/x509/_get_attributes.js.map +0 -1
- package/dist-cjs/source/x509/coerce_private_key.js +0 -90
- package/dist-cjs/source/x509/coerce_private_key.js.map +0 -1
- package/dist-cjs/source/x509/create_certificate_signing_request.js +0 -92
- package/dist-cjs/source/x509/create_certificate_signing_request.js.map +0 -1
- package/dist-cjs/source/x509/create_key_pair.js +0 -123
- package/dist-cjs/source/x509/create_key_pair.js.map +0 -1
- package/dist-cjs/source/x509/create_self_signed_certificate.js +0 -103
- package/dist-cjs/source/x509/create_self_signed_certificate.js.map +0 -1
- package/dist-cjs/source_nodejs/generate_private_key_filename.js +0 -88
- package/dist-cjs/source_nodejs/generate_private_key_filename.js.map +0 -1
- package/dist-cjs/source_nodejs/index.js +0 -21
- package/dist-cjs/source_nodejs/index.js.map +0 -1
- package/dist-cjs/source_nodejs/read.js +0 -115
- package/dist-cjs/source_nodejs/read.js.map +0 -1
- package/dist-cjs/source_nodejs/read_certificate_revocation_list.js +0 -64
- package/dist-cjs/source_nodejs/read_certificate_revocation_list.js.map +0 -1
- package/dist-cjs/source_nodejs/read_certificate_signing_request.js +0 -64
- package/dist-cjs/source_nodejs/read_certificate_signing_request.js.map +0 -1
- package/dist-esm/source/asn1.js +0 -275
- package/dist-esm/source/asn1.js.map +0 -1
- package/dist-esm/source/buffer_utils.js +0 -6
- package/dist-esm/source/buffer_utils.js.map +0 -1
- package/dist-esm/source/common.js +0 -8
- package/dist-esm/source/common.js.map +0 -1
- package/dist-esm/source/crypto_explore_certificate.js +0 -356
- package/dist-esm/source/crypto_explore_certificate.js.map +0 -1
- package/dist-esm/source/crypto_utils.js +0 -179
- package/dist-esm/source/crypto_utils.js.map +0 -1
- package/dist-esm/source/crypto_utils2.js +0 -58
- package/dist-esm/source/crypto_utils2.js.map +0 -1
- package/dist-esm/source/derived_keys.js +0 -117
- package/dist-esm/source/derived_keys.js.map +0 -1
- package/dist-esm/source/explore_certificate.js +0 -29
- package/dist-esm/source/explore_certificate.js.map +0 -1
- package/dist-esm/source/explore_certificate_revocation_list.js +0 -64
- package/dist-esm/source/explore_certificate_revocation_list.js.map +0 -1
- package/dist-esm/source/explore_certificate_signing_request.js +0 -40
- package/dist-esm/source/explore_certificate_signing_request.js.map +0 -1
- package/dist-esm/source/explore_private_key.js +0 -73
- package/dist-esm/source/explore_private_key.js.map +0 -1
- package/dist-esm/source/index.js +0 -19
- package/dist-esm/source/index.js.map +0 -1
- package/dist-esm/source/make_private_key_from_pem.js +0 -4
- package/dist-esm/source/make_private_key_from_pem.js.map +0 -1
- package/dist-esm/source/oid_map.js +0 -297
- package/dist-esm/source/oid_map.js.map +0 -1
- package/dist-esm/source/public_private_match.js +0 -27
- package/dist-esm/source/public_private_match.js.map +0 -1
- package/dist-esm/source/subject.js +0 -89
- package/dist-esm/source/subject.js.map +0 -1
- package/dist-esm/source/verify_certificate_signature.js +0 -110
- package/dist-esm/source/verify_certificate_signature.js.map +0 -1
- package/dist-esm/source/x509/_build_public_key.js +0 -65
- package/dist-esm/source/x509/_build_public_key.js.map +0 -1
- package/dist-esm/source/x509/_crypto.js +0 -25
- package/dist-esm/source/x509/_crypto.js.map +0 -1
- package/dist-esm/source/x509/_get_attributes.js +0 -35
- package/dist-esm/source/x509/_get_attributes.js.map +0 -1
- package/dist-esm/source/x509/coerce_private_key.js +0 -85
- package/dist-esm/source/x509/coerce_private_key.js.map +0 -1
- package/dist-esm/source/x509/create_certificate_signing_request.js +0 -88
- package/dist-esm/source/x509/create_certificate_signing_request.js.map +0 -1
- package/dist-esm/source/x509/create_key_pair.js +0 -115
- package/dist-esm/source/x509/create_key_pair.js.map +0 -1
- package/dist-esm/source/x509/create_self_signed_certificate.js +0 -99
- package/dist-esm/source/x509/create_self_signed_certificate.js.map +0 -1
- package/dist-esm/source_nodejs/generate_private_key_filename.js +0 -80
- package/dist-esm/source_nodejs/generate_private_key_filename.js.map +0 -1
- package/dist-esm/source_nodejs/index.js +0 -5
- package/dist-esm/source_nodejs/index.js.map +0 -1
- package/dist-esm/source_nodejs/read.js +0 -99
- package/dist-esm/source_nodejs/read.js.map +0 -1
- package/dist-esm/source_nodejs/read_certificate_revocation_list.js +0 -57
- package/dist-esm/source_nodejs/read_certificate_revocation_list.js.map +0 -1
- package/dist-esm/source_nodejs/read_certificate_signing_request.js +0 -57
- package/dist-esm/source_nodejs/read_certificate_signing_request.js.map +0 -1
- package/index.d.ts +0 -2
- package/index.js +0 -4
- package/index_web.d.ts +0 -1
- package/index_web.js +0 -3
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"asn1.js","sourceRoot":"","sources":["../../source/asn1.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA4B;AAC5B,2CAAuC;AAGvC,IAAY,OAwBX;AAxBD,WAAY,OAAO;IACf,2CAAc,CAAA;IACd,2CAAc,CAAA;IACd,iDAAiB,CAAA;IACjB,qDAAmB,CAAA;IACnB,qCAAW,CAAA;IACX,+DAAwB,CAAA;IACxB,kDAAiB,CAAA;IACjB,wDAAoB,CAAA;IACpB,4DAAsB,CAAA;IACtB,wDAAoB,CAAA;IACpB,gDAAgB,CAAA;IAChB,4CAAc,CAAA;IACd,4DAAsB,CAAA;IACtB,wDAAoB,CAAA;IACpB,wDAAoB,CAAA;IACpB,wDAAoB,CAAA;IACpB,4DAAsB,CAAA;IACtB,gDAAgB,CAAA;IAEhB,8CAAe,CAAA;IACf,oCAAU,CAAA;IAEV,mCAAS,CAAA;AACb,CAAC,EAxBW,OAAO,uBAAP,OAAO,QAwBlB;AAQD,SAAgB,OAAO,CAAC,GAAW,EAAE,GAAW;IAC5C,IAAA,gBAAM,EAAC,GAAG,YAAY,MAAM,CAAC,CAAC;IAC9B,IAAA,gBAAM,EAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC;IAEzC,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,gCAAgC,GAAG,GAAG,CAAC,MAAM,GAAG,QAAQ,GAAG,GAAG,CAAC,CAAC;KACnF;IACD,IAAM,GAAG,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC/B,GAAG,IAAI,CAAC,CAAC;IAET,IAAI,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAChC,GAAG,IAAI,CAAC,CAAC;IAGT,IAAI,MAAM,GAAG,GAAG,EAAE;QACd,IAAM,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC;QAC9B,MAAM,GAAG,CAAC,CAAC;QACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,GAAG,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YAC3C,GAAG,IAAI,CAAC,CAAC;SACZ;KACJ;IACD,OAAO,EAAE,GAAG,KAAA,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,QAAA,EAAE,CAAC;AAC1C,CAAC;AAvBD,0BAuBC;AAED,SAAgB,WAAW,CAAC,GAAW,EAAE,SAAoB;IACzD,IAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;IAChC,IAAI,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC;IAChC,IAAM,GAAG,GAAG,SAAS,CAAC,QAAQ,GAAG,MAAM,CAAC;IACxC,IAAM,MAAM,GAAgB,EAAE,CAAC;IAC/B,OAAO,MAAM,GAAG,GAAG,EAAE;QACjB,IAAM,KAAK,GAAG,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACnC,MAAM,GAAG,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KACtB;IACD,OAAO,MAAM,CAAC;AAClB,CAAC;AAXD,kCAWC;AAED,SAAgB,cAAc,CAAC,MAAc,EAAE,KAAa,EAAE,GAAW,EAAE,SAAiB;IACxF,IAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EACrC,MAAM,GAAG,CAAC,CAAC,GAAG,GAAG,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,EAC7C,KAAK,GAAG,GAAG,GAAG,MAAM,GAAG,SAAS,CAAC;IAErC,IAAI,CAAC,GAAG,EAAE,EACN,IAAI,GAAG,SAAS,CAAC;IAErB,KAAK,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,EAAE,CAAC,EAAE;QAClC,IAAM,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAE9B,KAAK,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;YAE3B,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;SACjC;QACD,IAAI,GAAG,CAAC,CAAC;QACT,IAAA,gBAAM,EAAC,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC;KACjC;IACD,OAAO,KAAK,GAAG,CAAC,CAAC;AACrB,CAAC;AAnBD,wCAmBC;AASD,SAAgB,cAAc,CAAC,MAAc,EAAE,KAAgB;IAC3D,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;IACzC,IAAM,IAAI,GAAG,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAEtC,IAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAEtC,OAAO;QACH,YAAY,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,WAAW;QAC3C,aAAa,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC;QAC9B,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QACtB,KAAK,EAAE,cAAc,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,GAAC,EAAE,GAAC,IAAI,CAAC;KAC1F,CAAC;AACN,CAAC;AAZD,wCAYC;AAED,SAAgB,8BAA8B,CAAC,MAAc;IACzD,IAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACpC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KACvE;IAED,OAAO,KAAK;SACP,IAAI,CAAC,GAAG,CAAC;SACT,WAAW,EAAE;SACb,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;AAChC,CAAC;AAVD,wEAUC;AAED,SAAgB,gBAAgB,CAAC,MAAc,EAAE,KAAgB;IAC7D,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,YAAY,CAAC,CAAC;IAC3C,IAAM,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC5C,IAAA,gBAAM,EAAC,GAAG,CAAC,GAAG,KAAK,OAAO,CAAC,YAAY,CAAC,CAAC;IAEzC,IAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC;IAC3B,IAAM,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC;IACzB,IAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC;IAC9C,OAAO,CAAC,CAAC;AACb,CAAC;AATD,4CASC;AAED,SAAgB,SAAS,CAAC,MAAc,EAAE,KAAgB;IACtD,IAAM,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAC;IAC7B,IAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;IAC1C,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;AACvC,CAAC;AAJD,8BAIC;AAMD,SAAgB,wBAAwB,CAAC,MAAc,EAAE,KAAgB;IACrE,OAAO,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACpC,CAAC;AAFD,4DAEC;AAED,SAAgB,kBAAkB,CAAC,MAAc;IAC7C,IAAM,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACjC,IAAM,YAAY,GAAG,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChD,OAAO,YAAY,CAAC,GAAG,CAAC,UAAC,MAAiB;QACtC,OAAO,wBAAwB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACP,CAAC;AAND,gDAMC;AAED,SAAS,QAAQ,CAAC,MAAc,EAAE,KAAa,EAAE,GAAW;IAGxD,IAAI,CAAC,GAAG,EAAE,EACN,CAAC,GAAG,CAAC,EACL,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;QAC9B,IAAM,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAG9B,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QACzB,IAAI,IAAI,CAAC,CAAC;QAIV,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE;YAEb,IAAI,CAAC,KAAK,EAAE,EAAE;gBACV,IAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC;aAC9B;iBAAM;gBACH,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aAC3B;YACD,CAAC,GAAG,CAAC,CAAC;YACN,IAAI,GAAG,CAAC,CAAC;SACZ;KACJ;IACD,IAAA,gBAAM,EAAC,IAAI,KAAK,CAAC,CAAC,CAAC;IACnB,OAAO,CAAC,CAAC;AACb,CAAC;AAED,SAAgB,qBAAqB,CAAC,MAAc,EAAE,KAAgB;IAClE,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,iBAAiB,CAAC,CAAC;IAChD,IAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IACzE,IAAM,GAAG,GAAG,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACzC,OAAO;QACH,GAAG,KAAA;QACH,IAAI,EAAE,oBAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,oBAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG;KAC5C,CAAC;AACN,CAAC;AARD,sDAQC;AAED,SAAgB,wBAAwB,CAAC,MAAc,EAAE,KAAgB;IACrE,IAAM,YAAY,GAAG,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChD,OAAO;QACH,UAAU,EAAE,qBAAqB,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;KAClE,CAAA;AACL,CAAC;AALD,4DAKC;AAAA,CAAC;AAEF,SAAgB,2BAA2B,CAAC,MAAc,EAAE,KAAgB;IACxE,IAAM,YAAY,GAAG,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChD,OAAO;QACH,UAAU,EAAE,qBAAqB,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;KAClE,CAAA;AACL,CAAC;AALD,kEAKC;AAAA,CAAC;AAIF,SAAgB,sBAAsB,CAAC,MAAc,EAAE,KAAgB;IACnE,OAAO,cAAc,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC;AAC9C,CAAC;AAFD,wDAEC;AAED,SAAgB,mBAAmB,CAAC,MAAc,EAAE,KAAgB;IAChE,OAAO,sBAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AACjE,CAAC;AAFD,kDAEC;AAED,SAAgB,qBAAqB,CAAC,MAAc,EAAE,KAAgB;IAClE,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,OAAO,EAAE,yBAAyB,CAAC,CAAC;IACjE,IAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC;IAC3B,IAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;IAC7B,IAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC;IAChD,OAAO,GAAG,CAAC;AACf,CAAC;AAND,sDAMC;AAED,SAAgB,iBAAiB,CAAC,MAAc,EAAE,KAAgB;IAC9D,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,OAAO,EAAE,yBAAyB,CAAC,CAAC;IACjE,IAAI,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC;IACzB,IAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;IAC7B,IAAA,gBAAM,EAAC,OAAO,GAAG,CAAC,CAAC,CAAC;IACpB,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE;QAC9B,KAAK,GAAG,KAAK,GAAG,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC5C,GAAG,IAAI,CAAC,CAAC;KACZ;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAXD,8CAWC;AAED,SAAgB,iBAAiB,CAAC,MAAc,EAAE,KAAgB;IAC9D,IAAA,gBAAM,EAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC,OAAO,EAAE,+BAA+B,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5F,IAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC;IAC3B,IAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;IAC7B,IAAA,gBAAM,EAAC,OAAO,GAAG,CAAC,CAAC,CAAC;IACpB,IAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IACnD,OAAO,KAAgB,CAAC;AAC5B,CAAC;AAPD,8CAOC;AAED,SAAgB,iBAAiB,CAAC,MAAc,EAAE,KAAgB;IAC9D,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;IACxC,OAAO,iBAAiB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAC5C,CAAC;AAHD,8CAGC;AAgBD,SAAS,sBAAsB,CAAC,GAAW;IACvC,IAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC5C,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IACjD,IAAM,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3C,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC7C,IAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC7C,IAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAE7C,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;AACnE,CAAC;AAED,SAAS,cAAc,CAAC,MAAc,EAAE,KAAgB;IACpD,IAAM,OAAO,GAAG,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IACzC,IAAI,GAAG,GAAG,EAAE,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;QACxC,IAAM,IAAI,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACrC,GAAG,IAAI,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;KACpC;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAgCD,SAAS,cAAc,CAAC,GAAW;IAC/B,IAAI,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC1C,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IACjD,IAAM,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3C,IAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC7C,IAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC5C,IAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAE7C,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IACjC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;AACnE,CAAC;AAED,SAAgB,UAAU,CAAC,MAAc,EAAE,KAAgB;IACvD,QAAQ,KAAK,CAAC,GAAG,EAAE;QACf,KAAK,OAAO,CAAC,OAAO;YAChB,OAAO,iBAAiB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5C,KAAK,OAAO,CAAC,SAAS;YAClB,OAAO,cAAc,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACzC,KAAK,OAAO,CAAC,eAAe,CAAC;QAC7B,KAAK,OAAO,CAAC,aAAa,CAAC;QAC3B,KAAK,OAAO,CAAC,UAAU,CAAC;QACxB,KAAK,OAAO,CAAC,aAAa,CAAC;QAC3B,KAAK,OAAO,CAAC,SAAS;YAClB,OAAO,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACtD,KAAK,OAAO,CAAC,OAAO;YAChB,OAAO,cAAc,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;QACtE,KAAK,OAAO,CAAC,eAAe;YACxB,OAAO,sBAAsB,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;QAC9E;YACI,MAAM,IAAI,KAAK,CAAC,gBAAgB,GAAG,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC;KAEvE;AACL,CAAC;AApBD,gCAoBC;AAUD,SAAgB,oBAAoB,CAAC,CAAgB;IACjD,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC;AAFD,oDAEC;AAED,SAAgB,kBAAkB,CAAC,MAAc,EAAE,KAAgB;IAI/D,IAAM,UAAU,GAAG,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC9C,IAAM,KAAK,GAAkB,EAAE,CAAC;IAChC,KAAwB,UAAU,EAAV,yBAAU,EAAV,wBAAU,EAAV,IAAU,EAAE;QAA/B,IAAM,SAAS,mBAAA;QAChB,IAAA,gBAAM,EAAC,SAAS,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;QAC/B,IAAM,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC9C,IAAA,gBAAM,EAAC,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;QAC5B,IAAA,gBAAM,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;QAE/B,IAAM,aAAa,GAAG,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACrD,IAAA,gBAAM,EAAC,aAAa,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;QAEnC,IAAM,IAAI,GAAG,qBAAqB,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,KAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;KACpE;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAnBD,gDAmBC;AAED,SAAgB,iBAAiB,CAAC,MAAmB,EAAE,KAAa;IAChE,IAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,UAAC,CAAY,IAAK,OAAA,CAAC,CAAC,GAAG,KAAK,IAAI,GAAG,KAAK,IAAI,CAAC,CAAC,GAAG,KAAK,IAAI,GAAG,KAAK,EAAhD,CAAgD,CAAC,CAAC;IAC9F,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;QAClB,OAAO,IAAI,CAAC;KACf;IACD,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAND,8CAMC;AAED,SAAgB,SAAS,CAAC,MAAc,EAAE,KAAgB;IACtD,OAAO,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACrC,CAAC;AAFD,8BAEC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createFastUninitializedBuffer = void 0;
|
|
4
|
-
exports.createFastUninitializedBuffer = Buffer.allocUnsafe
|
|
5
|
-
? Buffer.allocUnsafe
|
|
6
|
-
: function (size) {
|
|
7
|
-
return new Buffer(size);
|
|
8
|
-
};
|
|
9
|
-
//# sourceMappingURL=buffer_utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"buffer_utils.js","sourceRoot":"","sources":["../../source/buffer_utils.ts"],"names":[],"mappings":";;;AAkCa,QAAA,6BAA6B,GAAG,MAAM,CAAC,WAAW;IAC3D,CAAC,CAAC,MAAM,CAAC,WAAW;IACpB,CAAC,CAAC,UAAC,IAAY;QAET,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC,CAAC"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CertificatePurpose = void 0;
|
|
4
|
-
var CertificatePurpose;
|
|
5
|
-
(function (CertificatePurpose) {
|
|
6
|
-
CertificatePurpose[CertificatePurpose["NotSpecified"] = 0] = "NotSpecified";
|
|
7
|
-
CertificatePurpose[CertificatePurpose["ForCertificateAuthority"] = 1] = "ForCertificateAuthority";
|
|
8
|
-
CertificatePurpose[CertificatePurpose["ForApplication"] = 2] = "ForApplication";
|
|
9
|
-
CertificatePurpose[CertificatePurpose["ForUserAuthentication"] = 3] = "ForUserAuthentication";
|
|
10
|
-
})(CertificatePurpose || (exports.CertificatePurpose = CertificatePurpose = {}));
|
|
11
|
-
//# sourceMappingURL=common.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../source/common.ts"],"names":[],"mappings":";;;AAsCA,IAAY,kBAKX;AALD,WAAY,kBAAkB;IAC1B,2EAAgB,CAAA;IAChB,iGAA2B,CAAA;IAC3B,+EAAkB,CAAA;IAClB,6FAAyB,CAAA;AAC7B,CAAC,EALW,kBAAkB,kCAAlB,kBAAkB,QAK7B"}
|
|
@@ -1,367 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.combine_der = exports.split_der = exports.exploreCertificate = exports.readTbsCertificate = exports._readExtension = void 0;
|
|
7
|
-
var assert_1 = __importDefault(require("assert"));
|
|
8
|
-
var asn1_js_1 = require("./asn1.js");
|
|
9
|
-
var crypto_utils_js_1 = require("./crypto_utils.js");
|
|
10
|
-
var doDebug = false;
|
|
11
|
-
function _readAttributeTypeAndValue(buffer, block) {
|
|
12
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
13
|
-
inner_blocks = (0, asn1_js_1._readStruct)(buffer, inner_blocks[0]);
|
|
14
|
-
var data = {
|
|
15
|
-
identifier: (0, asn1_js_1._readObjectIdentifier)(buffer, inner_blocks[0]).name,
|
|
16
|
-
value: (0, asn1_js_1._readValue)(buffer, inner_blocks[1]),
|
|
17
|
-
};
|
|
18
|
-
var result = {};
|
|
19
|
-
for (var _i = 0, _a = Object.entries(data); _i < _a.length; _i++) {
|
|
20
|
-
var _b = _a[_i], key = _b[0], value = _b[1];
|
|
21
|
-
result[key] = value;
|
|
22
|
-
}
|
|
23
|
-
return result;
|
|
24
|
-
}
|
|
25
|
-
function _readRelativeDistinguishedName(buffer, block) {
|
|
26
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
27
|
-
var data = inner_blocks.map(function (block) { return _readAttributeTypeAndValue(buffer, block); });
|
|
28
|
-
var result = {};
|
|
29
|
-
for (var _i = 0, data_1 = data; _i < data_1.length; _i++) {
|
|
30
|
-
var e = data_1[_i];
|
|
31
|
-
result[e.identifier] = e.value;
|
|
32
|
-
}
|
|
33
|
-
return result;
|
|
34
|
-
}
|
|
35
|
-
function _readName(buffer, block) {
|
|
36
|
-
return _readRelativeDistinguishedName(buffer, block);
|
|
37
|
-
}
|
|
38
|
-
function _readValidity(buffer, block) {
|
|
39
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
40
|
-
return {
|
|
41
|
-
notBefore: (0, asn1_js_1._readTime)(buffer, inner_blocks[0]),
|
|
42
|
-
notAfter: (0, asn1_js_1._readTime)(buffer, inner_blocks[1]),
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
function _readAuthorityKeyIdentifier(buffer) {
|
|
46
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
47
|
-
var blocks = (0, asn1_js_1._readStruct)(buffer, block_info);
|
|
48
|
-
var keyIdentifier_block = (0, asn1_js_1._findBlockAtIndex)(blocks, 0);
|
|
49
|
-
var authorityCertIssuer_block = (0, asn1_js_1._findBlockAtIndex)(blocks, 1);
|
|
50
|
-
var authorityCertSerialNumber_block = (0, asn1_js_1._findBlockAtIndex)(blocks, 2);
|
|
51
|
-
function _readAuthorityCertIssuer(block) {
|
|
52
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
53
|
-
var directoryName_block = (0, asn1_js_1._findBlockAtIndex)(inner_blocks, 4);
|
|
54
|
-
if (directoryName_block) {
|
|
55
|
-
var a = (0, asn1_js_1._readStruct)(buffer, directoryName_block);
|
|
56
|
-
return (0, asn1_js_1._readDirectoryName)(buffer, a[0]);
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
throw new Error("Invalid _readAuthorityCertIssuer");
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
function _readAuthorityCertIssuerFingerPrint(block) {
|
|
63
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
64
|
-
var directoryName_block = (0, asn1_js_1._findBlockAtIndex)(inner_blocks, 4);
|
|
65
|
-
if (!directoryName_block) {
|
|
66
|
-
return "";
|
|
67
|
-
}
|
|
68
|
-
var a = (0, asn1_js_1._readStruct)(buffer, directoryName_block);
|
|
69
|
-
if (a.length < 1) {
|
|
70
|
-
return "";
|
|
71
|
-
}
|
|
72
|
-
return directoryName_block ? (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, crypto_utils_js_1.makeSHA1Thumbprint)((0, asn1_js_1._getBlock)(buffer, a[0]))) : "";
|
|
73
|
-
}
|
|
74
|
-
var authorityCertIssuer = authorityCertIssuer_block ? _readAuthorityCertIssuer(authorityCertIssuer_block) : null;
|
|
75
|
-
var authorityCertIssuerFingerPrint = authorityCertIssuer_block
|
|
76
|
-
? _readAuthorityCertIssuerFingerPrint(authorityCertIssuer_block)
|
|
77
|
-
: "";
|
|
78
|
-
return {
|
|
79
|
-
authorityCertIssuer: authorityCertIssuer,
|
|
80
|
-
authorityCertIssuerFingerPrint: authorityCertIssuerFingerPrint,
|
|
81
|
-
serial: authorityCertSerialNumber_block
|
|
82
|
-
? (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, asn1_js_1._getBlock)(buffer, authorityCertSerialNumber_block))
|
|
83
|
-
: null,
|
|
84
|
-
keyIdentifier: keyIdentifier_block ? (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, asn1_js_1._getBlock)(buffer, keyIdentifier_block)) : null,
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
function readBasicConstraint2_5_29_19(buffer, block) {
|
|
88
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
89
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block_info);
|
|
90
|
-
var cA = inner_blocks.length > 0 ? (0, asn1_js_1._readBooleanValue)(buffer, inner_blocks[0]) : false;
|
|
91
|
-
var pathLengthConstraint = 0;
|
|
92
|
-
if (inner_blocks.length > 1) {
|
|
93
|
-
pathLengthConstraint = (0, asn1_js_1._readIntegerValue)(buffer, inner_blocks[1]);
|
|
94
|
-
}
|
|
95
|
-
return { critical: true, cA: cA, pathLengthConstraint: pathLengthConstraint };
|
|
96
|
-
}
|
|
97
|
-
function _readGeneralNames(buffer, block) {
|
|
98
|
-
var _data = {
|
|
99
|
-
1: { name: "rfc822Name", type: "IA5String" },
|
|
100
|
-
2: { name: "dNSName", type: "IA5String" },
|
|
101
|
-
3: { name: "x400Address", type: "ORAddress" },
|
|
102
|
-
4: { name: "directoryName", type: "Name" },
|
|
103
|
-
5: { name: "ediPartyName", type: "EDIPartyName" },
|
|
104
|
-
6: { name: "uniformResourceIdentifier", type: "IA5String" },
|
|
105
|
-
7: { name: "iPAddress", type: "OCTET_STRING" },
|
|
106
|
-
8: { name: "registeredID", type: "OBJECT_IDENTIFIER" },
|
|
107
|
-
};
|
|
108
|
-
var blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
109
|
-
function _readFromType(buffer, block, type) {
|
|
110
|
-
switch (type) {
|
|
111
|
-
case "IA5String":
|
|
112
|
-
return buffer.subarray(block.position, block.position + block.length).toString("ascii");
|
|
113
|
-
default:
|
|
114
|
-
return buffer.subarray(block.position, block.position + block.length).toString("hex");
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
var n = {};
|
|
118
|
-
for (var _i = 0, blocks_1 = blocks; _i < blocks_1.length; _i++) {
|
|
119
|
-
var block_1 = blocks_1[_i];
|
|
120
|
-
(0, assert_1.default)((block_1.tag & 0x80) === 0x80);
|
|
121
|
-
var t = block_1.tag & 0x7f;
|
|
122
|
-
var type = _data[t];
|
|
123
|
-
if (!type) {
|
|
124
|
-
throw new Error(" INVALID TYPE => " + t + "0x" + t.toString(16));
|
|
125
|
-
}
|
|
126
|
-
n[type.name] = n[type.name] || [];
|
|
127
|
-
n[type.name].push(_readFromType(buffer, block_1, type.type));
|
|
128
|
-
}
|
|
129
|
-
return n;
|
|
130
|
-
}
|
|
131
|
-
function _readSubjectAltNames(buffer) {
|
|
132
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
133
|
-
return _readGeneralNames(buffer, block_info);
|
|
134
|
-
}
|
|
135
|
-
function readKeyUsage(oid, buffer) {
|
|
136
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
137
|
-
var b2 = 0x00;
|
|
138
|
-
var b3 = 0x00;
|
|
139
|
-
if (block_info.length > 1) {
|
|
140
|
-
b2 = buffer[block_info.position + 1];
|
|
141
|
-
b3 = block_info.length > 2 ? buffer[block_info.position + 2] : 0;
|
|
142
|
-
}
|
|
143
|
-
return {
|
|
144
|
-
digitalSignature: (b2 & 0x80) === 0x80,
|
|
145
|
-
nonRepudiation: (b2 & 0x40) === 0x40,
|
|
146
|
-
keyEncipherment: (b2 & 0x20) === 0x20,
|
|
147
|
-
dataEncipherment: (b2 & 0x10) === 0x10,
|
|
148
|
-
keyAgreement: (b2 & 0x08) === 0x08,
|
|
149
|
-
keyCertSign: (b2 & 0x04) === 0x04,
|
|
150
|
-
cRLSign: (b2 & 0x02) === 0x02,
|
|
151
|
-
encipherOnly: (b2 & 0x01) === 0x01,
|
|
152
|
-
decipherOnly: (b3 & 0x80) === 0x80,
|
|
153
|
-
};
|
|
154
|
-
}
|
|
155
|
-
function readExtKeyUsage(oid, buffer) {
|
|
156
|
-
(0, assert_1.default)(oid === "2.5.29.37");
|
|
157
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
158
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block_info);
|
|
159
|
-
var extKeyUsage = {
|
|
160
|
-
serverAuth: false,
|
|
161
|
-
clientAuth: false,
|
|
162
|
-
codeSigning: false,
|
|
163
|
-
emailProtection: false,
|
|
164
|
-
timeStamping: false,
|
|
165
|
-
ipsecEndSystem: false,
|
|
166
|
-
ipsecTunnel: false,
|
|
167
|
-
ipsecUser: false,
|
|
168
|
-
ocspSigning: false,
|
|
169
|
-
};
|
|
170
|
-
for (var _i = 0, inner_blocks_1 = inner_blocks; _i < inner_blocks_1.length; _i++) {
|
|
171
|
-
var block = inner_blocks_1[_i];
|
|
172
|
-
var identifier = (0, asn1_js_1._readObjectIdentifier)(buffer, block);
|
|
173
|
-
extKeyUsage[identifier.name] = true;
|
|
174
|
-
}
|
|
175
|
-
return extKeyUsage;
|
|
176
|
-
}
|
|
177
|
-
function _readSubjectPublicKey(buffer) {
|
|
178
|
-
var block_info = (0, asn1_js_1.readTag)(buffer, 0);
|
|
179
|
-
var blocks = (0, asn1_js_1._readStruct)(buffer, block_info);
|
|
180
|
-
return {
|
|
181
|
-
modulus: buffer.subarray(blocks[0].position + 1, blocks[0].position + blocks[0].length),
|
|
182
|
-
};
|
|
183
|
-
}
|
|
184
|
-
function _readExtension(buffer, block) {
|
|
185
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
186
|
-
if (inner_blocks.length === 3) {
|
|
187
|
-
(0, assert_1.default)(inner_blocks[1].tag === asn1_js_1.TagType.BOOLEAN);
|
|
188
|
-
inner_blocks[1] = inner_blocks[2];
|
|
189
|
-
}
|
|
190
|
-
var identifier = (0, asn1_js_1._readObjectIdentifier)(buffer, inner_blocks[0]);
|
|
191
|
-
var buf = (0, asn1_js_1._getBlock)(buffer, inner_blocks[1]);
|
|
192
|
-
var value = null;
|
|
193
|
-
switch (identifier.name) {
|
|
194
|
-
case "subjectKeyIdentifier":
|
|
195
|
-
value = (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, asn1_js_1._readOctetString)(buffer, inner_blocks[1]));
|
|
196
|
-
break;
|
|
197
|
-
case "subjectAltName":
|
|
198
|
-
value = _readSubjectAltNames(buf);
|
|
199
|
-
break;
|
|
200
|
-
case "authorityKeyIdentifier":
|
|
201
|
-
value = _readAuthorityKeyIdentifier(buf);
|
|
202
|
-
break;
|
|
203
|
-
case "basicConstraints":
|
|
204
|
-
value = readBasicConstraint2_5_29_19(buf, inner_blocks[1]);
|
|
205
|
-
break;
|
|
206
|
-
case "certExtension":
|
|
207
|
-
value = "basicConstraints ( not implemented yet) " + buf.toString("hex");
|
|
208
|
-
break;
|
|
209
|
-
case "extKeyUsage":
|
|
210
|
-
value = readExtKeyUsage(identifier.oid, buf);
|
|
211
|
-
break;
|
|
212
|
-
case "keyUsage":
|
|
213
|
-
value = readKeyUsage(identifier.oid, buf);
|
|
214
|
-
break;
|
|
215
|
-
default:
|
|
216
|
-
value = "Unknown " + identifier.name + buf.toString("hex");
|
|
217
|
-
}
|
|
218
|
-
return {
|
|
219
|
-
identifier: identifier,
|
|
220
|
-
value: value,
|
|
221
|
-
};
|
|
222
|
-
}
|
|
223
|
-
exports._readExtension = _readExtension;
|
|
224
|
-
function _readExtensions(buffer, block) {
|
|
225
|
-
(0, assert_1.default)(block.tag === 0xa3);
|
|
226
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
227
|
-
inner_blocks = (0, asn1_js_1._readStruct)(buffer, inner_blocks[0]);
|
|
228
|
-
var extensions = inner_blocks.map(function (block) { return _readExtension(buffer, block); });
|
|
229
|
-
var result = {};
|
|
230
|
-
for (var _i = 0, extensions_1 = extensions; _i < extensions_1.length; _i++) {
|
|
231
|
-
var e = extensions_1[_i];
|
|
232
|
-
result[e.identifier.name] = e.value;
|
|
233
|
-
}
|
|
234
|
-
return result;
|
|
235
|
-
}
|
|
236
|
-
function _readSubjectPublicKeyInfo(buffer, block) {
|
|
237
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
238
|
-
var algorithm = (0, asn1_js_1._readAlgorithmIdentifier)(buffer, inner_blocks[0]);
|
|
239
|
-
var subjectPublicKey = (0, asn1_js_1._readBitString)(buffer, inner_blocks[1]);
|
|
240
|
-
var data = subjectPublicKey.data;
|
|
241
|
-
var values = (0, asn1_js_1._readListOfInteger)(data);
|
|
242
|
-
return {
|
|
243
|
-
algorithm: algorithm.identifier,
|
|
244
|
-
keyLength: (values[0].length - 1),
|
|
245
|
-
subjectPublicKey: _readSubjectPublicKey(subjectPublicKey.data),
|
|
246
|
-
};
|
|
247
|
-
}
|
|
248
|
-
function _readSubjectECCPublicKeyInfo(buffer, block) {
|
|
249
|
-
var inner_blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
250
|
-
var algorithm = (0, asn1_js_1._readECCAlgorithmIdentifier)(buffer, inner_blocks[0]);
|
|
251
|
-
var subjectPublicKey = (0, asn1_js_1._readBitString)(buffer, inner_blocks[1]);
|
|
252
|
-
var data = subjectPublicKey.data;
|
|
253
|
-
return {
|
|
254
|
-
algorithm: algorithm.identifier,
|
|
255
|
-
keyLength: (data.length - 1),
|
|
256
|
-
subjectPublicKey: {
|
|
257
|
-
modulus: data,
|
|
258
|
-
},
|
|
259
|
-
};
|
|
260
|
-
}
|
|
261
|
-
function readTbsCertificate(buffer, block) {
|
|
262
|
-
var blocks = (0, asn1_js_1._readStruct)(buffer, block);
|
|
263
|
-
var version, serialNumber, signature, issuer, validity, subject, subjectFingerPrint, extensions;
|
|
264
|
-
var subjectPublicKeyInfo;
|
|
265
|
-
if (blocks.length === 6) {
|
|
266
|
-
version = 1;
|
|
267
|
-
serialNumber = (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, asn1_js_1._readLongIntegerValue)(buffer, blocks[0]));
|
|
268
|
-
signature = (0, asn1_js_1._readAlgorithmIdentifier)(buffer, blocks[1]);
|
|
269
|
-
issuer = _readName(buffer, blocks[2]);
|
|
270
|
-
validity = _readValidity(buffer, blocks[3]);
|
|
271
|
-
subject = _readName(buffer, blocks[4]);
|
|
272
|
-
subjectFingerPrint = (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, crypto_utils_js_1.makeSHA1Thumbprint)((0, asn1_js_1._getBlock)(buffer, blocks[4])));
|
|
273
|
-
subjectPublicKeyInfo = _readSubjectPublicKeyInfo(buffer, blocks[5]);
|
|
274
|
-
extensions = null;
|
|
275
|
-
}
|
|
276
|
-
else {
|
|
277
|
-
var version_block = (0, asn1_js_1._findBlockAtIndex)(blocks, 0);
|
|
278
|
-
if (!version_block) {
|
|
279
|
-
throw new Error("cannot find version block");
|
|
280
|
-
}
|
|
281
|
-
version = (0, asn1_js_1._readVersionValue)(buffer, version_block) + 1;
|
|
282
|
-
serialNumber = (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, asn1_js_1._readLongIntegerValue)(buffer, blocks[1]));
|
|
283
|
-
signature = (0, asn1_js_1._readAlgorithmIdentifier)(buffer, blocks[2]);
|
|
284
|
-
issuer = _readName(buffer, blocks[3]);
|
|
285
|
-
validity = _readValidity(buffer, blocks[4]);
|
|
286
|
-
subject = _readName(buffer, blocks[5]);
|
|
287
|
-
subjectFingerPrint = (0, asn1_js_1.formatBuffer2DigitHexWithColum)((0, crypto_utils_js_1.makeSHA1Thumbprint)((0, asn1_js_1._getBlock)(buffer, blocks[5])));
|
|
288
|
-
var inner_block = (0, asn1_js_1._readStruct)(buffer, blocks[6]);
|
|
289
|
-
var what_type = (0, asn1_js_1._readAlgorithmIdentifier)(buffer, inner_block[0]).identifier;
|
|
290
|
-
switch (what_type) {
|
|
291
|
-
case "rsaEncryption": {
|
|
292
|
-
subjectPublicKeyInfo = _readSubjectPublicKeyInfo(buffer, blocks[6]);
|
|
293
|
-
break;
|
|
294
|
-
}
|
|
295
|
-
case "ecPublicKey":
|
|
296
|
-
default: {
|
|
297
|
-
subjectPublicKeyInfo = _readSubjectECCPublicKeyInfo(buffer, blocks[6]);
|
|
298
|
-
break;
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
var extensionBlock = (0, asn1_js_1._findBlockAtIndex)(blocks, 3);
|
|
302
|
-
if (!extensionBlock) {
|
|
303
|
-
doDebug && console.log("X509 certificate is invalid : cannot find extension block version =" + version_block);
|
|
304
|
-
extensions = null;
|
|
305
|
-
}
|
|
306
|
-
else {
|
|
307
|
-
extensions = _readExtensions(buffer, extensionBlock);
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
return {
|
|
311
|
-
version: version,
|
|
312
|
-
serialNumber: serialNumber,
|
|
313
|
-
signature: signature,
|
|
314
|
-
issuer: issuer,
|
|
315
|
-
validity: validity,
|
|
316
|
-
subject: subject,
|
|
317
|
-
subjectFingerPrint: subjectFingerPrint,
|
|
318
|
-
subjectPublicKeyInfo: subjectPublicKeyInfo,
|
|
319
|
-
extensions: extensions,
|
|
320
|
-
};
|
|
321
|
-
}
|
|
322
|
-
exports.readTbsCertificate = readTbsCertificate;
|
|
323
|
-
function exploreCertificate(certificate) {
|
|
324
|
-
(0, assert_1.default)(certificate instanceof Buffer);
|
|
325
|
-
if (!certificate._exploreCertificate_cache) {
|
|
326
|
-
var block_info = (0, asn1_js_1.readTag)(certificate, 0);
|
|
327
|
-
var blocks = (0, asn1_js_1._readStruct)(certificate, block_info);
|
|
328
|
-
certificate._exploreCertificate_cache = {
|
|
329
|
-
tbsCertificate: readTbsCertificate(certificate, blocks[0]),
|
|
330
|
-
signatureAlgorithm: (0, asn1_js_1._readAlgorithmIdentifier)(certificate, blocks[1]),
|
|
331
|
-
signatureValue: (0, asn1_js_1._readSignatureValue)(certificate, blocks[2]),
|
|
332
|
-
};
|
|
333
|
-
}
|
|
334
|
-
return certificate._exploreCertificate_cache;
|
|
335
|
-
}
|
|
336
|
-
exports.exploreCertificate = exploreCertificate;
|
|
337
|
-
function split_der(certificateChain) {
|
|
338
|
-
var certificate_chain = [];
|
|
339
|
-
do {
|
|
340
|
-
var block_info = (0, asn1_js_1.readTag)(certificateChain, 0);
|
|
341
|
-
var length_1 = block_info.position + block_info.length;
|
|
342
|
-
var der_certificate = certificateChain.subarray(0, length_1);
|
|
343
|
-
certificate_chain.push(der_certificate);
|
|
344
|
-
certificateChain = certificateChain.subarray(length_1);
|
|
345
|
-
} while (certificateChain.length > 0);
|
|
346
|
-
return certificate_chain;
|
|
347
|
-
}
|
|
348
|
-
exports.split_der = split_der;
|
|
349
|
-
function combine_der(certificates) {
|
|
350
|
-
var _loop_1 = function (cert) {
|
|
351
|
-
var b = split_der(cert);
|
|
352
|
-
var sum = 0;
|
|
353
|
-
b.forEach(function (block) {
|
|
354
|
-
var block_info = (0, asn1_js_1.readTag)(block, 0);
|
|
355
|
-
(0, assert_1.default)(block_info.position + block_info.length === block.length);
|
|
356
|
-
sum += block.length;
|
|
357
|
-
});
|
|
358
|
-
(0, assert_1.default)(sum === cert.length);
|
|
359
|
-
};
|
|
360
|
-
for (var _i = 0, certificates_1 = certificates; _i < certificates_1.length; _i++) {
|
|
361
|
-
var cert = certificates_1[_i];
|
|
362
|
-
_loop_1(cert);
|
|
363
|
-
}
|
|
364
|
-
return Buffer.concat(certificates);
|
|
365
|
-
}
|
|
366
|
-
exports.combine_der = combine_der;
|
|
367
|
-
//# sourceMappingURL=crypto_explore_certificate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"crypto_explore_certificate.js","sourceRoot":"","sources":["../../source/crypto_explore_certificate.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,200 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.extractPublicKeyFromCertificate = exports.extractPublicKeyFromCertificateSync = exports.coerceCertificatePem = exports.privateDecrypt_long = exports.publicEncrypt_long = exports.privateDecrypt = exports.publicEncrypt = exports.privateDecrypt_native = exports.publicEncrypt_native = exports.PaddingAlgorithm = exports.RSA_PKCS1_PADDING = exports.RSA_PKCS1_OAEP_PADDING = exports.makeSHA1Thumbprint = exports.verifyMessageChunkSignature = exports.makeMessageChunkSignature = exports.hexDump = exports.convertPEMtoDER = exports.toPem = exports.removeTrailingLF = exports.identifyPemType = void 0;
|
|
7
|
-
var constants_1 = __importDefault(require("constants"));
|
|
8
|
-
var assert_1 = __importDefault(require("assert"));
|
|
9
|
-
var crypto_1 = require("crypto");
|
|
10
|
-
var hexy = require("hexy").hexy;
|
|
11
|
-
var buffer_utils_js_1 = require("./buffer_utils.js");
|
|
12
|
-
var crypto_explore_certificate_js_1 = require("./crypto_explore_certificate.js");
|
|
13
|
-
var jsrsasign = require("jsrsasign");
|
|
14
|
-
var PEM_REGEX = /^(-----BEGIN (.*)-----\r?\n([/+=a-zA-Z0-9\r\n]*)\r?\n-----END \2-----\r?\n?)/gm;
|
|
15
|
-
var PEM_TYPE_REGEX = /^(-----BEGIN (.*)-----)/m;
|
|
16
|
-
function identifyPemType(rawKey) {
|
|
17
|
-
if (rawKey instanceof Buffer) {
|
|
18
|
-
rawKey = rawKey.toString("utf8");
|
|
19
|
-
}
|
|
20
|
-
var match = PEM_TYPE_REGEX.exec(rawKey);
|
|
21
|
-
return !match ? undefined : match[2];
|
|
22
|
-
}
|
|
23
|
-
exports.identifyPemType = identifyPemType;
|
|
24
|
-
function removeTrailingLF(str) {
|
|
25
|
-
var tmp = str.replace(/(\r|\n)+$/m, "").replace(/\r\n/gm, "\n");
|
|
26
|
-
return tmp;
|
|
27
|
-
}
|
|
28
|
-
exports.removeTrailingLF = removeTrailingLF;
|
|
29
|
-
function toPem(raw_key, pem) {
|
|
30
|
-
(0, assert_1.default)(raw_key, "expecting a key");
|
|
31
|
-
(0, assert_1.default)(typeof pem === "string");
|
|
32
|
-
var pemType = identifyPemType(raw_key);
|
|
33
|
-
if (pemType) {
|
|
34
|
-
return raw_key instanceof Buffer ? removeTrailingLF(raw_key.toString("utf8")) : removeTrailingLF(raw_key);
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
pemType = pem;
|
|
38
|
-
(0, assert_1.default)(["CERTIFICATE REQUEST", "CERTIFICATE", "RSA PRIVATE KEY", "PUBLIC KEY", "X509 CRL"].indexOf(pemType) >= 0);
|
|
39
|
-
var b = raw_key.toString("base64");
|
|
40
|
-
var str = "-----BEGIN " + pemType + "-----\n";
|
|
41
|
-
while (b.length) {
|
|
42
|
-
str += b.substring(0, 64) + "\n";
|
|
43
|
-
b = b.substring(64);
|
|
44
|
-
}
|
|
45
|
-
str += "-----END " + pemType + "-----";
|
|
46
|
-
return str;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
exports.toPem = toPem;
|
|
50
|
-
function convertPEMtoDER(raw_key) {
|
|
51
|
-
var match;
|
|
52
|
-
var pemType;
|
|
53
|
-
var base64str;
|
|
54
|
-
var parts = [];
|
|
55
|
-
PEM_REGEX.lastIndex = 0;
|
|
56
|
-
while ((match = PEM_REGEX.exec(raw_key)) !== null) {
|
|
57
|
-
pemType = match[2];
|
|
58
|
-
base64str = match[3];
|
|
59
|
-
base64str = base64str.replace(/\r?\n/g, "");
|
|
60
|
-
parts.push(Buffer.from(base64str, "base64"));
|
|
61
|
-
}
|
|
62
|
-
return (0, crypto_explore_certificate_js_1.combine_der)(parts);
|
|
63
|
-
}
|
|
64
|
-
exports.convertPEMtoDER = convertPEMtoDER;
|
|
65
|
-
function hexDump(buffer, width) {
|
|
66
|
-
if (!buffer) {
|
|
67
|
-
return "<>";
|
|
68
|
-
}
|
|
69
|
-
width = width || 32;
|
|
70
|
-
if (buffer.length > 1024) {
|
|
71
|
-
return hexy(buffer.subarray(0, 1024), { width: width, format: "twos" }) + "\n .... ( " + buffer.length + ")";
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
return hexy(buffer, { width: width, format: "twos" });
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
exports.hexDump = hexDump;
|
|
78
|
-
function makeMessageChunkSignature(chunk, options) {
|
|
79
|
-
var signer = (0, crypto_1.createSign)(options.algorithm);
|
|
80
|
-
signer.update(chunk);
|
|
81
|
-
var signature = signer.sign(options.privateKey.hidden);
|
|
82
|
-
(0, assert_1.default)(!options.signatureLength || signature.length === options.signatureLength);
|
|
83
|
-
return signature;
|
|
84
|
-
}
|
|
85
|
-
exports.makeMessageChunkSignature = makeMessageChunkSignature;
|
|
86
|
-
function verifyMessageChunkSignature(blockToVerify, signature, options) {
|
|
87
|
-
var verify = (0, crypto_1.createVerify)(options.algorithm);
|
|
88
|
-
verify.update(blockToVerify);
|
|
89
|
-
return verify.verify(options.publicKey, signature);
|
|
90
|
-
}
|
|
91
|
-
exports.verifyMessageChunkSignature = verifyMessageChunkSignature;
|
|
92
|
-
function makeSHA1Thumbprint(buffer) {
|
|
93
|
-
return (0, crypto_1.createHash)("sha1").update(buffer).digest();
|
|
94
|
-
}
|
|
95
|
-
exports.makeSHA1Thumbprint = makeSHA1Thumbprint;
|
|
96
|
-
exports.RSA_PKCS1_OAEP_PADDING = constants_1.default.RSA_PKCS1_OAEP_PADDING;
|
|
97
|
-
exports.RSA_PKCS1_PADDING = constants_1.default.RSA_PKCS1_PADDING;
|
|
98
|
-
var PaddingAlgorithm;
|
|
99
|
-
(function (PaddingAlgorithm) {
|
|
100
|
-
PaddingAlgorithm[PaddingAlgorithm["RSA_PKCS1_OAEP_PADDING"] = 4] = "RSA_PKCS1_OAEP_PADDING";
|
|
101
|
-
PaddingAlgorithm[PaddingAlgorithm["RSA_PKCS1_PADDING"] = 1] = "RSA_PKCS1_PADDING";
|
|
102
|
-
})(PaddingAlgorithm || (exports.PaddingAlgorithm = PaddingAlgorithm = {}));
|
|
103
|
-
(0, assert_1.default)(PaddingAlgorithm.RSA_PKCS1_OAEP_PADDING === constants_1.default.RSA_PKCS1_OAEP_PADDING);
|
|
104
|
-
(0, assert_1.default)(PaddingAlgorithm.RSA_PKCS1_PADDING === constants_1.default.RSA_PKCS1_PADDING);
|
|
105
|
-
function publicEncrypt_native(buffer, publicKey, algorithm) {
|
|
106
|
-
if (algorithm === undefined) {
|
|
107
|
-
algorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
|
|
108
|
-
}
|
|
109
|
-
return (0, crypto_1.publicEncrypt)({
|
|
110
|
-
key: publicKey,
|
|
111
|
-
padding: algorithm,
|
|
112
|
-
}, buffer);
|
|
113
|
-
}
|
|
114
|
-
exports.publicEncrypt_native = publicEncrypt_native;
|
|
115
|
-
function privateDecrypt_native(buffer, privateKey, algorithm) {
|
|
116
|
-
if (algorithm === undefined) {
|
|
117
|
-
algorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
|
|
118
|
-
}
|
|
119
|
-
try {
|
|
120
|
-
return (0, crypto_1.privateDecrypt)({
|
|
121
|
-
key: privateKey.hidden,
|
|
122
|
-
padding: algorithm,
|
|
123
|
-
}, buffer);
|
|
124
|
-
}
|
|
125
|
-
catch (err) {
|
|
126
|
-
return Buffer.alloc(1);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
exports.privateDecrypt_native = privateDecrypt_native;
|
|
130
|
-
exports.publicEncrypt = publicEncrypt_native;
|
|
131
|
-
exports.privateDecrypt = privateDecrypt_native;
|
|
132
|
-
function publicEncrypt_long(buffer, publicKey, blockSize, padding, paddingAlgorithm) {
|
|
133
|
-
if (paddingAlgorithm === undefined) {
|
|
134
|
-
paddingAlgorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
|
|
135
|
-
}
|
|
136
|
-
if (paddingAlgorithm !== exports.RSA_PKCS1_PADDING && paddingAlgorithm !== exports.RSA_PKCS1_OAEP_PADDING) {
|
|
137
|
-
throw new Error("Invalid padding algorithm " + paddingAlgorithm);
|
|
138
|
-
}
|
|
139
|
-
var chunk_size = blockSize - padding;
|
|
140
|
-
var nbBlocks = Math.ceil(buffer.length / chunk_size);
|
|
141
|
-
var outputBuffer = (0, buffer_utils_js_1.createFastUninitializedBuffer)(nbBlocks * blockSize);
|
|
142
|
-
for (var i = 0; i < nbBlocks; i++) {
|
|
143
|
-
var currentBlock = buffer.subarray(chunk_size * i, chunk_size * (i + 1));
|
|
144
|
-
var encrypted_chunk = (0, exports.publicEncrypt)(currentBlock, publicKey, paddingAlgorithm);
|
|
145
|
-
if (encrypted_chunk.length !== blockSize) {
|
|
146
|
-
throw new Error("publicEncrypt_long unexpected chunk length ".concat(encrypted_chunk.length, " expecting ").concat(blockSize));
|
|
147
|
-
}
|
|
148
|
-
encrypted_chunk.copy(outputBuffer, i * blockSize);
|
|
149
|
-
}
|
|
150
|
-
return outputBuffer;
|
|
151
|
-
}
|
|
152
|
-
exports.publicEncrypt_long = publicEncrypt_long;
|
|
153
|
-
function privateDecrypt_long(buffer, privateKey, blockSize, paddingAlgorithm) {
|
|
154
|
-
paddingAlgorithm = paddingAlgorithm || exports.RSA_PKCS1_PADDING;
|
|
155
|
-
if (paddingAlgorithm !== exports.RSA_PKCS1_PADDING && paddingAlgorithm !== exports.RSA_PKCS1_OAEP_PADDING) {
|
|
156
|
-
throw new Error("Invalid padding algorithm " + paddingAlgorithm);
|
|
157
|
-
}
|
|
158
|
-
var nbBlocks = Math.ceil(buffer.length / blockSize);
|
|
159
|
-
var outputBuffer = (0, buffer_utils_js_1.createFastUninitializedBuffer)(nbBlocks * blockSize);
|
|
160
|
-
var total_length = 0;
|
|
161
|
-
for (var i = 0; i < nbBlocks; i++) {
|
|
162
|
-
var currentBlock = buffer.subarray(blockSize * i, Math.min(blockSize * (i + 1), buffer.length));
|
|
163
|
-
var decrypted_buf = (0, exports.privateDecrypt)(currentBlock, privateKey, paddingAlgorithm);
|
|
164
|
-
decrypted_buf.copy(outputBuffer, total_length);
|
|
165
|
-
total_length += decrypted_buf.length;
|
|
166
|
-
}
|
|
167
|
-
return outputBuffer.subarray(0, total_length);
|
|
168
|
-
}
|
|
169
|
-
exports.privateDecrypt_long = privateDecrypt_long;
|
|
170
|
-
function coerceCertificatePem(certificate) {
|
|
171
|
-
if (certificate instanceof Buffer) {
|
|
172
|
-
certificate = toPem(certificate, "CERTIFICATE");
|
|
173
|
-
}
|
|
174
|
-
(0, assert_1.default)(typeof certificate === "string");
|
|
175
|
-
return certificate;
|
|
176
|
-
}
|
|
177
|
-
exports.coerceCertificatePem = coerceCertificatePem;
|
|
178
|
-
function extractPublicKeyFromCertificateSync(certificate) {
|
|
179
|
-
certificate = coerceCertificatePem(certificate);
|
|
180
|
-
var key = jsrsasign.KEYUTIL.getKey(certificate);
|
|
181
|
-
var publicKeyAsPem = jsrsasign.KEYUTIL.getPEM(key);
|
|
182
|
-
(0, assert_1.default)(typeof publicKeyAsPem === "string");
|
|
183
|
-
return publicKeyAsPem;
|
|
184
|
-
}
|
|
185
|
-
exports.extractPublicKeyFromCertificateSync = extractPublicKeyFromCertificateSync;
|
|
186
|
-
function extractPublicKeyFromCertificate(certificate, callback) {
|
|
187
|
-
var err1 = null;
|
|
188
|
-
var keyPem;
|
|
189
|
-
try {
|
|
190
|
-
keyPem = extractPublicKeyFromCertificateSync(certificate);
|
|
191
|
-
}
|
|
192
|
-
catch (err) {
|
|
193
|
-
err1 = err;
|
|
194
|
-
}
|
|
195
|
-
setImmediate(function () {
|
|
196
|
-
callback(err1, keyPem);
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
exports.extractPublicKeyFromCertificate = extractPublicKeyFromCertificate;
|
|
200
|
-
//# sourceMappingURL=crypto_utils.js.map
|