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 +1 @@
1
- {"version":3,"names":["Buffer","defaultEncoding","setDefaultEncoding","encoding","getDefaultEncoding","kEmptyObject","Object","freeze","create","toArrayBuffer","buf","buffer","slice","byteOffset","byteLength","ab","ArrayBuffer","length","view","Uint8Array","i","bufferLikeToArrayBuffer","isBuffer","isView","binaryLikeToArrayBuffer","input","Error","from","ab2str","toString","validateString","str","name","isString","validateFunction","f","isStringOrBuffer","val","validateObject","value","options","useDefaultOptions","allowArray","allowFunction","nullable","Array","isArray","validateInt32","min","max","Number","isInteger","validateUint32","positive","hasAnyNotIn","set","checks","s","includes","lazyDOMException","message","domName","cause","kMaxBufferLength","kSupportedAlgorithms","HKDF","PBKDF2","ECDH","X25519","X448","simpleAlgorithmDictionaries","AesGcmParams","iv","additionalData","RsaHashedKeyGenParams","hash","EcKeyGenParams","HmacKeyGenParams","RsaPssParams","EcdsaParams","HmacImportParams","HkdfParams","salt","info","Ed448Params","context","Pbkdf2Params","RsaOaepParams","label","RsaHashedImportParams","EcKeyImportParams","validateMaxBufferLength","data","normalizeAlgorithm","algorithm","op","registeredAlgorithms","algName","undefined","desiredType","key","hasOwnProperty","toUpperCase","normalizedAlgorithm","dict","dictKeys","keys","member","validateBitLength","required","validateByteLength","target","getUsagesUnion","usageSet","usages","newset","n","push","kKeyOps","sign","verify","encrypt","decrypt","wrapKey","unwrapKey","deriveKey","deriveBits","validateKeyOps","keyOps","usagesSet","flags","op_flag","use","getHashes","getCiphers"],"sourceRoot":"../../src","sources":["Utils.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Buffer","defaultEncoding","setDefaultEncoding","encoding","getDefaultEncoding","kEmptyObject","Object","freeze","create","toArrayBuffer","buf","buffer","slice","byteOffset","byteLength","ab","ArrayBuffer","length","view","Uint8Array","i","bufferLikeToArrayBuffer","isBuffer","isView","binaryLikeToArrayBuffer","input","Error","from","ab2str","toString","validateString","str","name","isString","validateFunction","f","isStringOrBuffer","val","validateObject","value","options","useDefaultOptions","allowArray","allowFunction","nullable","Array","isArray","validateInt32","min","max","Number","isInteger","validateUint32","positive","hasAnyNotIn","set","checks","s","includes","lazyDOMException","message","domName","cause","kMaxBufferLength","kSupportedAlgorithms","HKDF","PBKDF2","ECDH","X25519","X448","simpleAlgorithmDictionaries","AesGcmParams","iv","additionalData","RsaHashedKeyGenParams","hash","EcKeyGenParams","HmacKeyGenParams","RsaPssParams","EcdsaParams","HmacImportParams","HkdfParams","salt","info","Ed448Params","context","Pbkdf2Params","RsaOaepParams","label","RsaHashedImportParams","EcKeyImportParams","validateMaxBufferLength","data","normalizeAlgorithm","algorithm","op","registeredAlgorithms","algName","undefined","desiredType","key","hasOwnProperty","toUpperCase","normalizedAlgorithm","dict","dictKeys","keys","member","validateBitLength","required","validateByteLength","target","getUsagesUnion","usageSet","usages","newset","n","push","kKeyOps","sign","verify","encrypt","decrypt","wrapKey","unwrapKey","deriveKey","deriveBits","validateKeyOps","keyOps","usagesSet","flags","op_flag","use","bigIntArrayToUnsignedInt","result","n_reversed","getHashes","getCiphers"],"sourceRoot":"../../src","sources":["Utils.ts"],"mappings":"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","ignoreList":[]}
package/lib/module/aes.js CHANGED
@@ -1,70 +1,27 @@
1
1
  import { NativeQuickCrypto } from './NativeQuickCrypto/NativeQuickCrypto';
2
- import { lazyDOMException, hasAnyNotIn, validateKeyOps } from './Utils';
3
- import { CryptoKey, createSecretKey, SecretKeyObject } from './keys';
4
-
5
- // const {
6
- // ArrayBufferIsView,
7
- // ArrayBufferPrototypeSlice,
8
- // ArrayFrom,
9
- // ArrayPrototypeIncludes,
10
- // ArrayPrototypePush,
11
- // MathFloor,
12
- // SafeSet,
13
- // TypedArrayPrototypeSlice,
14
- // } = primordials;
15
-
16
- // const {
17
- // AESCipherJob,
18
- // KeyObjectHandle,
19
- // kCryptoJobAsync,
20
- // kKeyVariantAES_CTR_128,
21
- // kKeyVariantAES_CBC_128,
22
- // kKeyVariantAES_GCM_128,
23
- // kKeyVariantAES_KW_128,
24
- // kKeyVariantAES_CTR_192,
25
- // kKeyVariantAES_CBC_192,
26
- // kKeyVariantAES_GCM_192,
27
- // kKeyVariantAES_KW_192,
28
- // kKeyVariantAES_CTR_256,
29
- // kKeyVariantAES_CBC_256,
30
- // kKeyVariantAES_GCM_256,
31
- // kKeyVariantAES_KW_256,
32
- // kWebCryptoCipherDecrypt,
33
- // kWebCryptoCipherEncrypt,
34
- // } = internalBinding('crypto');
35
-
36
- // const {
37
- // hasAnyNotIn,
38
- // jobPromise,
39
- // validateByteLength,
40
- // validateKeyOps,
41
- // validateMaxBufferLength,
42
- // kAesKeyLengths,
43
- // kHandle,
44
- // kKeyObject,
45
- // } = require('internal/crypto/util');
46
-
47
- // const {
48
- // lazyDOMException,
49
- // promisify,
50
- // } = require('internal/util');
51
-
52
- // const { PromiseReject } = primordials;
53
-
54
- // const {
55
- // InternalCryptoKey,
56
- // SecretKeyObject,
57
- // createSecretKey,
58
- // } = require('internal/crypto/keys');
59
-
60
- // const {
61
- // generateKey: _generateKey,
62
- // } = require('internal/crypto/keygen');
63
-
64
- // const kMaxCounterLength = 128;
65
- // const kTagLengths = [32, 64, 96, 104, 112, 120, 128];
66
- // const generateKey = promisify(_generateKey);
2
+ import { lazyDOMException, hasAnyNotIn, validateKeyOps, validateByteLength, validateMaxBufferLength, bufferLikeToArrayBuffer } from './Utils';
3
+ import { CryptoKey, createSecretKey, SecretKeyObject, CipherOrWrapMode } from './keys';
4
+ import { generateKeyPromise } from './keygen';
67
5
 
6
+ // needs to match the values in cpp/webcrypto/crypto_aes.{h,cpp}
7
+ export let AESKeyVariant = /*#__PURE__*/function (AESKeyVariant) {
8
+ AESKeyVariant[AESKeyVariant["AES_CTR_128"] = 0] = "AES_CTR_128";
9
+ AESKeyVariant[AESKeyVariant["AES_CTR_192"] = 1] = "AES_CTR_192";
10
+ AESKeyVariant[AESKeyVariant["AES_CTR_256"] = 2] = "AES_CTR_256";
11
+ AESKeyVariant[AESKeyVariant["AES_CBC_128"] = 3] = "AES_CBC_128";
12
+ AESKeyVariant[AESKeyVariant["AES_CBC_192"] = 4] = "AES_CBC_192";
13
+ AESKeyVariant[AESKeyVariant["AES_CBC_256"] = 5] = "AES_CBC_256";
14
+ AESKeyVariant[AESKeyVariant["AES_GCM_128"] = 6] = "AES_GCM_128";
15
+ AESKeyVariant[AESKeyVariant["AES_GCM_192"] = 7] = "AES_GCM_192";
16
+ AESKeyVariant[AESKeyVariant["AES_GCM_256"] = 8] = "AES_GCM_256";
17
+ AESKeyVariant[AESKeyVariant["AES_KW_128"] = 9] = "AES_KW_128";
18
+ AESKeyVariant[AESKeyVariant["AES_KW_192"] = 10] = "AES_KW_192";
19
+ AESKeyVariant[AESKeyVariant["AES_KW_256"] = 11] = "AES_KW_256";
20
+ return AESKeyVariant;
21
+ }({});
22
+ const kMaxCounterLength = 128;
23
+ const kTagLengths = [32, 64, 96, 104, 112, 120, 128];
24
+ export const kAesKeyLengths = [128, 192, 256];
68
25
  export const getAlgorithmName = (name, length) => {
69
26
  if (length === undefined) throw lazyDOMException(`Invalid algorithm length: ${length}`, 'SyntaxError');
70
27
  switch (name) {
@@ -83,176 +40,174 @@ export const getAlgorithmName = (name, length) => {
83
40
  function validateKeyLength(length) {
84
41
  if (length !== 128 && length !== 192 && length !== 256) throw lazyDOMException(`Invalid key length: ${length}`, 'DataError');
85
42
  }
43
+ function getVariant(name, length) {
44
+ switch (name) {
45
+ case 'AES-CBC':
46
+ switch (length) {
47
+ case 128:
48
+ return AESKeyVariant.AES_CBC_128;
49
+ case 192:
50
+ return AESKeyVariant.AES_CBC_192;
51
+ case 256:
52
+ return AESKeyVariant.AES_CBC_256;
53
+ }
54
+ // @ts-ignore
55
+ break;
56
+ case 'AES-CTR':
57
+ switch (length) {
58
+ case 128:
59
+ return AESKeyVariant.AES_CTR_128;
60
+ case 192:
61
+ return AESKeyVariant.AES_CTR_192;
62
+ case 256:
63
+ return AESKeyVariant.AES_CTR_256;
64
+ }
65
+ // @ts-ignore
66
+ break;
67
+ case 'AES-GCM':
68
+ switch (length) {
69
+ case 128:
70
+ return AESKeyVariant.AES_GCM_128;
71
+ case 192:
72
+ return AESKeyVariant.AES_GCM_192;
73
+ case 256:
74
+ return AESKeyVariant.AES_GCM_256;
75
+ }
76
+ // @ts-ignore
77
+ break;
78
+ case 'AES-KW':
79
+ switch (length) {
80
+ case 128:
81
+ return AESKeyVariant.AES_KW_128;
82
+ case 192:
83
+ return AESKeyVariant.AES_KW_192;
84
+ case 256:
85
+ return AESKeyVariant.AES_KW_256;
86
+ }
87
+ // @ts-ignore
88
+ break;
89
+ }
86
90
 
87
- // function getVariant(name, length) {
88
- // switch (name) {
89
- // case 'AES-CBC':
90
- // switch (length) {
91
- // case 128: return kKeyVariantAES_CBC_128;
92
- // case 192: return kKeyVariantAES_CBC_192;
93
- // case 256: return kKeyVariantAES_CBC_256;
94
- // }
95
- // break;
96
- // case 'AES-CTR':
97
- // switch (length) {
98
- // case 128: return kKeyVariantAES_CTR_128;
99
- // case 192: return kKeyVariantAES_CTR_192;
100
- // case 256: return kKeyVariantAES_CTR_256;
101
- // }
102
- // break;
103
- // case 'AES-GCM':
104
- // switch (length) {
105
- // case 128: return kKeyVariantAES_GCM_128;
106
- // case 192: return kKeyVariantAES_GCM_192;
107
- // case 256: return kKeyVariantAES_GCM_256;
108
- // }
109
- // break;
110
- // case 'AES-KW':
111
- // switch (length) {
112
- // case 128: return kKeyVariantAES_KW_128;
113
- // case 192: return kKeyVariantAES_KW_192;
114
- // case 256: return kKeyVariantAES_KW_256;
115
- // }
116
- // break;
117
- // }
118
- // }
119
-
120
- // function asyncAesCtrCipher(mode, key, data, { counter, length }) {
121
- // validateByteLength(counter, 'algorithm.counter', 16);
122
- // // The length must specify an integer between 1 and 128. While
123
- // // there is no default, this should typically be 64.
124
- // if (length === 0 || length > kMaxCounterLength) {
125
- // throw lazyDOMException(
126
- // 'AES-CTR algorithm.length must be between 1 and 128',
127
- // 'OperationError');
128
- // }
129
-
130
- // return jobPromise(() => new AESCipherJob(
131
- // kCryptoJobAsync,
132
- // mode,
133
- // key[kKeyObject][kHandle],
134
- // data,
135
- // getVariant('AES-CTR', key.algorithm.length),
136
- // counter,
137
- // length));
138
- // }
139
-
140
- // function asyncAesCbcCipher(mode, key, data, { iv }) {
141
- // validateByteLength(iv, 'algorithm.iv', 16);
142
- // return jobPromise(() => new AESCipherJob(
143
- // kCryptoJobAsync,
144
- // mode,
145
- // key[kKeyObject][kHandle],
146
- // data,
147
- // getVariant('AES-CBC', key.algorithm.length),
148
- // iv));
149
- // }
150
-
151
- // function asyncAesKwCipher(mode, key, data) {
152
- // return jobPromise(() => new AESCipherJob(
153
- // kCryptoJobAsync,
154
- // mode,
155
- // key[kKeyObject][kHandle],
156
- // data,
157
- // getVariant('AES-KW', key.algorithm.length)));
158
- // }
159
-
160
- // function asyncAesGcmCipher(
161
- // mode,
162
- // key,
163
- // data,
164
- // { iv, additionalData, tagLength = 128 }) {
165
- // if (!ArrayPrototypeIncludes(kTagLengths, tagLength)) {
166
- // return PromiseReject(lazyDOMException(
167
- // `${tagLength} is not a valid AES-GCM tag length`,
168
- // 'OperationError'));
169
- // }
170
-
171
- // validateMaxBufferLength(iv, 'algorithm.iv');
172
-
173
- // if (additionalData !== undefined) {
174
- // validateMaxBufferLength(additionalData, 'algorithm.additionalData');
175
- // }
176
-
177
- // const tagByteLength = MathFloor(tagLength / 8);
178
- // let tag;
179
- // switch (mode) {
180
- // case kWebCryptoCipherDecrypt: {
181
- // const slice = ArrayBufferIsView(data) ?
182
- // TypedArrayPrototypeSlice : ArrayBufferPrototypeSlice;
183
- // tag = slice(data, -tagByteLength);
184
-
185
- // // Refs: https://www.w3.org/TR/WebCryptoAPI/#aes-gcm-operations
186
- // //
187
- // // > If *plaintext* has a length less than *tagLength* bits, then `throw`
188
- // // > an `OperationError`.
189
- // if (tagByteLength > tag.byteLength) {
190
- // return PromiseReject(lazyDOMException(
191
- // 'The provided data is too small.',
192
- // 'OperationError'));
193
- // }
194
-
195
- // data = slice(data, 0, -tagByteLength);
196
- // break;
197
- // }
198
- // case kWebCryptoCipherEncrypt:
199
- // tag = tagByteLength;
200
- // break;
201
- // }
91
+ // @ts-ignore
92
+ throw lazyDOMException(`Error getting variant ${name} at length: ${length}`, 'DataError');
93
+ }
94
+ function asyncAesCtrCipher(mode, key, data, {
95
+ counter,
96
+ length
97
+ }) {
98
+ validateByteLength(counter, 'algorithm.counter', 16);
99
+ // The length must specify an integer between 1 and 128. While
100
+ // there is no default, this should typically be 64.
101
+ if (length === 0 || length > kMaxCounterLength) {
102
+ throw lazyDOMException('AES-CTR algorithm.length must be between 1 and 128', 'OperationError');
103
+ }
104
+ return NativeQuickCrypto.webcrypto.aesCipher(mode, key.keyObject.handle, data, getVariant('AES-CTR', key.algorithm.length), bufferLikeToArrayBuffer(counter), length);
105
+ }
106
+ function asyncAesCbcCipher(mode, key, data, {
107
+ iv
108
+ }) {
109
+ validateByteLength(iv, 'algorithm.iv', 16);
110
+ return NativeQuickCrypto.webcrypto.aesCipher(mode, key.keyObject.handle, data, getVariant('AES-CBC', key.algorithm.length), bufferLikeToArrayBuffer(iv));
111
+ }
202
112
 
203
- // return jobPromise(() => new AESCipherJob(
204
- // kCryptoJobAsync,
113
+ // function asyncAesKwCipher(
114
+ // mode: CipherOrWrapMode,
115
+ // key: CryptoKey,
116
+ // data: BufferLike
117
+ // ): Promise<ArrayBuffer> {
118
+ // return NativeQuickCrypto.webcrypto.aesCipher(
205
119
  // mode,
206
- // key[kKeyObject][kHandle],
120
+ // key.keyObject.handle,
207
121
  // data,
208
- // getVariant('AES-GCM', key.algorithm.length),
209
- // iv,
210
- // tag,
211
- // additionalData));
122
+ // getVariant('AES-KW', key.algorithm.length)
123
+ // );
212
124
  // }
213
125
 
214
- // export const aesCipher = (mode, key, data, algorithm) => {
215
- // switch (algorithm.name) {
216
- // case 'AES-CTR': return asyncAesCtrCipher(mode, key, data, algorithm);
217
- // case 'AES-CBC': return asyncAesCbcCipher(mode, key, data, algorithm);
218
- // case 'AES-GCM': return asyncAesGcmCipher(mode, key, data, algorithm);
219
- // case 'AES-KW': return asyncAesKwCipher(mode, key, data);
220
- // }
221
- // };
222
-
223
- // export const aesGenerateKey = async (algorithm, extractable, keyUsages) => {
224
- // const { name, length } = algorithm;
225
- // if (!ArrayPrototypeIncludes(kAesKeyLengths, length)) {
226
- // throw lazyDOMException(
227
- // 'AES key length must be 128, 192, or 256 bits',
228
- // 'OperationError');
229
- // }
230
-
231
- // const checkUsages = ['wrapKey', 'unwrapKey'];
232
- // if (name !== 'AES-KW')
233
- // ArrayPrototypePush(checkUsages, 'encrypt', 'decrypt');
234
-
235
- // const usagesSet = new SafeSet(keyUsages);
236
- // if (hasAnyNotIn(usagesSet, checkUsages)) {
237
- // throw lazyDOMException(
238
- // 'Unsupported key usage for an AES key',
239
- // 'SyntaxError');
240
- // }
241
-
242
- // const key = await generateKey('aes', { length }).catch((err) => {
243
- // throw lazyDOMException(
244
- // 'The operation failed for an operation-specific reason' +
245
- // `[${err.message}]`,
246
- // { name: 'OperationError', cause: err });
247
- // });
248
-
249
- // return new InternalCryptoKey(
250
- // key,
251
- // { name, length },
252
- // ArrayFrom(usagesSet),
253
- // extractable);
254
- // };
126
+ function asyncAesGcmCipher(mode, key, data, {
127
+ iv,
128
+ additionalData,
129
+ tagLength = 128
130
+ }) {
131
+ if (!kTagLengths.includes(tagLength)) {
132
+ throw lazyDOMException(`${tagLength} is not a valid AES-GCM tag length`, 'OperationError');
133
+ }
134
+ validateMaxBufferLength(iv, 'algorithm.iv');
135
+ if (additionalData !== undefined) {
136
+ validateMaxBufferLength(additionalData, 'algorithm.additionalData');
137
+ }
138
+ const tagByteLength = Math.floor(tagLength / 8);
139
+ let length;
140
+ let tag = new ArrayBuffer(0);
141
+ switch (mode) {
142
+ case CipherOrWrapMode.kWebCryptoCipherDecrypt:
143
+ {
144
+ // const slice = ArrayBuffer.isView(data)
145
+ // ? DataView.prototype.buffer.slice
146
+ // : ArrayBuffer.prototype.slice;
147
+ tag = data.slice(-tagByteLength);
255
148
 
149
+ // Refs: https://www.w3.org/TR/WebCryptoAPI/#aes-gcm-operations
150
+ //
151
+ // > If *plaintext* has a length less than *tagLength* bits, then `throw`
152
+ // > an `OperationError`.
153
+ if (tagByteLength > tag.byteLength) {
154
+ throw lazyDOMException('The provided data is too small.', 'OperationError');
155
+ }
156
+ data = data.slice(0, -tagByteLength);
157
+ break;
158
+ }
159
+ case CipherOrWrapMode.kWebCryptoCipherEncrypt:
160
+ length = tagByteLength;
161
+ break;
162
+ }
163
+ return NativeQuickCrypto.webcrypto.aesCipher(mode, key.keyObject.handle, data, getVariant('AES-GCM', key.algorithm.length), bufferLikeToArrayBuffer(iv), length, bufferLikeToArrayBuffer(tag), bufferLikeToArrayBuffer(additionalData || new ArrayBuffer(0)));
164
+ }
165
+ export const aesCipher = (mode, key, data, algorithm) => {
166
+ switch (algorithm.name) {
167
+ case 'AES-CTR':
168
+ return asyncAesCtrCipher(mode, key, data, algorithm);
169
+ case 'AES-CBC':
170
+ return asyncAesCbcCipher(mode, key, data, algorithm);
171
+ case 'AES-GCM':
172
+ return asyncAesGcmCipher(mode, key, data, algorithm);
173
+ // case 'AES-KW':
174
+ // return asyncAesKwCipher(mode, key, data);
175
+ }
176
+ throw new Error(`aesCipher: Unknown algorithm ${algorithm.name}`);
177
+ };
178
+ export const aesGenerateKey = async (algorithm, extractable, keyUsages) => {
179
+ const {
180
+ name,
181
+ length
182
+ } = algorithm;
183
+ if (!name) {
184
+ throw lazyDOMException('Algorithm name is undefined', 'SyntaxError');
185
+ }
186
+ if (!kAesKeyLengths.includes(length)) {
187
+ throw lazyDOMException('AES key length must be 128, 192, or 256 bits', 'OperationError');
188
+ }
189
+ const checkUsages = ['wrapKey', 'unwrapKey'];
190
+ if (name !== 'AES-KW') {
191
+ checkUsages.push('encrypt', 'decrypt');
192
+ }
193
+ // const usagesSet = new SafeSet(keyUsages);
194
+ if (hasAnyNotIn(keyUsages, checkUsages)) {
195
+ throw lazyDOMException(`Unsupported key usage for an AES key: ${keyUsages}`, 'SyntaxError');
196
+ }
197
+ const [err, key] = await generateKeyPromise('aes', {
198
+ length
199
+ });
200
+ if (err) {
201
+ throw lazyDOMException(`aesGenerateKey (generateKeyPromise) failed: [${err.message}]`, {
202
+ name: 'OperationError',
203
+ cause: err
204
+ });
205
+ }
206
+ return new CryptoKey(key, {
207
+ name,
208
+ length
209
+ }, Array.from(keyUsages), extractable);
210
+ };
256
211
  export const aesImportKey = async (algorithm, format, keyData, extractable, keyUsages) => {
257
212
  const {
258
213
  name
@@ -1 +1 @@
1
- {"version":3,"names":["NativeQuickCrypto","lazyDOMException","hasAnyNotIn","validateKeyOps","CryptoKey","createSecretKey","SecretKeyObject","getAlgorithmName","name","length","undefined","validateKeyLength","aesImportKey","algorithm","format","keyData","extractable","keyUsages","checkUsages","push","keyObject","data","byteLength","kty","use","key_ops","ext","handle","webcrypto","createKeyObjectHandle","initJwk","keyDetail","alg"],"sourceRoot":"../../src","sources":["aes.ts"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,uCAAuC;AACzE,SACEC,gBAAgB,EAEhBC,WAAW,EACXC,cAAc,QACT,SAAS;AAChB,SAIEC,SAAS,EACTC,eAAe,EACfC,eAAe,QAEV,QAAQ;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,OAAO,MAAMC,gBAAgB,GAAGA,CAACC,IAAY,EAAEC,MAAe,KAAK;EACjE,IAAIA,MAAM,KAAKC,SAAS,EACtB,MAAMT,gBAAgB,CACnB,6BAA4BQ,MAAO,EAAC,EACrC,aACF,CAAC;EACH,QAAQD,IAAI;IACV,KAAK,SAAS;MACZ,OAAQ,IAAGC,MAAO,KAAI;IACxB,KAAK,SAAS;MACZ,OAAQ,IAAGA,MAAO,KAAI;IACxB,KAAK,SAAS;MACZ,OAAQ,IAAGA,MAAO,KAAI;IACxB,KAAK,QAAQ;MACX,OAAQ,IAAGA,MAAO,IAAG;IACvB;MACE,MAAMR,gBAAgB,CAAE,2BAA0BO,IAAK,EAAC,EAAE,aAAa,CAAC;EAC5E;AACF,CAAC;AAED,SAASG,iBAAiBA,CAACF,MAAe,EAAE;EAC1C,IAAIA,MAAM,KAAK,GAAG,IAAIA,MAAM,KAAK,GAAG,IAAIA,MAAM,KAAK,GAAG,EACpD,MAAMR,gBAAgB,CAAE,uBAAsBQ,MAAO,EAAC,EAAE,WAAW,CAAC;AACxE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO,MAAMG,YAAY,GAAG,MAAAA,CAC1BC,SAA0B,EAC1BC,MAAoB,EACpBC,OAAyB,EACzBC,WAAoB,EACpBC,SAAqB,KACE;EACvB,MAAM;IAAET;EAAK,CAAC,GAAGK,SAAS;EAC1B,MAAMK,WAAW,GAAG,CAAC,SAAS,EAAE,WAAW,CAAC;EAC5C,IAAIV,IAAI,KAAK,QAAQ,EAAE;IACrBU,WAAW,CAACC,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC;EACxC;;EAEA;EACA,IAAIjB,WAAW,CAACe,SAAS,EAAEC,WAAW,CAAC,EAAE;IACvC,MAAMjB,gBAAgB,CACpB,sCAAsC,EACtC,aACF,CAAC;EACH;EAEA,IAAImB,SAA0B;EAC9B,IAAIX,MAA0B;EAE9B,QAAQK,MAAM;IACZ,KAAK,KAAK;MAAE;QACV,MAAMO,IAAI,GAAGN,OAAqB;QAClCJ,iBAAiB,CAACU,IAAI,CAACC,UAAU,GAAG,CAAC,CAAC;QACtCF,SAAS,GAAGf,eAAe,CAACU,OAAO,CAAC;QACpC;MACF;IACA,KAAK,KAAK;MAAE;QACV,MAAMM,IAAI,GAAGN,OAAc;QAE3B,IAAI,CAACM,IAAI,CAACE,GAAG,EAAE,MAAMtB,gBAAgB,CAAC,iBAAiB,EAAE,WAAW,CAAC;QAErE,IAAIoB,IAAI,CAACE,GAAG,KAAK,KAAK,EACpB,MAAMtB,gBAAgB,CAAC,6BAA6B,EAAE,WAAW,CAAC;QAEpE,IACEgB,SAAS,CAACR,MAAM,GAAG,CAAC,IACpBY,IAAI,CAACG,GAAG,KAAKd,SAAS,IACtBW,IAAI,CAACG,GAAG,KAAK,KAAK,EAClB;UACA,MAAMvB,gBAAgB,CAAC,6BAA6B,EAAE,WAAW,CAAC;QACpE;QAEAE,cAAc,CAACkB,IAAI,CAACI,OAAO,EAAER,SAAS,CAAC;QAEvC,IACEI,IAAI,CAACK,GAAG,KAAKhB,SAAS,IACtBW,IAAI,CAACK,GAAG,KAAK,KAAK,IAClBV,WAAW,KAAK,IAAI,EACpB;UACA,MAAMf,gBAAgB,CACpB,8CAA8C,EAC9C,WACF,CAAC;QACH;QAEA,MAAM0B,MAAM,GAAG3B,iBAAiB,CAAC4B,SAAS,CAACC,qBAAqB,CAAC,CAAC;QAClEF,MAAM,CAACG,OAAO,CAACT,IAAI,CAAC;QAEpB,CAAC;UAAEZ;QAAO,CAAC,GAAGkB,MAAM,CAACI,SAAS,CAAC,CAAC;QAChCpB,iBAAiB,CAACF,MAAM,CAAC;QAEzB,IAAIY,IAAI,CAACW,GAAG,KAAKtB,SAAS,EAAE;UAC1B,IAAIW,IAAI,CAACW,GAAG,KAAKzB,gBAAgB,CAACM,SAAS,CAACL,IAAI,EAAEC,MAAM,CAAC,EACvD,MAAMR,gBAAgB,CACpB,kDAAkD,EAClD,WACF,CAAC;QACL;QAEAmB,SAAS,GAAG,IAAId,eAAe,CAACqB,MAAM,CAAC;QACvC;MACF;IACA;MACE,MAAM1B,gBAAgB,CACnB,wCAAuCa,MAAO,EAAC,EAChD,mBACF,CAAC;EACL;EAEA,IAAIL,MAAM,KAAKC,SAAS,EAAE;IACxB,CAAC;MAAED;IAAO,CAAC,GAAGW,SAAS,CAACO,MAAM,CAACI,SAAS,CAAC,CAAC;IAC1CpB,iBAAiB,CAACF,MAAM,CAAC;EAC3B;EAEA,OAAO,IAAIL,SAAS,CAACgB,SAAS,EAAE;IAAEZ,IAAI;IAAEC;EAAO,CAAC,EAAEQ,SAAS,EAAED,WAAW,CAAC;AAC3E,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["NativeQuickCrypto","lazyDOMException","hasAnyNotIn","validateKeyOps","validateByteLength","validateMaxBufferLength","bufferLikeToArrayBuffer","CryptoKey","createSecretKey","SecretKeyObject","CipherOrWrapMode","generateKeyPromise","AESKeyVariant","kMaxCounterLength","kTagLengths","kAesKeyLengths","getAlgorithmName","name","length","undefined","validateKeyLength","getVariant","AES_CBC_128","AES_CBC_192","AES_CBC_256","AES_CTR_128","AES_CTR_192","AES_CTR_256","AES_GCM_128","AES_GCM_192","AES_GCM_256","AES_KW_128","AES_KW_192","AES_KW_256","asyncAesCtrCipher","mode","key","data","counter","webcrypto","aesCipher","keyObject","handle","algorithm","asyncAesCbcCipher","iv","asyncAesGcmCipher","additionalData","tagLength","includes","tagByteLength","Math","floor","tag","ArrayBuffer","kWebCryptoCipherDecrypt","slice","byteLength","kWebCryptoCipherEncrypt","Error","aesGenerateKey","extractable","keyUsages","checkUsages","push","err","message","cause","Array","from","aesImportKey","format","keyData","kty","use","key_ops","ext","createKeyObjectHandle","initJwk","keyDetail","alg"],"sourceRoot":"../../src","sources":["aes.ts"],"mappings":"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","ignoreList":[]}
@@ -2,15 +2,18 @@ import { Buffer } from '@craftzdog/react-native-buffer';
2
2
  import * as pbkdf2 from './pbkdf2';
3
3
  import * as random from './random';
4
4
  import { createCipher, createCipheriv, createDecipher, createDecipheriv, publicEncrypt, publicDecrypt, privateDecrypt, generateKeyPair, generateKeyPairSync } from './Cipher';
5
+ import { generateKey, generateKeySync } from './keygen';
5
6
  import { createSign, createVerify } from './sig';
6
7
  import { createHmac } from './Hmac';
7
8
  import { createHash } from './Hash';
8
9
  import { constants } from './constants';
9
10
  import { subtle } from './subtle';
10
11
  import { getCiphers, getHashes } from './Utils';
12
+ import webcrypto from './webcrypto';
13
+ import { createPrivateKey, createPublicKey, createSecretKey } from './keys';
11
14
 
12
15
  /**
13
- * Loosesly matches Node.js {crypto} with some unimplemented functionality
16
+ * Loosely matches Node.js {crypto} with some unimplemented functionality
14
17
  */
15
18
  const QuickCrypto = {
16
19
  createHmac,
@@ -21,11 +24,16 @@ const QuickCrypto = {
21
24
  createCipheriv,
22
25
  createDecipher,
23
26
  createDecipheriv,
27
+ createPublicKey,
28
+ createPrivateKey,
29
+ createSecretKey,
24
30
  publicEncrypt,
25
31
  publicDecrypt,
26
32
  privateDecrypt,
33
+ generateKey,
27
34
  generateKeyPair,
28
35
  generateKeyPairSync,
36
+ generateKeySync,
29
37
  createSign,
30
38
  createVerify,
31
39
  subtle,
@@ -33,7 +41,8 @@ const QuickCrypto = {
33
41
  ...pbkdf2,
34
42
  ...random,
35
43
  getCiphers,
36
- getHashes
44
+ getHashes,
45
+ webcrypto
37
46
  };
38
47
 
39
48
  /**
@@ -1 +1 @@
1
- {"version":3,"names":["Buffer","pbkdf2","random","createCipher","createCipheriv","createDecipher","createDecipheriv","publicEncrypt","publicDecrypt","privateDecrypt","generateKeyPair","generateKeyPairSync","createSign","createVerify","createHmac","createHash","constants","subtle","getCiphers","getHashes","QuickCrypto","Hmac","Hash","install","global","crypto","module","exports","default"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,SAASA,MAAM,QAAQ,gCAAgC;AACvD,OAAO,KAAKC,MAAM,MAAM,UAAU;AAClC,OAAO,KAAKC,MAAM,MAAM,UAAU;AAClC,SACEC,YAAY,EACZC,cAAc,EACdC,cAAc,EACdC,gBAAgB,EAChBC,aAAa,EACbC,aAAa,EACbC,cAAc,EACdC,eAAe,EACfC,mBAAmB,QACd,UAAU;AACjB,SAASC,UAAU,EAAEC,YAAY,QAAQ,OAAO;AAChD,SAASC,UAAU,QAAQ,QAAQ;AACnC,SAASC,UAAU,QAAQ,QAAQ;AACnC,SAASC,SAAS,QAAQ,aAAa;AACvC,SAASC,MAAM,QAAQ,UAAU;AACjC,SAASC,UAAU,EAAEC,SAAS,QAAQ,SAAS;;AAE/C;AACA;AACA;AACA,MAAMC,WAAW,GAAG;EAClBN,UAAU;EACVO,IAAI,EAAEP,UAAU;EAChBQ,IAAI,EAAEP,UAAU;EAChBA,UAAU;EACVZ,YAAY;EACZC,cAAc;EACdC,cAAc;EACdC,gBAAgB;EAChBC,aAAa;EACbC,aAAa;EACbC,cAAc;EACdC,eAAe;EACfC,mBAAmB;EACnBC,UAAU;EACVC,YAAY;EACZI,MAAM;EACND,SAAS;EACT,GAAGf,MAAM;EACT,GAAGC,MAAM;EACTgB,UAAU;EACVC;AACF,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMI,OAAO,GAAGA,CAAA,KAAM;EAC3B;EACAC,MAAM,CAACxB,MAAM,GAAGA,MAAM;;EAEtB;EACAwB,MAAM,CAACC,MAAM,GAAGL,WAAW;AAC7B,CAAC;AAED,eAAeA,WAAW;;AAE1B;AACAM,MAAM,CAACC,OAAO,GAAGP,WAAW;AAC5BM,MAAM,CAACC,OAAO,CAACC,OAAO,GAAGR,WAAW;AACpCM,MAAM,CAACC,OAAO,CAACJ,OAAO,GAAGA,OAAO","ignoreList":[]}
1
+ {"version":3,"names":["Buffer","pbkdf2","random","createCipher","createCipheriv","createDecipher","createDecipheriv","publicEncrypt","publicDecrypt","privateDecrypt","generateKeyPair","generateKeyPairSync","generateKey","generateKeySync","createSign","createVerify","createHmac","createHash","constants","subtle","getCiphers","getHashes","webcrypto","createPrivateKey","createPublicKey","createSecretKey","QuickCrypto","Hmac","Hash","install","global","crypto","module","exports","default"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,SAASA,MAAM,QAAQ,gCAAgC;AACvD,OAAO,KAAKC,MAAM,MAAM,UAAU;AAClC,OAAO,KAAKC,MAAM,MAAM,UAAU;AAClC,SACEC,YAAY,EACZC,cAAc,EACdC,cAAc,EACdC,gBAAgB,EAChBC,aAAa,EACbC,aAAa,EACbC,cAAc,EACdC,eAAe,EACfC,mBAAmB,QACd,UAAU;AACjB,SAASC,WAAW,EAAEC,eAAe,QAAQ,UAAU;AACvD,SAASC,UAAU,EAAEC,YAAY,QAAQ,OAAO;AAChD,SAASC,UAAU,QAAQ,QAAQ;AACnC,SAASC,UAAU,QAAQ,QAAQ;AACnC,SAASC,SAAS,QAAQ,aAAa;AACvC,SAASC,MAAM,QAAQ,UAAU;AACjC,SAASC,UAAU,EAAEC,SAAS,QAAQ,SAAS;AAC/C,OAAOC,SAAS,MAAM,aAAa;AACnC,SAASC,gBAAgB,EAAEC,eAAe,EAAEC,eAAe,QAAQ,QAAQ;;AAE3E;AACA;AACA;AACA,MAAMC,WAAW,GAAG;EAClBV,UAAU;EACVW,IAAI,EAAEX,UAAU;EAChBY,IAAI,EAAEX,UAAU;EAChBA,UAAU;EACVd,YAAY;EACZC,cAAc;EACdC,cAAc;EACdC,gBAAgB;EAChBkB,eAAe;EACfD,gBAAgB;EAChBE,eAAe;EACflB,aAAa;EACbC,aAAa;EACbC,cAAc;EACdG,WAAW;EACXF,eAAe;EACfC,mBAAmB;EACnBE,eAAe;EACfC,UAAU;EACVC,YAAY;EACZI,MAAM;EACND,SAAS;EACT,GAAGjB,MAAM;EACT,GAAGC,MAAM;EACTkB,UAAU;EACVC,SAAS;EACTC;AACF,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMO,OAAO,GAAGA,CAAA,KAAM;EAC3B;EACAC,MAAM,CAAC9B,MAAM,GAAGA,MAAM;;EAEtB;EACA8B,MAAM,CAACC,MAAM,GAAGL,WAAW;AAC7B,CAAC;AAED,eAAeA,WAAW;;AAE1B;AACAM,MAAM,CAACC,OAAO,GAAGP,WAAW;AAC5BM,MAAM,CAACC,OAAO,CAACC,OAAO,GAAGR,WAAW;AACpCM,MAAM,CAACC,OAAO,CAACJ,OAAO,GAAGA,OAAO","ignoreList":[]}
@@ -0,0 +1,47 @@
1
+ import { NativeQuickCrypto } from './NativeQuickCrypto/NativeQuickCrypto';
2
+ import { lazyDOMException, validateFunction } from './Utils';
3
+ import { kAesKeyLengths } from './aes';
4
+ import { SecretKeyObject } from './keys';
5
+ export const generateKeyPromise = (type, options) => {
6
+ return new Promise((resolve, reject) => {
7
+ generateKey(type, options, (err, key) => {
8
+ if (err) {
9
+ reject([err, undefined]);
10
+ }
11
+ resolve([undefined, key]);
12
+ });
13
+ });
14
+ };
15
+ export const generateKey = (type, options, callback) => {
16
+ validateLength(type, options.length);
17
+ if (!validateFunction(callback)) {
18
+ throw lazyDOMException('Callback is not a function', 'SyntaxError');
19
+ }
20
+ NativeQuickCrypto.webcrypto.generateSecretKey(options.length).then(handle => {
21
+ callback(undefined, new SecretKeyObject(handle));
22
+ }).catch(err => {
23
+ callback(err, undefined);
24
+ });
25
+ };
26
+ export const generateKeySync = (type, options) => {
27
+ validateLength(type, options.length);
28
+ const handle = NativeQuickCrypto.webcrypto.generateSecretKeySync(options.length);
29
+ return new SecretKeyObject(handle);
30
+ };
31
+ const validateLength = (type, length) => {
32
+ switch (type) {
33
+ case 'aes':
34
+ if (!kAesKeyLengths.includes(length)) {
35
+ throw lazyDOMException('AES key length must be 128, 192, or 256 bits', 'OperationError');
36
+ }
37
+ break;
38
+ case 'hmac':
39
+ if (length < 8 || length > 2 ** 31 - 1) {
40
+ throw lazyDOMException('HMAC key length must be between 8 and 2^31 - 1', 'OperationError');
41
+ }
42
+ break;
43
+ default:
44
+ throw new Error(`Unsupported key type '${type}' for generateKey()`);
45
+ }
46
+ };
47
+ //# sourceMappingURL=keygen.js.map