react-native-quick-crypto 1.1.1 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/QuickCrypto.podspec +1 -0
- package/android/CMakeLists.txt +4 -0
- package/cpp/cipher/CCMCipher.cpp +7 -11
- package/cpp/cipher/ChaCha20Cipher.cpp +6 -10
- package/cpp/cipher/ChaCha20Poly1305Cipher.cpp +10 -16
- package/cpp/cipher/GCMCipher.cpp +3 -5
- package/cpp/cipher/HybridCipher.cpp +7 -13
- package/cpp/cipher/HybridRsaCipher.cpp +19 -27
- package/cpp/cipher/OCBCipher.cpp +2 -3
- package/cpp/cipher/XChaCha20Poly1305Cipher.cpp +13 -19
- package/cpp/cipher/XSalsa20Cipher.cpp +8 -12
- package/cpp/cipher/XSalsa20Poly1305Cipher.cpp +11 -16
- package/cpp/keys/HybridKeyObjectHandle.cpp +630 -2
- package/cpp/keys/HybridKeyObjectHandle.hpp +21 -1
- package/cpp/sign/HybridSignHandle.cpp +26 -8
- package/cpp/sign/HybridVerifyHandle.cpp +28 -11
- package/cpp/slhdsa/HybridSlhDsaKeyPair.cpp +245 -0
- package/cpp/slhdsa/HybridSlhDsaKeyPair.hpp +48 -0
- package/cpp/turboshake/HybridTurboShake.cpp +379 -0
- package/cpp/turboshake/HybridTurboShake.hpp +28 -0
- package/cpp/utils/HybridUtils.cpp +26 -14
- package/deps/blake3/README.md +6 -7
- package/deps/blake3/c/blake3.c +3 -2
- package/deps/blake3/c/blake3.h +2 -2
- package/deps/blake3/c/blake3_dispatch.c +2 -2
- package/deps/blake3/c/blake3_impl.h +1 -1
- package/deps/blake3/c/blake3_neon.c +5 -4
- package/deps/ncrypto/include/ncrypto/version.h +2 -2
- package/deps/ncrypto/include/ncrypto.h +9 -2
- package/deps/ncrypto/src/ncrypto.cpp +130 -35
- package/lib/commonjs/dhKeyPair.js +3 -0
- package/lib/commonjs/dhKeyPair.js.map +1 -1
- package/lib/commonjs/dsa.js +3 -0
- package/lib/commonjs/dsa.js.map +1 -1
- package/lib/commonjs/ec.js +37 -30
- package/lib/commonjs/ec.js.map +1 -1
- package/lib/commonjs/ed.js +60 -6
- package/lib/commonjs/ed.js.map +1 -1
- package/lib/commonjs/hash.js +52 -5
- package/lib/commonjs/hash.js.map +1 -1
- package/lib/commonjs/keys/classes.js +33 -7
- package/lib/commonjs/keys/classes.js.map +1 -1
- package/lib/commonjs/keys/generateKeyPair.js +85 -4
- package/lib/commonjs/keys/generateKeyPair.js.map +1 -1
- package/lib/commonjs/keys/index.js +50 -2
- package/lib/commonjs/keys/index.js.map +1 -1
- package/lib/commonjs/keys/signVerify.js +9 -2
- package/lib/commonjs/keys/signVerify.js.map +1 -1
- package/lib/commonjs/keys/utils.js +59 -1
- package/lib/commonjs/keys/utils.js.map +1 -1
- package/lib/commonjs/random.js +63 -9
- package/lib/commonjs/random.js.map +1 -1
- package/lib/commonjs/rsa.js +3 -0
- package/lib/commonjs/rsa.js.map +1 -1
- package/lib/commonjs/slhdsa.js +70 -0
- package/lib/commonjs/slhdsa.js.map +1 -0
- package/lib/commonjs/specs/slhDsaKeyPair.nitro.js +6 -0
- package/lib/commonjs/specs/slhDsaKeyPair.nitro.js.map +1 -0
- package/lib/commonjs/specs/turboshake.nitro.js +6 -0
- package/lib/commonjs/specs/turboshake.nitro.js.map +1 -0
- package/lib/commonjs/subtle.js +926 -275
- package/lib/commonjs/subtle.js.map +1 -1
- package/lib/commonjs/utils/conversion.js +53 -19
- package/lib/commonjs/utils/conversion.js.map +1 -1
- package/lib/commonjs/utils/errors.js +63 -4
- package/lib/commonjs/utils/errors.js.map +1 -1
- package/lib/commonjs/utils/types.js.map +1 -1
- package/lib/commonjs/utils/validation.js +46 -0
- package/lib/commonjs/utils/validation.js.map +1 -1
- package/lib/module/dhKeyPair.js +3 -0
- package/lib/module/dhKeyPair.js.map +1 -1
- package/lib/module/dsa.js +3 -0
- package/lib/module/dsa.js.map +1 -1
- package/lib/module/ec.js +38 -31
- package/lib/module/ec.js.map +1 -1
- package/lib/module/ed.js +61 -7
- package/lib/module/ed.js.map +1 -1
- package/lib/module/hash.js +52 -5
- package/lib/module/hash.js.map +1 -1
- package/lib/module/keys/classes.js +31 -5
- package/lib/module/keys/classes.js.map +1 -1
- package/lib/module/keys/generateKeyPair.js +86 -5
- package/lib/module/keys/generateKeyPair.js.map +1 -1
- package/lib/module/keys/index.js +50 -2
- package/lib/module/keys/index.js.map +1 -1
- package/lib/module/keys/signVerify.js +9 -2
- package/lib/module/keys/signVerify.js.map +1 -1
- package/lib/module/keys/utils.js +57 -1
- package/lib/module/keys/utils.js.map +1 -1
- package/lib/module/random.js +63 -10
- package/lib/module/random.js.map +1 -1
- package/lib/module/rsa.js +3 -0
- package/lib/module/rsa.js.map +1 -1
- package/lib/module/slhdsa.js +64 -0
- package/lib/module/slhdsa.js.map +1 -0
- package/lib/module/specs/slhDsaKeyPair.nitro.js +4 -0
- package/lib/module/specs/slhDsaKeyPair.nitro.js.map +1 -0
- package/lib/module/specs/turboshake.nitro.js +4 -0
- package/lib/module/specs/turboshake.nitro.js.map +1 -0
- package/lib/module/subtle.js +927 -276
- package/lib/module/subtle.js.map +1 -1
- package/lib/module/utils/conversion.js +51 -19
- package/lib/module/utils/conversion.js.map +1 -1
- package/lib/module/utils/errors.js +61 -4
- package/lib/module/utils/errors.js.map +1 -1
- package/lib/module/utils/types.js.map +1 -1
- package/lib/module/utils/validation.js +44 -0
- package/lib/module/utils/validation.js.map +1 -1
- package/lib/typescript/dhKeyPair.d.ts.map +1 -1
- package/lib/typescript/dsa.d.ts.map +1 -1
- package/lib/typescript/ec.d.ts.map +1 -1
- package/lib/typescript/ed.d.ts.map +1 -1
- package/lib/typescript/hash.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +12 -7
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/keys/classes.d.ts +10 -1
- package/lib/typescript/keys/classes.d.ts.map +1 -1
- package/lib/typescript/keys/generateKeyPair.d.ts +12 -1
- package/lib/typescript/keys/generateKeyPair.d.ts.map +1 -1
- package/lib/typescript/keys/index.d.ts +3 -1
- package/lib/typescript/keys/index.d.ts.map +1 -1
- package/lib/typescript/keys/signVerify.d.ts.map +1 -1
- package/lib/typescript/keys/utils.d.ts +21 -4
- package/lib/typescript/keys/utils.d.ts.map +1 -1
- package/lib/typescript/random.d.ts +5 -1
- package/lib/typescript/random.d.ts.map +1 -1
- package/lib/typescript/rsa.d.ts.map +1 -1
- package/lib/typescript/slhdsa.d.ts +19 -0
- package/lib/typescript/slhdsa.d.ts.map +1 -0
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts +9 -0
- package/lib/typescript/specs/keyObjectHandle.nitro.d.ts.map +1 -1
- package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts +16 -0
- package/lib/typescript/specs/slhDsaKeyPair.nitro.d.ts.map +1 -0
- package/lib/typescript/specs/turboshake.nitro.d.ts +11 -0
- package/lib/typescript/specs/turboshake.nitro.d.ts.map +1 -0
- package/lib/typescript/subtle.d.ts +3 -2
- package/lib/typescript/subtle.d.ts.map +1 -1
- package/lib/typescript/utils/conversion.d.ts +4 -3
- package/lib/typescript/utils/conversion.d.ts.map +1 -1
- package/lib/typescript/utils/errors.d.ts +12 -0
- package/lib/typescript/utils/errors.d.ts.map +1 -1
- package/lib/typescript/utils/types.d.ts +32 -15
- package/lib/typescript/utils/types.d.ts.map +1 -1
- package/lib/typescript/utils/validation.d.ts +3 -1
- package/lib/typescript/utils/validation.d.ts.map +1 -1
- package/nitrogen/generated/android/QuickCrypto+autolinking.cmake +2 -0
- package/nitrogen/generated/android/QuickCryptoOnLoad.cpp +20 -0
- package/nitrogen/generated/ios/QuickCryptoAutolinking.mm +20 -0
- package/nitrogen/generated/shared/c++/AsymmetricKeyType.hpp +48 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.cpp +9 -0
- package/nitrogen/generated/shared/c++/HybridKeyObjectHandleSpec.hpp +9 -0
- package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.cpp +29 -0
- package/nitrogen/generated/shared/c++/HybridSlhDsaKeyPairSpec.hpp +72 -0
- package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridTurboShakeSpec.hpp +70 -0
- package/nitrogen/generated/shared/c++/JWK.hpp +9 -1
- package/nitrogen/generated/shared/c++/JWKkty.hpp +4 -0
- package/nitrogen/generated/shared/c++/KangarooTwelveVariant.hpp +76 -0
- package/nitrogen/generated/shared/c++/TurboShakeVariant.hpp +76 -0
- package/package.json +2 -3
- package/src/dhKeyPair.ts +8 -0
- package/src/dsa.ts +8 -0
- package/src/ec.ts +52 -29
- package/src/ed.ts +95 -16
- package/src/hash.ts +108 -5
- package/src/keys/classes.ts +46 -5
- package/src/keys/generateKeyPair.ts +151 -5
- package/src/keys/index.ts +73 -3
- package/src/keys/signVerify.ts +13 -2
- package/src/keys/utils.ts +78 -5
- package/src/random.ts +93 -9
- package/src/rsa.ts +8 -0
- package/src/slhdsa.ts +146 -0
- package/src/specs/keyObjectHandle.nitro.ts +17 -0
- package/src/specs/slhDsaKeyPair.nitro.ts +29 -0
- package/src/specs/turboshake.nitro.ts +21 -0
- package/src/subtle.ts +1191 -360
- package/src/utils/conversion.ts +72 -21
- package/src/utils/errors.ts +72 -4
- package/src/utils/types.ts +80 -15
- package/src/utils/validation.ts +70 -1
package/lib/module/hash.js
CHANGED
|
@@ -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
|
-
|
|
203
|
-
|
|
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.
|
|
206
|
-
throw lazyDOMException('Unsupported CShakeParams
|
|
208
|
+
if (algorithm.outputLength % 8) {
|
|
209
|
+
throw lazyDOMException('Unsupported CShakeParams outputLength', 'NotSupportedError');
|
|
207
210
|
}
|
|
208
|
-
return internalDigest(algorithm, data, algorithm.
|
|
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 ? {
|
package/lib/module/hash.js.map
CHANGED
|
@@ -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":";;AAAA,SAASA,MAAM,QAAQ,iBAAiB;AACxC,SAASC,YAAY,QAAQ,4BAA4B;AAEzD,SAASC,MAAM,QAAQ,gCAAgC;
|
|
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":"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","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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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":";;AAAA,SAASA,MAAM,QAAQ,
|
|
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 {
|
|
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","
|
|
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":[]}
|
package/lib/module/keys/index.js
CHANGED
|
@@ -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
|
|
81
|
-
|
|
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);
|
|
@@ -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","NitroModules","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","KeyType","randomBytes","
|
|
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","isRawFormat","format","createPublicKeyFromRaw","input","Error","asymmetricKeyType","namedCurve","handle","createHybridObject","initRawPublic","key","createPrivateKeyFromRaw","initRawSeed","initRawPrivate","createSecretKey","keyBuffer","createKeyObject","prepareAsymmetricKey","isPublic","type","exported","exportKey","DER","SPKI","data","PKCS8","cryptoKey","keyObject","isPem","includes","undefined","keyObj","filteredFormat","createPublicKey","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":[]}
|
|
@@ -5,6 +5,7 @@ import { NitroModules } from 'react-native-nitro-modules';
|
|
|
5
5
|
import { KeyObject } from './classes';
|
|
6
6
|
import { isCryptoKey } from './utils';
|
|
7
7
|
import { binaryLikeToArrayBuffer as toAB, isStringOrBuffer, KFormatType, KeyEncoding } from '../utils';
|
|
8
|
+
import { constants } from '../constants';
|
|
8
9
|
function prepareKey(key, isPublic) {
|
|
9
10
|
// Already a KeyObject
|
|
10
11
|
if (key instanceof KeyObject) {
|
|
@@ -106,6 +107,12 @@ function dsaEncodingToNumber(dsaEncoding) {
|
|
|
106
107
|
if (dsaEncoding === 'ieee-p1363') return 1;
|
|
107
108
|
return undefined;
|
|
108
109
|
}
|
|
110
|
+
function getSaltLength(options) {
|
|
111
|
+
if (options?.padding === constants.RSA_PKCS1_PSS_PADDING && options?.saltLength === undefined) {
|
|
112
|
+
return constants.RSA_PSS_SALTLEN_MAX_SIGN;
|
|
113
|
+
}
|
|
114
|
+
return options?.saltLength;
|
|
115
|
+
}
|
|
109
116
|
export class Sign {
|
|
110
117
|
constructor(algorithm) {
|
|
111
118
|
this.handle = NitroModules.createHybridObject('SignHandle');
|
|
@@ -124,7 +131,7 @@ export class Sign {
|
|
|
124
131
|
keyObject,
|
|
125
132
|
options
|
|
126
133
|
} = prepareKey(privateKey, false);
|
|
127
|
-
const signature = this.handle.sign(keyObject.handle, options?.padding, options
|
|
134
|
+
const signature = this.handle.sign(keyObject.handle, options?.padding, getSaltLength(options), dsaEncodingToNumber(options?.dsaEncoding));
|
|
128
135
|
const buf = Buffer.from(signature);
|
|
129
136
|
if (outputEncoding) {
|
|
130
137
|
return buf.toString(outputEncoding);
|
|
@@ -158,7 +165,7 @@ export class Verify {
|
|
|
158
165
|
} else {
|
|
159
166
|
sigBuffer = toAB(signature);
|
|
160
167
|
}
|
|
161
|
-
return this.handle.verify(keyObject.handle, sigBuffer, options?.padding, options
|
|
168
|
+
return this.handle.verify(keyObject.handle, sigBuffer, options?.padding, getSaltLength(options), dsaEncodingToNumber(options?.dsaEncoding));
|
|
162
169
|
}
|
|
163
170
|
}
|
|
164
171
|
export function createSign(algorithm) {
|
|
@@ -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","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":";;AAAA,SAASA,MAAM,QAAQ,gCAAgC;AACvD,SAASC,YAAY,QAAQ,4BAA4B;AAKzD,SAASC,SAAS,QAAmB,WAAW;AAChD,SAASC,WAAW,QAAQ,SAAS;AAErC,SACEC,uBAAuB,IAAIC,IAAI,EAC/BC,gBAAgB,EAChBC,WAAW,EACXC,WAAW,QACN,UAAU;
|
|
1
|
+
{"version":3,"names":["Buffer","NitroModules","KeyObject","isCryptoKey","binaryLikeToArrayBuffer","toAB","isStringOrBuffer","KFormatType","KeyEncoding","constants","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","getSaltLength","RSA_PKCS1_PSS_PADDING","RSA_PSS_SALTLEN_MAX_SIGN","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":[]}
|