@logsn/arweave
Version:
Arweave JS client library
35 lines (34 loc) • 1.47 kB
TypeScript
/// <reference types="node" />
import { JWKInterface } from "../wallet";
import CryptoInterface, { SignatureOptions } from "./crypto-interface";
export default class NodeCryptoDriver implements CryptoInterface {
readonly keyLength = 4096;
readonly publicExponent = 65537;
readonly hashAlgorithm = "sha256";
readonly encryptionAlgorithm = "aes-256-cbc";
generateJWK(): Promise<JWKInterface>;
sign(jwk: object, data: Uint8Array, { saltLength }?: SignatureOptions): Promise<Uint8Array>;
verify(publicModulus: string, data: Uint8Array, signature: Uint8Array): Promise<boolean>;
hash(data: Uint8Array, algorithm?: string): Promise<Uint8Array>;
/**
* If a key is passed as a buffer it *must* be exactly 32 bytes.
* If a key is passed as a string then any length may be used.
*
* @param {Buffer} data
* @param {(string | Buffer)} key
* @returns {Promise<Uint8Array>}
*/
encrypt(data: Buffer, key: string | Buffer, salt?: string): Promise<Uint8Array>;
/**
* If a key is passed as a buffer it *must* be exactly 32 bytes.
* If a key is passed as a string then any length may be used.
*
* @param {Buffer} encrypted
* @param {(string | Buffer)} key
* @returns {Promise<Uint8Array>}
*/
decrypt(encrypted: Buffer, key: string | Buffer, salt?: string): Promise<Uint8Array>;
jwkToPem(jwk: object): string;
private pemToJWK;
private parseHashAlgorithm;
}