///
///
declare namespace NodeWebcryptoOpenSSL {
type NodeBufferSource = BufferSource | Buffer;
enum EcNamedCurves {
secp112r1 = 704,
secp112r2 = 705,
secp128r1 = 706,
secp128r2 = 707,
secp160k1 = 708,
secp160r1 = 709,
secp160r2 = 710,
secp192r1 = 409,
secp192k1 = 711,
secp224k1 = 712,
secp224r1 = 713,
secp256k1 = 714,
secp256r1 = 415,
secp384r1 = 715,
secp521r1 = 716,
sect113r1 = 717,
sect113r2 = 718,
sect131r1 = 719,
sect131r2 = 720,
sect163k1 = 721,
sect163r1 = 722,
sect163r2 = 723,
sect193r1 = 724,
sect193r2 = 725,
sect233k1 = 726,
sect233r1 = 727,
sect239k1 = 728,
sect283k1 = 729,
sect283r1 = 730,
sect409k1 = 731,
sect409r1 = 732,
sect571k1 = 733,
sect571r1 = 734,
}
enum RsaPublicExponent {
RSA_3 = 0,
RSA_F4 = 1,
}
enum KeyType {
PUBLIC = 0,
PRIVATE = 1,
}
class Key {
type: number;
modulusLength(): number;
publicExponent(): Buffer;
exportJwk(keyType: KeyType, callback: (err: Error, jwk: any) => void): void;
exportJwk(keyType: KeyType): any;
exportSpki(callback: (err: Error, raw: Buffer) => void): void;
exportPkcs8(callback: (err: Error, raw: Buffer) => void): void;
sign(digestName: string, message: Buffer, callback: (err: Error, signature: Buffer) => void): void;
verify(digestName: string, message: Buffer, signature: Buffer, callback: (err: Error, valid: boolean) => void): void;
RsaOaepEncDec(digestName: string, data: Buffer, label: Buffer | null, decrypt: boolean, callback: (err: Error, raw: Buffer) => void): void;
RsaPssSign(digestName: string, saltLength: number, data: Buffer, cb: (err: Error, signature: Buffer) => void): void;
RsaPssVerify(digestName: string, saltLength: number, data: Buffer, signature: Buffer, cb: (err: Error, verified: boolean) => void): void;
EcdhDeriveKey(pubkey: Key, derivedLen: number, callback: (err: Error, raw: Buffer) => void): void;
EcdhDeriveBits(pubkey: Key, lengthBits: number, callback: (err: Error, raw: Buffer) => void): void;
static generateRsa(modulus: number, publicExponent: RsaPublicExponent, callback: (err: Error, key: Key) => void): void;
static generateEc(namedCurve: EcNamedCurves, callback: (err: Error, key: Key) => void): void;
static importJwk(jwk: Object, keyType: KeyType, callback: (err: Error, key: Key) => void): void;
static importJwk(jwk: {
[key: string]: Buffer;
}, keyType: KeyType): any;
static importSpki(raw: Buffer, callback: (err: Error, key: Key) => void): void;
static importPkcs8(raw: Buffer, callback: (err: Error, key: Key) => void): void;
}
class AesKey {
static generate(keySize: number, callback: (err: Error, key: AesKey) => void): void;
encrypt(cipher: string, iv: Buffer, input: Buffer, callback: (err: Error, data: Buffer) => void): void;
encryptGcm(iv: Buffer, input: Buffer, aad: Buffer | undefined, tag: number, callback: (err: Error, data: Buffer) => void): void;
decrypt(cipher: string, iv: Buffer, input: Buffer, callback: (err: Error, data: Buffer) => void): void;
decryptGcm(iv: Buffer, input: Buffer, aad: Buffer | undefined, tag: number, callback: (err: Error, data: Buffer) => void): void;
export(callback: (err: Error, raw: Buffer) => void): void;
static import(raw: Buffer, callback: (err: Error, key: AesKey) => void): void;
}
class Core {
static digest(digestName: string, messgae: Buffer, callback: (err: Error, digest: Buffer) => void): void;
}
interface CryptoKeyPair extends NativeCryptoKeyPair {
privateKey: CryptoKey;
publicKey: CryptoKey;
}
class CryptoKey implements NativeCryptoKey {
type: string;
extractable: boolean;
algorithm: Algorithm;
usages: string[];
private native_: AesKey | Key;
readonly native: AesKey | Key;
constructor(key: AesKey | Key, alg: Algorithm, type: string, extractable: boolean, keyUsages: string[]);
}
interface IKeyStorageItem extends NativeCryptoKey {
name: string;
keyJwk: any;
file?: string;
}
class KeyStorage {
protected directory: string;
protected keys: {
[key: string]: IKeyStorageItem;
};
constructor(directory: string);
protected createDirectory(directory: string, flags?: any): void;
protected readFile(file: string): IKeyStorageItem | null;
protected readDirectory(): void;
protected saveFile(key: IKeyStorageItem): void;
protected removeFile(key: IKeyStorageItem): void;
readonly length: number;
clear(): void;
protected getItemById(id: string): IKeyStorageItem;
getItem(key: string): CryptoKey | null;
key(index: number): string;
removeItem(key: string): void;
setItem(key: string, data: CryptoKey): void;
}
interface WebCryptoOptions {
directory?: string;
}
class SubtleCrypto extends WebcryptoCore.SubtleCrypto {
digest(algorithm: AlgorithmIdentifier, data: NodeBufferSource): PromiseLike;
generateKey(algorithm: string, extractable: boolean, keyUsages: string[]): PromiseLike;
generateKey(algorithm: RsaHashedKeyGenParams | EcKeyGenParams | DhKeyGenParams, extractable: boolean, keyUsages: string[]): PromiseLike;
generateKey(algorithm: AesKeyGenParams | HmacKeyGenParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike;
sign(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, data: NodeBufferSource): PromiseLike;
verify(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, signature: NodeBufferSource, data: NodeBufferSource): PromiseLike;
encrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: NodeBufferSource): PromiseLike;
decrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: NodeBufferSource): PromiseLike;
wrapKey(format: string, key: CryptoKey, wrappingKey: CryptoKey, wrapAlgorithm: AlgorithmIdentifier): PromiseLike;
unwrapKey(format: string, wrappedKey: NodeBufferSource, unwrappingKey: CryptoKey, unwrapAlgorithm: AlgorithmIdentifier, unwrappedKeyAlgorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: string[]): PromiseLike;
deriveKey(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, derivedKeyType: string | AesDerivedKeyParams | HmacImportParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike;
deriveBits(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, length: number): PromiseLike;
exportKey(format: "jwk", key: CryptoKey): PromiseLike;
exportKey(format: "raw" | "pkcs8" | "spki", key: CryptoKey): PromiseLike;
exportKey(format: string, key: CryptoKey): PromiseLike;
importKey(format: "jwk", keyData: JsonWebKey, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike;
importKey(format: "raw" | "pkcs8" | "spki", keyData: NodeBufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike;
importKey(format: string, keyData: JsonWebKey | NodeBufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike;
}
/**
* OpenSSL with WebCrypto Interface
*/
class WebCrypto implements NativeCrypto {
keyStorage: KeyStorage;
subtle: SubtleCrypto;
/**
* Generates cryptographically random values
* @param array Initialize array
*/
getRandomValues(array: NodeBufferSource): NodeBufferSource;
getRandomValues(array: ArrayBufferView): ArrayBufferView;
/**
* Constructor
*/
constructor(options?: WebCryptoOptions);
}
}
declare module "tresorit-node-webcrypto-ossl" {
export = NodeWebcryptoOpenSSL.WebCrypto;
}