react-native-quick-crypto 0.7.0 → 0.7.2

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 (133) hide show
  1. package/README.md +11 -63
  2. package/android/CMakeLists.txt +2 -0
  3. package/cpp/Cipher/MGLRsa.cpp +179 -3
  4. package/cpp/Cipher/MGLRsa.h +40 -0
  5. package/cpp/JSIUtils/MGLJSIUtils.h +8 -0
  6. package/cpp/MGLKeys.cpp +41 -43
  7. package/cpp/MGLKeys.h +9 -2
  8. package/cpp/MGLQuickCryptoHostObject.cpp +6 -6
  9. package/cpp/Sig/MGLSignHostObjects.cpp +22 -15
  10. package/cpp/Utils/MGLUtils.cpp +71 -1
  11. package/cpp/Utils/MGLUtils.h +55 -1
  12. package/cpp/webcrypto/MGLWebCrypto.cpp +89 -37
  13. package/cpp/webcrypto/MGLWebCrypto.h +5 -7
  14. package/cpp/webcrypto/crypto_aes.cpp +516 -0
  15. package/cpp/webcrypto/crypto_aes.h +79 -0
  16. package/cpp/webcrypto/crypto_ec.cpp +4 -20
  17. package/cpp/webcrypto/crypto_ec.h +0 -5
  18. package/cpp/webcrypto/crypto_keygen.cpp +86 -0
  19. package/cpp/webcrypto/crypto_keygen.h +38 -0
  20. package/lib/commonjs/Cipher.js +3 -1
  21. package/lib/commonjs/Cipher.js.map +1 -1
  22. package/lib/commonjs/Hashnames.js +20 -8
  23. package/lib/commonjs/Hashnames.js.map +1 -1
  24. package/lib/commonjs/NativeQuickCrypto/Cipher.js +13 -1
  25. package/lib/commonjs/NativeQuickCrypto/Cipher.js.map +1 -1
  26. package/lib/commonjs/NativeQuickCrypto/NativeQuickCrypto.js.map +1 -1
  27. package/lib/commonjs/NativeQuickCrypto/aes.js +6 -0
  28. package/lib/commonjs/NativeQuickCrypto/aes.js.map +1 -0
  29. package/lib/commonjs/NativeQuickCrypto/keygen.js +6 -0
  30. package/lib/commonjs/NativeQuickCrypto/keygen.js.map +1 -0
  31. package/lib/commonjs/NativeQuickCrypto/rsa.js +6 -0
  32. package/lib/commonjs/NativeQuickCrypto/rsa.js.map +1 -0
  33. package/lib/commonjs/Utils.js +30 -6
  34. package/lib/commonjs/Utils.js.map +1 -1
  35. package/lib/commonjs/aes.js +184 -227
  36. package/lib/commonjs/aes.js.map +1 -1
  37. package/lib/commonjs/index.js +12 -2
  38. package/lib/commonjs/index.js.map +1 -1
  39. package/lib/commonjs/keygen.js +56 -0
  40. package/lib/commonjs/keygen.js.map +1 -0
  41. package/lib/commonjs/keys.js +74 -5
  42. package/lib/commonjs/keys.js.map +1 -1
  43. package/lib/commonjs/rsa.js +115 -196
  44. package/lib/commonjs/rsa.js.map +1 -1
  45. package/lib/commonjs/sig.js.map +1 -1
  46. package/lib/commonjs/subtle.js +140 -78
  47. package/lib/commonjs/subtle.js.map +1 -1
  48. package/lib/commonjs/webcrypto.js +14 -0
  49. package/lib/commonjs/webcrypto.js.map +1 -0
  50. package/lib/module/Cipher.js +3 -1
  51. package/lib/module/Cipher.js.map +1 -1
  52. package/lib/module/Hashnames.js +20 -8
  53. package/lib/module/Hashnames.js.map +1 -1
  54. package/lib/module/NativeQuickCrypto/Cipher.js +12 -0
  55. package/lib/module/NativeQuickCrypto/Cipher.js.map +1 -1
  56. package/lib/module/NativeQuickCrypto/NativeQuickCrypto.js.map +1 -1
  57. package/lib/module/NativeQuickCrypto/aes.js +2 -0
  58. package/lib/module/NativeQuickCrypto/aes.js.map +1 -0
  59. package/lib/module/NativeQuickCrypto/keygen.js +2 -0
  60. package/lib/module/NativeQuickCrypto/keygen.js.map +1 -0
  61. package/lib/module/NativeQuickCrypto/rsa.js +2 -0
  62. package/lib/module/NativeQuickCrypto/rsa.js.map +1 -0
  63. package/lib/module/Utils.js +26 -5
  64. package/lib/module/Utils.js.map +1 -1
  65. package/lib/module/aes.js +183 -228
  66. package/lib/module/aes.js.map +1 -1
  67. package/lib/module/index.js +11 -2
  68. package/lib/module/index.js.map +1 -1
  69. package/lib/module/keygen.js +47 -0
  70. package/lib/module/keygen.js.map +1 -0
  71. package/lib/module/keys.js +68 -4
  72. package/lib/module/keys.js.map +1 -1
  73. package/lib/module/rsa.js +115 -198
  74. package/lib/module/rsa.js.map +1 -1
  75. package/lib/module/sig.js.map +1 -1
  76. package/lib/module/subtle.js +143 -82
  77. package/lib/module/subtle.js.map +1 -1
  78. package/lib/module/webcrypto.js +8 -0
  79. package/lib/module/webcrypto.js.map +1 -0
  80. package/lib/typescript/Cipher.d.ts +0 -1
  81. package/lib/typescript/Cipher.d.ts.map +1 -1
  82. package/lib/typescript/Hash.d.ts.map +1 -1
  83. package/lib/typescript/Hashnames.d.ts +2 -2
  84. package/lib/typescript/Hashnames.d.ts.map +1 -1
  85. package/lib/typescript/NativeQuickCrypto/Cipher.d.ts +5 -0
  86. package/lib/typescript/NativeQuickCrypto/Cipher.d.ts.map +1 -1
  87. package/lib/typescript/NativeQuickCrypto/NativeQuickCrypto.d.ts +4 -1
  88. package/lib/typescript/NativeQuickCrypto/NativeQuickCrypto.d.ts.map +1 -1
  89. package/lib/typescript/NativeQuickCrypto/aes.d.ts +5 -0
  90. package/lib/typescript/NativeQuickCrypto/aes.d.ts.map +1 -0
  91. package/lib/typescript/NativeQuickCrypto/keygen.d.ts +4 -0
  92. package/lib/typescript/NativeQuickCrypto/keygen.d.ts.map +1 -0
  93. package/lib/typescript/NativeQuickCrypto/rsa.d.ts +5 -0
  94. package/lib/typescript/NativeQuickCrypto/rsa.d.ts.map +1 -0
  95. package/lib/typescript/NativeQuickCrypto/webcrypto.d.ts +12 -2
  96. package/lib/typescript/NativeQuickCrypto/webcrypto.d.ts.map +1 -1
  97. package/lib/typescript/Utils.d.ts +4 -4
  98. package/lib/typescript/Utils.d.ts.map +1 -1
  99. package/lib/typescript/aes.d.ts +18 -1
  100. package/lib/typescript/aes.d.ts.map +1 -1
  101. package/lib/typescript/ec.d.ts.map +1 -1
  102. package/lib/typescript/index.d.ts +27 -24
  103. package/lib/typescript/index.d.ts.map +1 -1
  104. package/lib/typescript/keygen.d.ts +6 -0
  105. package/lib/typescript/keygen.d.ts.map +1 -0
  106. package/lib/typescript/keys.d.ts +58 -17
  107. package/lib/typescript/keys.d.ts.map +1 -1
  108. package/lib/typescript/rsa.d.ts +9 -1
  109. package/lib/typescript/rsa.d.ts.map +1 -1
  110. package/lib/typescript/sig.d.ts +3 -17
  111. package/lib/typescript/sig.d.ts.map +1 -1
  112. package/lib/typescript/subtle.d.ts +6 -5
  113. package/lib/typescript/subtle.d.ts.map +1 -1
  114. package/lib/typescript/webcrypto.d.ts +9 -0
  115. package/lib/typescript/webcrypto.d.ts.map +1 -0
  116. package/package.json +12 -12
  117. package/src/Cipher.ts +1 -1
  118. package/src/Hashnames.ts +23 -21
  119. package/src/NativeQuickCrypto/Cipher.ts +32 -0
  120. package/src/NativeQuickCrypto/NativeQuickCrypto.ts +6 -0
  121. package/src/NativeQuickCrypto/aes.ts +14 -0
  122. package/src/NativeQuickCrypto/keygen.ts +7 -0
  123. package/src/NativeQuickCrypto/rsa.ts +12 -0
  124. package/src/NativeQuickCrypto/webcrypto.ts +26 -2
  125. package/src/Utils.ts +37 -8
  126. package/src/aes.ts +259 -222
  127. package/src/index.ts +10 -1
  128. package/src/keygen.ts +80 -0
  129. package/src/keys.ts +143 -30
  130. package/src/rsa.ts +161 -187
  131. package/src/sig.ts +7 -23
  132. package/src/subtle.ts +211 -93
  133. package/src/webcrypto.ts +8 -0
@@ -1,29 +1,58 @@
1
- import { CryptoKey, KWebCryptoKeyFormat, createSecretKey } from './keys';
2
- import { hasAnyNotIn, normalizeAlgorithm, lazyDOMException, normalizeHashName, HashContext } from './Utils';
1
+ import { CryptoKey, KWebCryptoKeyFormat, createSecretKey, CipherOrWrapMode } from './keys';
2
+ import { hasAnyNotIn, normalizeAlgorithm, lazyDOMException, normalizeHashName, HashContext, validateMaxBufferLength, bufferLikeToArrayBuffer } from './Utils';
3
3
  import { ecImportKey, ecExportKey, ecGenerateKey, ecdsaSignVerify } from './ec';
4
4
  import { pbkdf2DeriveBits } from './pbkdf2';
5
5
  import { asyncDigest } from './Hash';
6
- import { aesImportKey, getAlgorithmName } from './aes';
7
- import { rsaImportKey } from './rsa';
6
+ import { aesCipher, aesGenerateKey, aesImportKey, getAlgorithmName } from './aes';
7
+ import { rsaCipher, rsaExportKey, rsaImportKey, rsaKeyGenerate } from './rsa';
8
8
  const exportKeySpki = async key => {
9
9
  switch (key.algorithm.name) {
10
- // case 'RSASSA-PKCS1-v1_5':
10
+ case 'RSASSA-PKCS1-v1_5':
11
+ // Fall through
12
+ case 'RSA-PSS':
13
+ // Fall through
14
+ case 'RSA-OAEP':
15
+ if (key.type === 'public') {
16
+ return rsaExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatSPKI);
17
+ }
18
+ break;
19
+ case 'ECDSA':
20
+ // Fall through
21
+ case 'ECDH':
22
+ if (key.type === 'public') {
23
+ return ecExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatSPKI);
24
+ }
25
+ break;
26
+ // case 'Ed25519':
11
27
  // // Fall through
12
- // case 'RSA-PSS':
28
+ // case 'Ed448':
13
29
  // // Fall through
14
- // case 'RSA-OAEP':
30
+ // case 'X25519':
31
+ // // Fall through
32
+ // case 'X448':
15
33
  // if (key.type === 'public') {
16
- // return require('internal/crypto/rsa').rsaExportKey(
17
- // key,
18
- // kWebCryptoKeyFormatSPKI
19
- // );
34
+ // return cfrgExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatSPKI);
20
35
  // }
21
36
  // break;
37
+ }
38
+ throw new Error(`Unable to export a spki ${key.algorithm.name} ${key.type} key`);
39
+ };
40
+ const exportKeyPkcs8 = async key => {
41
+ switch (key.algorithm.name) {
42
+ case 'RSASSA-PKCS1-v1_5':
43
+ // Fall through
44
+ case 'RSA-PSS':
45
+ // Fall through
46
+ case 'RSA-OAEP':
47
+ if (key.type === 'private') {
48
+ return rsaExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatPKCS8);
49
+ }
50
+ break;
22
51
  case 'ECDSA':
23
52
  // Fall through
24
53
  case 'ECDH':
25
- if (key.type === 'public') {
26
- return ecExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatSPKI);
54
+ if (key.type === 'private') {
55
+ return ecExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatPKCS8);
27
56
  }
28
57
  break;
29
58
  // case 'Ed25519':
@@ -33,15 +62,12 @@ const exportKeySpki = async key => {
33
62
  // case 'X25519':
34
63
  // // Fall through
35
64
  // case 'X448':
36
- // if (key.type === 'public') {
37
- // return require('internal/crypto/cfrg').cfrgExportKey(
38
- // key,
39
- // kWebCryptoKeyFormatSPKI
40
- // );
65
+ // if (key.type === 'private') {
66
+ // return cfrgExportKey(key, KWebCryptoKeyFormat.kWebCryptoKeyFormatPKCS8);
41
67
  // }
42
68
  // break;
43
69
  }
44
- throw new Error(`Unable to export a raw ${key.algorithm.name} ${key.type} key`);
70
+ throw new Error(`Unable to export a pkcs8 ${key.algorithm.name} ${key.type} key`);
45
71
  };
46
72
  const exportKeyRaw = key => {
47
73
  switch (key.algorithm.name) {
@@ -219,7 +245,42 @@ const signVerify = (algorithm, key, data, signature) => {
219
245
  }
220
246
  throw lazyDOMException(`Unrecognized algorithm name '${algorithm}' for '${usage}'`, 'NotSupportedError');
221
247
  };
222
- class Subtle {
248
+ const cipherOrWrap = async (mode, algorithm, key, data, op) => {
249
+ // We use a Node.js style error here instead of a DOMException because
250
+ // the WebCrypto spec is not specific what kind of error is to be thrown
251
+ // in this case. Both Firefox and Chrome throw simple TypeErrors here.
252
+ // The key algorithm and cipher algorithm must match, and the
253
+ // key must have the proper usage.
254
+ if (key.algorithm.name !== algorithm.name || !key.usages.includes(op)) {
255
+ throw lazyDOMException('The requested operation is not valid for the provided key', 'InvalidAccessError');
256
+ }
257
+
258
+ // While WebCrypto allows for larger input buffer sizes, we limit
259
+ // those to sizes that can fit within uint32_t because of limitations
260
+ // in the OpenSSL API.
261
+ validateMaxBufferLength(data, 'data');
262
+ switch (algorithm.name) {
263
+ case 'RSA-OAEP':
264
+ return rsaCipher(mode, key, data, algorithm);
265
+ case 'AES-CTR':
266
+ // Fall through
267
+ case 'AES-CBC':
268
+ // Fall through
269
+ case 'AES-GCM':
270
+ return aesCipher(mode, key, data, algorithm);
271
+ // case 'AES-KW':
272
+ // if (op === 'wrapKey' || op === 'unwrapKey') {
273
+ // return aesCipher(mode, key, data, algorithm);
274
+ // }
275
+ }
276
+ // @ts-ignore
277
+ throw lazyDOMException(`Unrecognized algorithm name '${algorithm}' for '${op}'`, 'NotSupportedError');
278
+ };
279
+ export class Subtle {
280
+ async decrypt(algorithm, key, data) {
281
+ const normalizedAlgorithm = normalizeAlgorithm(algorithm, 'decrypt');
282
+ return cipherOrWrap(CipherOrWrapMode.kWebCryptoCipherDecrypt, normalizedAlgorithm, key, bufferLikeToArrayBuffer(data), 'decrypt');
283
+ }
223
284
  async digest(algorithm, data) {
224
285
  const normalizedAlgorithm = normalizeAlgorithm(algorithm, 'digest');
225
286
  return asyncDigest(normalizedAlgorithm, data);
@@ -245,6 +306,68 @@ class Subtle {
245
306
  }
246
307
  throw new Error(`'subtle.deriveBits()' for ${algorithm.name} is not implemented.`);
247
308
  }
309
+ async encrypt(algorithm, key, data) {
310
+ const normalizedAlgorithm = normalizeAlgorithm(algorithm, 'encrypt');
311
+ return cipherOrWrap(CipherOrWrapMode.kWebCryptoCipherEncrypt, normalizedAlgorithm, key, bufferLikeToArrayBuffer(data), 'encrypt');
312
+ }
313
+ async exportKey(format, key) {
314
+ if (!key.extractable) throw new Error('key is not extractable');
315
+ switch (format) {
316
+ case 'spki':
317
+ return await exportKeySpki(key);
318
+ case 'pkcs8':
319
+ return await exportKeyPkcs8(key);
320
+ case 'jwk':
321
+ return exportKeyJWK(key);
322
+ case 'raw':
323
+ return exportKeyRaw(key);
324
+ }
325
+ }
326
+ async generateKey(algorithm, extractable, keyUsages) {
327
+ algorithm = normalizeAlgorithm(algorithm, 'generateKey');
328
+ let result;
329
+ switch (algorithm.name) {
330
+ case 'RSASSA-PKCS1-v1_5':
331
+ // Fall through
332
+ case 'RSA-PSS':
333
+ // Fall through
334
+ case 'RSA-OAEP':
335
+ result = await rsaKeyGenerate(algorithm, extractable, keyUsages);
336
+ break;
337
+ // case 'Ed25519':
338
+ // // Fall through
339
+ // case 'Ed448':
340
+ // // Fall through
341
+ // case 'X25519':
342
+ // // Fall through
343
+ // case 'X448':
344
+ // resultType = 'CryptoKeyPair';
345
+ // result = await cfrgGenerateKey(algorithm, extractable, keyUsages);
346
+ // break;
347
+ case 'ECDSA':
348
+ // Fall through
349
+ case 'ECDH':
350
+ result = await ecGenerateKey(algorithm, extractable, keyUsages);
351
+ checkCryptoKeyPairUsages(result);
352
+ break;
353
+ // case 'HMAC':
354
+ // result = await hmacGenerateKey(algorithm, extractable, keyUsages);
355
+ // break;
356
+ case 'AES-CTR':
357
+ // Fall through
358
+ case 'AES-CBC':
359
+ // Fall through
360
+ case 'AES-GCM':
361
+ // Fall through
362
+ case 'AES-KW':
363
+ result = await aesGenerateKey(algorithm, extractable, keyUsages);
364
+ break;
365
+ default:
366
+ throw new Error(`'subtle.generateKey()' is not implemented for ${algorithm.name}.
367
+ Unrecognized algorithm name`);
368
+ }
369
+ return result;
370
+ }
248
371
  async importKey(format, data, algorithm, extractable, keyUsages) {
249
372
  const normalizedAlgorithm = normalizeAlgorithm(algorithm, 'importKey');
250
373
  let result;
@@ -307,68 +430,6 @@ class Subtle {
307
430
  }
308
431
  return result;
309
432
  }
310
- async exportKey(format, key) {
311
- if (!key.extractable) throw new Error('key is not extractable');
312
- switch (format) {
313
- case 'spki':
314
- return await exportKeySpki(key);
315
- // case 'pkcs8':
316
- // return await exportKeyPkcs8(key);
317
- case 'jwk':
318
- return exportKeyJWK(key);
319
- case 'raw':
320
- return exportKeyRaw(key);
321
- }
322
- throw new Error(`'subtle.exportKey()' is not implemented for ${format}`);
323
- }
324
- async generateKey(algorithm, extractable, keyUsages) {
325
- algorithm = normalizeAlgorithm(algorithm, 'generateKey');
326
- let result;
327
- switch (algorithm.name) {
328
- // case 'RSASSA-PKCS1-v1_5':
329
- // // Fall through
330
- // case 'RSA-PSS':
331
- // // Fall through
332
- // case 'RSA-OAEP':
333
- // resultType = 'CryptoKeyPair';
334
- // result = await rsaKeyGenerate(algorithm, extractable, keyUsages);
335
- // break;
336
- // case 'Ed25519':
337
- // // Fall through
338
- // case 'Ed448':
339
- // // Fall through
340
- // case 'X25519':
341
- // // Fall through
342
- // case 'X448':
343
- // resultType = 'CryptoKeyPair';
344
- // result = await cfrgGenerateKey(algorithm, extractable, keyUsages);
345
- // break;
346
- case 'ECDSA':
347
- // Fall through
348
- case 'ECDH':
349
- result = await ecGenerateKey(algorithm, extractable, keyUsages);
350
- checkCryptoKeyPairUsages(result);
351
- break;
352
- // case 'HMAC':
353
- // resultType = 'CryptoKey';
354
- // result = await hmacGenerateKey(algorithm, extractable, keyUsages);
355
- // break;
356
- // case 'AES-CTR':
357
- // // Fall through
358
- // case 'AES-CBC':
359
- // // Fall through
360
- // case 'AES-GCM':
361
- // // Fall through
362
- // case 'AES-KW':
363
- // resultType = 'CryptoKey';
364
- // result = await aesGenerateKey(algorithm, extractable, keyUsages);
365
- // break;
366
- default:
367
- throw new Error(`'subtle.generateKey()' is not implemented for ${algorithm.name}.
368
- Unrecognized algorithm name`);
369
- }
370
- return result;
371
- }
372
433
  async sign(algorithm, key, data) {
373
434
  return signVerify(algorithm, key, data);
374
435
  }
@@ -1 +1 @@
1
- {"version":3,"names":["CryptoKey","KWebCryptoKeyFormat","createSecretKey","hasAnyNotIn","normalizeAlgorithm","lazyDOMException","normalizeHashName","HashContext","ecImportKey","ecExportKey","ecGenerateKey","ecdsaSignVerify","pbkdf2DeriveBits","asyncDigest","aesImportKey","getAlgorithmName","rsaImportKey","exportKeySpki","key","algorithm","name","type","kWebCryptoKeyFormatSPKI","Error","exportKeyRaw","kWebCryptoKeyFormatRaw","keyObject","export","exportKeyJWK","jwk","handle","exportJwk","key_ops","usages","ext","extractable","alg","hash","JwkRsa","JwkRsaPss","JwkRsaOaep","crv","namedCurve","length","importGenericSecretKey","format","keyData","keyUsages","checkLength","byteLength","undefined","checkCryptoKeyPairUsages","pair","privateKey","Buffer","hasOwnProperty","priv","console","log","signVerify","data","signature","usage","includes","Subtle","digest","normalizedAlgorithm","deriveBits","baseKey","importKey","result","exportKey","generateKey","sign","verify","subtle"],"sourceRoot":"../../src","sources":["subtle.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["CryptoKey","KWebCryptoKeyFormat","createSecretKey","CipherOrWrapMode","hasAnyNotIn","normalizeAlgorithm","lazyDOMException","normalizeHashName","HashContext","validateMaxBufferLength","bufferLikeToArrayBuffer","ecImportKey","ecExportKey","ecGenerateKey","ecdsaSignVerify","pbkdf2DeriveBits","asyncDigest","aesCipher","aesGenerateKey","aesImportKey","getAlgorithmName","rsaCipher","rsaExportKey","rsaImportKey","rsaKeyGenerate","exportKeySpki","key","algorithm","name","type","kWebCryptoKeyFormatSPKI","Error","exportKeyPkcs8","kWebCryptoKeyFormatPKCS8","exportKeyRaw","kWebCryptoKeyFormatRaw","keyObject","export","exportKeyJWK","jwk","handle","exportJwk","key_ops","usages","ext","extractable","alg","hash","JwkRsa","JwkRsaPss","JwkRsaOaep","crv","namedCurve","length","importGenericSecretKey","format","keyData","keyUsages","checkLength","byteLength","undefined","checkCryptoKeyPairUsages","pair","privateKey","Buffer","hasOwnProperty","priv","console","log","signVerify","data","signature","usage","includes","cipherOrWrap","mode","op","Subtle","decrypt","normalizedAlgorithm","kWebCryptoCipherDecrypt","digest","deriveBits","baseKey","encrypt","kWebCryptoCipherEncrypt","exportKey","generateKey","result","importKey","sign","verify","subtle"],"sourceRoot":"../../src","sources":["subtle.ts"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,8 @@
1
+ import { subtle, Subtle } from './subtle';
2
+ import { CryptoKey } from './keys';
3
+ export default {
4
+ subtle,
5
+ SubtleCrypto: Subtle,
6
+ CryptoKey
7
+ };
8
+ //# sourceMappingURL=webcrypto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["subtle","Subtle","CryptoKey","SubtleCrypto"],"sourceRoot":"../../src","sources":["webcrypto.ts"],"mappings":"AAAA,SAASA,MAAM,EAAEC,MAAM,QAAQ,UAAU;AACzC,SAASC,SAAS,QAAQ,QAAQ;AAElC,eAAe;EACbF,MAAM;EACNG,YAAY,EAAEF,MAAM;EACpBC;AACF,CAAC","ignoreList":[]}
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  import { type BinaryLike, type BinaryLikeNode } from './Utils';
3
2
  import type { CipherCCMOptions, CipherCCMTypes, CipherGCMTypes, CipherGCMOptions, CipherOCBOptions, CipherOCBTypes, DecipherGCM, DecipherOCB, DecipherCCM, CipherCCM, CipherOCB, CipherGCM } from 'crypto';
4
3
  import { Buffer } from '@craftzdog/react-native-buffer';
@@ -1 +1 @@
1
- {"version":3,"file":"Cipher.d.ts","sourceRoot":"","sources":["../../src/Cipher.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Cipher.d.ts","sourceRoot":"","sources":["../../src/Cipher.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"Hash.d.ts","sourceRoot":"","sources":["../../src/Hash.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,QAAQ,EAIb,KAAK,UAAU,EAEhB,MAAM,SAAS,CAAC;AACjB,OAAO,MAAM,MAAM,iBAAiB,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAExD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9C,UAAU,eAAgB,SAAQ,MAAM,CAAC,gBAAgB;IACvD,YAAY,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CACnC;AAED,KAAK,WAAW,GAAG,IAAI,GAAG,SAAS,GAAG,eAAe,CAAC;AAMtD,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,QAElE;AAED,cAAM,IAAK,SAAQ,MAAM,CAAC,SAAS;IACjC,OAAO,CAAC,YAAY,CAAe;gBAEvB,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,EAAE,WAAW;gBAClC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW;IAUpD,IAAI,CAAC,OAAO,CAAC,EAAE,eAAe,GAAG,IAAI;IAIrC;;;;;;;;;OASG;IACH,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,EAAE,aAAa,CAAC,EAAE,QAAQ,GAAG,IAAI;IAUlE,UAAU,CACR,KAAK,EAAE,MAAM,GAAG,WAAW,EAC3B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,MAAM,IAAI;IAMtB,MAAM,CAAC,QAAQ,EAAE,MAAM,IAAI;IAK3B;;;;;;;;;OASG;IACH,MAAM,IAAI,MAAM;IAChB,MAAM,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM;IAClC,MAAM,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM;CAUnC;AAID,eAAO,MAAM,WAAW,cACX,eAAe,QACpB,UAAU,KACf,QAAQ,WAAW,CAqBrB,CAAC"}
1
+ {"version":3,"file":"Hash.d.ts","sourceRoot":"","sources":["../../src/Hash.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,QAAQ,EAIb,KAAK,UAAU,EAEhB,MAAM,SAAS,CAAC;AACjB,OAAO,MAAM,MAAM,iBAAiB,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAExD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9C,UAAU,eAAgB,SAAQ,MAAM,CAAC,gBAAgB;IACvD,YAAY,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CACnC;AAED,KAAK,WAAW,GAAG,IAAI,GAAG,SAAS,GAAG,eAAe,CAAC;AAMtD,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,QAElE;AAED,cAAM,IAAK,SAAQ,MAAM,CAAC,SAAS;IACjC,OAAO,CAAC,YAAY,CAAe;gBAEvB,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,EAAE,WAAW;gBAClC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW;IAUpD,IAAI,CAAC,OAAO,CAAC,EAAE,eAAe,GAAG,IAAI;IAIrC;;;;;;;;;OASG;IACH,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,EAAE,aAAa,CAAC,EAAE,QAAQ,GAAG,IAAI;IAUlE,UAAU,CACR,KAAK,EAAE,MAAM,GAAG,WAAW,EAC3B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,MAAM,IAAI;IAMtB,MAAM,CAAC,QAAQ,EAAE,MAAM,IAAI;IAK3B;;;;;;;;;OASG;IACH,MAAM,IAAI,MAAM;IAChB,MAAM,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM;IAClC,MAAM,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM;CAUnC;AAID,eAAO,MAAM,WAAW,cACX,eAAe,QACpB,UAAU,KACf,OAAO,CAAC,WAAW,CAqBrB,CAAC"}
@@ -1,4 +1,4 @@
1
- import type { HashAlgorithm, KeyPairAlgorithm, SecretKeyAlgorithm, SubtleAlgorithm } from './keys';
1
+ import type { HashAlgorithm } from './keys';
2
2
  export declare enum HashContext {
3
3
  Node = 0,
4
4
  WebCrypto = 1,
@@ -7,5 +7,5 @@ export declare enum HashContext {
7
7
  JwkRsaOaep = 4,
8
8
  JwkHmac = 5
9
9
  }
10
- export declare function normalizeHashName(algo: SubtleAlgorithm | HashAlgorithm | KeyPairAlgorithm | SecretKeyAlgorithm | undefined, context?: HashContext): string;
10
+ export declare function normalizeHashName(algo: string | HashAlgorithm | undefined, context?: HashContext): HashAlgorithm;
11
11
  //# sourceMappingURL=Hashnames.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Hashnames.d.ts","sourceRoot":"","sources":["../../src/Hashnames.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EAChB,MAAM,QAAQ,CAAC;AAEhB,oBAAY,WAAW;IACrB,IAAI,IAAA;IACJ,SAAS,IAAA;IACT,MAAM,IAAA;IACN,SAAS,IAAA;IACT,UAAU,IAAA;IACV,OAAO,IAAA;CACR;AA2DD,wBAAgB,iBAAiB,CAC/B,IAAI,EACA,eAAe,GACf,aAAa,GACb,gBAAgB,GAChB,kBAAkB,GAClB,SAAS,EACb,OAAO,GAAE,WAA8B,GACtC,MAAM,CASR"}
1
+ {"version":3,"file":"Hashnames.d.ts","sourceRoot":"","sources":["../../src/Hashnames.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAE5C,oBAAY,WAAW;IACrB,IAAI,IAAA;IACJ,SAAS,IAAA;IACT,MAAM,IAAA;IACN,SAAS,IAAA;IACT,UAAU,IAAA;IACV,OAAO,IAAA;CACR;AAuED,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS,EACxC,OAAO,GAAE,WAA8B,GACtC,aAAa,CASf"}
@@ -1,6 +1,7 @@
1
1
  import type { GenerateKeyPairReturn } from '../Cipher';
2
2
  import type { BinaryLike } from '../Utils';
3
3
  import type { Buffer } from '@craftzdog/react-native-buffer';
4
+ import type { EncodingOptions, PrivateKeyObject, PublicKeyObject, SecretKeyObject } from '../keys';
4
5
  export declare enum KeyVariant {
5
6
  RSA_SSA_PKCS1_v1_5 = 0,
6
7
  RSA_PSS = 1,
@@ -10,6 +11,7 @@ export declare enum KeyVariant {
10
11
  NID = 5,
11
12
  DH = 6
12
13
  }
14
+ export declare const KeyVariantLookup: Record<string, KeyVariant>;
13
15
  export type InternalCipher = {
14
16
  update: (data: BinaryLike | ArrayBufferView) => ArrayBuffer;
15
17
  final: () => ArrayBuffer;
@@ -36,4 +38,7 @@ export type PublicEncryptMethod = (data: ArrayBuffer, format: number, type: any,
36
38
  export type PrivateDecryptMethod = (data: ArrayBuffer, format: number, type: any, passphrase: any, buffer: ArrayBuffer, padding: number, oaepHash: any, oaepLabel: any) => Buffer;
37
39
  export type GenerateKeyPairMethod = (keyVariant: KeyVariant, ...rest: any[]) => Promise<GenerateKeyPairReturn>;
38
40
  export type GenerateKeyPairSyncMethod = (keyVariant: KeyVariant, ...rest: any[]) => GenerateKeyPairReturn;
41
+ export type CreatePublicKeyMethod = (key: BinaryLike | EncodingOptions) => PublicKeyObject;
42
+ export type CreatePrivateKeyMethod = (key: BinaryLike | EncodingOptions) => PrivateKeyObject;
43
+ export type CreateSecretKeyMethod = (key: BinaryLike | EncodingOptions, encoding?: string) => SecretKeyObject;
39
44
  //# sourceMappingURL=Cipher.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Cipher.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/Cipher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AACvD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAG7D,oBAAY,UAAU;IACpB,kBAAkB,IAAA;IAClB,OAAO,IAAA;IACP,QAAQ,IAAA;IACR,GAAG,IAAA;IACH,EAAE,IAAA;IACF,GAAG,IAAA;IACH,EAAE,IAAA;CACH;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,MAAM,EAAE,CAAC,IAAI,EAAE,UAAU,GAAG,eAAe,KAAK,WAAW,CAAC;IAC5D,KAAK,EAAE,MAAM,WAAW,CAAC;IACzB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,MAAM,EAAE,CAAC,IAAI,EAAE;QACb,IAAI,EAAE,UAAU,CAAC;QACjB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC1B,KAAK,cAAc,CAAC;IACrB,cAAc,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC;IAC9C,UAAU,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,OAAO,CAAC;IAC1C,UAAU,EAAE,MAAM,WAAW,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,CAAC,MAAM,EAAE;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,WAAW,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;CACtB,KAAK,cAAc,CAAC;AAErB,MAAM,MAAM,oBAAoB,GAAG,CAAC,MAAM,EAAE;IAC1C,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,WAAW,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;CACtB,KAAK,cAAc,CAAC;AAErB,MAAM,MAAM,mBAAmB,GAAG,CAChC,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,GAAG,EACT,UAAU,EAAE,GAAG,EACf,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,GAAG,EACb,SAAS,EAAE,GAAG,KACX,MAAM,CAAC;AACZ,MAAM,MAAM,oBAAoB,GAAG,CACjC,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,GAAG,EACT,UAAU,EAAE,GAAG,EACf,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,GAAG,EACb,SAAS,EAAE,GAAG,KACX,MAAM,CAAC;AAEZ,MAAM,MAAM,qBAAqB,GAAG,CAClC,UAAU,EAAE,UAAU,EACtB,GAAG,IAAI,EAAE,GAAG,EAAE,KACX,OAAO,CAAC,qBAAqB,CAAC,CAAC;AAEpC,MAAM,MAAM,yBAAyB,GAAG,CACtC,UAAU,EAAE,UAAU,EACtB,GAAG,IAAI,EAAE,GAAG,EAAE,KACX,qBAAqB,CAAC"}
1
+ {"version":3,"file":"Cipher.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/Cipher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AACvD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,KAAK,EACV,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,eAAe,EAChB,MAAM,SAAS,CAAC;AAGjB,oBAAY,UAAU;IACpB,kBAAkB,IAAA;IAClB,OAAO,IAAA;IACP,QAAQ,IAAA;IACR,GAAG,IAAA;IACH,EAAE,IAAA;IACF,GAAG,IAAA;IACH,EAAE,IAAA;CACH;AAED,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAWvD,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,MAAM,EAAE,CAAC,IAAI,EAAE,UAAU,GAAG,eAAe,KAAK,WAAW,CAAC;IAC5D,KAAK,EAAE,MAAM,WAAW,CAAC;IACzB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,MAAM,EAAE,CAAC,IAAI,EAAE;QACb,IAAI,EAAE,UAAU,CAAC;QACjB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC1B,KAAK,cAAc,CAAC;IACrB,cAAc,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC;IAC9C,UAAU,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,OAAO,CAAC;IAC1C,UAAU,EAAE,MAAM,WAAW,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,CAAC,MAAM,EAAE;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,WAAW,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;CACtB,KAAK,cAAc,CAAC;AAErB,MAAM,MAAM,oBAAoB,GAAG,CAAC,MAAM,EAAE;IAC1C,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,WAAW,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;CACtB,KAAK,cAAc,CAAC;AAErB,MAAM,MAAM,mBAAmB,GAAG,CAChC,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,GAAG,EACT,UAAU,EAAE,GAAG,EACf,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,GAAG,EACb,SAAS,EAAE,GAAG,KACX,MAAM,CAAC;AACZ,MAAM,MAAM,oBAAoB,GAAG,CACjC,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,GAAG,EACT,UAAU,EAAE,GAAG,EACf,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,GAAG,EACb,SAAS,EAAE,GAAG,KACX,MAAM,CAAC;AAEZ,MAAM,MAAM,qBAAqB,GAAG,CAClC,UAAU,EAAE,UAAU,EACtB,GAAG,IAAI,EAAE,GAAG,EAAE,KACX,OAAO,CAAC,qBAAqB,CAAC,CAAC;AAEpC,MAAM,MAAM,yBAAyB,GAAG,CACtC,UAAU,EAAE,UAAU,EACtB,GAAG,IAAI,EAAE,GAAG,EAAE,KACX,qBAAqB,CAAC;AAE3B,MAAM,MAAM,qBAAqB,GAAG,CAClC,GAAG,EAAE,UAAU,GAAG,eAAe,KAC9B,eAAe,CAAC;AAErB,MAAM,MAAM,sBAAsB,GAAG,CACnC,GAAG,EAAE,UAAU,GAAG,eAAe,KAC9B,gBAAgB,CAAC;AAEtB,MAAM,MAAM,qBAAqB,GAAG,CAClC,GAAG,EAAE,UAAU,GAAG,eAAe,EACjC,QAAQ,CAAC,EAAE,MAAM,KACd,eAAe,CAAC"}
@@ -2,7 +2,7 @@ import type { CreateHmacMethod } from './hmac';
2
2
  import type { CreateHashMethod } from './hash';
3
3
  import type { Pbkdf2Object } from './pbkdf2';
4
4
  import type { RandomObject } from './random';
5
- import type { CreateCipherMethod, CreateDecipherMethod, PublicEncryptMethod, PrivateDecryptMethod, GenerateKeyPairMethod, GenerateKeyPairSyncMethod } from './Cipher';
5
+ import type { CreateCipherMethod, CreateDecipherMethod, PublicEncryptMethod, PrivateDecryptMethod, GenerateKeyPairMethod, GenerateKeyPairSyncMethod, CreatePublicKeyMethod, CreatePrivateKeyMethod, CreateSecretKeyMethod } from './Cipher';
6
6
  import type { CreateSignMethod, CreateVerifyMethod } from './sig';
7
7
  import type { webcrypto } from './webcrypto';
8
8
  interface NativeQuickCryptoSpec {
@@ -12,6 +12,9 @@ interface NativeQuickCryptoSpec {
12
12
  createHash: CreateHashMethod;
13
13
  createCipher: CreateCipherMethod;
14
14
  createDecipher: CreateDecipherMethod;
15
+ createPublicKey: CreatePublicKeyMethod;
16
+ createPrivateKey: CreatePrivateKeyMethod;
17
+ createSecretKey: CreateSecretKeyMethod;
15
18
  publicEncrypt: PublicEncryptMethod;
16
19
  publicDecrypt: PublicEncryptMethod;
17
20
  privateDecrypt: PrivateDecryptMethod;
@@ -1 +1 @@
1
- {"version":3,"file":"NativeQuickCrypto.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/NativeQuickCrypto.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC/C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACpB,qBAAqB,EACrB,yBAAyB,EAC1B,MAAM,UAAU,CAAC;AAClB,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAE7C,UAAU,qBAAqB;IAC7B,UAAU,EAAE,gBAAgB,CAAC;IAC7B,MAAM,EAAE,YAAY,CAAC;IACrB,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,EAAE,gBAAgB,CAAC;IAC7B,YAAY,EAAE,kBAAkB,CAAC;IACjC,cAAc,EAAE,oBAAoB,CAAC;IACrC,aAAa,EAAE,mBAAmB,CAAC;IACnC,aAAa,EAAE,mBAAmB,CAAC;IACnC,cAAc,EAAE,oBAAoB,CAAC;IACrC,eAAe,EAAE,qBAAqB,CAAC;IACvC,mBAAmB,EAAE,yBAAyB,CAAC;IAC/C,UAAU,EAAE,gBAAgB,CAAC;IAC7B,YAAY,EAAE,kBAAkB,CAAC;IACjC,SAAS,EAAE,SAAS,CAAC;CACtB;AAGD,OAAO,CAAC,MAAM,CAAC;IACb,SAAS,kBAAkB,IAAI,OAAO,CAAC;IACvC,IAAI,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;CAC5C;AA0DD,eAAO,MAAM,iBAAiB,uBAAwC,CAAC"}
1
+ {"version":3,"file":"NativeQuickCrypto.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/NativeQuickCrypto.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC/C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACpB,qBAAqB,EACrB,yBAAyB,EACzB,qBAAqB,EACrB,sBAAsB,EACtB,qBAAqB,EACtB,MAAM,UAAU,CAAC;AAClB,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAE7C,UAAU,qBAAqB;IAC7B,UAAU,EAAE,gBAAgB,CAAC;IAC7B,MAAM,EAAE,YAAY,CAAC;IACrB,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,EAAE,gBAAgB,CAAC;IAC7B,YAAY,EAAE,kBAAkB,CAAC;IACjC,cAAc,EAAE,oBAAoB,CAAC;IACrC,eAAe,EAAE,qBAAqB,CAAC;IACvC,gBAAgB,EAAE,sBAAsB,CAAC;IACzC,eAAe,EAAE,qBAAqB,CAAC;IACvC,aAAa,EAAE,mBAAmB,CAAC;IACnC,aAAa,EAAE,mBAAmB,CAAC;IACnC,cAAc,EAAE,oBAAoB,CAAC;IACrC,eAAe,EAAE,qBAAqB,CAAC;IACvC,mBAAmB,EAAE,yBAAyB,CAAC;IAC/C,UAAU,EAAE,gBAAgB,CAAC;IAC7B,YAAY,EAAE,kBAAkB,CAAC;IACjC,SAAS,EAAE,SAAS,CAAC;CACtB;AAGD,OAAO,CAAC,MAAM,CAAC;IACb,SAAS,kBAAkB,IAAI,OAAO,CAAC;IACvC,IAAI,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;CAC5C;AA0DD,eAAO,MAAM,iBAAiB,EAAmB,qBAAqB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { AESKeyVariant } from '../aes';
2
+ import type { CipherOrWrapMode } from '../keys';
3
+ import type { KeyObjectHandle } from './webcrypto';
4
+ export type AESCipher = (mode: CipherOrWrapMode, handle: KeyObjectHandle, data: ArrayBuffer, variant: AESKeyVariant, iv_or_counter?: ArrayBuffer, length?: number, authTag?: ArrayBuffer, additionalData?: ArrayBuffer) => Promise<ArrayBuffer>;
5
+ //# sourceMappingURL=aes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aes.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/aes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAC5C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,MAAM,MAAM,SAAS,GAAG,CACtB,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,eAAe,EACvB,IAAI,EAAE,WAAW,EACjB,OAAO,EAAE,aAAa,EACtB,aAAa,CAAC,EAAE,WAAW,EAC3B,MAAM,CAAC,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,WAAW,EACrB,cAAc,CAAC,EAAE,WAAW,KACzB,OAAO,CAAC,WAAW,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { KeyObjectHandle } from './webcrypto';
2
+ export type GenerateSecretKeyMethod = (length: number) => Promise<KeyObjectHandle>;
3
+ export type GenerateSecretKeySyncMethod = (length: number) => KeyObjectHandle;
4
+ //# sourceMappingURL=keygen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keygen.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/keygen.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,MAAM,MAAM,uBAAuB,GAAG,CACpC,MAAM,EAAE,MAAM,KACX,OAAO,CAAC,eAAe,CAAC,CAAC;AAE9B,MAAM,MAAM,2BAA2B,GAAG,CAAC,MAAM,EAAE,MAAM,KAAK,eAAe,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { CipherOrWrapMode, DigestAlgorithm } from '../keys';
2
+ import type { RSAKeyVariant } from '../rsa';
3
+ import type { KeyObjectHandle } from './webcrypto';
4
+ export type RSACipher = (mode: CipherOrWrapMode, handle: KeyObjectHandle, data: ArrayBuffer, variant: RSAKeyVariant, hash: DigestAlgorithm, label?: ArrayBuffer) => Promise<ArrayBuffer>;
5
+ //# sourceMappingURL=rsa.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rsa.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/rsa.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AACjE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAC5C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,MAAM,MAAM,SAAS,GAAG,CACtB,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,eAAe,EACvB,IAAI,EAAE,WAAW,EACjB,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE,eAAe,EACrB,KAAK,CAAC,EAAE,WAAW,KAChB,OAAO,CAAC,WAAW,CAAC,CAAC"}
@@ -1,5 +1,9 @@
1
+ import type { AESCipher } from './aes';
1
2
  import type { AsymmetricKeyType, JWK, KeyEncoding, KeyType, KFormatType, KWebCryptoKeyFormat, NamedCurve } from '../keys';
2
3
  import type { SignVerify } from './sig';
4
+ import type { GenerateSecretKeyMethod, GenerateSecretKeySyncMethod } from './keygen';
5
+ import type { KeyVariant } from './Cipher';
6
+ import type { RSACipher } from './rsa';
3
7
  type KeyDetail = {
4
8
  length?: number;
5
9
  publicExponent?: number;
@@ -10,19 +14,25 @@ type KeyDetail = {
10
14
  namedCurve?: string;
11
15
  };
12
16
  type ECExportKey = (format: KWebCryptoKeyFormat, handle: KeyObjectHandle) => ArrayBuffer;
17
+ type RSAExportKey = (format: KWebCryptoKeyFormat, handle: KeyObjectHandle, variant: KeyVariant) => ArrayBuffer;
13
18
  export type KeyObjectHandle = {
14
19
  export(format?: KFormatType, type?: KeyEncoding, cipher?: string, passphrase?: ArrayBuffer): ArrayBuffer;
15
20
  exportJwk(key: JWK, handleRsaPss: boolean): JWK;
16
21
  getAsymmetricKeyType(): AsymmetricKeyType;
17
- init(keyType: KeyType, key: any): boolean;
22
+ init(keyType: KeyType, key: any, format?: KFormatType, type?: KeyEncoding, passphrase?: string | ArrayBuffer): boolean;
18
23
  initECRaw(curveName: string, keyData: ArrayBuffer): boolean;
19
24
  initJwk(keyData: JWK, namedCurve?: NamedCurve): KeyType | undefined;
20
25
  keyDetail(): KeyDetail;
21
26
  };
22
27
  type CreateKeyObjectHandle = () => KeyObjectHandle;
23
28
  export type webcrypto = {
24
- ecExportKey: ECExportKey;
29
+ aesCipher: AESCipher;
25
30
  createKeyObjectHandle: CreateKeyObjectHandle;
31
+ ecExportKey: ECExportKey;
32
+ generateSecretKey: GenerateSecretKeyMethod;
33
+ generateSecretKeySync: GenerateSecretKeySyncMethod;
34
+ rsaCipher: RSACipher;
35
+ rsaExportKey: RSAExportKey;
26
36
  signVerify: SignVerify;
27
37
  };
28
38
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"webcrypto.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/webcrypto.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,GAAG,EACH,WAAW,EACX,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,UAAU,EACX,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAExC,KAAK,SAAS,GAAG;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,KAAK,WAAW,GAAG,CACjB,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,eAAe,KACpB,WAAW,CAAC;AAEjB,MAAM,MAAM,eAAe,GAAG;IAC5B,MAAM,CACJ,MAAM,CAAC,EAAE,WAAW,EACpB,IAAI,CAAC,EAAE,WAAW,EAClB,MAAM,CAAC,EAAE,MAAM,EACf,UAAU,CAAC,EAAE,WAAW,GACvB,WAAW,CAAC;IACf,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,YAAY,EAAE,OAAO,GAAG,GAAG,CAAC;IAChD,oBAAoB,IAAI,iBAAiB,CAAC;IAC1C,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC;IAC1C,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC;IAC5D,OAAO,CAAC,OAAO,EAAE,GAAG,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,CAAC;IACpE,SAAS,IAAI,SAAS,CAAC;CACxB,CAAC;AAEF,KAAK,qBAAqB,GAAG,MAAM,eAAe,CAAC;AAEnD,MAAM,MAAM,SAAS,GAAG;IACtB,WAAW,EAAE,WAAW,CAAC;IACzB,qBAAqB,EAAE,qBAAqB,CAAC;IAC7C,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC"}
1
+ {"version":3,"file":"webcrypto.d.ts","sourceRoot":"","sources":["../../../src/NativeQuickCrypto/webcrypto.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EACV,iBAAiB,EACjB,GAAG,EACH,WAAW,EACX,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,UAAU,EACX,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,KAAK,EACV,uBAAuB,EACvB,2BAA2B,EAC5B,MAAM,UAAU,CAAC;AAClB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,KAAK,SAAS,GAAG;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,KAAK,WAAW,GAAG,CACjB,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,eAAe,KACpB,WAAW,CAAC;AAEjB,KAAK,YAAY,GAAG,CAClB,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,UAAU,KAChB,WAAW,CAAC;AAEjB,MAAM,MAAM,eAAe,GAAG;IAC5B,MAAM,CACJ,MAAM,CAAC,EAAE,WAAW,EACpB,IAAI,CAAC,EAAE,WAAW,EAClB,MAAM,CAAC,EAAE,MAAM,EACf,UAAU,CAAC,EAAE,WAAW,GACvB,WAAW,CAAC;IACf,SAAS,CAAC,GAAG,EAAE,GAAG,EAAE,YAAY,EAAE,OAAO,GAAG,GAAG,CAAC;IAChD,oBAAoB,IAAI,iBAAiB,CAAC;IAC1C,IAAI,CACF,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,GAAG,EACR,MAAM,CAAC,EAAE,WAAW,EACpB,IAAI,CAAC,EAAE,WAAW,EAClB,UAAU,CAAC,EAAE,MAAM,GAAG,WAAW,GAChC,OAAO,CAAC;IACX,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC;IAC5D,OAAO,CAAC,OAAO,EAAE,GAAG,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,CAAC;IACpE,SAAS,IAAI,SAAS,CAAC;CACxB,CAAC;AAEF,KAAK,qBAAqB,GAAG,MAAM,eAAe,CAAC;AAEnD,MAAM,MAAM,SAAS,GAAG;IACtB,SAAS,EAAE,SAAS,CAAC;IACrB,qBAAqB,EAAE,qBAAqB,CAAC;IAC7C,WAAW,EAAE,WAAW,CAAC;IACzB,iBAAiB,EAAE,uBAAuB,CAAC;IAC3C,qBAAqB,EAAE,2BAA2B,CAAC;IACnD,SAAS,EAAE,SAAS,CAAC;IACrB,YAAY,EAAE,YAAY,CAAC;IAC3B,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC"}
@@ -1,6 +1,5 @@
1
- /// <reference types="node" />
2
1
  import { Buffer } from '@craftzdog/react-native-buffer';
3
- import type { AnyAlgorithm, KeyUsage, SubtleAlgorithm } from './keys';
2
+ import type { AnyAlgorithm, EncryptDecryptParams, KeyUsage, SubtleAlgorithm } from './keys';
4
3
  import { type CipherKey } from 'crypto';
5
4
  export type BufferLike = ArrayBuffer | Buffer | ArrayBufferView;
6
5
  export type BinaryLike = string | ArrayBuffer | Buffer | TypedArray;
@@ -24,7 +23,7 @@ export declare function binaryLikeToArrayBuffer(input: BinaryLikeNode, // Cipher
24
23
  encoding?: string): ArrayBuffer;
25
24
  export declare function ab2str(buf: ArrayBuffer, encoding?: string): string;
26
25
  export declare function validateString(str: any, name?: string): str is string;
27
- export declare function validateFunction(f: any): f is Function;
26
+ export declare function validateFunction(f: any): boolean;
28
27
  export declare function isStringOrBuffer(val: any): val is string | ArrayBuffer;
29
28
  export declare function validateObject<T>(value: any, name: string, options?: {
30
29
  allowArray: boolean;
@@ -37,11 +36,12 @@ export declare function hasAnyNotIn(set: string[], checks: string[]): boolean;
37
36
  export declare function lazyDOMException(message: string, domName: DOMName): Error;
38
37
  export type Operation = 'digest' | 'generateKey' | 'sign' | 'verify' | 'importKey' | 'deriveBits' | 'encrypt' | 'decrypt' | 'get key length' | 'wrapKey' | 'unwrapKey';
39
38
  export declare const validateMaxBufferLength: (data: BinaryLike | BufferLike, name: string) => void;
40
- export declare const normalizeAlgorithm: (algorithm: SubtleAlgorithm | AnyAlgorithm, op: Operation) => SubtleAlgorithm;
39
+ export declare const normalizeAlgorithm: (algorithm: SubtleAlgorithm | EncryptDecryptParams | AnyAlgorithm, op: Operation) => SubtleAlgorithm | EncryptDecryptParams;
41
40
  export declare const validateBitLength: (length: number, name: string, required?: boolean) => void;
42
41
  export declare const validateByteLength: (buf: BufferLike, name: string, target: number) => void;
43
42
  export declare const getUsagesUnion: (usageSet: KeyUsage[], ...usages: KeyUsage[]) => KeyUsage[];
44
43
  export declare const validateKeyOps: (keyOps: KeyUsage[] | undefined, usagesSet: KeyUsage[]) => void;
44
+ export declare const bigIntArrayToUnsignedInt: (input: Uint8Array) => number | undefined;
45
45
  export declare const getHashes: () => string[];
46
46
  export declare const getCiphers: () => string[];
47
47
  export * from './Hashnames';
@@ -1 +1 @@
1
- {"version":3,"file":"Utils.d.ts","sourceRoot":"","sources":["../../src/Utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Utils.d.ts","sourceRoot":"","sources":["../../src/Utils.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,22 @@
1
1
  import { type BufferLike } from './Utils';
2
- import { type ImportFormat, type SubtleAlgorithm, type KeyUsage, CryptoKey, type JWK } from './keys';
2
+ import { type ImportFormat, type SubtleAlgorithm, type KeyUsage, CryptoKey, type JWK, CipherOrWrapMode, type EncryptDecryptParams, type AesKeyGenParams } from './keys';
3
+ export declare enum AESKeyVariant {
4
+ AES_CTR_128 = 0,
5
+ AES_CTR_192 = 1,
6
+ AES_CTR_256 = 2,
7
+ AES_CBC_128 = 3,
8
+ AES_CBC_192 = 4,
9
+ AES_CBC_256 = 5,
10
+ AES_GCM_128 = 6,
11
+ AES_GCM_192 = 7,
12
+ AES_GCM_256 = 8,
13
+ AES_KW_128 = 9,
14
+ AES_KW_192 = 10,
15
+ AES_KW_256 = 11
16
+ }
17
+ export declare const kAesKeyLengths: number[];
3
18
  export declare const getAlgorithmName: (name: string, length?: number) => string;
19
+ export declare const aesCipher: (mode: CipherOrWrapMode, key: CryptoKey, data: ArrayBuffer, algorithm: EncryptDecryptParams) => Promise<ArrayBuffer>;
20
+ export declare const aesGenerateKey: (algorithm: AesKeyGenParams, extractable: boolean, keyUsages: KeyUsage[]) => Promise<CryptoKey>;
4
21
  export declare const aesImportKey: (algorithm: SubtleAlgorithm, format: ImportFormat, keyData: BufferLike | JWK, extractable: boolean, keyUsages: KeyUsage[]) => Promise<CryptoKey>;
5
22
  //# sourceMappingURL=aes.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"aes.d.ts","sourceRoot":"","sources":["../../src/aes.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,KAAK,UAAU,EAGhB,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,QAAQ,EACb,SAAS,EAGT,KAAK,GAAG,EACT,MAAM,QAAQ,CAAC;AAiEhB,eAAO,MAAM,gBAAgB,SAAU,MAAM,WAAW,MAAM,WAkB7D,CAAC;AAgLF,eAAO,MAAM,YAAY,cACZ,eAAe,UAClB,YAAY,WACX,UAAU,GAAG,GAAG,eACZ,OAAO,aACT,QAAQ,EAAE,KACpB,QAAQ,SAAS,CAoFnB,CAAC"}
1
+ {"version":3,"file":"aes.d.ts","sourceRoot":"","sources":["../../src/aes.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,KAAK,UAAU,EAMhB,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,QAAQ,EACb,SAAS,EAGT,KAAK,GAAG,EAER,gBAAgB,EAChB,KAAK,oBAAoB,EAMzB,KAAK,eAAe,EACrB,MAAM,QAAQ,CAAC;AAIhB,oBAAY,aAAa;IACvB,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,WAAW,IAAA;IACX,UAAU,IAAA;IACV,UAAU,KAAA;IACV,UAAU,KAAA;CACX;AAID,eAAO,MAAM,cAAc,UAAkB,CAAC;AAE9C,eAAO,MAAM,gBAAgB,SAAU,MAAM,WAAW,MAAM,WAkB7D,CAAC;AAiLF,eAAO,MAAM,SAAS,SACd,gBAAgB,OACjB,SAAS,QACR,WAAW,aACN,oBAAoB,KAC9B,OAAO,CAAC,WAAW,CAYrB,CAAC;AAEF,eAAO,MAAM,cAAc,cACd,eAAe,eACb,OAAO,aACT,QAAQ,EAAE,KACpB,OAAO,CAAC,SAAS,CAyCnB,CAAC;AAEF,eAAO,MAAM,YAAY,cACZ,eAAe,UAClB,YAAY,WACX,UAAU,GAAG,GAAG,eACZ,OAAO,aACT,QAAQ,EAAE,KACpB,OAAO,CAAC,SAAS,CAoFnB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"ec.d.ts","sourceRoot":"","sources":["../../src/ec.ts"],"names":[],"mappings":"AAGA,OAAO,EAEL,KAAK,UAAU,EACf,KAAK,UAAU,EAQhB,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,QAAQ,EAIb,mBAAmB,EACnB,SAAS,EACT,KAAK,GAAG,EAIR,KAAK,aAAa,EACnB,MAAM,QAAQ,CAAC;AA6FhB,wBAAgB,WAAW,CACzB,GAAG,EAAE,SAAS,EACd,MAAM,EAAE,mBAAmB,GAC1B,WAAW,CAEb;AAED,wBAAgB,WAAW,CACzB,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,UAAU,GAAG,UAAU,GAAG,GAAG,EACtC,SAAS,EAAE,eAAe,EAC1B,WAAW,EAAE,OAAO,EACpB,SAAS,EAAE,QAAQ,EAAE,GACpB,SAAS,CAoIX;AAED,eAAO,MAAM,eAAe,QACrB,SAAS,QACR,UAAU,YACN,eAAe,cACb,UAAU,0BA2BvB,CAAC;AAEF,eAAO,MAAM,aAAa,cACb,eAAe,eACb,OAAO,aACT,QAAQ,EAAE,KACpB,QAAQ,aAAa,CAoEvB,CAAC"}
1
+ {"version":3,"file":"ec.d.ts","sourceRoot":"","sources":["../../src/ec.ts"],"names":[],"mappings":"AAGA,OAAO,EAEL,KAAK,UAAU,EACf,KAAK,UAAU,EAQhB,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,eAAe,EACpB,KAAK,QAAQ,EAIb,mBAAmB,EACnB,SAAS,EACT,KAAK,GAAG,EAIR,KAAK,aAAa,EACnB,MAAM,QAAQ,CAAC;AA6FhB,wBAAgB,WAAW,CACzB,GAAG,EAAE,SAAS,EACd,MAAM,EAAE,mBAAmB,GAC1B,WAAW,CAEb;AAED,wBAAgB,WAAW,CACzB,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,UAAU,GAAG,UAAU,GAAG,GAAG,EACtC,SAAS,EAAE,eAAe,EAC1B,WAAW,EAAE,OAAO,EACpB,SAAS,EAAE,QAAQ,EAAE,GACpB,SAAS,CAoIX;AAED,eAAO,MAAM,eAAe,QACrB,SAAS,QACR,UAAU,YACN,eAAe,cACb,UAAU,0BA2BvB,CAAC;AAEF,eAAO,MAAM,aAAa,cACb,eAAe,eACb,OAAO,aACT,QAAQ,EAAE,KACpB,OAAO,CAAC,aAAa,CAoEvB,CAAC"}