react-native-quick-crypto 1.0.11 → 1.0.13
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.
- package/android/CMakeLists.txt +7 -0
- package/cpp/cipher/CCMCipher.cpp +4 -1
- package/cpp/cipher/ChaCha20Cipher.cpp +3 -1
- package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +5 -5
- package/cpp/cipher/ChaCha20Poly1305Cipher.hpp +1 -2
- package/cpp/cipher/HybridCipher.cpp +10 -1
- package/cpp/cipher/HybridCipher.hpp +2 -0
- package/cpp/cipher/HybridRsaCipher.cpp +0 -13
- package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +7 -5
- package/cpp/cipher/XChaCha20Poly1305Cipher.hpp +1 -2
- package/cpp/cipher/XSalsa20Cipher.cpp +4 -0
- package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +7 -5
- package/cpp/cipher/XSalsa20Poly1305Cipher.hpp +1 -2
- package/cpp/ecdh/HybridECDH.cpp +20 -133
- package/cpp/keys/HybridKeyObjectHandle.cpp +144 -141
- package/cpp/keys/HybridKeyObjectHandle.hpp +6 -3
- package/cpp/keys/KeyObjectData.hpp +2 -0
- package/cpp/kmac/HybridKmac.cpp +83 -0
- package/cpp/kmac/HybridKmac.hpp +31 -0
- package/cpp/mldsa/HybridMlDsaKeyPair.cpp +11 -20
- package/cpp/mldsa/HybridMlDsaKeyPair.hpp +4 -2
- package/cpp/mlkem/HybridMlKemKeyPair.cpp +319 -0
- package/cpp/mlkem/HybridMlKemKeyPair.hpp +48 -0
- package/cpp/sign/SignUtils.hpp +9 -26
- package/cpp/utils/QuickCryptoUtils.cpp +44 -0
- package/cpp/utils/QuickCryptoUtils.hpp +39 -0
- package/cpp/x509/HybridX509Certificate.cpp +174 -0
- package/cpp/x509/HybridX509Certificate.hpp +51 -0
- package/lib/commonjs/cipher.js +15 -2
- package/lib/commonjs/cipher.js.map +1 -1
- package/lib/commonjs/dhKeyPair.js +3 -3
- package/lib/commonjs/dhKeyPair.js.map +1 -1
- package/lib/commonjs/dsa.js +3 -3
- package/lib/commonjs/dsa.js.map +1 -1
- package/lib/commonjs/ec.js +18 -18
- package/lib/commonjs/ec.js.map +1 -1
- package/lib/commonjs/ed.js +9 -9
- package/lib/commonjs/ed.js.map +1 -1
- package/lib/commonjs/hash.js +17 -12
- package/lib/commonjs/hash.js.map +1 -1
- package/lib/commonjs/hkdf.js.map +1 -1
- package/lib/commonjs/index.js +22 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/keys/classes.js +2 -2
- package/lib/commonjs/keys/classes.js.map +1 -1
- package/lib/commonjs/keys/index.js +24 -0
- package/lib/commonjs/keys/index.js.map +1 -1
- package/lib/commonjs/keys/publicCipher.js +2 -2
- package/lib/commonjs/keys/publicCipher.js.map +1 -1
- package/lib/commonjs/keys/signVerify.js +0 -2
- package/lib/commonjs/keys/signVerify.js.map +1 -1
- package/lib/commonjs/mlkem.js +219 -0
- package/lib/commonjs/mlkem.js.map +1 -0
- package/lib/commonjs/pbkdf2.js +18 -1
- package/lib/commonjs/pbkdf2.js.map +1 -1
- package/lib/commonjs/rsa.js +7 -7
- package/lib/commonjs/rsa.js.map +1 -1
- package/lib/commonjs/specs/kmac.nitro.js +6 -0
- package/lib/commonjs/specs/kmac.nitro.js.map +1 -0
- package/lib/commonjs/specs/mlKemKeyPair.nitro.js +6 -0
- package/lib/commonjs/specs/mlKemKeyPair.nitro.js.map +1 -0
- package/lib/commonjs/specs/x509certificate.nitro.js +6 -0
- package/lib/commonjs/specs/x509certificate.nitro.js.map +1 -0
- package/lib/commonjs/subtle.js +292 -112
- package/lib/commonjs/subtle.js.map +1 -1
- package/lib/commonjs/utils/conversion.js +3 -3
- package/lib/commonjs/utils/conversion.js.map +1 -1
- package/lib/commonjs/utils/hashnames.js +31 -0
- package/lib/commonjs/utils/hashnames.js.map +1 -1
- package/lib/commonjs/utils/types.js.map +1 -1
- package/lib/commonjs/x509certificate.js +189 -0
- package/lib/commonjs/x509certificate.js.map +1 -0
- package/lib/module/cipher.js +16 -3
- package/lib/module/cipher.js.map +1 -1
- package/lib/module/dhKeyPair.js +1 -1
- package/lib/module/dhKeyPair.js.map +1 -1
- package/lib/module/dsa.js +1 -1
- package/lib/module/dsa.js.map +1 -1
- package/lib/module/ec.js +6 -6
- package/lib/module/ec.js.map +1 -1
- package/lib/module/ed.js +1 -1
- package/lib/module/ed.js.map +1 -1
- package/lib/module/hash.js +17 -12
- package/lib/module/hash.js.map +1 -1
- package/lib/module/hkdf.js.map +1 -1
- package/lib/module/index.js +6 -0
- package/lib/module/index.js.map +1 -1
- package/lib/module/keys/classes.js +2 -2
- package/lib/module/keys/classes.js.map +1 -1
- package/lib/module/keys/index.js +25 -1
- package/lib/module/keys/index.js.map +1 -1
- package/lib/module/keys/publicCipher.js +2 -2
- package/lib/module/keys/publicCipher.js.map +1 -1
- package/lib/module/keys/signVerify.js +0 -2
- package/lib/module/keys/signVerify.js.map +1 -1
- package/lib/module/mlkem.js +211 -0
- package/lib/module/mlkem.js.map +1 -0
- package/lib/module/pbkdf2.js +18 -1
- package/lib/module/pbkdf2.js.map +1 -1
- package/lib/module/rsa.js +1 -1
- package/lib/module/rsa.js.map +1 -1
- package/lib/module/specs/kmac.nitro.js +4 -0
- package/lib/module/specs/kmac.nitro.js.map +1 -0
- package/lib/module/specs/mlKemKeyPair.nitro.js +4 -0
- package/lib/module/specs/mlKemKeyPair.nitro.js.map +1 -0
- package/lib/module/specs/x509certificate.nitro.js +4 -0
- package/lib/module/specs/x509certificate.nitro.js.map +1 -0
- package/lib/module/subtle.js +292 -112
- package/lib/module/subtle.js.map +1 -1
- package/lib/module/utils/conversion.js +3 -4
- package/lib/module/utils/conversion.js.map +1 -1
- package/lib/module/utils/hashnames.js +31 -0
- package/lib/module/utils/hashnames.js.map +1 -1
- package/lib/module/utils/types.js.map +1 -1
- package/lib/module/x509certificate.js +184 -0
- package/lib/module/x509certificate.js.map +1 -0
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/typescript/cipher.d.ts +3 -0
- package/lib/typescript/cipher.d.ts.map +1 -1
- package/lib/typescript/dhKeyPair.d.ts +1 -1
- package/lib/typescript/dhKeyPair.d.ts.map +1 -1
- package/lib/typescript/dsa.d.ts +1 -1
- package/lib/typescript/dsa.d.ts.map +1 -1
- package/lib/typescript/ec.d.ts +1 -1
- package/lib/typescript/ec.d.ts.map +1 -1
- package/lib/typescript/ed.d.ts +1 -1
- package/lib/typescript/ed.d.ts.map +1 -1
- package/lib/typescript/hash.d.ts.map +1 -1
- package/lib/typescript/hkdf.d.ts +2 -6
- package/lib/typescript/hkdf.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +15 -4
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/keys/classes.d.ts +5 -5
- package/lib/typescript/keys/classes.d.ts.map +1 -1
- package/lib/typescript/keys/index.d.ts +2 -2
- package/lib/typescript/keys/index.d.ts.map +1 -1
- package/lib/typescript/keys/signVerify.d.ts.map +1 -1
- package/lib/typescript/mlkem.d.ts +30 -0
- package/lib/typescript/mlkem.d.ts.map +1 -0
- package/lib/typescript/pbkdf2.d.ts +2 -2
- package/lib/typescript/pbkdf2.d.ts.map +1 -1
- package/lib/typescript/rsa.d.ts +1 -1
- package/lib/typescript/rsa.d.ts.map +1 -1
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +1 -0
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
- package/lib/typescript/specs/kmac.nitro.d.ts +10 -0
- package/lib/typescript/specs/kmac.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts +18 -0
- package/lib/typescript/specs/mlKemKeyPair.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/x509certificate.nitro.d.ts +34 -0
- package/lib/typescript/specs/x509certificate.nitro.d.ts.map +1 -0
- package/lib/typescript/subtle.d.ts +10 -0
- package/lib/typescript/subtle.d.ts.map +1 -1
- package/lib/typescript/utils/conversion.d.ts.map +1 -1
- package/lib/typescript/utils/hashnames.d.ts +1 -1
- package/lib/typescript/utils/hashnames.d.ts.map +1 -1
- package/lib/typescript/utils/types.d.ts +13 -7
- package/lib/typescript/utils/types.d.ts.map +1 -1
- package/lib/typescript/x509certificate.d.ts +64 -0
- package/lib/typescript/x509certificate.d.ts.map +1 -0
- package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +3 -0
- package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +30 -0
- package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +30 -0
- package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +12 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +1 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +1 -0
- package/nitrogen/generated/shared/c++/HybridKmacSpec.cpp +23 -0
- package/nitrogen/generated/shared/c++/HybridKmacSpec.hpp +66 -0
- package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.cpp +31 -0
- package/nitrogen/generated/shared/c++/HybridMlKemKeyPairSpec.hpp +74 -0
- package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.cpp +46 -0
- package/nitrogen/generated/shared/c++/HybridX509CertificateHandleSpec.hpp +96 -0
- package/package.json +4 -1
- package/src/cipher.ts +17 -3
- package/src/dhKeyPair.ts +1 -1
- package/src/dsa.ts +1 -1
- package/src/ec.ts +9 -9
- package/src/ed.ts +2 -2
- package/src/hash.ts +34 -11
- package/src/hkdf.ts +2 -7
- package/src/index.ts +7 -0
- package/src/keys/classes.ts +10 -9
- package/src/keys/index.ts +37 -2
- package/src/keys/publicCipher.ts +2 -2
- package/src/keys/signVerify.ts +0 -5
- package/src/mlkem.ts +350 -0
- package/src/pbkdf2.ts +34 -5
- package/src/rsa.ts +1 -1
- package/src/specs/keyObjectHandle.nitro.ts +5 -0
- package/src/specs/kmac.nitro.ts +12 -0
- package/src/specs/mlKemKeyPair.nitro.ts +32 -0
- package/src/specs/x509certificate.nitro.ts +38 -0
- package/src/subtle.ts +551 -125
- package/src/utils/conversion.ts +10 -4
- package/src/utils/hashnames.ts +33 -2
- package/src/utils/types.ts +42 -5
- package/src/x509certificate.ts +277 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["AsymmetricKeyObject","CryptoKey","KeyObject","SecretKeyObject","PublicKeyObject","PrivateKeyObject","generateKeyPair","generateKeyPairSync","createSign","createVerify","sign","verify","Sign","Verify","publicEncrypt","publicDecrypt","privateEncrypt","privateDecrypt","isCryptoKey","parseKeyEncoding","parsePrivateKeyEncoding","parsePublicKeyEncoding","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","randomBytes","createSecretKey","key","keyBuffer","createKeyObject","prepareAsymmetricKey","isPublic","type","Error","exported","handle","exportKey","DER","SPKI","data","format","PKCS8","cryptoKey","keyObject","isPem","includes","undefined","keyObj","filteredFormat","createPublicKey","kFormat","PEM","kType","PKCS1","createPrivateKey","SEC1","generateKeySync","options","TypeError","length","Number","isInteger","RangeError","keyBytes","keyMaterial","generateKey","callback","process","nextTick","err"],"sourceRoot":"../../../src","sources":["keys/index.ts"],"mappings":";;AAAA,SACEA,mBAAmB,EACnBC,SAAS,EACTC,SAAS,EACTC,eAAe,EACfC,eAAe,EACfC,gBAAgB,QACX,WAAW;AAClB,SAASC,eAAe,EAAEC,mBAAmB,QAAQ,mBAAmB;AACxE,SACEC,UAAU,EACVC,YAAY,EACZC,IAAI,EACJC,MAAM,EACNC,IAAI,EACJC,MAAM,QACD,cAAc;AACrB,SACEC,aAAa,EACbC,aAAa,EACbC,cAAc,EACdC,cAAc,QACT,gBAAgB;AACvB,SACEC,WAAW,EACXC,gBAAgB,EAChBC,uBAAuB,EACvBC,sBAAsB,QACjB,SAAS;
|
|
1
|
+
{"version":3,"names":["AsymmetricKeyObject","CryptoKey","KeyObject","SecretKeyObject","PublicKeyObject","PrivateKeyObject","generateKeyPair","generateKeyPairSync","createSign","createVerify","sign","verify","Sign","Verify","publicEncrypt","publicDecrypt","privateEncrypt","privateDecrypt","isCryptoKey","parseKeyEncoding","parsePrivateKeyEncoding","parsePublicKeyEncoding","NitroModules","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","KeyType","randomBytes","createSecretKey","key","keyBuffer","createKeyObject","prepareAsymmetricKey","isPublic","type","Error","exported","handle","exportKey","DER","SPKI","data","format","PKCS8","cryptoKey","keyObject","isPem","includes","undefined","keyObj","filteredFormat","createPublicKey","createHybridObject","keyType","initJwk","PRIVATE","pubHandle","init","PUBLIC","kFormat","PEM","kType","PKCS1","createPrivateKey","SEC1","generateKeySync","options","TypeError","length","Number","isInteger","RangeError","keyBytes","keyMaterial","generateKey","callback","process","nextTick","err"],"sourceRoot":"../../../src","sources":["keys/index.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -59,7 +59,7 @@ export function publicEncrypt(key, buffer) {
|
|
|
59
59
|
const rsaCipher = NitroModules.createHybridObject('RsaCipher');
|
|
60
60
|
const data = toAB(buffer);
|
|
61
61
|
const paddingMode = padding ?? constants.RSA_PKCS1_OAEP_PADDING;
|
|
62
|
-
const hashAlgorithm = oaepHash || '
|
|
62
|
+
const hashAlgorithm = oaepHash || 'sha1';
|
|
63
63
|
try {
|
|
64
64
|
const encrypted = rsaCipher.encrypt(keyHandle.handle, data, paddingMode, hashAlgorithm, oaepLabel);
|
|
65
65
|
return Buffer.from(encrypted);
|
|
@@ -146,7 +146,7 @@ export function privateDecrypt(key, buffer) {
|
|
|
146
146
|
const rsaCipher = NitroModules.createHybridObject('RsaCipher');
|
|
147
147
|
const data = toAB(buffer);
|
|
148
148
|
const paddingMode = padding ?? constants.RSA_PKCS1_OAEP_PADDING;
|
|
149
|
-
const hashAlgorithm = oaepHash || '
|
|
149
|
+
const hashAlgorithm = oaepHash || 'sha1';
|
|
150
150
|
try {
|
|
151
151
|
const decrypted = rsaCipher.privateDecrypt(keyHandle.handle, data, paddingMode, hashAlgorithm, oaepLabel);
|
|
152
152
|
return Buffer.from(decrypted);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["NitroModules","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","isCryptoKey","KeyObject","constants","preparePublicCipherKey","key","isEncrypt","keyObj","padding","oaepHash","oaepLabel","type","Error","cryptoKey","keyObject","data","isPem","includes","isPrivatePem","createKeyObject","PEM","PKCS8","DER","SPKI","options","result","keyHandle","publicEncrypt","buffer","rsaCipher","createHybridObject","paddingMode","RSA_PKCS1_OAEP_PADDING","hashAlgorithm","encrypted","encrypt","handle","Buffer","from","error","message","publicDecrypt","RSA_PKCS1_PADDING","decrypted","preparePrivateCipherKey","privateEncrypt","privateDecrypt"],"sourceRoot":"../../../src","sources":["keys/publicCipher.ts"],"mappings":"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
|
|
1
|
+
{"version":3,"names":["NitroModules","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","isCryptoKey","KeyObject","constants","preparePublicCipherKey","key","isEncrypt","keyObj","padding","oaepHash","oaepLabel","type","Error","cryptoKey","keyObject","data","isPem","includes","isPrivatePem","createKeyObject","PEM","PKCS8","DER","SPKI","options","result","keyHandle","publicEncrypt","buffer","rsaCipher","createHybridObject","paddingMode","RSA_PKCS1_OAEP_PADDING","hashAlgorithm","encrypted","encrypt","handle","Buffer","from","error","message","publicDecrypt","RSA_PKCS1_PADDING","decrypted","preparePrivateCipherKey","privateEncrypt","privateDecrypt"],"sourceRoot":"../../../src","sources":["keys/publicCipher.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -88,9 +88,7 @@ function prepareKey(key, isPublic) {
|
|
|
88
88
|
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;
|
|
89
89
|
const keyType = isPublic ? 'public' : 'private';
|
|
90
90
|
// Always convert to ArrayBuffer to avoid Nitro bridge string truncation bug
|
|
91
|
-
const originalLength = typeof data === 'string' ? data.length : data.byteLength;
|
|
92
91
|
const keyData = toAB(data);
|
|
93
|
-
console.log(`[prepareKey KeyInputObject] ${keyType} key, original length: ${originalLength}, ArrayBuffer size: ${keyData.byteLength}`);
|
|
94
92
|
const keyObject = KeyObject.createKeyObject(keyType, keyData, kFormat, kType);
|
|
95
93
|
return {
|
|
96
94
|
keyObject,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["Buffer","NitroModules","KeyObject","isCryptoKey","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","prepareKey","key","isPublic","type","Error","keyObject","cryptoKey","isPem","includes","format","PEM","undefined","keyData","createKeyObject","keyObj","data","padding","saltLength","dsaEncoding","options","kFormat","DER","kType","PKCS8","PKCS1","SEC1","SPKI","keyType","
|
|
1
|
+
{"version":3,"names":["Buffer","NitroModules","KeyObject","isCryptoKey","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","prepareKey","key","isPublic","type","Error","keyObject","cryptoKey","isPem","includes","format","PEM","undefined","keyData","createKeyObject","keyObj","data","padding","saltLength","dsaEncoding","options","kFormat","DER","kType","PKCS8","PKCS1","SEC1","SPKI","keyType","dsaEncodingToNumber","Sign","constructor","algorithm","handle","createHybridObject","init","update","dataBuffer","sign","privateKey","outputEncoding","signature","buf","from","toString","Verify","verify","publicKey","signatureEncoding","sigBuffer","createSign","createVerify","callback","doSign","signer","process","nextTick","err","doVerify","verifier","result"],"sourceRoot":"../../../src","sources":["keys/signVerify.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -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":[]}
|
package/lib/module/pbkdf2.js
CHANGED
|
@@ -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 =
|
|
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);
|
package/lib/module/pbkdf2.js.map
CHANGED
|
@@ -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","
|
|
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":"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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) {
|
package/lib/module/rsa.js.map
CHANGED
|
@@ -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":";;AAAA,SAASA,YAAY,QAAQ,4BAA4B;AACzD,SACEC,SAAS,EACTC,SAAS,QAGJ,
|
|
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 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/kmac.nitro.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/mlKemKeyPair.nitro.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/x509certificate.nitro.ts"],"mappings":"","ignoreList":[]}
|