react-native-quick-crypto 1.1.1 → 1.1.3

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 (185) hide show
  1. package/QuickCrypto.podspec +1 -0
  2. package/android/CMakeLists.txt +4 -0
  3. package/cpp/cipher/CCMCipher.cpp +7 -11
  4. package/cpp/cipher/ChaCha20Cipher.cpp +6 -10
  5. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +10 -16
  6. package/cpp/cipher/GCMCipher.cpp +3 -5
  7. package/cpp/cipher/HybridCipher.cpp +7 -13
  8. package/cpp/cipher/HybridRsaCipher.cpp +19 -27
  9. package/cpp/cipher/OCBCipher.cpp +2 -3
  10. package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +13 -19
  11. package/cpp/cipher/XSalsa20Cipher.cpp +8 -12
  12. package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +11 -16
  13. package/cpp/keys/HybridKeyObjectHandle.cpp +630 -2
  14. package/cpp/keys/HybridKeyObjectHandle.hpp +21 -1
  15. package/cpp/sign/HybridSignHandle.cpp +26 -8
  16. package/cpp/sign/HybridVerifyHandle.cpp +28 -11
  17. package/cpp/slhdsa/HybridSlhDsaKeyPair.cpp +245 -0
  18. package/cpp/slhdsa/HybridSlhDsaKeyPair.hpp +48 -0
  19. package/cpp/turboshake/HybridTurboShake.cpp +379 -0
  20. package/cpp/turboshake/HybridTurboShake.hpp +28 -0
  21. package/cpp/utils/HybridUtils.cpp +83 -21
  22. package/cpp/utils/HybridUtils.hpp +4 -0
  23. package/deps/blake3/README.md +6 -7
  24. package/deps/blake3/c/blake3.c +3 -2
  25. package/deps/blake3/c/blake3.h +2 -2
  26. package/deps/blake3/c/blake3_dispatch.c +2 -2
  27. package/deps/blake3/c/blake3_impl.h +1 -1
  28. package/deps/blake3/c/blake3_neon.c +5 -4
  29. package/deps/ncrypto/include/ncrypto/version.h +2 -2
  30. package/deps/ncrypto/include/ncrypto.h +9 -2
  31. package/deps/ncrypto/src/ncrypto.cpp +130 -35
  32. package/lib/commonjs/dhKeyPair.js +3 -0
  33. package/lib/commonjs/dhKeyPair.js.map +1 -1
  34. package/lib/commonjs/dsa.js +3 -0
  35. package/lib/commonjs/dsa.js.map +1 -1
  36. package/lib/commonjs/ec.js +37 -30
  37. package/lib/commonjs/ec.js.map +1 -1
  38. package/lib/commonjs/ed.js +60 -6
  39. package/lib/commonjs/ed.js.map +1 -1
  40. package/lib/commonjs/expo-plugin/withXCode.js +3 -3
  41. package/lib/commonjs/hash.js +52 -5
  42. package/lib/commonjs/hash.js.map +1 -1
  43. package/lib/commonjs/keys/classes.js +33 -7
  44. package/lib/commonjs/keys/classes.js.map +1 -1
  45. package/lib/commonjs/keys/generateKeyPair.js +85 -4
  46. package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
  47. package/lib/commonjs/keys/index.js +50 -2
  48. package/lib/commonjs/keys/index.js.map +1 -1
  49. package/lib/commonjs/keys/signVerify.js +9 -2
  50. package/lib/commonjs/keys/signVerify.js.map +1 -1
  51. package/lib/commonjs/keys/utils.js +59 -1
  52. package/lib/commonjs/keys/utils.js.map +1 -1
  53. package/lib/commonjs/random.js +63 -9
  54. package/lib/commonjs/random.js.map +1 -1
  55. package/lib/commonjs/rsa.js +3 -0
  56. package/lib/commonjs/rsa.js.map +1 -1
  57. package/lib/commonjs/slhdsa.js +70 -0
  58. package/lib/commonjs/slhdsa.js.map +1 -0
  59. package/lib/commonjs/specs/slhDsaKeyPair.nitro.js +6 -0
  60. package/lib/commonjs/specs/slhDsaKeyPair.nitro.js.map +1 -0
  61. package/lib/commonjs/specs/turboshake.nitro.js +6 -0
  62. package/lib/commonjs/specs/turboshake.nitro.js.map +1 -0
  63. package/lib/commonjs/subtle.js +926 -275
  64. package/lib/commonjs/subtle.js.map +1 -1
  65. package/lib/commonjs/utils/conversion.js +61 -25
  66. package/lib/commonjs/utils/conversion.js.map +1 -1
  67. package/lib/commonjs/utils/errors.js +63 -4
  68. package/lib/commonjs/utils/errors.js.map +1 -1
  69. package/lib/commonjs/utils/types.js.map +1 -1
  70. package/lib/commonjs/utils/validation.js +46 -0
  71. package/lib/commonjs/utils/validation.js.map +1 -1
  72. package/lib/module/dhKeyPair.js +3 -0
  73. package/lib/module/dhKeyPair.js.map +1 -1
  74. package/lib/module/dsa.js +3 -0
  75. package/lib/module/dsa.js.map +1 -1
  76. package/lib/module/ec.js +38 -31
  77. package/lib/module/ec.js.map +1 -1
  78. package/lib/module/ed.js +61 -7
  79. package/lib/module/ed.js.map +1 -1
  80. package/lib/module/expo-plugin/withXCode.js +3 -3
  81. package/lib/module/hash.js +52 -5
  82. package/lib/module/hash.js.map +1 -1
  83. package/lib/module/keys/classes.js +31 -5
  84. package/lib/module/keys/classes.js.map +1 -1
  85. package/lib/module/keys/generateKeyPair.js +86 -5
  86. package/lib/module/keys/generateKeyPair.js.map +1 -1
  87. package/lib/module/keys/index.js +50 -2
  88. package/lib/module/keys/index.js.map +1 -1
  89. package/lib/module/keys/signVerify.js +9 -2
  90. package/lib/module/keys/signVerify.js.map +1 -1
  91. package/lib/module/keys/utils.js +57 -1
  92. package/lib/module/keys/utils.js.map +1 -1
  93. package/lib/module/random.js +63 -10
  94. package/lib/module/random.js.map +1 -1
  95. package/lib/module/rsa.js +3 -0
  96. package/lib/module/rsa.js.map +1 -1
  97. package/lib/module/slhdsa.js +64 -0
  98. package/lib/module/slhdsa.js.map +1 -0
  99. package/lib/module/specs/slhDsaKeyPair.nitro.js +4 -0
  100. package/lib/module/specs/slhDsaKeyPair.nitro.js.map +1 -0
  101. package/lib/module/specs/turboshake.nitro.js +4 -0
  102. package/lib/module/specs/turboshake.nitro.js.map +1 -0
  103. package/lib/module/subtle.js +927 -276
  104. package/lib/module/subtle.js.map +1 -1
  105. package/lib/module/utils/conversion.js +59 -25
  106. package/lib/module/utils/conversion.js.map +1 -1
  107. package/lib/module/utils/errors.js +61 -4
  108. package/lib/module/utils/errors.js.map +1 -1
  109. package/lib/module/utils/types.js.map +1 -1
  110. package/lib/module/utils/validation.js +44 -0
  111. package/lib/module/utils/validation.js.map +1 -1
  112. package/lib/typescript/dhKeyPair.d.ts.map +1 -1
  113. package/lib/typescript/dsa.d.ts.map +1 -1
  114. package/lib/typescript/ec.d.ts.map +1 -1
  115. package/lib/typescript/ed.d.ts.map +1 -1
  116. package/lib/typescript/hash.d.ts.map +1 -1
  117. package/lib/typescript/index.d.ts +12 -7
  118. package/lib/typescript/index.d.ts.map +1 -1
  119. package/lib/typescript/keys/classes.d.ts +10 -1
  120. package/lib/typescript/keys/classes.d.ts.map +1 -1
  121. package/lib/typescript/keys/generateKeyPair.d.ts +12 -1
  122. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
  123. package/lib/typescript/keys/index.d.ts +3 -1
  124. package/lib/typescript/keys/index.d.ts.map +1 -1
  125. package/lib/typescript/keys/signVerify.d.ts.map +1 -1
  126. package/lib/typescript/keys/utils.d.ts +21 -4
  127. package/lib/typescript/keys/utils.d.ts.map +1 -1
  128. package/lib/typescript/random.d.ts +5 -1
  129. package/lib/typescript/random.d.ts.map +1 -1
  130. package/lib/typescript/rsa.d.ts.map +1 -1
  131. package/lib/typescript/slhdsa.d.ts +19 -0
  132. package/lib/typescript/slhdsa.d.ts.map +1 -0
  133. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +9 -0
  134. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
  135. package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts +16 -0
  136. package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts.map +1 -0
  137. package/lib/typescript/specs/turboshake.nitro.d.ts +11 -0
  138. package/lib/typescript/specs/turboshake.nitro.d.ts.map +1 -0
  139. package/lib/typescript/subtle.d.ts +3 -2
  140. package/lib/typescript/subtle.d.ts.map +1 -1
  141. package/lib/typescript/utils/conversion.d.ts +9 -6
  142. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  143. package/lib/typescript/utils/errors.d.ts +12 -0
  144. package/lib/typescript/utils/errors.d.ts.map +1 -1
  145. package/lib/typescript/utils/types.d.ts +32 -15
  146. package/lib/typescript/utils/types.d.ts.map +1 -1
  147. package/lib/typescript/utils/validation.d.ts +3 -1
  148. package/lib/typescript/utils/validation.d.ts.map +1 -1
  149. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +2 -0
  150. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +20 -0
  151. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +20 -0
  152. package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +48 -0
  153. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +9 -0
  154. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +9 -0
  155. package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.cpp +29 -0
  156. package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.hpp +72 -0
  157. package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.cpp +22 -0
  158. package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.hpp +70 -0
  159. package/nitrogen/generated/shared/c++/JWK.hpp +9 -1
  160. package/nitrogen/generated/shared/c++/JWKkty.hpp +4 -0
  161. package/nitrogen/generated/shared/c++/KangarooTwelveVariant.hpp +76 -0
  162. package/nitrogen/generated/shared/c++/TurboShakeVariant.hpp +76 -0
  163. package/package.json +4 -5
  164. package/src/dhKeyPair.ts +8 -0
  165. package/src/dsa.ts +8 -0
  166. package/src/ec.ts +52 -29
  167. package/src/ed.ts +95 -16
  168. package/src/expo-plugin/withXCode.ts +3 -3
  169. package/src/hash.ts +108 -5
  170. package/src/keys/classes.ts +46 -5
  171. package/src/keys/generateKeyPair.ts +151 -5
  172. package/src/keys/index.ts +73 -3
  173. package/src/keys/signVerify.ts +13 -2
  174. package/src/keys/utils.ts +78 -5
  175. package/src/random.ts +93 -9
  176. package/src/rsa.ts +8 -0
  177. package/src/slhdsa.ts +146 -0
  178. package/src/specs/keyObjectHandle.nitro.ts +17 -0
  179. package/src/specs/slhDsaKeyPair.nitro.ts +29 -0
  180. package/src/specs/turboshake.nitro.ts +21 -0
  181. package/src/subtle.ts +1191 -360
  182. package/src/utils/conversion.ts +80 -27
  183. package/src/utils/errors.ts +72 -4
  184. package/src/utils/types.ts +80 -15
  185. package/src/utils/validation.ts +70 -1
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","Buffer","CryptoKey","KeyObject","binaryLikeToArrayBuffer","toAB","hasAnyNotIn","lazyDOMException","getUsagesUnion","KFormatType","KeyEncoding","ECDH","Ed","constructor","type","config","native","createHybridObject","setCurve","diffieHellman","options","callback","privKeyObj","privateKey","pubKeyObj","publicKey","handle","exportKey","ret","Error","from","e","err","undefined","generateKeyPair","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","generateKeyPairSync","getPublicKey","getPrivateKey","getSharedSecret","sign","message","key","signSync","verify","signature","verifySync","checkDiffieHellmanOptions","keyType","asymmetricKeyType","ecDiffieHellman","ed","ed_createKeyObjects","publicKeyData","privateKeyData","pub","createKeyObject","DER","SPKI","priv","PKCS8","ed_formatKeyPairOutput","encoding","format","PEM","exported","Uint8Array","toString","ed_generateKeyPair","isAsync","derConfig","then","catch","String","curveName","namedCurve","ecdh","jwkPrivate","exportJwk","d","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","privateKeyAsym","publicKeyAsym","privateCurve","publicCurve","ed_generateKeyPairWebCrypto","extractable","keyUsages","publicUsages","privateUsages","length","algorithmName","name","x_generateKeyPairWebCrypto","xDeriveBits","algorithm","baseKey","public","toLowerCase","privateKeyBytes","keyObject","publicKeyBytes","privateKeyTyped","publicKeyTyped","byteLength","Math","ceil","slice"],"sourceRoot":"../../src","sources":["ed.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","Buffer","CryptoKey","KeyObject","PublicKeyObject","PrivateKeyObject","PrivateKeyObjectClass","binaryLikeToArrayBuffer","toAB","hasAnyNotIn","lazyDOMException","getUsagesUnion","KFormatType","KeyEncoding","ECDH","coerceToNumeric","value","Ed","constructor","type","config","native","createHybridObject","setCurve","diffieHellman","options","callback","privKeyObj","privateKey","pubKeyObj","publicKey","handle","exportKey","ret","Error","from","e","err","undefined","generateKeyPair","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","generateKeyPairSync","getPublicKey","getPrivateKey","getSharedSecret","sign","message","key","signSync","verify","signature","verifySync","TypeError","resolvedOptions","resolveDhKeyInput","checkDiffieHellmanOptions","keyType","asymmetricKeyType","ecDiffieHellman","ed","isRawKeyInput","obj","format","input","name","expectedKeyType","namedCurve","keyData","initRawPublic","initRawSeed","initRawPrivate","ed_createKeyObjects","publicKeyData","privateKeyData","pub","createKeyObject","DER","SPKI","priv","PKCS8","ed_formatKeyPairOutput","encoding","exportRawPublic","PEM","exported","Uint8Array","toString","exportRawPrivate","exportRawSeed","ed_generateKeyPair","isAsync","derConfig","then","catch","String","curveName","ecdh","jwkPrivate","exportJwk","d","setPrivateKey","jwkPublic","x","y","publicBytes","concat","secret","computeSecret","privateKeyAsym","publicKeyAsym","privateCurve","publicCurve","ed_generateKeyPairWebCrypto","extractable","keyUsages","publicUsages","privateUsages","length","algorithmName","x_generateKeyPairWebCrypto","xDeriveBits","algorithm","baseKey","public","toLowerCase","privateKeyBytes","keyObject","publicKeyBytes","privateKeyTyped","publicKeyTyped","byteLength","Math","ceil","slice"],"sourceRoot":"../../src","sources":["ed.ts"],"mappings":"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","ignoreList":[]}
@@ -14,10 +14,10 @@ export const withXCode = config => {
14
14
  // Use expo-build-properties to bump iOS deployment target
15
15
  config = withBuildProperties(config, {
16
16
  ios: {
17
- deploymentTarget: '16.1'
17
+ deploymentTarget: '16.4'
18
18
  }
19
19
  });
20
- // Patch the generated Podfile fallback to ensure platform is always 16.1
20
+ // Patch the generated Podfile fallback to ensure platform is always 16.4
21
21
  config = withDangerousMod(config, ['ios', modConfig => {
22
22
  const podfilePath = path.join(modConfig.modRequest.platformProjectRoot, 'Podfile');
23
23
  let contents = fs.readFileSync(podfilePath, 'utf-8');
@@ -33,7 +33,7 @@ export const withXCode = config => {
33
33
  # https://github.com/mrousavy/nitro/issues/422#issuecomment-2545988256
34
34
  installer.pods_project.targets.each do |target|
35
35
  target.build_configurations.each do |config|
36
- config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '16.1'
36
+ config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '16.4'
37
37
  end
38
38
  end
39
39
  $2`);
@@ -199,16 +199,63 @@ export const asyncDigest = async (algorithm, data) => {
199
199
  return internalDigest(algorithm, data);
200
200
  }
201
201
  if (name === 'cSHAKE128' || name === 'cSHAKE256') {
202
- if (typeof algorithm.length !== 'number' || algorithm.length <= 0) {
203
- throw lazyDOMException('cSHAKE requires a length parameter', 'OperationError');
202
+ // CShakeParams.outputLength is required (in bits) per the WICG modern-algos
203
+ // spec, renamed from `length` (commit ab8dc2b84c2). Mirror Node's
204
+ // hash.js:223-228 / webidl.js:570-595.
205
+ if (typeof algorithm.outputLength !== 'number' || algorithm.outputLength <= 0) {
206
+ throw lazyDOMException('CShakeParams.outputLength is required', 'OperationError');
204
207
  }
205
- if (algorithm.length % 8) {
206
- throw lazyDOMException('Unsupported CShakeParams length', 'NotSupportedError');
208
+ if (algorithm.outputLength % 8) {
209
+ throw lazyDOMException('Unsupported CShakeParams outputLength', 'NotSupportedError');
207
210
  }
208
- return internalDigest(algorithm, data, algorithm.length);
211
+ return internalDigest(algorithm, data, algorithm.outputLength / 8);
212
+ }
213
+ if (name === 'TurboSHAKE128' || name === 'TurboSHAKE256') {
214
+ return turboShakeDigest(name, algorithm, data);
215
+ }
216
+ if (name === 'KT128' || name === 'KT256') {
217
+ return kangarooTwelveDigest(name, algorithm, data);
209
218
  }
210
219
  throw lazyDOMException(`Unrecognized algorithm name: ${name}`, 'NotSupportedError');
211
220
  };
221
+
222
+ // TurboSHAKE / KangarooTwelve are not exposed by OpenSSL EVP, so we route
223
+ // them to a dedicated Nitro module (cpp/turboshake) that ports the Node.js
224
+ // reference implementation. Lazy-load to keep the module out of the hot path
225
+ // for callers that only use SHA-2/SHA-3.
226
+ let nativeTurboShake;
227
+ const getTurboShake = () => {
228
+ if (!nativeTurboShake) {
229
+ nativeTurboShake = NitroModules.createHybridObject('TurboShake');
230
+ }
231
+ return nativeTurboShake;
232
+ };
233
+
234
+ // RFC 9861 §2.2 default per the WICG Modern Algos draft for TurboSHAKE.
235
+ const kDefaultTurboShakeDomainSeparation = 0x1f;
236
+ const turboShakeDigest = async (name, algorithm, data) => {
237
+ if (typeof algorithm.outputLength !== 'number' || algorithm.outputLength <= 0) {
238
+ throw lazyDOMException('TurboShakeParams.outputLength is required', 'OperationError');
239
+ }
240
+ if (algorithm.outputLength % 8) {
241
+ throw lazyDOMException('Invalid TurboShakeParams outputLength', 'OperationError');
242
+ }
243
+ const ds = algorithm.domainSeparation ?? kDefaultTurboShakeDomainSeparation;
244
+ if (typeof ds !== 'number' || !Number.isInteger(ds) || ds < 0x01 || ds > 0x7f) {
245
+ throw lazyDOMException('TurboShakeParams.domainSeparation must be in range 0x01-0x7f', 'OperationError');
246
+ }
247
+ return getTurboShake().turboShake(name, ds, algorithm.outputLength / 8, bufferLikeToArrayBuffer(data));
248
+ };
249
+ const kangarooTwelveDigest = async (name, algorithm, data) => {
250
+ if (typeof algorithm.outputLength !== 'number' || algorithm.outputLength <= 0) {
251
+ throw lazyDOMException('KangarooTwelveParams.outputLength is required', 'OperationError');
252
+ }
253
+ if (algorithm.outputLength % 8) {
254
+ throw lazyDOMException('Invalid KangarooTwelveParams outputLength', 'OperationError');
255
+ }
256
+ const customization = algorithm.customization !== undefined ? bufferLikeToArrayBuffer(algorithm.customization) : undefined;
257
+ return getTurboShake().kangarooTwelve(name, algorithm.outputLength / 8, bufferLikeToArrayBuffer(data), customization);
258
+ };
212
259
  const internalDigest = (algorithm, data, outputLength) => {
213
260
  const normalizedHashName = normalizeHashName(algorithm.name);
214
261
  const hash = createHash(normalizedHashName, outputLength ? {
@@ -1 +1 @@
1
- {"version":3,"names":["Stream","NitroModules","Buffer","ab2str","binaryLikeToArrayBuffer","bufferLikeToArrayBuffer","validateMaxBufferLength","lazyDOMException","normalizeHashName","HashUtils","native","createHybridObject","getSupportedHashAlgorithms","getHashes","Hash","Transform","validate","args","algorithm","length","Error","options","outputLength","undefined","constructor","createHash","update","data","inputEncoding","defaultEncoding","digest","encoding","nativeDigest","from","copy","newOptions","newNativeHash","hash","getOpenSSLVersion","_transform","chunk","callback","err","_flush","push","asyncDigest","name","internalDigest","normalizedHashName","result","arrayBuffer","ArrayBuffer","view","Uint8Array","set","outputEncoding","h","hashExports"],"sourceRoot":"../../src","sources":["hash.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Stream","NitroModules","Buffer","ab2str","binaryLikeToArrayBuffer","bufferLikeToArrayBuffer","validateMaxBufferLength","lazyDOMException","normalizeHashName","HashUtils","native","createHybridObject","getSupportedHashAlgorithms","getHashes","Hash","Transform","validate","args","algorithm","length","Error","options","outputLength","undefined","constructor","createHash","update","data","inputEncoding","defaultEncoding","digest","encoding","nativeDigest","from","copy","newOptions","newNativeHash","hash","getOpenSSLVersion","_transform","chunk","callback","err","_flush","push","asyncDigest","name","internalDigest","turboShakeDigest","kangarooTwelveDigest","nativeTurboShake","getTurboShake","kDefaultTurboShakeDomainSeparation","ds","domainSeparation","Number","isInteger","turboShake","customization","kangarooTwelve","normalizedHashName","result","arrayBuffer","ArrayBuffer","view","Uint8Array","set","outputEncoding","h","hashExports"],"sourceRoot":"../../src","sources":["hash.ts"],"mappings":";;AAAA,SAASA,MAAM,QAAQ,iBAAiB;AACxC,SAASC,YAAY,QAAQ,4BAA4B;AAEzD,SAASC,MAAM,QAAQ,gCAAgC;AASvD,SACEC,MAAM,EACNC,uBAAuB,EACvBC,uBAAuB,QAClB,SAAS;AAChB,SAASC,uBAAuB,QAAQ,oBAAoB;AAC5D,SAASC,gBAAgB,QAAQ,gBAAgB;AACjD,SAASC,iBAAiB,QAAQ,mBAAmB;AAErD,MAAMC,SAAS,CAAC;EACd,OAAeC,MAAM,GAAGT,YAAY,CAACU,kBAAkB,CAAa,MAAM,CAAC;EAC3E,OAAcC,0BAA0BA,CAAA,EAAa;IACnD,OAAO,IAAI,CAACF,MAAM,CAACE,0BAA0B,CAAC,CAAC;EACjD;AACF;AAEA,OAAO,SAASC,SAASA,CAAA,EAAG;EAC1B,OAAOJ,SAAS,CAACG,0BAA0B,CAAC,CAAC;AAC/C;AAgBA,MAAME,IAAI,SAASd,MAAM,CAACe,SAAS,CAAC;EAK1BC,QAAQA,CAACC,IAAc,EAAE;IAC/B,IAAI,OAAOA,IAAI,CAACC,SAAS,KAAK,QAAQ,IAAID,IAAI,CAACC,SAAS,CAACC,MAAM,KAAK,CAAC,EACnE,MAAM,IAAIC,KAAK,CAAC,sCAAsC,CAAC;IACzD,IACEH,IAAI,CAACI,OAAO,EAAEC,YAAY,KAAKC,SAAS,IACxCN,IAAI,CAACI,OAAO,CAACC,YAAY,GAAG,CAAC,EAE7B,MAAM,IAAIF,KAAK,CAAC,6CAA6C,CAAC;IAChE,IACEH,IAAI,CAACI,OAAO,EAAEC,YAAY,KAAKC,SAAS,IACxC,OAAON,IAAI,CAACI,OAAO,CAACC,YAAY,KAAK,QAAQ,EAE7C,MAAM,IAAIF,KAAK,CAAC,gCAAgC,CAAC;EACrD;;EAEA;AACF;AACA;EACUI,WAAWA,CAACP,IAAc,EAAE;IAClC,KAAK,CAACA,IAAI,CAACI,OAAO,CAAC;IAEnB,IAAI,CAACL,QAAQ,CAACC,IAAI,CAAC;IAEnB,IAAI,CAACC,SAAS,GAAGD,IAAI,CAACC,SAAS;IAC/B,IAAI,CAACG,OAAO,GAAGJ,IAAI,CAACI,OAAO,IAAI,CAAC,CAAC;IAEjC,IAAIJ,IAAI,CAACP,MAAM,EAAE;MACf,IAAI,CAACA,MAAM,GAAGO,IAAI,CAACP,MAAM;MACzB;IACF;IAEA,IAAI,CAACA,MAAM,GAAGT,YAAY,CAACU,kBAAkB,CAAa,MAAM,CAAC;IACjE,IAAI,CAACD,MAAM,CAACe,UAAU,CAAC,IAAI,CAACP,SAAS,EAAE,IAAI,CAACG,OAAO,CAACC,YAAY,CAAC;EACnE;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;EAGEI,MAAMA,CAACC,IAAgB,EAAEC,aAAwB,EAAiB;IAChE,MAAMC,eAAyB,GAAG,MAAM;IACxCD,aAAa,GAAGA,aAAa,IAAIC,eAAe;;IAEhD;IACA,IAAI,OAAOF,IAAI,KAAK,QAAQ,IAAIC,aAAa,KAAK,MAAM,EAAE;MACxD,IAAI,CAAClB,MAAM,CAACgB,MAAM,CAACC,IAAI,CAAC;IAC1B,CAAC,MAAM;MACL,IAAI,CAACjB,MAAM,CAACgB,MAAM,CAACtB,uBAAuB,CAACuB,IAAI,EAAEC,aAAa,CAAC,CAAC;IAClE;IAEA,OAAO,IAAI,CAAC,CAAC;EACf;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;EAGEE,MAAMA,CAACC,QAAmB,EAAmB;IAC3C,MAAMC,YAAY,GAAG,IAAI,CAACtB,MAAM,CAACoB,MAAM,CAACC,QAAQ,CAAC;IAEjD,IAAIA,QAAQ,IAAIA,QAAQ,KAAK,QAAQ,EAAE;MACrC,OAAO5B,MAAM,CAAC6B,YAAY,EAAED,QAAQ,CAAC;IACvC;IAEA,OAAO7B,MAAM,CAAC+B,IAAI,CAACD,YAAY,CAAC;EAClC;;EAEA;AACF;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;;EAGEE,IAAIA,CAACb,OAAqB,EAAQ;IAChC,MAAMc,UAAU,GAAGd,OAAO,IAAI,IAAI,CAACA,OAAO;IAC1C,MAAMe,aAAa,GAAG,IAAI,CAAC1B,MAAM,CAACwB,IAAI,CAACC,UAAU,CAACb,YAAY,CAAC;IAC/D,MAAMe,IAAI,GAAG,IAAIvB,IAAI,CAAC;MACpBI,SAAS,EAAE,IAAI,CAACA,SAAS;MACzBG,OAAO,EAAEc,UAAU;MACnBzB,MAAM,EAAE0B;IACV,CAAC,CAAC;IACF,OAAOC,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEC,iBAAiBA,CAAA,EAAW;IAC1B,OAAO,IAAI,CAAC5B,MAAM,CAAC4B,iBAAiB,CAAC,CAAC;EACxC;;EAEA;EACA;EACA;EACAC,UAAUA,CACRC,KAAiB,EACjBT,QAAwB,EACxBU,QAAsC,EACtC;IACA,IAAI;MACF,IAAI,CAACf,MAAM,CAACc,KAAK,EAAET,QAAoB,CAAC;MACxCU,QAAQ,CAAC,CAAC;IACZ,CAAC,CAAC,OAAOC,GAAG,EAAE;MACZD,QAAQ,CAACC,GAAY,CAAC;IACxB;EACF;EACAC,MAAMA,CAACF,QAAsC,EAAE;IAC7C,IAAI;MACF,IAAI,CAACG,IAAI,CAAC,IAAI,CAACd,MAAM,CAAC,CAAC,CAAC;MACxBW,QAAQ,CAAC,CAAC;IACZ,CAAC,CAAC,OAAOC,GAAG,EAAE;MACZD,QAAQ,CAACC,GAAY,CAAC;IACxB;EACF;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASjB,UAAUA,CAACP,SAAiB,EAAEG,OAAqB,EAAQ;EACzE;EACA,OAAO,IAAIP,IAAI,CAAC;IACdI,SAAS;IACTG;EACF,CAAC,CAAC;AACJ;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMwB,WAAW,GAAG,MAAAA,CACzB3B,SAA0B,EAC1BS,IAAgB,KACS;EACzBrB,uBAAuB,CAACqB,IAAI,EAAE,MAAM,CAAC;EAErC,MAAMmB,IAAI,GAAG5B,SAAS,CAAC4B,IAAI;EAE3B,IACEA,IAAI,KAAK,OAAO,IAChBA,IAAI,KAAK,SAAS,IAClBA,IAAI,KAAK,SAAS,IAClBA,IAAI,KAAK,SAAS,IAClBA,IAAI,KAAK,UAAU,IACnBA,IAAI,KAAK,UAAU,IACnBA,IAAI,KAAK,UAAU,EACnB;IACA,OAAOC,cAAc,CAAC7B,SAAS,EAAES,IAAI,CAAC;EACxC;EAEA,IAAImB,IAAI,KAAK,WAAW,IAAIA,IAAI,KAAK,WAAW,EAAE;IAChD;IACA;IACA;IACA,IACE,OAAO5B,SAAS,CAACI,YAAY,KAAK,QAAQ,IAC1CJ,SAAS,CAACI,YAAY,IAAI,CAAC,EAC3B;MACA,MAAMf,gBAAgB,CACpB,uCAAuC,EACvC,gBACF,CAAC;IACH;IACA,IAAIW,SAAS,CAACI,YAAY,GAAG,CAAC,EAAE;MAC9B,MAAMf,gBAAgB,CACpB,uCAAuC,EACvC,mBACF,CAAC;IACH;IACA,OAAOwC,cAAc,CAAC7B,SAAS,EAAES,IAAI,EAAET,SAAS,CAACI,YAAY,GAAG,CAAC,CAAC;EACpE;EAEA,IAAIwB,IAAI,KAAK,eAAe,IAAIA,IAAI,KAAK,eAAe,EAAE;IACxD,OAAOE,gBAAgB,CAACF,IAAI,EAAE5B,SAAS,EAAES,IAAI,CAAC;EAChD;EAEA,IAAImB,IAAI,KAAK,OAAO,IAAIA,IAAI,KAAK,OAAO,EAAE;IACxC,OAAOG,oBAAoB,CAACH,IAAI,EAAE5B,SAAS,EAAES,IAAI,CAAC;EACpD;EAEA,MAAMpB,gBAAgB,CACpB,gCAAgCuC,IAAI,EAAE,EACtC,mBACF,CAAC;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA,IAAII,gBAA8C;AAClD,MAAMC,aAAa,GAAGA,CAAA,KAAwB;EAC5C,IAAI,CAACD,gBAAgB,EAAE;IACrBA,gBAAgB,GACdjD,YAAY,CAACU,kBAAkB,CAAmB,YAAY,CAAC;EACnE;EACA,OAAOuC,gBAAgB;AACzB,CAAC;;AAED;AACA,MAAME,kCAAkC,GAAG,IAAI;AAE/C,MAAMJ,gBAAgB,GAAG,MAAAA,CACvBF,IAAuC,EACvC5B,SAA0B,EAC1BS,IAAgB,KACS;EACzB,IACE,OAAOT,SAAS,CAACI,YAAY,KAAK,QAAQ,IAC1CJ,SAAS,CAACI,YAAY,IAAI,CAAC,EAC3B;IACA,MAAMf,gBAAgB,CACpB,2CAA2C,EAC3C,gBACF,CAAC;EACH;EACA,IAAIW,SAAS,CAACI,YAAY,GAAG,CAAC,EAAE;IAC9B,MAAMf,gBAAgB,CACpB,uCAAuC,EACvC,gBACF,CAAC;EACH;EACA,MAAM8C,EAAE,GAAGnC,SAAS,CAACoC,gBAAgB,IAAIF,kCAAkC;EAC3E,IACE,OAAOC,EAAE,KAAK,QAAQ,IACtB,CAACE,MAAM,CAACC,SAAS,CAACH,EAAE,CAAC,IACrBA,EAAE,GAAG,IAAI,IACTA,EAAE,GAAG,IAAI,EACT;IACA,MAAM9C,gBAAgB,CACpB,8DAA8D,EAC9D,gBACF,CAAC;EACH;EACA,OAAO4C,aAAa,CAAC,CAAC,CAACM,UAAU,CAC/BX,IAAI,EACJO,EAAE,EACFnC,SAAS,CAACI,YAAY,GAAG,CAAC,EAC1BjB,uBAAuB,CAACsB,IAAI,CAC9B,CAAC;AACH,CAAC;AAED,MAAMsB,oBAAoB,GAAG,MAAAA,CAC3BH,IAAuB,EACvB5B,SAA0B,EAC1BS,IAAgB,KACS;EACzB,IACE,OAAOT,SAAS,CAACI,YAAY,KAAK,QAAQ,IAC1CJ,SAAS,CAACI,YAAY,IAAI,CAAC,EAC3B;IACA,MAAMf,gBAAgB,CACpB,+CAA+C,EAC/C,gBACF,CAAC;EACH;EACA,IAAIW,SAAS,CAACI,YAAY,GAAG,CAAC,EAAE;IAC9B,MAAMf,gBAAgB,CACpB,2CAA2C,EAC3C,gBACF,CAAC;EACH;EACA,MAAMmD,aAAa,GACjBxC,SAAS,CAACwC,aAAa,KAAKnC,SAAS,GACjClB,uBAAuB,CAACa,SAAS,CAACwC,aAAa,CAAC,GAChDnC,SAAS;EACf,OAAO4B,aAAa,CAAC,CAAC,CAACQ,cAAc,CACnCb,IAAI,EACJ5B,SAAS,CAACI,YAAY,GAAG,CAAC,EAC1BjB,uBAAuB,CAACsB,IAAI,CAAC,EAC7B+B,aACF,CAAC;AACH,CAAC;AAED,MAAMX,cAAc,GAAGA,CACrB7B,SAA0B,EAC1BS,IAAgB,EAChBL,YAAqB,KACL;EAChB,MAAMsC,kBAAkB,GAAGpD,iBAAiB,CAACU,SAAS,CAAC4B,IAAI,CAAC;EAC5D,MAAMT,IAAI,GAAGZ,UAAU,CACrBmC,kBAAkB,EAClBtC,YAAY,GAAG;IAAEA;EAAa,CAAC,GAAGC,SACpC,CAAC;EACDc,IAAI,CAACX,MAAM,CAACrB,uBAAuB,CAACsB,IAAI,CAAC,CAAC;EAC1C,MAAMkC,MAAM,GAAGxB,IAAI,CAACP,MAAM,CAAC,CAAC;EAC5B,MAAMgC,WAAW,GAAG,IAAIC,WAAW,CAACF,MAAM,CAAC1C,MAAM,CAAC;EAClD,MAAM6C,IAAI,GAAG,IAAIC,UAAU,CAACH,WAAW,CAAC;EACxCE,IAAI,CAACE,GAAG,CAACL,MAAM,CAAC;EAChB,OAAOC,WAAW;AACpB,CAAC;AAQD,OAAO,SAASzB,IAAIA,CAClBnB,SAAiB,EACjBS,IAAgB,EAChBwC,cAAyB,EACR;EACjB,MAAMC,CAAC,GAAG3C,UAAU,CAACP,SAAS,CAAC;EAC/BkD,CAAC,CAAC1C,MAAM,CAACC,IAAI,CAAC;EACd,OAAOwC,cAAc,GAAGC,CAAC,CAACtC,MAAM,CAACqC,cAAc,CAAC,GAAGC,CAAC,CAACtC,MAAM,CAAC,CAAC;AAC/D;AAEA,OAAO,MAAMuC,WAAW,GAAG;EACzB5C,UAAU;EACVZ,SAAS;EACTwB,IAAI;EACJQ;AACF,CAAC","ignoreList":[]}
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
 
3
- import { Buffer } from 'buffer';
3
+ import { Buffer } from '@craftzdog/react-native-buffer';
4
4
  import { NitroModules } from 'react-native-nitro-modules';
5
- import { KeyType } from '../utils';
5
+ import { KeyType, getSortedUsages } from '../utils';
6
6
  import { parsePrivateKeyEncoding, parsePublicKeyEncoding } from './utils';
7
7
  export class CryptoKey {
8
8
  get [Symbol.toStringTag]() {
@@ -11,7 +11,8 @@ export class CryptoKey {
11
11
  constructor(keyObject, keyAlgorithm, keyUsages, keyExtractable) {
12
12
  this.keyObject = keyObject;
13
13
  this.keyAlgorithm = keyAlgorithm;
14
- this.keyUsages = keyUsages;
14
+ // Frozen so external code can't mutate `key.usages` (per WebCrypto spec).
15
+ this.keyUsages = Object.freeze(getSortedUsages(keyUsages));
15
16
  this.keyExtractable = keyExtractable;
16
17
  }
17
18
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
@@ -211,11 +212,24 @@ export class PublicKeyObject extends AsymmetricKeyObject {
211
212
  if (options?.format === 'jwk') {
212
213
  return this.handle.exportJwk({}, false);
213
214
  }
215
+ if (options?.format === 'raw-public') {
216
+ if (this.asymmetricKeyType === 'ec') {
217
+ const pointType = options.type ?? 'uncompressed';
218
+ if (pointType !== 'compressed' && pointType !== 'uncompressed') {
219
+ throw new Error(`Invalid options.type for raw-public EC export: ${pointType}`);
220
+ }
221
+ return Buffer.from(this.handle.exportECPublicRaw(pointType === 'compressed'));
222
+ }
223
+ return Buffer.from(this.handle.exportRawPublic());
224
+ }
214
225
  const {
215
226
  format,
216
227
  type
217
228
  } = parsePublicKeyEncoding(options, this.asymmetricKeyType);
218
- const key = this.handle.exportKey(format, type);
229
+ if (typeof format !== 'number') {
230
+ throw new Error(`Unexpected format ${format} after raw-format dispatch`);
231
+ }
232
+ const key = this.handle.exportKey(format, typeof type === 'string' ? undefined : type);
219
233
  const buffer = Buffer.from(key);
220
234
  if (options?.format === 'pem') {
221
235
  return buffer.toString('utf-8');
@@ -234,13 +248,25 @@ export class PrivateKeyObject extends AsymmetricKeyObject {
234
248
  }
235
249
  return this.handle.exportJwk({}, false);
236
250
  }
251
+ if (options?.format === 'raw-private') {
252
+ if (this.asymmetricKeyType === 'ec') {
253
+ return Buffer.from(this.handle.exportECPrivateRaw());
254
+ }
255
+ return Buffer.from(this.handle.exportRawPrivate());
256
+ }
257
+ if (options?.format === 'raw-seed') {
258
+ return Buffer.from(this.handle.exportRawSeed());
259
+ }
237
260
  const {
238
261
  format,
239
262
  type,
240
263
  cipher,
241
264
  passphrase
242
265
  } = parsePrivateKeyEncoding(options, this.asymmetricKeyType);
243
- const key = this.handle.exportKey(format, type, cipher, passphrase);
266
+ if (typeof format !== 'number') {
267
+ throw new Error(`Unexpected format ${format} after raw-format dispatch`);
268
+ }
269
+ const key = this.handle.exportKey(format, typeof type === 'string' ? undefined : type, cipher, passphrase);
244
270
  const buffer = Buffer.from(key);
245
271
  if (options?.format === 'pem') {
246
272
  return buffer.toString('utf-8');
@@ -1 +1 @@
1
- {"version":3,"names":["Buffer","NitroModules","KeyType","parsePrivateKeyEncoding","parsePublicKeyEncoding","CryptoKey","Symbol","toStringTag","constructor","keyObject","keyAlgorithm","keyUsages","keyExtractable","inspect","_depth","_options","Error","type","extractable","algorithm","usages","KeyObject","export","equals","otherKeyObject","TypeError","handle","keyEquals","handleOrKey","ArrayBuffer","createHybridObject","keyType","PUBLIC","PRIVATE","SECRET","init","from","key","toCryptoKey","createKeyObject","format","encoding","undefined","getAsymmetricKeyType","PublicKeyObject","PrivateKeyObject","SecretKeyObject","getAsymmetricKeyDetails","symmetricKeySize","getSymmetricKeySize","options","exportKey","AsymmetricKeyObject","asymmetricKeyType","_asymmetricKeyType","asymmetricKeyDetails","_asymmetricKeyDetails","keyDetail","namedCurve","exportJwk","buffer","toString","passphrase","cipher"],"sourceRoot":"../../../src","sources":["keys/classes.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Buffer","NitroModules","KeyType","getSortedUsages","parsePrivateKeyEncoding","parsePublicKeyEncoding","CryptoKey","Symbol","toStringTag","constructor","keyObject","keyAlgorithm","keyUsages","keyExtractable","Object","freeze","inspect","_depth","_options","Error","type","extractable","algorithm","usages","KeyObject","export","equals","otherKeyObject","TypeError","handle","keyEquals","handleOrKey","ArrayBuffer","createHybridObject","keyType","PUBLIC","PRIVATE","SECRET","init","from","key","toCryptoKey","createKeyObject","format","encoding","undefined","getAsymmetricKeyType","PublicKeyObject","PrivateKeyObject","SecretKeyObject","getAsymmetricKeyDetails","symmetricKeySize","getSymmetricKeySize","options","exportKey","AsymmetricKeyObject","asymmetricKeyType","_asymmetricKeyType","asymmetricKeyDetails","_asymmetricKeyDetails","keyDetail","namedCurve","exportJwk","pointType","exportECPublicRaw","exportRawPublic","buffer","toString","passphrase","exportECPrivateRaw","exportRawPrivate","exportRawSeed","cipher"],"sourceRoot":"../../../src","sources":["keys/classes.ts"],"mappings":"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","ignoreList":[]}
@@ -1,12 +1,86 @@
1
1
  "use strict";
2
2
 
3
3
  import { ed_generateKeyPair } from '../ed';
4
+ import { Buffer } from '@craftzdog/react-native-buffer';
4
5
  import { rsa_generateKeyPairNode, rsa_generateKeyPairNodeSync } from '../rsa';
5
6
  import { ec_generateKeyPairNode, ec_generateKeyPairNodeSync } from '../ec';
6
7
  import { dsa_generateKeyPairNode, dsa_generateKeyPairNodeSync } from '../dsa';
7
8
  import { dh_generateKeyPairNode, dh_generateKeyPairNodeSync } from '../dhKeyPair';
8
- import { kEmptyObject, validateFunction } from '../utils';
9
+ import { SlhDsa } from '../slhdsa';
10
+ import { kEmptyObject, validateFunction, KFormatType, KeyEncoding } from '../utils';
11
+ import { KeyObject } from './classes';
9
12
  import { parsePrivateKeyEncoding, parsePublicKeyEncoding } from './utils';
13
+ const SLH_DSA_TYPE_TO_VARIANT = {
14
+ 'slh-dsa-sha2-128s': 'SLH-DSA-SHA2-128s',
15
+ 'slh-dsa-sha2-128f': 'SLH-DSA-SHA2-128f',
16
+ 'slh-dsa-sha2-192s': 'SLH-DSA-SHA2-192s',
17
+ 'slh-dsa-sha2-192f': 'SLH-DSA-SHA2-192f',
18
+ 'slh-dsa-sha2-256s': 'SLH-DSA-SHA2-256s',
19
+ 'slh-dsa-sha2-256f': 'SLH-DSA-SHA2-256f',
20
+ 'slh-dsa-shake-128s': 'SLH-DSA-SHAKE-128s',
21
+ 'slh-dsa-shake-128f': 'SLH-DSA-SHAKE-128f',
22
+ 'slh-dsa-shake-192s': 'SLH-DSA-SHAKE-192s',
23
+ 'slh-dsa-shake-192f': 'SLH-DSA-SHAKE-192f',
24
+ 'slh-dsa-shake-256s': 'SLH-DSA-SHAKE-256s',
25
+ 'slh-dsa-shake-256f': 'SLH-DSA-SHAKE-256f'
26
+ };
27
+ function isSlhDsaType(type) {
28
+ return type in SLH_DSA_TYPE_TO_VARIANT;
29
+ }
30
+ function slhDsaFormatKeyPairOutput(slhdsa, encoding) {
31
+ const {
32
+ publicFormat,
33
+ privateFormat,
34
+ cipher,
35
+ passphrase
36
+ } = encoding;
37
+ const publicKey = KeyObject.createKeyObject('public', slhdsa.getPublicKey(), KFormatType.DER, KeyEncoding.SPKI);
38
+ const privateKey = KeyObject.createKeyObject('private', slhdsa.getPrivateKey(), KFormatType.DER, KeyEncoding.PKCS8);
39
+ let publicKeyOutput;
40
+ let privateKeyOutput;
41
+ if (publicFormat === -1) {
42
+ publicKeyOutput = publicKey;
43
+ } else if (publicFormat === 'raw-public') {
44
+ publicKeyOutput = Buffer.from(publicKey.handle.exportRawPublic());
45
+ } else {
46
+ const format = publicFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
47
+ const exported = publicKey.handle.exportKey(format, KeyEncoding.SPKI);
48
+ if (format === KFormatType.PEM) {
49
+ publicKeyOutput = Buffer.from(new Uint8Array(exported)).toString('utf-8');
50
+ } else {
51
+ publicKeyOutput = exported;
52
+ }
53
+ }
54
+ if (privateFormat === -1) {
55
+ privateKeyOutput = privateKey;
56
+ } else if (privateFormat === 'raw-private') {
57
+ privateKeyOutput = Buffer.from(privateKey.handle.exportRawPrivate());
58
+ } else if (privateFormat === 'raw-seed') {
59
+ privateKeyOutput = Buffer.from(privateKey.handle.exportRawSeed());
60
+ } else {
61
+ const format = privateFormat === KFormatType.PEM ? KFormatType.PEM : KFormatType.DER;
62
+ const exported = privateKey.handle.exportKey(format, KeyEncoding.PKCS8, cipher, passphrase);
63
+ if (format === KFormatType.PEM) {
64
+ privateKeyOutput = Buffer.from(new Uint8Array(exported)).toString('utf-8');
65
+ } else {
66
+ privateKeyOutput = exported;
67
+ }
68
+ }
69
+ return {
70
+ publicKey: publicKeyOutput,
71
+ privateKey: privateKeyOutput
72
+ };
73
+ }
74
+ function slhDsaGenerateKeyPairNodeSync(type, encoding) {
75
+ const slhdsa = new SlhDsa(SLH_DSA_TYPE_TO_VARIANT[type]);
76
+ slhdsa.generateKeyPairSync();
77
+ return slhDsaFormatKeyPairOutput(slhdsa, encoding);
78
+ }
79
+ async function slhDsaGenerateKeyPairNode(type, encoding) {
80
+ const slhdsa = new SlhDsa(SLH_DSA_TYPE_TO_VARIANT[type]);
81
+ await slhdsa.generateKeyPair();
82
+ return slhDsaFormatKeyPairOutput(slhdsa, encoding);
83
+ }
10
84
  export const generateKeyPair = (type, options, callback) => {
11
85
  validateFunction(callback);
12
86
  internalGenerateKeyPair(true, type, options, callback);
@@ -71,10 +145,10 @@ function parseKeyPairEncoding(keyType, options = kEmptyObject) {
71
145
  throw new Error('Invalid argument options.privateKeyEncoding', publicKeyEncoding);
72
146
  }
73
147
  return {
74
- publicFormat,
75
- publicType,
76
- privateFormat,
77
- privateType,
148
+ publicFormat: publicFormat,
149
+ publicType: publicType,
150
+ privateFormat: privateFormat,
151
+ privateType: privateType,
78
152
  cipher,
79
153
  passphrase
80
154
  };
@@ -95,6 +169,9 @@ function internalGenerateKeyPair(isAsync, type, options, callback) {
95
169
  break;
96
170
  default:
97
171
  {
172
+ if (isSlhDsaType(type)) {
173
+ break;
174
+ }
98
175
  const err = new Error(`
99
176
  Invalid Argument options: '${type}' scheme not supported for
100
177
  generateKeyPair(). Currently not all encryption methods are supported in
@@ -115,6 +192,8 @@ function internalGenerateKeyPair(isAsync, type, options, callback) {
115
192
  result = await dsa_generateKeyPairNode(options, encoding);
116
193
  } else if (type === 'dh') {
117
194
  result = await dh_generateKeyPairNode(options, encoding);
195
+ } else if (isSlhDsaType(type)) {
196
+ result = await slhDsaGenerateKeyPairNode(type, encoding);
118
197
  } else {
119
198
  throw new Error(`Unsupported key type: ${type}`);
120
199
  }
@@ -139,6 +218,8 @@ function internalGenerateKeyPair(isAsync, type, options, callback) {
139
218
  result = dsa_generateKeyPairNodeSync(options, encoding);
140
219
  } else if (type === 'dh') {
141
220
  result = dh_generateKeyPairNodeSync(options, encoding);
221
+ } else if (isSlhDsaType(type)) {
222
+ result = slhDsaGenerateKeyPairNodeSync(type, encoding);
142
223
  } else {
143
224
  throw new Error(`Unsupported key type: ${type}`);
144
225
  }
@@ -1 +1 @@
1
- {"version":3,"names":["ed_generateKeyPair","rsa_generateKeyPairNode","rsa_generateKeyPairNodeSync","ec_generateKeyPairNode","ec_generateKeyPairNodeSync","dsa_generateKeyPairNode","dsa_generateKeyPairNodeSync","dh_generateKeyPairNode","dh_generateKeyPairNodeSync","kEmptyObject","validateFunction","parsePrivateKeyEncoding","parsePublicKeyEncoding","generateKeyPair","type","options","callback","internalGenerateKeyPair","generateKeyPairPromise","Promise","resolve","reject","err","publicKey","privateKey","undefined","generateKeyPairSync","parseKeyPairEncoding","keyType","publicKeyEncoding","privateKeyEncoding","publicFormat","publicType","format","Error","privateFormat","privateType","cipher","passphrase","isAsync","encoding","impl","result","error","then"],"sourceRoot":"../../../src","sources":["keys/generateKeyPair.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["ed_generateKeyPair","Buffer","rsa_generateKeyPairNode","rsa_generateKeyPairNodeSync","ec_generateKeyPairNode","ec_generateKeyPairNodeSync","dsa_generateKeyPairNode","dsa_generateKeyPairNodeSync","dh_generateKeyPairNode","dh_generateKeyPairNodeSync","SlhDsa","kEmptyObject","validateFunction","KFormatType","KeyEncoding","KeyObject","parsePrivateKeyEncoding","parsePublicKeyEncoding","SLH_DSA_TYPE_TO_VARIANT","isSlhDsaType","type","slhDsaFormatKeyPairOutput","slhdsa","encoding","publicFormat","privateFormat","cipher","passphrase","publicKey","createKeyObject","getPublicKey","DER","SPKI","privateKey","getPrivateKey","PKCS8","publicKeyOutput","privateKeyOutput","from","handle","exportRawPublic","format","PEM","exported","exportKey","Uint8Array","toString","exportRawPrivate","exportRawSeed","slhDsaGenerateKeyPairNodeSync","generateKeyPairSync","slhDsaGenerateKeyPairNode","generateKeyPair","options","callback","internalGenerateKeyPair","generateKeyPairPromise","Promise","resolve","reject","err","undefined","parseKeyPairEncoding","keyType","publicKeyEncoding","privateKeyEncoding","publicType","Error","privateType","isAsync","impl","result","error","then"],"sourceRoot":"../../../src","sources":["keys/generateKeyPair.ts"],"mappings":"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","ignoreList":[]}
@@ -8,6 +8,41 @@ import { isCryptoKey, parseKeyEncoding, parsePrivateKeyEncoding, parsePublicKeyE
8
8
  import { NitroModules } from 'react-native-nitro-modules';
9
9
  import { binaryLikeToArrayBuffer as toAB, isStringOrBuffer, KFormatType, KeyEncoding, KeyType } from '../utils';
10
10
  import { randomBytes } from '../random';
11
+ function isRawFormat(format) {
12
+ return format === 'raw-public' || format === 'raw-private' || format === 'raw-seed';
13
+ }
14
+ function createPublicKeyFromRaw(input) {
15
+ if (input.format !== 'raw-public') {
16
+ throw new Error('Invalid format for createPublicKey raw import');
17
+ }
18
+ if (typeof input.asymmetricKeyType !== 'string') {
19
+ throw new Error('options.asymmetricKeyType is required for raw key import');
20
+ }
21
+ if (input.asymmetricKeyType === 'ec' && !input.namedCurve) {
22
+ throw new Error('options.namedCurve is required for EC raw key import');
23
+ }
24
+ const handle = NitroModules.createHybridObject('KeyObjectHandle');
25
+ handle.initRawPublic(input.asymmetricKeyType, toAB(input.key), input.namedCurve);
26
+ return new PublicKeyObject(handle);
27
+ }
28
+ function createPrivateKeyFromRaw(input) {
29
+ if (input.format !== 'raw-private' && input.format !== 'raw-seed') {
30
+ throw new Error('Invalid format for createPrivateKey raw import');
31
+ }
32
+ if (typeof input.asymmetricKeyType !== 'string') {
33
+ throw new Error('options.asymmetricKeyType is required for raw key import');
34
+ }
35
+ if (input.asymmetricKeyType === 'ec' && !input.namedCurve) {
36
+ throw new Error('options.namedCurve is required for EC raw key import');
37
+ }
38
+ const handle = NitroModules.createHybridObject('KeyObjectHandle');
39
+ if (input.format === 'raw-seed') {
40
+ handle.initRawSeed(input.asymmetricKeyType, toAB(input.key));
41
+ } else {
42
+ handle.initRawPrivate(input.asymmetricKeyType, toAB(input.key), input.namedCurve);
43
+ }
44
+ return new PrivateKeyObject(handle);
45
+ }
11
46
  function createSecretKey(key) {
12
47
  const keyBuffer = toAB(key);
13
48
  return KeyObject.createKeyObject('secret', keyBuffer);
@@ -77,8 +112,9 @@ function prepareAsymmetricKey(key, isPublic) {
77
112
  };
78
113
  }
79
114
 
80
- // Filter out 'jwk' format - only 'pem' and 'der' are supported here
81
- const filteredFormat = format === 'jwk' ? undefined : format;
115
+ // Filter to only 'pem' or 'der' — JWK and raw formats are handled
116
+ // separately via dedicated paths.
117
+ const filteredFormat = format === 'pem' || format === 'der' ? format : undefined;
82
118
  return {
83
119
  data: toAB(data),
84
120
  format: filteredFormat,
@@ -88,6 +124,12 @@ function prepareAsymmetricKey(key, isPublic) {
88
124
  throw new Error('Invalid key input');
89
125
  }
90
126
  function createPublicKey(key) {
127
+ if (typeof key === 'object' && 'key' in key && isRawFormat(key.format)) {
128
+ if (key.format !== 'raw-public') {
129
+ throw new Error(`Invalid format ${key.format} for createPublicKey — only 'raw-public' is allowed`);
130
+ }
131
+ return createPublicKeyFromRaw(key);
132
+ }
91
133
  if (typeof key === 'object' && 'key' in key && key.format === 'jwk') {
92
134
  const handle = NitroModules.createHybridObject('KeyObjectHandle');
93
135
  const keyType = handle.initJwk(key.key);
@@ -119,6 +161,12 @@ function createPublicKey(key) {
119
161
  return KeyObject.createKeyObject('public', data, kFormat, kType);
120
162
  }
121
163
  function createPrivateKey(key) {
164
+ if (typeof key === 'object' && 'key' in key && isRawFormat(key.format)) {
165
+ if (key.format === 'raw-public') {
166
+ throw new Error("Invalid format 'raw-public' for createPrivateKey");
167
+ }
168
+ return createPrivateKeyFromRaw(key);
169
+ }
122
170
  if (typeof key === 'object' && 'key' in key && key.format === 'jwk') {
123
171
  const handle = NitroModules.createHybridObject('KeyObjectHandle');
124
172
  const keyType = handle.initJwk(key.key);