node-opcua-crypto 2.2.0 → 3.0.0-beta.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.
Files changed (194) hide show
  1. package/{dist → dist-cjs}/source/asn1.js +95 -151
  2. package/dist-cjs/source/asn1.js.map +1 -0
  3. package/dist-cjs/source/buffer_utils.js +9 -0
  4. package/dist-cjs/source/buffer_utils.js.map +1 -0
  5. package/dist-cjs/source/common.js +11 -0
  6. package/dist-cjs/source/common.js.map +1 -0
  7. package/dist-cjs/source/crypto_explore_certificate.js +367 -0
  8. package/dist-cjs/source/crypto_explore_certificate.js.map +1 -0
  9. package/{dist → dist-cjs}/source/crypto_utils.js +80 -141
  10. package/dist-cjs/source/crypto_utils.js.map +1 -0
  11. package/dist-cjs/source/derived_keys.js +133 -0
  12. package/dist-cjs/source/derived_keys.js.map +1 -0
  13. package/{dist → dist-cjs}/source/explore_certificate.js +10 -17
  14. package/dist-cjs/source/explore_certificate.js.map +1 -0
  15. package/dist-cjs/source/explore_certificate_revocation_list.js +69 -0
  16. package/dist-cjs/source/explore_certificate_revocation_list.js.map +1 -0
  17. package/dist-cjs/source/explore_certificate_signing_request.js +45 -0
  18. package/dist-cjs/source/explore_certificate_signing_request.js.map +1 -0
  19. package/dist-cjs/source/explore_private_key.js +75 -0
  20. package/dist-cjs/source/explore_private_key.js.map +1 -0
  21. package/dist-cjs/source/index.js +32 -0
  22. package/dist-cjs/source/index.js.map +1 -0
  23. package/{dist → dist-cjs}/source/oid_map.js +0 -4
  24. package/dist-cjs/source/oid_map.js.map +1 -0
  25. package/dist-cjs/source/public_private_match.js +32 -0
  26. package/dist-cjs/source/public_private_match.js.map +1 -0
  27. package/dist-cjs/source/subject.js +92 -0
  28. package/dist-cjs/source/subject.js.map +1 -0
  29. package/dist-cjs/source/verify_certificate_signature.js +120 -0
  30. package/dist-cjs/source/verify_certificate_signature.js.map +1 -0
  31. package/dist-cjs/source/x509/_build_public_key.js +69 -0
  32. package/dist-cjs/source/x509/_build_public_key.js.map +1 -0
  33. package/dist-cjs/source/x509/_crypto.js +50 -0
  34. package/dist-cjs/source/x509/_crypto.js.map +1 -0
  35. package/dist-cjs/source/x509/_get_attributes.js +35 -0
  36. package/dist-cjs/source/x509/_get_attributes.js.map +1 -0
  37. package/dist-cjs/source/x509/create_certificate_signing_request.js +92 -0
  38. package/dist-cjs/source/x509/create_certificate_signing_request.js.map +1 -0
  39. package/dist-cjs/source/x509/create_key_pair.js +123 -0
  40. package/dist-cjs/source/x509/create_key_pair.js.map +1 -0
  41. package/dist-cjs/source/x509/create_self_signed_certificate.js +102 -0
  42. package/dist-cjs/source/x509/create_self_signed_certificate.js.map +1 -0
  43. package/dist-cjs/source_nodejs/generate_private_key_filename.js +67 -0
  44. package/dist-cjs/source_nodejs/generate_private_key_filename.js.map +1 -0
  45. package/{dist → dist-cjs}/source_nodejs/index.js +4 -3
  46. package/{dist → dist-cjs}/source_nodejs/index.js.map +1 -1
  47. package/{dist → dist-cjs}/source_nodejs/read.js +32 -43
  48. package/dist-cjs/source_nodejs/read.js.map +1 -0
  49. package/dist-cjs/source_nodejs/read_certificate_revocation_list.js +64 -0
  50. package/dist-cjs/source_nodejs/read_certificate_revocation_list.js.map +1 -0
  51. package/dist-cjs/source_nodejs/read_certificate_signing_request.js +64 -0
  52. package/dist-cjs/source_nodejs/read_certificate_signing_request.js.map +1 -0
  53. package/dist-esm/source/asn1.js +275 -0
  54. package/dist-esm/source/asn1.js.map +1 -0
  55. package/dist-esm/source/buffer_utils.js +6 -0
  56. package/dist-esm/source/buffer_utils.js.map +1 -0
  57. package/dist-esm/source/common.js +8 -0
  58. package/dist-esm/source/common.js.map +1 -0
  59. package/dist-esm/source/crypto_explore_certificate.js +356 -0
  60. package/dist-esm/source/crypto_explore_certificate.js.map +1 -0
  61. package/dist-esm/source/crypto_utils.js +242 -0
  62. package/dist-esm/source/crypto_utils.js.map +1 -0
  63. package/dist-esm/source/derived_keys.js +117 -0
  64. package/dist-esm/source/derived_keys.js.map +1 -0
  65. package/dist-esm/source/explore_certificate.js +29 -0
  66. package/dist-esm/source/explore_certificate.js.map +1 -0
  67. package/dist-esm/source/explore_certificate_revocation_list.js +64 -0
  68. package/dist-esm/source/explore_certificate_revocation_list.js.map +1 -0
  69. package/dist-esm/source/explore_certificate_signing_request.js +40 -0
  70. package/dist-esm/source/explore_certificate_signing_request.js.map +1 -0
  71. package/dist-esm/source/explore_private_key.js +71 -0
  72. package/dist-esm/source/explore_private_key.js.map +1 -0
  73. package/dist-esm/source/index.js +16 -0
  74. package/dist-esm/source/index.js.map +1 -0
  75. package/{source/oid_map.ts → dist-esm/source/oid_map.js} +2 -15
  76. package/dist-esm/source/oid_map.js.map +1 -0
  77. package/dist-esm/source/public_private_match.js +27 -0
  78. package/dist-esm/source/public_private_match.js.map +1 -0
  79. package/dist-esm/source/subject.js +89 -0
  80. package/dist-esm/source/subject.js.map +1 -0
  81. package/dist-esm/source/verify_certificate_signature.js +110 -0
  82. package/dist-esm/source/verify_certificate_signature.js.map +1 -0
  83. package/dist-esm/source/x509/_build_public_key.js +65 -0
  84. package/dist-esm/source/x509/_build_public_key.js.map +1 -0
  85. package/dist-esm/source/x509/_crypto.js +23 -0
  86. package/dist-esm/source/x509/_crypto.js.map +1 -0
  87. package/dist-esm/source/x509/_get_attributes.js +31 -0
  88. package/dist-esm/source/x509/_get_attributes.js.map +1 -0
  89. package/dist-esm/source/x509/create_certificate_signing_request.js +88 -0
  90. package/dist-esm/source/x509/create_certificate_signing_request.js.map +1 -0
  91. package/dist-esm/source/x509/create_key_pair.js +115 -0
  92. package/dist-esm/source/x509/create_key_pair.js.map +1 -0
  93. package/dist-esm/source/x509/create_self_signed_certificate.js +98 -0
  94. package/dist-esm/source/x509/create_self_signed_certificate.js.map +1 -0
  95. package/dist-esm/source_nodejs/generate_private_key_filename.js +60 -0
  96. package/dist-esm/source_nodejs/generate_private_key_filename.js.map +1 -0
  97. package/dist-esm/source_nodejs/index.js +5 -0
  98. package/dist-esm/source_nodejs/index.js.map +1 -0
  99. package/dist-esm/source_nodejs/read.js +81 -0
  100. package/dist-esm/source_nodejs/read.js.map +1 -0
  101. package/dist-esm/source_nodejs/read_certificate_revocation_list.js +57 -0
  102. package/dist-esm/source_nodejs/read_certificate_revocation_list.js.map +1 -0
  103. package/dist-esm/source_nodejs/read_certificate_signing_request.js +57 -0
  104. package/dist-esm/source_nodejs/read_certificate_signing_request.js.map +1 -0
  105. package/{dist → dist-types}/source/common.d.ts +6 -0
  106. package/{dist → dist-types}/source/crypto_explore_certificate.d.ts +3 -3
  107. package/{dist → dist-types}/source/crypto_utils.d.ts +2 -2
  108. package/{dist → dist-types}/source/derived_keys.d.ts +2 -2
  109. package/{dist → dist-types}/source/explore_certificate.d.ts +3 -6
  110. package/{dist → dist-types}/source/explore_certificate_revocation_list.d.ts +2 -2
  111. package/{dist → dist-types}/source/explore_certificate_signing_request.d.ts +2 -2
  112. package/{dist → dist-types}/source/explore_private_key.d.ts +1 -1
  113. package/dist-types/source/index.d.ts +18 -0
  114. package/{dist → dist-types}/source/public_private_match.d.ts +1 -1
  115. package/dist-types/source/subject.d.ts +27 -0
  116. package/{dist → dist-types}/source/verify_certificate_signature.d.ts +1 -1
  117. package/dist-types/source/x509/_build_public_key.d.ts +1 -0
  118. package/dist-types/source/x509/_crypto.d.ts +2 -0
  119. package/dist-types/source/x509/_get_attributes.d.ts +8 -0
  120. package/dist-types/source/x509/create_certificate_signing_request.d.ts +18 -0
  121. package/dist-types/source/x509/create_key_pair.d.ts +8 -0
  122. package/dist-types/source/x509/create_self_signed_certificate.d.ts +17 -0
  123. package/dist-types/source_nodejs/generate_private_key_filename.d.ts +1 -0
  124. package/dist-types/source_nodejs/index.d.ts +4 -0
  125. package/{dist → dist-types}/source_nodejs/read.d.ts +1 -1
  126. package/{dist → dist-types}/source_nodejs/read_certificate_revocation_list.d.ts +1 -1
  127. package/index.d.ts +2 -2
  128. package/index.js +2 -2
  129. package/index_web.d.ts +1 -0
  130. package/index_web.js +1 -1
  131. package/package.json +31 -7
  132. package/web/esbuild.mjs +15 -0
  133. package/web/index.html +9 -0
  134. package/web/main.js +28 -0
  135. package/web/rollup.config.mjs +20 -0
  136. package/.fossa.yml +0 -18
  137. package/.github/FUNDING.yml +0 -12
  138. package/.github/workflows/main.yml +0 -106
  139. package/.prettierrc.js +0 -7
  140. package/dist/source/asn1.js.map +0 -1
  141. package/dist/source/buffer_utils.js +0 -22
  142. package/dist/source/buffer_utils.js.map +0 -1
  143. package/dist/source/common.js +0 -3
  144. package/dist/source/common.js.map +0 -1
  145. package/dist/source/crypto_explore_certificate.js +0 -602
  146. package/dist/source/crypto_explore_certificate.js.map +0 -1
  147. package/dist/source/crypto_utils.js.map +0 -1
  148. package/dist/source/derived_keys.js +0 -249
  149. package/dist/source/derived_keys.js.map +0 -1
  150. package/dist/source/explore_certificate.js.map +0 -1
  151. package/dist/source/explore_certificate_revocation_list.js +0 -70
  152. package/dist/source/explore_certificate_revocation_list.js.map +0 -1
  153. package/dist/source/explore_certificate_signing_request.js +0 -45
  154. package/dist/source/explore_certificate_signing_request.js.map +0 -1
  155. package/dist/source/explore_private_key.js +0 -98
  156. package/dist/source/explore_private_key.js.map +0 -1
  157. package/dist/source/index.d.ts +0 -13
  158. package/dist/source/index.js +0 -30
  159. package/dist/source/index.js.map +0 -1
  160. package/dist/source/oid_map.js.map +0 -1
  161. package/dist/source/public_private_match.js +0 -37
  162. package/dist/source/public_private_match.js.map +0 -1
  163. package/dist/source/verify_certificate_signature.js +0 -102
  164. package/dist/source/verify_certificate_signature.js.map +0 -1
  165. package/dist/source_nodejs/index.d.ts +0 -3
  166. package/dist/source_nodejs/read.js.map +0 -1
  167. package/dist/source_nodejs/read_certificate_revocation_list.js +0 -28
  168. package/dist/source_nodejs/read_certificate_revocation_list.js.map +0 -1
  169. package/dist/source_nodejs/read_certificate_signing_request.js +0 -28
  170. package/dist/source_nodejs/read_certificate_signing_request.js.map +0 -1
  171. package/source/asn1.ts +0 -404
  172. package/source/buffer_utils.ts +0 -18
  173. package/source/common.ts +0 -15
  174. package/source/crypto_explore_certificate.ts +0 -764
  175. package/source/crypto_utils.ts +0 -376
  176. package/source/derived_keys.ts +0 -287
  177. package/source/explore_certificate.ts +0 -66
  178. package/source/explore_certificate_revocation_list.ts +0 -122
  179. package/source/explore_certificate_signing_request.ts +0 -58
  180. package/source/explore_private_key.ts +0 -119
  181. package/source/index.ts +0 -13
  182. package/source/public_private_match.ts +0 -37
  183. package/source/verify_certificate_signature.ts +0 -105
  184. package/source_nodejs/index.ts +0 -3
  185. package/source_nodejs/read.ts +0 -105
  186. package/source_nodejs/read_certificate_revocation_list.ts +0 -14
  187. package/source_nodejs/read_certificate_signing_request.ts +0 -17
  188. package/test_certificate.ts +0 -34
  189. package/tsconfig.json +0 -18
  190. package/tslint.json +0 -35
  191. /package/{dist → dist-types}/source/asn1.d.ts +0 -0
  192. /package/{dist → dist-types}/source/buffer_utils.d.ts +0 -0
  193. /package/{dist → dist-types}/source/oid_map.d.ts +0 -0
  194. /package/{dist → dist-types}/source_nodejs/read_certificate_signing_request.d.ts +0 -0
@@ -0,0 +1,356 @@
1
+ import assert from "assert";
2
+ import { _readBitString, TagType, readTag, _getBlock, _readStruct, formatBuffer2DigitHexWithColum, _readOctetString, _readListOfInteger, _readObjectIdentifier, _readAlgorithmIdentifier, _readECCAlgorithmIdentifier, _readBooleanValue, _readIntegerValue, _readLongIntegerValue, _readVersionValue, _readSignatureValue, _readValue, _readTime, _findBlockAtIndex, _readDirectoryName, } from "./asn1.js";
3
+ import { makeSHA1Thumbprint } from "./crypto_utils.js";
4
+ var doDebug = false;
5
+ function _readAttributeTypeAndValue(buffer, block) {
6
+ var inner_blocks = _readStruct(buffer, block);
7
+ inner_blocks = _readStruct(buffer, inner_blocks[0]);
8
+ var data = {
9
+ identifier: _readObjectIdentifier(buffer, inner_blocks[0]).name,
10
+ value: _readValue(buffer, inner_blocks[1]),
11
+ };
12
+ var result = {};
13
+ for (var _i = 0, _a = Object.entries(data); _i < _a.length; _i++) {
14
+ var _b = _a[_i], key = _b[0], value = _b[1];
15
+ result[key] = value;
16
+ }
17
+ return result;
18
+ }
19
+ function _readRelativeDistinguishedName(buffer, block) {
20
+ var inner_blocks = _readStruct(buffer, block);
21
+ var data = inner_blocks.map(function (block) { return _readAttributeTypeAndValue(buffer, block); });
22
+ var result = {};
23
+ for (var _i = 0, data_1 = data; _i < data_1.length; _i++) {
24
+ var e = data_1[_i];
25
+ result[e.identifier] = e.value;
26
+ }
27
+ return result;
28
+ }
29
+ function _readName(buffer, block) {
30
+ return _readRelativeDistinguishedName(buffer, block);
31
+ }
32
+ function _readValidity(buffer, block) {
33
+ var inner_blocks = _readStruct(buffer, block);
34
+ return {
35
+ notBefore: _readTime(buffer, inner_blocks[0]),
36
+ notAfter: _readTime(buffer, inner_blocks[1]),
37
+ };
38
+ }
39
+ function _readAuthorityKeyIdentifier(buffer) {
40
+ var block_info = readTag(buffer, 0);
41
+ var blocks = _readStruct(buffer, block_info);
42
+ var keyIdentifier_block = _findBlockAtIndex(blocks, 0);
43
+ var authorityCertIssuer_block = _findBlockAtIndex(blocks, 1);
44
+ var authorityCertSerialNumber_block = _findBlockAtIndex(blocks, 2);
45
+ function _readAuthorityCertIssuer(block) {
46
+ var inner_blocks = _readStruct(buffer, block);
47
+ var directoryName_block = _findBlockAtIndex(inner_blocks, 4);
48
+ if (directoryName_block) {
49
+ var a = _readStruct(buffer, directoryName_block);
50
+ return _readDirectoryName(buffer, a[0]);
51
+ }
52
+ else {
53
+ throw new Error("Invalid _readAuthorityCertIssuer");
54
+ }
55
+ }
56
+ function _readAuthorityCertIssuerFingerPrint(block) {
57
+ var inner_blocks = _readStruct(buffer, block);
58
+ var directoryName_block = _findBlockAtIndex(inner_blocks, 4);
59
+ if (!directoryName_block) {
60
+ return "";
61
+ }
62
+ var a = _readStruct(buffer, directoryName_block);
63
+ if (a.length < 1) {
64
+ return "";
65
+ }
66
+ return directoryName_block ? formatBuffer2DigitHexWithColum(makeSHA1Thumbprint(_getBlock(buffer, a[0]))) : "";
67
+ }
68
+ var authorityCertIssuer = authorityCertIssuer_block ? _readAuthorityCertIssuer(authorityCertIssuer_block) : null;
69
+ var authorityCertIssuerFingerPrint = authorityCertIssuer_block
70
+ ? _readAuthorityCertIssuerFingerPrint(authorityCertIssuer_block)
71
+ : "";
72
+ return {
73
+ authorityCertIssuer: authorityCertIssuer,
74
+ authorityCertIssuerFingerPrint: authorityCertIssuerFingerPrint,
75
+ serial: authorityCertSerialNumber_block
76
+ ? formatBuffer2DigitHexWithColum(_getBlock(buffer, authorityCertSerialNumber_block))
77
+ : null,
78
+ keyIdentifier: keyIdentifier_block ? formatBuffer2DigitHexWithColum(_getBlock(buffer, keyIdentifier_block)) : null,
79
+ };
80
+ }
81
+ function readBasicConstraint2_5_29_19(buffer, block) {
82
+ var block_info = readTag(buffer, 0);
83
+ var inner_blocks = _readStruct(buffer, block_info);
84
+ var cA = inner_blocks.length > 0 ? _readBooleanValue(buffer, inner_blocks[0]) : false;
85
+ var pathLengthConstraint = 0;
86
+ if (inner_blocks.length > 1) {
87
+ pathLengthConstraint = _readIntegerValue(buffer, inner_blocks[1]);
88
+ }
89
+ return { critical: true, cA: cA, pathLengthConstraint: pathLengthConstraint };
90
+ }
91
+ function _readGeneralNames(buffer, block) {
92
+ var _data = {
93
+ 1: { name: "rfc822Name", type: "IA5String" },
94
+ 2: { name: "dNSName", type: "IA5String" },
95
+ 3: { name: "x400Address", type: "ORAddress" },
96
+ 4: { name: "directoryName", type: "Name" },
97
+ 5: { name: "ediPartyName", type: "EDIPartyName" },
98
+ 6: { name: "uniformResourceIdentifier", type: "IA5String" },
99
+ 7: { name: "iPAddress", type: "OCTET_STRING" },
100
+ 8: { name: "registeredID", type: "OBJECT_IDENTIFIER" },
101
+ };
102
+ var blocks = _readStruct(buffer, block);
103
+ function _readFromType(buffer, block, type) {
104
+ switch (type) {
105
+ case "IA5String":
106
+ return buffer.slice(block.position, block.position + block.length).toString("ascii");
107
+ default:
108
+ return buffer.slice(block.position, block.position + block.length).toString("hex");
109
+ }
110
+ }
111
+ var n = {};
112
+ for (var _i = 0, blocks_1 = blocks; _i < blocks_1.length; _i++) {
113
+ var block_1 = blocks_1[_i];
114
+ assert((block_1.tag & 0x80) === 0x80);
115
+ var t = block_1.tag & 0x7f;
116
+ var type = _data[t];
117
+ if (!type) {
118
+ throw new Error(" INVALID TYPE => " + t + "0x" + t.toString(16));
119
+ }
120
+ n[type.name] = n[type.name] || [];
121
+ n[type.name].push(_readFromType(buffer, block_1, type.type));
122
+ }
123
+ return n;
124
+ }
125
+ function _readSubjectAltNames(buffer) {
126
+ var block_info = readTag(buffer, 0);
127
+ return _readGeneralNames(buffer, block_info);
128
+ }
129
+ function readKeyUsage(oid, buffer) {
130
+ var block_info = readTag(buffer, 0);
131
+ var b2 = 0x00;
132
+ var b3 = 0x00;
133
+ if (block_info.length > 1) {
134
+ b2 = buffer[block_info.position + 1];
135
+ b3 = block_info.length > 2 ? buffer[block_info.position + 2] : 0;
136
+ }
137
+ return {
138
+ digitalSignature: (b2 & 0x80) === 0x80,
139
+ nonRepudiation: (b2 & 0x40) === 0x40,
140
+ keyEncipherment: (b2 & 0x20) === 0x20,
141
+ dataEncipherment: (b2 & 0x10) === 0x10,
142
+ keyAgreement: (b2 & 0x08) === 0x08,
143
+ keyCertSign: (b2 & 0x04) === 0x04,
144
+ cRLSign: (b2 & 0x02) === 0x02,
145
+ encipherOnly: (b2 & 0x01) === 0x01,
146
+ decipherOnly: (b3 & 0x80) === 0x80,
147
+ };
148
+ }
149
+ function readExtKeyUsage(oid, buffer) {
150
+ assert(oid === "2.5.29.37");
151
+ var block_info = readTag(buffer, 0);
152
+ var inner_blocks = _readStruct(buffer, block_info);
153
+ var extKeyUsage = {
154
+ serverAuth: false,
155
+ clientAuth: false,
156
+ codeSigning: false,
157
+ emailProtection: false,
158
+ timeStamping: false,
159
+ ipsecEndSystem: false,
160
+ ipsecTunnel: false,
161
+ ipsecUser: false,
162
+ ocspSigning: false,
163
+ };
164
+ for (var _i = 0, inner_blocks_1 = inner_blocks; _i < inner_blocks_1.length; _i++) {
165
+ var block = inner_blocks_1[_i];
166
+ var identifier = _readObjectIdentifier(buffer, block);
167
+ extKeyUsage[identifier.name] = true;
168
+ }
169
+ return extKeyUsage;
170
+ }
171
+ function _readSubjectPublicKey(buffer) {
172
+ var block_info = readTag(buffer, 0);
173
+ var blocks = _readStruct(buffer, block_info);
174
+ return {
175
+ modulus: buffer.slice(blocks[0].position + 1, blocks[0].position + blocks[0].length),
176
+ };
177
+ }
178
+ export function _readExtension(buffer, block) {
179
+ var inner_blocks = _readStruct(buffer, block);
180
+ if (inner_blocks.length === 3) {
181
+ assert(inner_blocks[1].tag === TagType.BOOLEAN);
182
+ inner_blocks[1] = inner_blocks[2];
183
+ }
184
+ var identifier = _readObjectIdentifier(buffer, inner_blocks[0]);
185
+ var buf = _getBlock(buffer, inner_blocks[1]);
186
+ var value = null;
187
+ switch (identifier.name) {
188
+ case "subjectKeyIdentifier":
189
+ value = formatBuffer2DigitHexWithColum(_readOctetString(buffer, inner_blocks[1]));
190
+ break;
191
+ case "subjectAltName":
192
+ value = _readSubjectAltNames(buf);
193
+ break;
194
+ case "authorityKeyIdentifier":
195
+ value = _readAuthorityKeyIdentifier(buf);
196
+ break;
197
+ case "basicConstraints":
198
+ value = readBasicConstraint2_5_29_19(buf, inner_blocks[1]);
199
+ break;
200
+ case "certExtension":
201
+ value = "basicConstraints ( not implemented yet) " + buf.toString("hex");
202
+ break;
203
+ case "extKeyUsage":
204
+ value = readExtKeyUsage(identifier.oid, buf);
205
+ break;
206
+ case "keyUsage":
207
+ value = readKeyUsage(identifier.oid, buf);
208
+ break;
209
+ default:
210
+ value = "Unknown " + identifier.name + buf.toString("hex");
211
+ }
212
+ return {
213
+ identifier: identifier,
214
+ value: value,
215
+ };
216
+ }
217
+ function _readExtensions(buffer, block) {
218
+ assert(block.tag === 0xa3);
219
+ var inner_blocks = _readStruct(buffer, block);
220
+ inner_blocks = _readStruct(buffer, inner_blocks[0]);
221
+ var extensions = inner_blocks.map(function (block) { return _readExtension(buffer, block); });
222
+ var result = {};
223
+ for (var _i = 0, extensions_1 = extensions; _i < extensions_1.length; _i++) {
224
+ var e = extensions_1[_i];
225
+ result[e.identifier.name] = e.value;
226
+ }
227
+ return result;
228
+ }
229
+ function _readSubjectPublicKeyInfo(buffer, block) {
230
+ var inner_blocks = _readStruct(buffer, block);
231
+ var algorithm = _readAlgorithmIdentifier(buffer, inner_blocks[0]);
232
+ var subjectPublicKey = _readBitString(buffer, inner_blocks[1]);
233
+ var data = subjectPublicKey.data;
234
+ var values = _readListOfInteger(data);
235
+ return {
236
+ algorithm: algorithm.identifier,
237
+ keyLength: (values[0].length - 1),
238
+ subjectPublicKey: _readSubjectPublicKey(subjectPublicKey.data),
239
+ };
240
+ }
241
+ function _readSubjectECCPublicKeyInfo(buffer, block) {
242
+ var inner_blocks = _readStruct(buffer, block);
243
+ var algorithm = _readECCAlgorithmIdentifier(buffer, inner_blocks[0]);
244
+ var subjectPublicKey = _readBitString(buffer, inner_blocks[1]);
245
+ var data = subjectPublicKey.data;
246
+ return {
247
+ algorithm: algorithm.identifier,
248
+ keyLength: (data.length - 1),
249
+ subjectPublicKey: {
250
+ modulus: data
251
+ }
252
+ };
253
+ }
254
+ export function readTbsCertificate(buffer, block) {
255
+ var blocks = _readStruct(buffer, block);
256
+ var version, serialNumber, signature, issuer, validity, subject, subjectFingerPrint, extensions;
257
+ var subjectPublicKeyInfo;
258
+ if (blocks.length === 6) {
259
+ version = 1;
260
+ serialNumber = formatBuffer2DigitHexWithColum(_readLongIntegerValue(buffer, blocks[0]));
261
+ signature = _readAlgorithmIdentifier(buffer, blocks[1]);
262
+ issuer = _readName(buffer, blocks[2]);
263
+ validity = _readValidity(buffer, blocks[3]);
264
+ subject = _readName(buffer, blocks[4]);
265
+ subjectFingerPrint = formatBuffer2DigitHexWithColum(makeSHA1Thumbprint(_getBlock(buffer, blocks[4])));
266
+ subjectPublicKeyInfo = _readSubjectPublicKeyInfo(buffer, blocks[5]);
267
+ extensions = null;
268
+ }
269
+ else {
270
+ var version_block = _findBlockAtIndex(blocks, 0);
271
+ if (!version_block) {
272
+ throw new Error("cannot find version block");
273
+ }
274
+ version = _readVersionValue(buffer, version_block) + 1;
275
+ serialNumber = formatBuffer2DigitHexWithColum(_readLongIntegerValue(buffer, blocks[1]));
276
+ signature = _readAlgorithmIdentifier(buffer, blocks[2]);
277
+ issuer = _readName(buffer, blocks[3]);
278
+ validity = _readValidity(buffer, blocks[4]);
279
+ subject = _readName(buffer, blocks[5]);
280
+ subjectFingerPrint = formatBuffer2DigitHexWithColum(makeSHA1Thumbprint(_getBlock(buffer, blocks[5])));
281
+ var inner_block = _readStruct(buffer, blocks[6]);
282
+ var what_type = _readAlgorithmIdentifier(buffer, inner_block[0]).identifier;
283
+ switch (what_type) {
284
+ case "rsaEncryption": {
285
+ subjectPublicKeyInfo = _readSubjectPublicKeyInfo(buffer, blocks[6]);
286
+ break;
287
+ }
288
+ case "ecPublicKey":
289
+ default: {
290
+ subjectPublicKeyInfo = _readSubjectECCPublicKeyInfo(buffer, blocks[6]);
291
+ break;
292
+ }
293
+ }
294
+ var extensionBlock = _findBlockAtIndex(blocks, 3);
295
+ if (!extensionBlock) {
296
+ console.log("X509 certificate is invalid : cannot find extension block version =" + version_block);
297
+ extensions = null;
298
+ }
299
+ else {
300
+ extensions = _readExtensions(buffer, extensionBlock);
301
+ }
302
+ }
303
+ return {
304
+ version: version,
305
+ serialNumber: serialNumber,
306
+ signature: signature,
307
+ issuer: issuer,
308
+ validity: validity,
309
+ subject: subject,
310
+ subjectFingerPrint: subjectFingerPrint,
311
+ subjectPublicKeyInfo: subjectPublicKeyInfo,
312
+ extensions: extensions,
313
+ };
314
+ }
315
+ export function exploreCertificate(certificate) {
316
+ assert(certificate instanceof Buffer);
317
+ if (!certificate._exploreCertificate_cache) {
318
+ var block_info = readTag(certificate, 0);
319
+ var blocks = _readStruct(certificate, block_info);
320
+ certificate._exploreCertificate_cache = {
321
+ tbsCertificate: readTbsCertificate(certificate, blocks[0]),
322
+ signatureAlgorithm: _readAlgorithmIdentifier(certificate, blocks[1]),
323
+ signatureValue: _readSignatureValue(certificate, blocks[2]),
324
+ };
325
+ }
326
+ return certificate._exploreCertificate_cache;
327
+ }
328
+ export function split_der(certificateChain) {
329
+ var certificate_chain = [];
330
+ do {
331
+ var block_info = readTag(certificateChain, 0);
332
+ var length_1 = block_info.position + block_info.length;
333
+ var der_certificate = certificateChain.slice(0, length_1);
334
+ certificate_chain.push(der_certificate);
335
+ certificateChain = certificateChain.slice(length_1);
336
+ } while (certificateChain.length > 0);
337
+ return certificate_chain;
338
+ }
339
+ export function combine_der(certificates) {
340
+ var _loop_1 = function (cert) {
341
+ var b = split_der(cert);
342
+ var sum = 0;
343
+ b.forEach(function (block) {
344
+ var block_info = readTag(block, 0);
345
+ assert(block_info.position + block_info.length === block.length);
346
+ sum += block.length;
347
+ });
348
+ assert(sum === cert.length);
349
+ };
350
+ for (var _i = 0, certificates_1 = certificates; _i < certificates_1.length; _i++) {
351
+ var cert = certificates_1[_i];
352
+ _loop_1(cert);
353
+ }
354
+ return Buffer.concat(certificates);
355
+ }
356
+ //# sourceMappingURL=crypto_explore_certificate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto_explore_certificate.js","sourceRoot":"","sources":["../../source/crypto_explore_certificate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,242 @@
1
+ import constants from "constants";
2
+ import crypto from "crypto";
3
+ import assert from "assert";
4
+ var hexy = require("hexy").hexy;
5
+ import { createFastUninitializedBuffer } from "./buffer_utils.js";
6
+ import { combine_der } from "./crypto_explore_certificate.js";
7
+ var jsrsasign = require("jsrsasign");
8
+ var PEM_REGEX = /^(-----BEGIN (.*)-----\r?\n([/+=a-zA-Z0-9\r\n]*)\r?\n-----END \2-----\r?\n?)/gm;
9
+ var PEM_TYPE_REGEX = /^(-----BEGIN (.*)-----)/m;
10
+ export function identifyPemType(rawKey) {
11
+ if (rawKey instanceof Buffer) {
12
+ rawKey = rawKey.toString("utf8");
13
+ }
14
+ var match = PEM_TYPE_REGEX.exec(rawKey);
15
+ return !match ? undefined : match[2];
16
+ }
17
+ export function convertPEMtoDER(raw_key) {
18
+ var match;
19
+ var pemType;
20
+ var base64str;
21
+ var parts = [];
22
+ PEM_REGEX.lastIndex = 0;
23
+ while ((match = PEM_REGEX.exec(raw_key)) !== null) {
24
+ pemType = match[2];
25
+ base64str = match[3];
26
+ base64str = base64str.replace(/\r?\n/g, "");
27
+ parts.push(Buffer.from(base64str, "base64"));
28
+ }
29
+ return combine_der(parts);
30
+ }
31
+ export function toPem(raw_key, pem) {
32
+ assert(raw_key, "expecting a key");
33
+ assert(typeof pem === "string");
34
+ if (raw_key instanceof crypto.KeyObject) {
35
+ if (pem === "RSA PRIVATE KEY") {
36
+ return raw_key.export({ format: "pem", type: "pkcs1" }).toString();
37
+ }
38
+ else if (pem === "PRIVATE KEY") {
39
+ return raw_key.export({ format: "pem", type: "pkcs8" }).toString();
40
+ }
41
+ else {
42
+ throw new Error("Unsupported case!");
43
+ }
44
+ }
45
+ var pemType = identifyPemType(raw_key);
46
+ if (pemType) {
47
+ return raw_key instanceof Buffer ? raw_key.toString("utf8") : raw_key;
48
+ }
49
+ else {
50
+ pemType = pem;
51
+ assert(["CERTIFICATE REQUEST", "CERTIFICATE", "RSA PRIVATE KEY", "PUBLIC KEY", "X509 CRL"].indexOf(pemType) >= 0);
52
+ var b = raw_key.toString("base64");
53
+ var str = "-----BEGIN " + pemType + "-----\n";
54
+ while (b.length) {
55
+ str += b.substr(0, 64) + "\n";
56
+ b = b.substr(64);
57
+ }
58
+ str += "-----END " + pemType + "-----";
59
+ str += "\n";
60
+ return str;
61
+ }
62
+ }
63
+ export function hexDump(buffer, width) {
64
+ if (!buffer) {
65
+ return "<>";
66
+ }
67
+ width = width || 32;
68
+ if (buffer.length > 1024) {
69
+ return hexy(buffer.subarray(0, 1024), { width: width, format: "twos" }) + "\n .... ( " + buffer.length + ")";
70
+ }
71
+ else {
72
+ return hexy(buffer, { width: width, format: "twos" });
73
+ }
74
+ }
75
+ export function makeMessageChunkSignature(chunk, options) {
76
+ var signer = crypto.createSign(options.algorithm);
77
+ signer.update(chunk);
78
+ var signature = signer.sign(options.privateKey);
79
+ assert(!options.signatureLength || signature.length === options.signatureLength);
80
+ return signature;
81
+ }
82
+ export function verifyMessageChunkSignature(blockToVerify, signature, options) {
83
+ assert(blockToVerify instanceof Buffer);
84
+ assert(signature instanceof Buffer);
85
+ assert(typeof options.publicKey === "string");
86
+ assert(identifyPemType(options.publicKey));
87
+ var verify = crypto.createVerify(options.algorithm);
88
+ verify.update(blockToVerify);
89
+ return verify.verify(options.publicKey, signature);
90
+ }
91
+ export function makeSHA1Thumbprint(buffer) {
92
+ return crypto.createHash("sha1").update(buffer).digest();
93
+ }
94
+ export var RSA_PKCS1_OAEP_PADDING = constants.RSA_PKCS1_OAEP_PADDING;
95
+ export var RSA_PKCS1_PADDING = constants.RSA_PKCS1_PADDING;
96
+ export var PaddingAlgorithm;
97
+ (function (PaddingAlgorithm) {
98
+ PaddingAlgorithm[PaddingAlgorithm["RSA_PKCS1_OAEP_PADDING"] = 4] = "RSA_PKCS1_OAEP_PADDING";
99
+ PaddingAlgorithm[PaddingAlgorithm["RSA_PKCS1_PADDING"] = 1] = "RSA_PKCS1_PADDING";
100
+ })(PaddingAlgorithm || (PaddingAlgorithm = {}));
101
+ assert(PaddingAlgorithm.RSA_PKCS1_OAEP_PADDING === constants.RSA_PKCS1_OAEP_PADDING);
102
+ assert(PaddingAlgorithm.RSA_PKCS1_PADDING === constants.RSA_PKCS1_PADDING);
103
+ export function publicEncrypt_native(buffer, publicKey, algorithm) {
104
+ if (algorithm === undefined) {
105
+ algorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
106
+ }
107
+ assert(algorithm === RSA_PKCS1_PADDING || algorithm === RSA_PKCS1_OAEP_PADDING);
108
+ assert(buffer instanceof Buffer, "Expecting a buffer");
109
+ return crypto.publicEncrypt({
110
+ key: publicKey,
111
+ padding: algorithm,
112
+ }, buffer);
113
+ }
114
+ export function privateDecrypt_native(buffer, privateKey, algorithm) {
115
+ if (algorithm === undefined) {
116
+ algorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
117
+ }
118
+ assert(algorithm === RSA_PKCS1_PADDING || algorithm === RSA_PKCS1_OAEP_PADDING);
119
+ assert(buffer instanceof Buffer, "Expecting a buffer");
120
+ try {
121
+ return crypto.privateDecrypt({
122
+ key: privateKey,
123
+ padding: algorithm,
124
+ }, buffer);
125
+ }
126
+ catch (err) {
127
+ return Buffer.alloc(1);
128
+ }
129
+ }
130
+ export var publicEncrypt = publicEncrypt_native;
131
+ export var privateDecrypt = privateDecrypt_native;
132
+ export function publicEncrypt_long(buffer, publicKey, blockSize, padding, paddingAlgorithm) {
133
+ if (paddingAlgorithm === undefined) {
134
+ paddingAlgorithm = PaddingAlgorithm.RSA_PKCS1_PADDING;
135
+ }
136
+ if (paddingAlgorithm !== RSA_PKCS1_PADDING && paddingAlgorithm !== 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 = 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 = 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
+ export function privateDecrypt_long(buffer, privateKey, blockSize, paddingAlgorithm) {
153
+ paddingAlgorithm = paddingAlgorithm || RSA_PKCS1_PADDING;
154
+ if (paddingAlgorithm !== RSA_PKCS1_PADDING && paddingAlgorithm !== RSA_PKCS1_OAEP_PADDING) {
155
+ throw new Error("Invalid padding algorithm " + paddingAlgorithm);
156
+ }
157
+ var nbBlocks = Math.ceil(buffer.length / blockSize);
158
+ var outputBuffer = createFastUninitializedBuffer(nbBlocks * blockSize);
159
+ var total_length = 0;
160
+ for (var i = 0; i < nbBlocks; i++) {
161
+ var currentBlock = buffer.subarray(blockSize * i, Math.min(blockSize * (i + 1), buffer.length));
162
+ var decrypted_buf = privateDecrypt(currentBlock, privateKey, paddingAlgorithm);
163
+ decrypted_buf.copy(outputBuffer, total_length);
164
+ total_length += decrypted_buf.length;
165
+ }
166
+ return outputBuffer.subarray(0, total_length);
167
+ }
168
+ export function coerceCertificatePem(certificate) {
169
+ if (certificate instanceof Buffer) {
170
+ certificate = toPem(certificate, "CERTIFICATE");
171
+ }
172
+ assert(typeof certificate === "string");
173
+ return certificate;
174
+ }
175
+ export function coercePublicKeyPem(publicKey) {
176
+ if (publicKey instanceof crypto.KeyObject) {
177
+ return publicKey.export({ format: "pem", type: "spki" }).toString();
178
+ }
179
+ assert(typeof publicKey === "string");
180
+ return publicKey;
181
+ }
182
+ export function coerceRsaPublicKeyPem(publicKey) {
183
+ if (publicKey instanceof crypto.KeyObject) {
184
+ return publicKey.export({ format: "pem", type: "spki" }).toString();
185
+ }
186
+ assert(typeof publicKey === "string");
187
+ return publicKey;
188
+ }
189
+ export function coercePrivateKey(privateKey) {
190
+ if (typeof privateKey === "string") {
191
+ return crypto.createPrivateKey(privateKey);
192
+ }
193
+ return privateKey;
194
+ }
195
+ export function coercePrivateKeyPem(privateKey) {
196
+ if (privateKey instanceof Buffer) {
197
+ var o = crypto.createPrivateKey({ key: privateKey, format: "der", type: "pkcs1" });
198
+ var e = o.export({ format: "der", type: "pkcs1" });
199
+ privateKey = toPem(e, "RSA PRIVATE KEY");
200
+ }
201
+ assert(typeof privateKey === "string");
202
+ return privateKey;
203
+ }
204
+ export function rsaLengthPrivateKey(key) {
205
+ key = coercePrivateKey(key);
206
+ var key2 = key.export({ type: "pkcs1", format: "pem" }).toString();
207
+ var a = jsrsasign.KEYUTIL.getKey(key2);
208
+ return a.n.toString(16).length / 2;
209
+ }
210
+ export function rsaLengthPublicKey(key) {
211
+ key = coercePublicKeyPem(key);
212
+ assert(typeof key === "string");
213
+ var a = jsrsasign.KEYUTIL.getKey(key);
214
+ return a.n.toString(16).length / 2;
215
+ }
216
+ export function rsaLengthRsaPublicKey(key) {
217
+ key = coerceRsaPublicKeyPem(key);
218
+ assert(typeof key === "string");
219
+ var a = jsrsasign.KEYUTIL.getKey(key);
220
+ return a.n.toString(16).length / 2;
221
+ }
222
+ export function extractPublicKeyFromCertificateSync(certificate) {
223
+ certificate = coerceCertificatePem(certificate);
224
+ var key = jsrsasign.KEYUTIL.getKey(certificate);
225
+ var publicKeyAsPem = jsrsasign.KEYUTIL.getPEM(key);
226
+ assert(typeof publicKeyAsPem === "string");
227
+ return publicKeyAsPem;
228
+ }
229
+ export function extractPublicKeyFromCertificate(certificate, callback) {
230
+ var err1 = null;
231
+ var keyPem;
232
+ try {
233
+ keyPem = extractPublicKeyFromCertificateSync(certificate);
234
+ }
235
+ catch (err) {
236
+ err1 = err;
237
+ }
238
+ setImmediate(function () {
239
+ callback(err1, keyPem);
240
+ });
241
+ }
242
+ //# sourceMappingURL=crypto_utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto_utils.js","sourceRoot":"","sources":["../../source/crypto_utils.ts"],"names":[],"mappings":"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"}