react-native-quick-crypto
Version:
A fast implementation of Node's `crypto` module written in C/C++ JSI
75 lines (72 loc) • 2.66 kB
JavaScript
;
import { Buffer } from '@craftzdog/react-native-buffer';
import { NitroModules } from 'react-native-nitro-modules';
import { binaryLikeToArrayBuffer, normalizeHashName } from './utils';
// Lazy load native module
let native;
function getNative() {
if (native == null) {
native = NitroModules.createHybridObject('Hkdf');
}
return native;
}
function validateCallback(callback) {
if (callback === undefined || typeof callback !== 'function') {
throw new Error('No callback provided to hkdf');
}
}
function sanitizeInput(input, name) {
try {
return binaryLikeToArrayBuffer(input);
} catch {
throw new Error(`${name} must be a string, a Buffer, a typed array, or a DataView`);
}
}
export function hkdf(digest, key, salt, info, keylen, callback) {
validateCallback(callback);
try {
const normalizedDigest = normalizeHashName(digest);
const sanitizedKey = sanitizeInput(key, 'Key');
const sanitizedSalt = sanitizeInput(salt, 'Salt');
const sanitizedInfo = sanitizeInput(info, 'Info');
if (keylen < 0) {
throw new TypeError('Bad key length');
}
const nativeMod = getNative();
nativeMod.deriveKey(normalizedDigest, sanitizedKey, sanitizedSalt, sanitizedInfo, keylen).then(res => {
callback(null, Buffer.from(res));
}, err => {
callback(err);
});
} catch (err) {
callback(err);
}
}
export function hkdfSync(digest, key, salt, info, keylen) {
const normalizedDigest = normalizeHashName(digest);
const sanitizedKey = sanitizeInput(key, 'Key');
const sanitizedSalt = sanitizeInput(salt, 'Salt');
const sanitizedInfo = sanitizeInput(info, 'Info');
if (keylen < 0) {
throw new TypeError('Bad key length');
}
const nativeMod = getNative();
const result = nativeMod.deriveKeySync(normalizedDigest, sanitizedKey, sanitizedSalt, sanitizedInfo, keylen);
return Buffer.from(result);
}
export function hkdfDeriveBits(algorithm, baseKey, length) {
const hash = algorithm.hash;
const salt = algorithm.salt;
const info = algorithm.info;
// Check if key is extractable or we can access its handle/buffer
// For raw keys, we can export.
const keyBuffer = baseKey.keyObject.export();
// length is in bits, native expects bytes
const keylen = Math.ceil(length / 8);
const hashName = typeof hash === 'string' ? hash : hash.name;
const normalizedDigest = normalizeHashName(hashName);
const nativeMod = getNative();
const result = nativeMod.deriveKeySync(normalizedDigest, binaryLikeToArrayBuffer(keyBuffer), binaryLikeToArrayBuffer(salt), binaryLikeToArrayBuffer(info), keylen);
return result;
}
//# sourceMappingURL=hkdf.js.map