react-native-quick-crypto 1.0.10 → 1.0.12

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 (293) hide show
  1. package/android/CMakeLists.txt +16 -0
  2. package/cpp/argon2/HybridArgon2.cpp +103 -0
  3. package/cpp/argon2/HybridArgon2.hpp +32 -0
  4. package/cpp/certificate/HybridCertificate.cpp +42 -0
  5. package/cpp/certificate/HybridCertificate.hpp +16 -0
  6. package/cpp/cipher/CCMCipher.cpp +4 -1
  7. package/cpp/cipher/ChaCha20Cipher.cpp +3 -1
  8. package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +5 -5
  9. package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +1 -2
  10. package/cpp/cipher/HybridCipher.cpp +68 -1
  11. package/cpp/cipher/HybridCipher.hpp +6 -0
  12. package/cpp/cipher/HybridRsaCipher.cpp +0 -13
  13. package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +7 -5
  14. package/cpp/cipher/XChaCha20Poly1305Cipher.hpp +1 -2
  15. package/cpp/cipher/XSalsa20Cipher.cpp +4 -0
  16. package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +7 -5
  17. package/cpp/cipher/XSalsa20Poly1305Cipher.hpp +1 -2
  18. package/cpp/dh/HybridDhKeyPair.cpp +179 -0
  19. package/cpp/dh/HybridDhKeyPair.hpp +37 -0
  20. package/cpp/dsa/HybridDsaKeyPair.cpp +128 -0
  21. package/cpp/dsa/HybridDsaKeyPair.hpp +32 -0
  22. package/cpp/ecdh/HybridECDH.cpp +42 -120
  23. package/cpp/ecdh/HybridECDH.hpp +1 -0
  24. package/cpp/keys/HybridKeyObjectHandle.cpp +150 -128
  25. package/cpp/keys/HybridKeyObjectHandle.hpp +6 -3
  26. package/cpp/keys/KeyObjectData.hpp +2 -0
  27. package/cpp/kmac/HybridKmac.cpp +83 -0
  28. package/cpp/kmac/HybridKmac.hpp +31 -0
  29. package/cpp/mldsa/HybridMlDsaKeyPair.cpp +11 -20
  30. package/cpp/mldsa/HybridMlDsaKeyPair.hpp +4 -2
  31. package/cpp/mlkem/HybridMlKemKeyPair.cpp +319 -0
  32. package/cpp/mlkem/HybridMlKemKeyPair.hpp +48 -0
  33. package/cpp/prime/HybridPrime.cpp +81 -0
  34. package/cpp/prime/HybridPrime.hpp +20 -0
  35. package/cpp/sign/SignUtils.hpp +9 -26
  36. package/cpp/utils/QuickCryptoUtils.cpp +44 -0
  37. package/cpp/utils/QuickCryptoUtils.hpp +39 -0
  38. package/cpp/x509/HybridX509Certificate.cpp +174 -0
  39. package/cpp/x509/HybridX509Certificate.hpp +51 -0
  40. package/lib/commonjs/argon2.js +39 -0
  41. package/lib/commonjs/argon2.js.map +1 -0
  42. package/lib/commonjs/certificate.js +35 -0
  43. package/lib/commonjs/certificate.js.map +1 -0
  44. package/lib/commonjs/cipher.js +23 -2
  45. package/lib/commonjs/cipher.js.map +1 -1
  46. package/lib/commonjs/dhKeyPair.js +109 -0
  47. package/lib/commonjs/dhKeyPair.js.map +1 -0
  48. package/lib/commonjs/dsa.js +92 -0
  49. package/lib/commonjs/dsa.js.map +1 -0
  50. package/lib/commonjs/ec.js +18 -18
  51. package/lib/commonjs/ec.js.map +1 -1
  52. package/lib/commonjs/ecdh.js +37 -0
  53. package/lib/commonjs/ecdh.js.map +1 -1
  54. package/lib/commonjs/ed.js +9 -9
  55. package/lib/commonjs/ed.js.map +1 -1
  56. package/lib/commonjs/hash.js +17 -12
  57. package/lib/commonjs/hash.js.map +1 -1
  58. package/lib/commonjs/hkdf.js.map +1 -1
  59. package/lib/commonjs/index.js +57 -0
  60. package/lib/commonjs/index.js.map +1 -1
  61. package/lib/commonjs/keys/classes.js +11 -9
  62. package/lib/commonjs/keys/classes.js.map +1 -1
  63. package/lib/commonjs/keys/generateKeyPair.js +11 -0
  64. package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
  65. package/lib/commonjs/keys/index.js +24 -0
  66. package/lib/commonjs/keys/index.js.map +1 -1
  67. package/lib/commonjs/keys/signVerify.js +0 -2
  68. package/lib/commonjs/keys/signVerify.js.map +1 -1
  69. package/lib/commonjs/mlkem.js +219 -0
  70. package/lib/commonjs/mlkem.js.map +1 -0
  71. package/lib/commonjs/pbkdf2.js +18 -1
  72. package/lib/commonjs/pbkdf2.js.map +1 -1
  73. package/lib/commonjs/prime.js +84 -0
  74. package/lib/commonjs/prime.js.map +1 -0
  75. package/lib/commonjs/rsa.js +7 -7
  76. package/lib/commonjs/rsa.js.map +1 -1
  77. package/lib/commonjs/specs/argon2.nitro.js +6 -0
  78. package/lib/commonjs/specs/argon2.nitro.js.map +1 -0
  79. package/lib/commonjs/specs/certificate.nitro.js +6 -0
  80. package/lib/commonjs/specs/certificate.nitro.js.map +1 -0
  81. package/lib/commonjs/specs/dhKeyPair.nitro.js +6 -0
  82. package/lib/commonjs/specs/dhKeyPair.nitro.js.map +1 -0
  83. package/lib/commonjs/specs/dsaKeyPair.nitro.js +6 -0
  84. package/lib/commonjs/specs/dsaKeyPair.nitro.js.map +1 -0
  85. package/lib/commonjs/specs/kmac.nitro.js +6 -0
  86. package/lib/commonjs/specs/kmac.nitro.js.map +1 -0
  87. package/lib/commonjs/specs/mlKemKeyPair.nitro.js +6 -0
  88. package/lib/commonjs/specs/mlKemKeyPair.nitro.js.map +1 -0
  89. package/lib/commonjs/specs/prime.nitro.js +6 -0
  90. package/lib/commonjs/specs/prime.nitro.js.map +1 -0
  91. package/lib/commonjs/specs/x509certificate.nitro.js +6 -0
  92. package/lib/commonjs/specs/x509certificate.nitro.js.map +1 -0
  93. package/lib/commonjs/subtle.js +385 -114
  94. package/lib/commonjs/subtle.js.map +1 -1
  95. package/lib/commonjs/utils/conversion.js +3 -3
  96. package/lib/commonjs/utils/conversion.js.map +1 -1
  97. package/lib/commonjs/utils/hashnames.js +31 -0
  98. package/lib/commonjs/utils/hashnames.js.map +1 -1
  99. package/lib/commonjs/utils/types.js.map +1 -1
  100. package/lib/commonjs/x509certificate.js +189 -0
  101. package/lib/commonjs/x509certificate.js.map +1 -0
  102. package/lib/module/argon2.js +34 -0
  103. package/lib/module/argon2.js.map +1 -0
  104. package/lib/module/certificate.js +30 -0
  105. package/lib/module/certificate.js.map +1 -0
  106. package/lib/module/cipher.js +23 -3
  107. package/lib/module/cipher.js.map +1 -1
  108. package/lib/module/dhKeyPair.js +102 -0
  109. package/lib/module/dhKeyPair.js.map +1 -0
  110. package/lib/module/dsa.js +85 -0
  111. package/lib/module/dsa.js.map +1 -0
  112. package/lib/module/ec.js +6 -6
  113. package/lib/module/ec.js.map +1 -1
  114. package/lib/module/ecdh.js +37 -0
  115. package/lib/module/ecdh.js.map +1 -1
  116. package/lib/module/ed.js +1 -1
  117. package/lib/module/ed.js.map +1 -1
  118. package/lib/module/hash.js +17 -12
  119. package/lib/module/hash.js.map +1 -1
  120. package/lib/module/hkdf.js.map +1 -1
  121. package/lib/module/index.js +15 -0
  122. package/lib/module/index.js.map +1 -1
  123. package/lib/module/keys/classes.js +11 -9
  124. package/lib/module/keys/classes.js.map +1 -1
  125. package/lib/module/keys/generateKeyPair.js +11 -0
  126. package/lib/module/keys/generateKeyPair.js.map +1 -1
  127. package/lib/module/keys/index.js +25 -1
  128. package/lib/module/keys/index.js.map +1 -1
  129. package/lib/module/keys/signVerify.js +0 -2
  130. package/lib/module/keys/signVerify.js.map +1 -1
  131. package/lib/module/mlkem.js +211 -0
  132. package/lib/module/mlkem.js.map +1 -0
  133. package/lib/module/pbkdf2.js +18 -1
  134. package/lib/module/pbkdf2.js.map +1 -1
  135. package/lib/module/prime.js +77 -0
  136. package/lib/module/prime.js.map +1 -0
  137. package/lib/module/rsa.js +1 -1
  138. package/lib/module/rsa.js.map +1 -1
  139. package/lib/module/specs/argon2.nitro.js +4 -0
  140. package/lib/module/specs/argon2.nitro.js.map +1 -0
  141. package/lib/module/specs/certificate.nitro.js +4 -0
  142. package/lib/module/specs/certificate.nitro.js.map +1 -0
  143. package/lib/module/specs/dhKeyPair.nitro.js +4 -0
  144. package/lib/module/specs/dhKeyPair.nitro.js.map +1 -0
  145. package/lib/module/specs/dsaKeyPair.nitro.js +4 -0
  146. package/lib/module/specs/dsaKeyPair.nitro.js.map +1 -0
  147. package/lib/module/specs/kmac.nitro.js +4 -0
  148. package/lib/module/specs/kmac.nitro.js.map +1 -0
  149. package/lib/module/specs/mlKemKeyPair.nitro.js +4 -0
  150. package/lib/module/specs/mlKemKeyPair.nitro.js.map +1 -0
  151. package/lib/module/specs/prime.nitro.js +4 -0
  152. package/lib/module/specs/prime.nitro.js.map +1 -0
  153. package/lib/module/specs/x509certificate.nitro.js +4 -0
  154. package/lib/module/specs/x509certificate.nitro.js.map +1 -0
  155. package/lib/module/subtle.js +386 -116
  156. package/lib/module/subtle.js.map +1 -1
  157. package/lib/module/utils/conversion.js +3 -4
  158. package/lib/module/utils/conversion.js.map +1 -1
  159. package/lib/module/utils/hashnames.js +31 -0
  160. package/lib/module/utils/hashnames.js.map +1 -1
  161. package/lib/module/utils/types.js.map +1 -1
  162. package/lib/module/x509certificate.js +184 -0
  163. package/lib/module/x509certificate.js.map +1 -0
  164. package/lib/tsconfig.tsbuildinfo +1 -1
  165. package/lib/typescript/argon2.d.ts +16 -0
  166. package/lib/typescript/argon2.d.ts.map +1 -0
  167. package/lib/typescript/certificate.d.ts +8 -0
  168. package/lib/typescript/certificate.d.ts.map +1 -0
  169. package/lib/typescript/cipher.d.ts +15 -0
  170. package/lib/typescript/cipher.d.ts.map +1 -1
  171. package/lib/typescript/dhKeyPair.d.ts +19 -0
  172. package/lib/typescript/dhKeyPair.d.ts.map +1 -0
  173. package/lib/typescript/dsa.d.ts +19 -0
  174. package/lib/typescript/dsa.d.ts.map +1 -0
  175. package/lib/typescript/ec.d.ts +1 -1
  176. package/lib/typescript/ec.d.ts.map +1 -1
  177. package/lib/typescript/ecdh.d.ts +3 -0
  178. package/lib/typescript/ecdh.d.ts.map +1 -1
  179. package/lib/typescript/ed.d.ts +1 -1
  180. package/lib/typescript/ed.d.ts.map +1 -1
  181. package/lib/typescript/hash.d.ts.map +1 -1
  182. package/lib/typescript/hkdf.d.ts +2 -6
  183. package/lib/typescript/hkdf.d.ts.map +1 -1
  184. package/lib/typescript/index.d.ts +32 -4
  185. package/lib/typescript/index.d.ts.map +1 -1
  186. package/lib/typescript/keys/classes.d.ts +7 -5
  187. package/lib/typescript/keys/classes.d.ts.map +1 -1
  188. package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
  189. package/lib/typescript/keys/index.d.ts +2 -2
  190. package/lib/typescript/keys/index.d.ts.map +1 -1
  191. package/lib/typescript/keys/signVerify.d.ts.map +1 -1
  192. package/lib/typescript/mlkem.d.ts +30 -0
  193. package/lib/typescript/mlkem.d.ts.map +1 -0
  194. package/lib/typescript/pbkdf2.d.ts +2 -2
  195. package/lib/typescript/pbkdf2.d.ts.map +1 -1
  196. package/lib/typescript/prime.d.ts +19 -0
  197. package/lib/typescript/prime.d.ts.map +1 -0
  198. package/lib/typescript/rsa.d.ts +1 -1
  199. package/lib/typescript/rsa.d.ts.map +1 -1
  200. package/lib/typescript/specs/argon2.nitro.d.ts +9 -0
  201. package/lib/typescript/specs/argon2.nitro.d.ts.map +1 -0
  202. package/lib/typescript/specs/certificate.nitro.d.ts +10 -0
  203. package/lib/typescript/specs/certificate.nitro.d.ts.map +1 -0
  204. package/lib/typescript/specs/cipher.nitro.d.ts +9 -0
  205. package/lib/typescript/specs/cipher.nitro.d.ts.map +1 -1
  206. package/lib/typescript/specs/dhKeyPair.nitro.d.ts +14 -0
  207. package/lib/typescript/specs/dhKeyPair.nitro.d.ts.map +1 -0
  208. package/lib/typescript/specs/dsaKeyPair.nitro.d.ts +13 -0
  209. package/lib/typescript/specs/dsaKeyPair.nitro.d.ts.map +1 -0
  210. package/lib/typescript/specs/ecdh.nitro.d.ts +1 -0
  211. package/lib/typescript/specs/ecdh.nitro.d.ts.map +1 -1
  212. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +1 -0
  213. package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
  214. package/lib/typescript/specs/kmac.nitro.d.ts +10 -0
  215. package/lib/typescript/specs/kmac.nitro.d.ts.map +1 -0
  216. package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts +18 -0
  217. package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts.map +1 -0
  218. package/lib/typescript/specs/prime.nitro.d.ts +11 -0
  219. package/lib/typescript/specs/prime.nitro.d.ts.map +1 -0
  220. package/lib/typescript/specs/x509certificate.nitro.d.ts +34 -0
  221. package/lib/typescript/specs/x509certificate.nitro.d.ts.map +1 -0
  222. package/lib/typescript/subtle.d.ts +12 -0
  223. package/lib/typescript/subtle.d.ts.map +1 -1
  224. package/lib/typescript/utils/conversion.d.ts.map +1 -1
  225. package/lib/typescript/utils/hashnames.d.ts +1 -1
  226. package/lib/typescript/utils/hashnames.d.ts.map +1 -1
  227. package/lib/typescript/utils/types.d.ts +25 -9
  228. package/lib/typescript/utils/types.d.ts.map +1 -1
  229. package/lib/typescript/x509certificate.d.ts +64 -0
  230. package/lib/typescript/x509certificate.d.ts.map +1 -0
  231. package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +8 -0
  232. package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +80 -0
  233. package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +80 -0
  234. package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +12 -0
  235. package/nitrogen/generated/shared/c++/CipherInfo.hpp +104 -0
  236. package/nitrogen/generated/shared/c++/HybridArgon2Spec.cpp +22 -0
  237. package/nitrogen/generated/shared/c++/HybridArgon2Spec.hpp +66 -0
  238. package/nitrogen/generated/shared/c++/HybridCertificateSpec.cpp +23 -0
  239. package/nitrogen/generated/shared/c++/HybridCertificateSpec.hpp +64 -0
  240. package/nitrogen/generated/shared/c++/HybridCipherSpec.cpp +1 -0
  241. package/nitrogen/generated/shared/c++/HybridCipherSpec.hpp +4 -0
  242. package/nitrogen/generated/shared/c++/HybridDhKeyPairSpec.cpp +27 -0
  243. package/nitrogen/generated/shared/c++/HybridDhKeyPairSpec.hpp +69 -0
  244. package/nitrogen/generated/shared/c++/HybridDsaKeyPairSpec.cpp +26 -0
  245. package/nitrogen/generated/shared/c++/HybridDsaKeyPairSpec.hpp +68 -0
  246. package/nitrogen/generated/shared/c++/HybridECDHSpec.cpp +1 -0
  247. package/nitrogen/generated/shared/c++/HybridECDHSpec.hpp +1 -0
  248. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +1 -0
  249. package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +1 -0
  250. package/nitrogen/generated/shared/c++/HybridKmacSpec.cpp +23 -0
  251. package/nitrogen/generated/shared/c++/HybridKmacSpec.hpp +66 -0
  252. package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.cpp +31 -0
  253. package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.hpp +74 -0
  254. package/nitrogen/generated/shared/c++/HybridPrimeSpec.cpp +24 -0
  255. package/nitrogen/generated/shared/c++/HybridPrimeSpec.hpp +67 -0
  256. package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.cpp +46 -0
  257. package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.hpp +96 -0
  258. package/package.json +4 -1
  259. package/src/argon2.ts +83 -0
  260. package/src/certificate.ts +41 -0
  261. package/src/cipher.ts +41 -3
  262. package/src/dhKeyPair.ts +156 -0
  263. package/src/dsa.ts +129 -0
  264. package/src/ec.ts +9 -9
  265. package/src/ecdh.ts +59 -0
  266. package/src/ed.ts +2 -2
  267. package/src/hash.ts +34 -11
  268. package/src/hkdf.ts +2 -7
  269. package/src/index.ts +16 -0
  270. package/src/keys/classes.ts +26 -14
  271. package/src/keys/generateKeyPair.ts +14 -0
  272. package/src/keys/index.ts +37 -2
  273. package/src/keys/signVerify.ts +0 -5
  274. package/src/mlkem.ts +350 -0
  275. package/src/pbkdf2.ts +34 -5
  276. package/src/prime.ts +134 -0
  277. package/src/rsa.ts +1 -1
  278. package/src/specs/argon2.nitro.ts +29 -0
  279. package/src/specs/certificate.nitro.ts +8 -0
  280. package/src/specs/cipher.nitro.ts +14 -0
  281. package/src/specs/dhKeyPair.nitro.ts +14 -0
  282. package/src/specs/dsaKeyPair.nitro.ts +13 -0
  283. package/src/specs/ecdh.nitro.ts +1 -0
  284. package/src/specs/keyObjectHandle.nitro.ts +5 -0
  285. package/src/specs/kmac.nitro.ts +12 -0
  286. package/src/specs/mlKemKeyPair.nitro.ts +32 -0
  287. package/src/specs/prime.nitro.ts +18 -0
  288. package/src/specs/x509certificate.nitro.ts +38 -0
  289. package/src/subtle.ts +821 -136
  290. package/src/utils/conversion.ts +10 -4
  291. package/src/utils/hashnames.ts +33 -2
  292. package/src/utils/types.ts +64 -8
  293. package/src/x509certificate.ts +277 -0
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+
3
+ import { NitroModules } from 'react-native-nitro-modules';
4
+ import { CryptoKey, KeyObject, isCryptoKey } from './keys';
5
+ import { hasAnyNotIn, lazyDOMException, getUsagesUnion, KFormatType, KeyEncoding, isStringOrBuffer, binaryLikeToArrayBuffer as toAB } from './utils';
6
+ const ML_KEM_VARIANTS = {
7
+ 'ml-kem-512': 'ML-KEM-512',
8
+ 'ml-kem-768': 'ML-KEM-768',
9
+ 'ml-kem-1024': 'ML-KEM-1024'
10
+ };
11
+ function isMlKemKeyType(type) {
12
+ return type in ML_KEM_VARIANTS;
13
+ }
14
+ function unpackEncapsulateResult(packed) {
15
+ const view = new DataView(packed);
16
+ const ciphertextLen = view.getUint32(0, true);
17
+ const sharedKeyLen = view.getUint32(4, true);
18
+ const headerSize = 8;
19
+ const ciphertext = packed.slice(headerSize, headerSize + ciphertextLen);
20
+ const sharedKey = packed.slice(headerSize + ciphertextLen, headerSize + ciphertextLen + sharedKeyLen);
21
+ return {
22
+ ciphertext,
23
+ sharedKey
24
+ };
25
+ }
26
+ export class MlKem {
27
+ constructor(variant) {
28
+ this.variant = variant;
29
+ this.native = NitroModules.createHybridObject('MlKemKeyPair');
30
+ this.native.setVariant(variant);
31
+ }
32
+ async generateKeyPair() {
33
+ await this.native.generateKeyPair(KFormatType.DER, KeyEncoding.SPKI, KFormatType.DER, KeyEncoding.PKCS8);
34
+ }
35
+ generateKeyPairSync() {
36
+ this.native.generateKeyPairSync(KFormatType.DER, KeyEncoding.SPKI, KFormatType.DER, KeyEncoding.PKCS8);
37
+ }
38
+ getPublicKey() {
39
+ return this.native.getPublicKey();
40
+ }
41
+ getPrivateKey() {
42
+ return this.native.getPrivateKey();
43
+ }
44
+ setPublicKey(keyData, format, type) {
45
+ this.native.setPublicKey(keyData, format, type);
46
+ }
47
+ setPrivateKey(keyData, format, type) {
48
+ this.native.setPrivateKey(keyData, format, type);
49
+ }
50
+ async encapsulate() {
51
+ const packed = await this.native.encapsulate();
52
+ return unpackEncapsulateResult(packed);
53
+ }
54
+ encapsulateSync() {
55
+ const packed = this.native.encapsulateSync();
56
+ return unpackEncapsulateResult(packed);
57
+ }
58
+ async decapsulate(ciphertext) {
59
+ return this.native.decapsulate(ciphertext);
60
+ }
61
+ decapsulateSync(ciphertext) {
62
+ return this.native.decapsulateSync(ciphertext);
63
+ }
64
+ }
65
+ function prepareKey(key, isPublic) {
66
+ if (key instanceof KeyObject) {
67
+ if (isPublic) {
68
+ if (key.type === 'secret') {
69
+ throw new Error('Cannot use secret key for encapsulation');
70
+ }
71
+ } else {
72
+ if (key.type !== 'private') {
73
+ throw new Error('Key must be a private key for decapsulation');
74
+ }
75
+ }
76
+ return {
77
+ keyObject: key
78
+ };
79
+ }
80
+ if (isCryptoKey(key)) {
81
+ const cryptoKey = key;
82
+ return prepareKey(cryptoKey.keyObject, isPublic);
83
+ }
84
+ if (isStringOrBuffer(key)) {
85
+ const isPem = typeof key === 'string' && key.includes('-----BEGIN');
86
+ const format = isPem ? KFormatType.PEM : undefined;
87
+ const keyType = isPublic ? 'public' : 'private';
88
+ const keyData = toAB(key);
89
+ const keyObject = KeyObject.createKeyObject(keyType, keyData, format);
90
+ return {
91
+ keyObject
92
+ };
93
+ }
94
+ if (typeof key === 'object' && 'key' in key) {
95
+ const keyObj = key;
96
+ const {
97
+ key: data,
98
+ format,
99
+ type
100
+ } = keyObj;
101
+ if (data instanceof KeyObject) {
102
+ return {
103
+ keyObject: data
104
+ };
105
+ }
106
+ if (isCryptoKey(data)) {
107
+ return {
108
+ keyObject: data.keyObject
109
+ };
110
+ }
111
+ if (!isStringOrBuffer(data)) {
112
+ throw new Error('Invalid key data type');
113
+ }
114
+ const isPem = format === 'pem' || typeof data === 'string' && data.includes('-----BEGIN');
115
+ const kFormat = isPem ? KFormatType.PEM : format === 'der' ? KFormatType.DER : undefined;
116
+ let kType;
117
+ if (type === 'pkcs8') kType = KeyEncoding.PKCS8;else if (type === 'pkcs1') kType = KeyEncoding.PKCS1;else if (type === 'sec1') kType = KeyEncoding.SEC1;else if (type === 'spki') kType = KeyEncoding.SPKI;
118
+ const keyType = isPublic ? 'public' : 'private';
119
+ const keyData = toAB(data);
120
+ const keyObject = KeyObject.createKeyObject(keyType, keyData, kFormat, kType);
121
+ return {
122
+ keyObject
123
+ };
124
+ }
125
+ throw new Error('Invalid key input');
126
+ }
127
+ function getVariantFromKey(keyObject) {
128
+ const keyType = keyObject.handle.getAsymmetricKeyType();
129
+ if (!isMlKemKeyType(keyType)) {
130
+ throw new Error(`Key is not an ML-KEM key. Got asymmetricKeyType: ${keyType}`);
131
+ }
132
+ return ML_KEM_VARIANTS[keyType];
133
+ }
134
+ export function encapsulate(key, callback) {
135
+ const doEncapsulate = () => {
136
+ if (key === null || key === undefined) {
137
+ throw new Error('Public key is required for encapsulation');
138
+ }
139
+ const {
140
+ keyObject
141
+ } = prepareKey(key, true);
142
+ const variant = getVariantFromKey(keyObject);
143
+ const mlkem = new MlKem(variant);
144
+ const keyData = keyObject.handle.exportKey(KFormatType.DER, KeyEncoding.SPKI);
145
+ mlkem.setPublicKey(keyData, KFormatType.DER, KeyEncoding.SPKI);
146
+ return mlkem.encapsulateSync();
147
+ };
148
+ if (callback) {
149
+ try {
150
+ const result = doEncapsulate();
151
+ process.nextTick(callback, null, result);
152
+ } catch (err) {
153
+ process.nextTick(callback, err);
154
+ }
155
+ return;
156
+ }
157
+ return doEncapsulate();
158
+ }
159
+ export function decapsulate(key, ciphertext, callback) {
160
+ const doDecapsulate = () => {
161
+ if (key === null || key === undefined) {
162
+ throw new Error('Private key is required for decapsulation');
163
+ }
164
+ const {
165
+ keyObject
166
+ } = prepareKey(key, false);
167
+ const variant = getVariantFromKey(keyObject);
168
+ const mlkem = new MlKem(variant);
169
+ const keyData = keyObject.handle.exportKey(KFormatType.DER, KeyEncoding.PKCS8);
170
+ mlkem.setPrivateKey(keyData, KFormatType.DER, KeyEncoding.PKCS8);
171
+ const ciphertextBuffer = toAB(ciphertext);
172
+ return mlkem.decapsulateSync(ciphertextBuffer);
173
+ };
174
+ if (callback) {
175
+ try {
176
+ const result = doDecapsulate();
177
+ process.nextTick(callback, null, result);
178
+ } catch (err) {
179
+ process.nextTick(callback, err);
180
+ }
181
+ return;
182
+ }
183
+ return doDecapsulate();
184
+ }
185
+ export async function mlkem_generateKeyPairWebCrypto(variant, extractable, keyUsages) {
186
+ if (hasAnyNotIn(keyUsages, ['encapsulateBits', 'encapsulateKey', 'decapsulateBits', 'decapsulateKey'])) {
187
+ throw lazyDOMException(`Unsupported key usage for ${variant}`, 'SyntaxError');
188
+ }
189
+ const publicUsages = getUsagesUnion(keyUsages, 'encapsulateBits', 'encapsulateKey');
190
+ const privateUsages = getUsagesUnion(keyUsages, 'decapsulateBits', 'decapsulateKey');
191
+ if (privateUsages.length === 0) {
192
+ throw lazyDOMException('Usages cannot be empty', 'SyntaxError');
193
+ }
194
+ const mlkem = new MlKem(variant);
195
+ await mlkem.generateKeyPair();
196
+ const publicKeyData = mlkem.getPublicKey();
197
+ const privateKeyData = mlkem.getPrivateKey();
198
+ const pub = KeyObject.createKeyObject('public', publicKeyData, KFormatType.DER, KeyEncoding.SPKI);
199
+ const publicKey = new CryptoKey(pub, {
200
+ name: variant
201
+ }, publicUsages, true);
202
+ const priv = KeyObject.createKeyObject('private', privateKeyData, KFormatType.DER, KeyEncoding.PKCS8);
203
+ const privateKey = new CryptoKey(priv, {
204
+ name: variant
205
+ }, privateUsages, extractable);
206
+ return {
207
+ publicKey,
208
+ privateKey
209
+ };
210
+ }
211
+ //# sourceMappingURL=mlkem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["NitroModules","CryptoKey","KeyObject","isCryptoKey","hasAnyNotIn","lazyDOMException","getUsagesUnion","KFormatType","KeyEncoding","isStringOrBuffer","binaryLikeToArrayBuffer","toAB","ML_KEM_VARIANTS","isMlKemKeyType","type","unpackEncapsulateResult","packed","view","DataView","ciphertextLen","getUint32","sharedKeyLen","headerSize","ciphertext","slice","sharedKey","MlKem","constructor","variant","native","createHybridObject","setVariant","generateKeyPair","DER","SPKI","PKCS8","generateKeyPairSync","getPublicKey","getPrivateKey","setPublicKey","keyData","format","setPrivateKey","encapsulate","encapsulateSync","decapsulate","decapsulateSync","prepareKey","key","isPublic","Error","keyObject","cryptoKey","isPem","includes","PEM","undefined","keyType","createKeyObject","keyObj","data","kFormat","kType","PKCS1","SEC1","getVariantFromKey","handle","getAsymmetricKeyType","callback","doEncapsulate","mlkem","exportKey","result","process","nextTick","err","doDecapsulate","ciphertextBuffer","mlkem_generateKeyPairWebCrypto","extractable","keyUsages","publicUsages","privateUsages","length","publicKeyData","privateKeyData","pub","publicKey","name","priv","privateKey"],"sourceRoot":"../../src","sources":["mlkem.ts"],"mappings":"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","ignoreList":[]}
@@ -15,6 +15,21 @@ function getNative() {
15
15
  }
16
16
  return native;
17
17
  }
18
+ const MAX_INT32 = 2147483647;
19
+ function validateParameters(iterations, keylen) {
20
+ if (typeof iterations !== 'number') {
21
+ throw new TypeError('Iterations not a number');
22
+ }
23
+ if (typeof keylen !== 'number') {
24
+ throw new TypeError('Key length not a number');
25
+ }
26
+ if (iterations < 1 || !Number.isFinite(iterations) || !Number.isInteger(iterations) || iterations > MAX_INT32) {
27
+ throw new TypeError('Bad iterations');
28
+ }
29
+ if (keylen < 0 || !Number.isFinite(keylen) || !Number.isInteger(keylen) || keylen > MAX_INT32) {
30
+ throw new TypeError('Bad key length');
31
+ }
32
+ }
18
33
  function sanitizeInput(input, errorMsg) {
19
34
  try {
20
35
  return binaryLikeToArrayBuffer(input);
@@ -27,6 +42,7 @@ export function pbkdf2(password, salt, iterations, keylen, digest, callback) {
27
42
  if (callback === undefined || typeof callback !== 'function') {
28
43
  throw new Error('No callback provided to pbkdf2');
29
44
  }
45
+ validateParameters(iterations, keylen);
30
46
  const sanitizedPassword = sanitizeInput(password, WRONG_PASS);
31
47
  const sanitizedSalt = sanitizeInput(salt, WRONG_SALT);
32
48
  const normalizedDigest = normalizeHashName(digest, HashContext.Node);
@@ -38,9 +54,10 @@ export function pbkdf2(password, salt, iterations, keylen, digest, callback) {
38
54
  });
39
55
  }
40
56
  export function pbkdf2Sync(password, salt, iterations, keylen, digest) {
57
+ validateParameters(iterations, keylen);
41
58
  const sanitizedPassword = sanitizeInput(password, WRONG_PASS);
42
59
  const sanitizedSalt = sanitizeInput(salt, WRONG_SALT);
43
- const algo = digest ? normalizeHashName(digest, HashContext.Node) : 'sha1';
60
+ const algo = normalizeHashName(digest, HashContext.Node);
44
61
  getNative();
45
62
  const result = native.pbkdf2Sync(sanitizedPassword, sanitizedSalt, iterations, keylen, algo);
46
63
  return Buffer.from(result);
@@ -1 +1 @@
1
- {"version":3,"names":["Buffer","NitroModules","HashContext","binaryLikeToArrayBuffer","bufferLikeToArrayBuffer","lazyDOMException","normalizeHashName","promisify","WRONG_PASS","WRONG_SALT","native","getNative","createHybridObject","sanitizeInput","input","errorMsg","_e","Error","pbkdf2","password","salt","iterations","keylen","digest","callback","undefined","sanitizedPassword","sanitizedSalt","normalizedDigest","Node","then","res","from","e","pbkdf2Sync","algo","result","pbkdf2WithDigest","pbkdf2Promise","pbkdf2DeriveBits","algorithm","baseKey","length","hash","normalizedHash","raw","keyObject","export"],"sourceRoot":"../../src","sources":["pbkdf2.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Buffer","NitroModules","HashContext","binaryLikeToArrayBuffer","bufferLikeToArrayBuffer","lazyDOMException","normalizeHashName","promisify","WRONG_PASS","WRONG_SALT","native","getNative","createHybridObject","MAX_INT32","validateParameters","iterations","keylen","TypeError","Number","isFinite","isInteger","sanitizeInput","input","errorMsg","_e","Error","pbkdf2","password","salt","digest","callback","undefined","sanitizedPassword","sanitizedSalt","normalizedDigest","Node","then","res","from","e","pbkdf2Sync","algo","result","pbkdf2WithDigest","pbkdf2Promise","pbkdf2DeriveBits","algorithm","baseKey","length","hash","normalizedHash","raw","keyObject","export"],"sourceRoot":"../../src","sources":["pbkdf2.ts"],"mappings":";;AAAA,SAASA,MAAM,QAAQ,gCAAgC;AACvD,SAASC,YAAY,QAAQ,4BAA4B;AAEzD,SACEC,WAAW,EACXC,uBAAuB,EACvBC,uBAAuB,EACvBC,gBAAgB,EAChBC,iBAAiB,QACZ,SAAS;AAGhB,SAASC,SAAS,QAAQ,MAAM;AAGhC,MAAMC,UAAU,GACd,kEAAkE;AACpE,MAAMC,UAAU,GAAG,8DAA8D;AAMjF;AACA,IAAIC,MAAc;AAClB,SAASC,SAASA,CAAA,EAAW;EAC3B,IAAID,MAAM,IAAI,IAAI,EAAE;IAClB;IACAA,MAAM,GAAGT,YAAY,CAACW,kBAAkB,CAAS,QAAQ,CAAC;EAC5D;EACA,OAAOF,MAAM;AACf;AAEA,MAAMG,SAAS,GAAG,UAAU;AAE5B,SAASC,kBAAkBA,CAACC,UAAkB,EAAEC,MAAc,EAAQ;EACpE,IAAI,OAAOD,UAAU,KAAK,QAAQ,EAAE;IAClC,MAAM,IAAIE,SAAS,CAAC,yBAAyB,CAAC;EAChD;EACA,IAAI,OAAOD,MAAM,KAAK,QAAQ,EAAE;IAC9B,MAAM,IAAIC,SAAS,CAAC,yBAAyB,CAAC;EAChD;EACA,IACEF,UAAU,GAAG,CAAC,IACd,CAACG,MAAM,CAACC,QAAQ,CAACJ,UAAU,CAAC,IAC5B,CAACG,MAAM,CAACE,SAAS,CAACL,UAAU,CAAC,IAC7BA,UAAU,GAAGF,SAAS,EACtB;IACA,MAAM,IAAII,SAAS,CAAC,gBAAgB,CAAC;EACvC;EACA,IACED,MAAM,GAAG,CAAC,IACV,CAACE,MAAM,CAACC,QAAQ,CAACH,MAAM,CAAC,IACxB,CAACE,MAAM,CAACE,SAAS,CAACJ,MAAM,CAAC,IACzBA,MAAM,GAAGH,SAAS,EAClB;IACA,MAAM,IAAII,SAAS,CAAC,gBAAgB,CAAC;EACvC;AACF;AAEA,SAASI,aAAaA,CAACC,KAAiB,EAAEC,QAAgB,EAAe;EACvE,IAAI;IACF,OAAOpB,uBAAuB,CAACmB,KAAK,CAAC;IACrC;EACF,CAAC,CAAC,OAAOE,EAAW,EAAE;IACpB,MAAM,IAAIC,KAAK,CAACF,QAAQ,CAAC;EAC3B;AACF;AAEA,OAAO,SAASG,MAAMA,CACpBC,QAAkB,EAClBC,IAAU,EACVb,UAAkB,EAClBC,MAAc,EACda,MAAc,EACdC,QAAwB,EAClB;EACN,IAAIA,QAAQ,KAAKC,SAAS,IAAI,OAAOD,QAAQ,KAAK,UAAU,EAAE;IAC5D,MAAM,IAAIL,KAAK,CAAC,gCAAgC,CAAC;EACnD;EACAX,kBAAkB,CAACC,UAAU,EAAEC,MAAM,CAAC;EACtC,MAAMgB,iBAAiB,GAAGX,aAAa,CAACM,QAAQ,EAAEnB,UAAU,CAAC;EAC7D,MAAMyB,aAAa,GAAGZ,aAAa,CAACO,IAAI,EAAEnB,UAAU,CAAC;EACrD,MAAMyB,gBAAgB,GAAG5B,iBAAiB,CAACuB,MAAM,EAAE3B,WAAW,CAACiC,IAAI,CAAC;EAEpExB,SAAS,CAAC,CAAC;EACXD,MAAM,CACHgB,MAAM,CACLM,iBAAiB,EACjBC,aAAa,EACblB,UAAU,EACVC,MAAM,EACNkB,gBACF,CAAC,CACAE,IAAI,CACFC,GAAgB,IAAK;IACpBP,QAAQ,CAAE,IAAI,EAAE9B,MAAM,CAACsC,IAAI,CAACD,GAAG,CAAC,CAAC;EACnC,CAAC,EACAE,CAAQ,IAAK;IACZT,QAAQ,CAAES,CAAC,CAAC;EACd,CACF,CAAC;AACL;AAEA,OAAO,SAASC,UAAUA,CACxBb,QAAkB,EAClBC,IAAU,EACVb,UAAkB,EAClBC,MAAc,EACda,MAAc,EACN;EACRf,kBAAkB,CAACC,UAAU,EAAEC,MAAM,CAAC;EACtC,MAAMgB,iBAAiB,GAAGX,aAAa,CAACM,QAAQ,EAAEnB,UAAU,CAAC;EAC7D,MAAMyB,aAAa,GAAGZ,aAAa,CAACO,IAAI,EAAEnB,UAAU,CAAC;EAErD,MAAMgC,IAAI,GAAGnC,iBAAiB,CAACuB,MAAM,EAAE3B,WAAW,CAACiC,IAAI,CAAC;EACxDxB,SAAS,CAAC,CAAC;EACX,MAAM+B,MAAmB,GAAGhC,MAAM,CAAC8B,UAAU,CAC3CR,iBAAiB,EACjBC,aAAa,EACblB,UAAU,EACVC,MAAM,EACNyB,IACF,CAAC;EAED,OAAOzC,MAAM,CAACsC,IAAI,CAACI,MAAM,CAAC;AAC5B;;AAEA;AACA;AACA,MAAMC,gBAAgB,GAAGA,CACvBhB,QAAkB,EAClBC,IAAU,EACVb,UAAkB,EAClBC,MAAc,EACda,MAAc,EACdC,QAAwB,KACrBJ,MAAM,CAACC,QAAQ,EAAEC,IAAI,EAAEb,UAAU,EAAEC,MAAM,EAAEa,MAAM,EAAEC,QAAQ,CAAC;AAEjE,MAAMc,aAAa,GAAGrC,SAAS,CAACoC,gBAAgB,CAAC;AACjD,OAAO,eAAeE,gBAAgBA,CACpCC,SAA0B,EAC1BC,OAAkB,EAClBC,MAAc,EACQ;EACtB,MAAM;IAAEjC,UAAU;IAAEkC,IAAI;IAAErB;EAAK,CAAC,GAAGkB,SAAS;EAC5C,MAAMI,cAAc,GAAG5C,iBAAiB,CAAC2C,IAAI,CAAC;EAC9C,IAAI,CAACC,cAAc,EAAE;IACnB,MAAM7C,gBAAgB,CAAC,sBAAsB,EAAE,gBAAgB,CAAC;EAClE;EACA,IAAI,CAACU,UAAU,IAAIA,UAAU,KAAK,CAAC,EAAE;IACnC,MAAMV,gBAAgB,CAAC,2BAA2B,EAAE,gBAAgB,CAAC;EACvE;EACA,IAAI,CAACuB,IAAI,EAAE;IACT,MAAMvB,gBAAgB,CAACI,UAAU,EAAE,gBAAgB,CAAC;EACtD;EACA,MAAM0C,GAAG,GAAGJ,OAAO,CAACK,SAAS,CAACC,MAAM,CAAC,CAAC;EAEtC,IAAIL,MAAM,KAAK,CAAC,EACd,MAAM3C,gBAAgB,CAAC,uBAAuB,EAAE,gBAAgB,CAAC;EACnE,IAAI2C,MAAM,KAAK,IAAI,EACjB,MAAM3C,gBAAgB,CAAC,uBAAuB,EAAE,gBAAgB,CAAC;EACnE,IAAI2C,MAAM,GAAG,CAAC,EAAE;IACd,MAAM3C,gBAAgB,CAAC,gCAAgC,EAAE,gBAAgB,CAAC;EAC5E;EAEA,MAAM2B,iBAAiB,GAAGX,aAAa,CAAC8B,GAAG,EAAE3C,UAAU,CAAC;EACxD,MAAMyB,aAAa,GAAGZ,aAAa,CAACO,IAAI,EAAEnB,UAAU,CAAC;EACrD,MAAMiC,MAA0B,GAAG,MAAME,aAAa,CACpDZ,iBAAiB,EACjBC,aAAa,EACblB,UAAU,EACViC,MAAM,GAAG,CAAC,EACVE,cACF,CAAC;EACD,IAAI,CAACR,MAAM,EAAE;IACX,MAAMrC,gBAAgB,CACpB,mCAAmC,EACnC,gBACF,CAAC;EACH;EACA,OAAOD,uBAAuB,CAACsC,MAAM,CAAC;AACxC","ignoreList":[]}
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ import { NitroModules } from 'react-native-nitro-modules';
4
+ import { Buffer } from '@craftzdog/react-native-buffer';
5
+ import { binaryLikeToArrayBuffer } from './utils';
6
+ let native;
7
+ function getNative() {
8
+ if (native == null) {
9
+ native = NitroModules.createHybridObject('Prime');
10
+ }
11
+ return native;
12
+ }
13
+ function toOptionalArrayBuffer(value) {
14
+ if (value == null) return undefined;
15
+ if (value instanceof ArrayBuffer) return value;
16
+ return binaryLikeToArrayBuffer(value);
17
+ }
18
+ function bufferToBigInt(buf) {
19
+ let result = 0n;
20
+ for (let i = 0; i < buf.length; i++) {
21
+ result = result << 8n | BigInt(buf[i]);
22
+ }
23
+ return result;
24
+ }
25
+ function bigIntToBuffer(value) {
26
+ if (value === 0n) return new Uint8Array([0]).buffer;
27
+ const hex = value.toString(16);
28
+ const paddedHex = hex.length % 2 ? '0' + hex : hex;
29
+ const bytes = new Uint8Array(paddedHex.length / 2);
30
+ for (let i = 0; i < bytes.length; i++) {
31
+ bytes[i] = parseInt(paddedHex.substring(i * 2, i * 2 + 2), 16);
32
+ }
33
+ return bytes.buffer;
34
+ }
35
+ export function generatePrimeSync(size, options) {
36
+ const safe = options?.safe ?? false;
37
+ const add = toOptionalArrayBuffer(options?.add);
38
+ const rem = toOptionalArrayBuffer(options?.rem);
39
+ const result = Buffer.from(getNative().generatePrimeSync(size, safe, add, rem));
40
+ if (options?.bigint) {
41
+ return bufferToBigInt(result);
42
+ }
43
+ return result;
44
+ }
45
+ export function generatePrime(size, options, callback) {
46
+ if (typeof options === 'function') {
47
+ callback = options;
48
+ options = {};
49
+ }
50
+ const safe = options?.safe ?? false;
51
+ const add = toOptionalArrayBuffer(options?.add);
52
+ const rem = toOptionalArrayBuffer(options?.rem);
53
+ const wantBigint = options?.bigint ?? false;
54
+ getNative().generatePrime(size, safe, add, rem).then(ab => {
55
+ const result = Buffer.from(ab);
56
+ if (wantBigint) {
57
+ callback?.(null, bufferToBigInt(result));
58
+ } else {
59
+ callback?.(null, result);
60
+ }
61
+ }).catch(err => callback?.(err, Buffer.alloc(0)));
62
+ }
63
+ export function checkPrimeSync(candidate, options) {
64
+ const checks = options?.checks ?? 0;
65
+ const buf = typeof candidate === 'bigint' ? bigIntToBuffer(candidate) : binaryLikeToArrayBuffer(candidate);
66
+ return getNative().checkPrimeSync(buf, checks);
67
+ }
68
+ export function checkPrime(candidate, options, callback) {
69
+ if (typeof options === 'function') {
70
+ callback = options;
71
+ options = {};
72
+ }
73
+ const checks = options.checks ?? 0;
74
+ const buf = typeof candidate === 'bigint' ? bigIntToBuffer(candidate) : binaryLikeToArrayBuffer(candidate);
75
+ getNative().checkPrime(buf, checks).then(result => callback?.(null, result)).catch(err => callback?.(err, false));
76
+ }
77
+ //# sourceMappingURL=prime.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["NitroModules","Buffer","binaryLikeToArrayBuffer","native","getNative","createHybridObject","toOptionalArrayBuffer","value","undefined","ArrayBuffer","bufferToBigInt","buf","result","i","length","BigInt","bigIntToBuffer","Uint8Array","buffer","hex","toString","paddedHex","bytes","parseInt","substring","generatePrimeSync","size","options","safe","add","rem","from","bigint","generatePrime","callback","wantBigint","then","ab","catch","err","alloc","checkPrimeSync","candidate","checks","checkPrime"],"sourceRoot":"../../src","sources":["prime.ts"],"mappings":"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","ignoreList":[]}
package/lib/module/rsa.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  import { NitroModules } from 'react-native-nitro-modules';
4
- import { CryptoKey, KeyObject } from './keys';
4
+ import { CryptoKey, KeyObject } from './keys/classes';
5
5
  import { getUsagesUnion, hasAnyNotIn, lazyDOMException, normalizeHashName, KFormatType, KeyEncoding } from './utils';
6
6
  export class Rsa {
7
7
  constructor(modulusLength, publicExponent, hashAlgorithm) {
@@ -1 +1 @@
1
- {"version":3,"names":["NitroModules","CryptoKey","KeyObject","getUsagesUnion","hasAnyNotIn","lazyDOMException","normalizeHashName","KFormatType","KeyEncoding","Rsa","constructor","modulusLength","publicExponent","hashAlgorithm","native","createHybridObject","setModulusLength","setPublicExponent","buffer","slice","byteOffset","byteLength","setHashAlgorithm","generateKeyPair","publicKey","getPublicKey","privateKey","getPrivateKey","generateKeyPairSync","rsa_generateKeyPair","algorithm","extractable","keyUsages","name","hash","length","hashName","normalizedHash","publicUsages","privateUsages","rsa","keyAlgorithm","publicKeyData","pub","createKeyObject","privateKeyData","priv","rsa_prepareKeyGenParams","_type","options","Error","pubExp","pubExpBytes","Uint8Array","rsa_formatKeyPairOutput","encoding","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","format","PEM","DER","keyEncoding","SPKI","PKCS1","exported","handle","exportKey","Buffer","from","toString","PKCS8","rsa_generateKeyPairNode","type","rsa_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["rsa.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["NitroModules","CryptoKey","KeyObject","getUsagesUnion","hasAnyNotIn","lazyDOMException","normalizeHashName","KFormatType","KeyEncoding","Rsa","constructor","modulusLength","publicExponent","hashAlgorithm","native","createHybridObject","setModulusLength","setPublicExponent","buffer","slice","byteOffset","byteLength","setHashAlgorithm","generateKeyPair","publicKey","getPublicKey","privateKey","getPrivateKey","generateKeyPairSync","rsa_generateKeyPair","algorithm","extractable","keyUsages","name","hash","length","hashName","normalizedHash","publicUsages","privateUsages","rsa","keyAlgorithm","publicKeyData","pub","createKeyObject","privateKeyData","priv","rsa_prepareKeyGenParams","_type","options","Error","pubExp","pubExpBytes","Uint8Array","rsa_formatKeyPairOutput","encoding","publicFormat","publicType","privateFormat","privateType","cipher","passphrase","format","PEM","DER","keyEncoding","SPKI","PKCS1","exported","handle","exportKey","Buffer","from","toString","PKCS8","rsa_generateKeyPairNode","type","rsa_generateKeyPairNodeSync"],"sourceRoot":"../../src","sources":["rsa.ts"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=argon2.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/argon2.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=certificate.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/certificate.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=dhKeyPair.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/dhKeyPair.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=dsaKeyPair.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/dsaKeyPair.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=kmac.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/kmac.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=mlKemKeyPair.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/mlKemKeyPair.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=prime.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/prime.nitro.ts"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+
3
+ export {};
4
+ //# sourceMappingURL=x509certificate.nitro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/x509certificate.nitro.ts"],"mappings":"","ignoreList":[]}