node-opcua-crypto 4.1.0 → 4.3.0

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 (178) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +1 -1
  3. package/dist/chunk-5NV4OKIV.mjs +1 -0
  4. package/dist/chunk-KPKFYTZJ.mjs +173 -0
  5. package/dist/chunk-QSSIRHMR.mjs +6243 -0
  6. package/dist/index.js +6521 -0
  7. package/dist/index.mjs +224 -0
  8. package/dist/source/index.js +6346 -0
  9. package/dist/source/index.mjs +192 -0
  10. package/dist/source/index_web.js +6346 -0
  11. package/dist/source/index_web.mjs +191 -0
  12. package/dist/source_nodejs/index.js +4170 -0
  13. package/dist/source_nodejs/index.mjs +37 -0
  14. package/dist-types/index.d.ts +2 -0
  15. package/dist-types/source/common.d.ts +21 -1
  16. package/dist-types/source/crypto_utils2.d.ts +2 -3
  17. package/dist-types/source/make_private_key_from_pem.d.ts +1 -1
  18. package/dist-types/source/x509/_crypto.d.ts +2 -2
  19. package/dist-types/source/x509/coerce_private_key.d.ts +5 -3
  20. package/dist-types/source/x509/create_key_pair.d.ts +6 -0
  21. package/dist-types/source/x509/create_self_signed_certificate.d.ts +4 -0
  22. package/dist-types/source_nodejs/generate_private_key_filename.d.ts +6 -0
  23. package/dist-types/source_nodejs/read.d.ts +1 -0
  24. package/doc/.nojekyll +1 -0
  25. package/doc/assets/highlight.css +71 -0
  26. package/doc/assets/main.js +58 -0
  27. package/doc/assets/search.js +1 -0
  28. package/doc/assets/style.css +1379 -0
  29. package/doc/classes/Subject.html +76 -0
  30. package/doc/functions/combine_der.html +80 -0
  31. package/doc/functions/createPrivateKeyFromNodeJSCrypto.html +81 -0
  32. package/doc/functions/createSelfSignedCertificate.html +76 -0
  33. package/doc/functions/exploreCertificate.html +77 -0
  34. package/doc/functions/exploreCertificateInfo.html +80 -0
  35. package/doc/functions/explorePrivateKey.html +74 -0
  36. package/doc/functions/extractPublicKeyFromCertificate.html +92 -0
  37. package/doc/functions/generatePrivateKey.html +76 -0
  38. package/doc/functions/generatePrivateKeyFileAlternate.html +79 -0
  39. package/doc/functions/makeMessageChunkSignatureWithDerivedKeys.html +78 -0
  40. package/doc/functions/privateKeyToPEM.html +76 -0
  41. package/doc/functions/readCertificate.html +76 -0
  42. package/doc/functions/readPrivateKey.html +76 -0
  43. package/doc/functions/readPrivateKeyPEM.html +75 -0
  44. package/doc/functions/readPrivateRsaKey.html +74 -0
  45. package/doc/functions/readPublicKey.html +76 -0
  46. package/doc/functions/reduceLength.html +79 -0
  47. package/doc/functions/removePadding.html +77 -0
  48. package/doc/functions/rsaLengthPrivateKey.html +80 -0
  49. package/doc/functions/split_der.html +80 -0
  50. package/doc/functions/toPem2.html +80 -0
  51. package/doc/functions/verifyChunkSignature.html +82 -0
  52. package/doc/functions/verifyChunkSignatureWithDerivedKeys.html +78 -0
  53. package/doc/functions/verifyMessageChunkSignature.html +83 -0
  54. package/doc/index.html +128 -0
  55. package/doc/interfaces/CertificateInfo.html +135 -0
  56. package/doc/modules.html +96 -0
  57. package/node-opcua-crypto-4.2.0.tgz +0 -0
  58. package/package.json +84 -90
  59. package/dist-cjs/source/asn1.js +0 -304
  60. package/dist-cjs/source/asn1.js.map +0 -1
  61. package/dist-cjs/source/buffer_utils.js +0 -9
  62. package/dist-cjs/source/buffer_utils.js.map +0 -1
  63. package/dist-cjs/source/common.js +0 -11
  64. package/dist-cjs/source/common.js.map +0 -1
  65. package/dist-cjs/source/crypto_explore_certificate.js +0 -367
  66. package/dist-cjs/source/crypto_explore_certificate.js.map +0 -1
  67. package/dist-cjs/source/crypto_utils.js +0 -200
  68. package/dist-cjs/source/crypto_utils.js.map +0 -1
  69. package/dist-cjs/source/crypto_utils2.js +0 -71
  70. package/dist-cjs/source/crypto_utils2.js.map +0 -1
  71. package/dist-cjs/source/derived_keys.js +0 -133
  72. package/dist-cjs/source/derived_keys.js.map +0 -1
  73. package/dist-cjs/source/explore_certificate.js +0 -37
  74. package/dist-cjs/source/explore_certificate.js.map +0 -1
  75. package/dist-cjs/source/explore_certificate_revocation_list.js +0 -69
  76. package/dist-cjs/source/explore_certificate_revocation_list.js.map +0 -1
  77. package/dist-cjs/source/explore_certificate_signing_request.js +0 -45
  78. package/dist-cjs/source/explore_certificate_signing_request.js.map +0 -1
  79. package/dist-cjs/source/explore_private_key.js +0 -77
  80. package/dist-cjs/source/explore_private_key.js.map +0 -1
  81. package/dist-cjs/source/index.js +0 -38
  82. package/dist-cjs/source/index.js.map +0 -1
  83. package/dist-cjs/source/make_private_key_from_pem.js +0 -8
  84. package/dist-cjs/source/make_private_key_from_pem.js.map +0 -1
  85. package/dist-cjs/source/oid_map.js +0 -300
  86. package/dist-cjs/source/oid_map.js.map +0 -1
  87. package/dist-cjs/source/public_private_match.js +0 -32
  88. package/dist-cjs/source/public_private_match.js.map +0 -1
  89. package/dist-cjs/source/subject.js +0 -92
  90. package/dist-cjs/source/subject.js.map +0 -1
  91. package/dist-cjs/source/verify_certificate_signature.js +0 -117
  92. package/dist-cjs/source/verify_certificate_signature.js.map +0 -1
  93. package/dist-cjs/source/x509/_build_public_key.js +0 -69
  94. package/dist-cjs/source/x509/_build_public_key.js.map +0 -1
  95. package/dist-cjs/source/x509/_crypto.js +0 -50
  96. package/dist-cjs/source/x509/_crypto.js.map +0 -1
  97. package/dist-cjs/source/x509/_get_attributes.js +0 -39
  98. package/dist-cjs/source/x509/_get_attributes.js.map +0 -1
  99. package/dist-cjs/source/x509/coerce_private_key.js +0 -90
  100. package/dist-cjs/source/x509/coerce_private_key.js.map +0 -1
  101. package/dist-cjs/source/x509/create_certificate_signing_request.js +0 -92
  102. package/dist-cjs/source/x509/create_certificate_signing_request.js.map +0 -1
  103. package/dist-cjs/source/x509/create_key_pair.js +0 -123
  104. package/dist-cjs/source/x509/create_key_pair.js.map +0 -1
  105. package/dist-cjs/source/x509/create_self_signed_certificate.js +0 -102
  106. package/dist-cjs/source/x509/create_self_signed_certificate.js.map +0 -1
  107. package/dist-cjs/source_nodejs/generate_private_key_filename.js +0 -67
  108. package/dist-cjs/source_nodejs/generate_private_key_filename.js.map +0 -1
  109. package/dist-cjs/source_nodejs/index.js +0 -21
  110. package/dist-cjs/source_nodejs/index.js.map +0 -1
  111. package/dist-cjs/source_nodejs/read.js +0 -115
  112. package/dist-cjs/source_nodejs/read.js.map +0 -1
  113. package/dist-cjs/source_nodejs/read_certificate_revocation_list.js +0 -64
  114. package/dist-cjs/source_nodejs/read_certificate_revocation_list.js.map +0 -1
  115. package/dist-cjs/source_nodejs/read_certificate_signing_request.js +0 -64
  116. package/dist-cjs/source_nodejs/read_certificate_signing_request.js.map +0 -1
  117. package/dist-esm/source/asn1.js +0 -275
  118. package/dist-esm/source/asn1.js.map +0 -1
  119. package/dist-esm/source/buffer_utils.js +0 -6
  120. package/dist-esm/source/buffer_utils.js.map +0 -1
  121. package/dist-esm/source/common.js +0 -8
  122. package/dist-esm/source/common.js.map +0 -1
  123. package/dist-esm/source/crypto_explore_certificate.js +0 -356
  124. package/dist-esm/source/crypto_explore_certificate.js.map +0 -1
  125. package/dist-esm/source/crypto_utils.js +0 -179
  126. package/dist-esm/source/crypto_utils.js.map +0 -1
  127. package/dist-esm/source/crypto_utils2.js +0 -58
  128. package/dist-esm/source/crypto_utils2.js.map +0 -1
  129. package/dist-esm/source/derived_keys.js +0 -117
  130. package/dist-esm/source/derived_keys.js.map +0 -1
  131. package/dist-esm/source/explore_certificate.js +0 -29
  132. package/dist-esm/source/explore_certificate.js.map +0 -1
  133. package/dist-esm/source/explore_certificate_revocation_list.js +0 -64
  134. package/dist-esm/source/explore_certificate_revocation_list.js.map +0 -1
  135. package/dist-esm/source/explore_certificate_signing_request.js +0 -40
  136. package/dist-esm/source/explore_certificate_signing_request.js.map +0 -1
  137. package/dist-esm/source/explore_private_key.js +0 -73
  138. package/dist-esm/source/explore_private_key.js.map +0 -1
  139. package/dist-esm/source/index.js +0 -19
  140. package/dist-esm/source/index.js.map +0 -1
  141. package/dist-esm/source/make_private_key_from_pem.js +0 -4
  142. package/dist-esm/source/make_private_key_from_pem.js.map +0 -1
  143. package/dist-esm/source/oid_map.js +0 -297
  144. package/dist-esm/source/oid_map.js.map +0 -1
  145. package/dist-esm/source/public_private_match.js +0 -27
  146. package/dist-esm/source/public_private_match.js.map +0 -1
  147. package/dist-esm/source/subject.js +0 -89
  148. package/dist-esm/source/subject.js.map +0 -1
  149. package/dist-esm/source/verify_certificate_signature.js +0 -110
  150. package/dist-esm/source/verify_certificate_signature.js.map +0 -1
  151. package/dist-esm/source/x509/_build_public_key.js +0 -65
  152. package/dist-esm/source/x509/_build_public_key.js.map +0 -1
  153. package/dist-esm/source/x509/_crypto.js +0 -23
  154. package/dist-esm/source/x509/_crypto.js.map +0 -1
  155. package/dist-esm/source/x509/_get_attributes.js +0 -35
  156. package/dist-esm/source/x509/_get_attributes.js.map +0 -1
  157. package/dist-esm/source/x509/coerce_private_key.js +0 -85
  158. package/dist-esm/source/x509/coerce_private_key.js.map +0 -1
  159. package/dist-esm/source/x509/create_certificate_signing_request.js +0 -88
  160. package/dist-esm/source/x509/create_certificate_signing_request.js.map +0 -1
  161. package/dist-esm/source/x509/create_key_pair.js +0 -115
  162. package/dist-esm/source/x509/create_key_pair.js.map +0 -1
  163. package/dist-esm/source/x509/create_self_signed_certificate.js +0 -98
  164. package/dist-esm/source/x509/create_self_signed_certificate.js.map +0 -1
  165. package/dist-esm/source_nodejs/generate_private_key_filename.js +0 -60
  166. package/dist-esm/source_nodejs/generate_private_key_filename.js.map +0 -1
  167. package/dist-esm/source_nodejs/index.js +0 -5
  168. package/dist-esm/source_nodejs/index.js.map +0 -1
  169. package/dist-esm/source_nodejs/read.js +0 -99
  170. package/dist-esm/source_nodejs/read.js.map +0 -1
  171. package/dist-esm/source_nodejs/read_certificate_revocation_list.js +0 -57
  172. package/dist-esm/source_nodejs/read_certificate_revocation_list.js.map +0 -1
  173. package/dist-esm/source_nodejs/read_certificate_signing_request.js +0 -57
  174. package/dist-esm/source_nodejs/read_certificate_signing_request.js.map +0 -1
  175. package/index.d.ts +0 -2
  176. package/index.js +0 -4
  177. package/index_web.d.ts +0 -1
  178. package/index_web.js +0 -3
@@ -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.slice(block.position, block.position + block.length).toString("ascii");
113
- default:
114
- return buffer.slice(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.slice(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.slice(0, length_1);
343
- certificate_chain.push(der_certificate);
344
- certificateChain = certificateChain.slice(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
@@ -1 +0,0 @@
1
- {"version":3,"file":"crypto_utils.js","sourceRoot":"","sources":["../../source/crypto_utils.ts"],"names":[],"mappings":"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"}