MyCrypto/common/typescript/ethereumjs-util.d.ts

414 lines
12 KiB
TypeScript

declare module 'ethereumjs-util' {
import { Buffer } from 'buffer';
import BN from 'bn.js';
export import rlp = require('rlp');
export * from 'ethjs-util';
//TODO: missing types for secp256k1, defineProperties, isZeroAddress, ethjs-util package
interface Signature {
v: number;
r: Buffer;
s: Buffer;
}
export const MAX_INTEGER: BN;
export const TWO_POW256: BN;
export const SHA3_NULL_S: string;
export const SHA3_NULL: Buffer;
export const SHA3_RLP_ARRAY_S: string;
export const SHA3_RLP_ARRAY: Buffer;
export const SHA3_RLP_S: string;
export const SHA3_RLP: Buffer;
/**
*
* @description Returns a buffer filled with 0s
* @export
* @param {number} bytes the number of bytes the buffer should be
* @returns {Buffer}
*/
export function zeros(bytes: number): Buffer;
/**
*
* @description
* @export
* @param {Buffer} msg the value to pad
* @param {number} length the number of bytes the output should be
* @param {boolean} right whether to start padding form the left or right (optional, default false)
* @returns {Buffer}
*/
export function setLength(msg: Buffer, length: number, right: boolean): Buffer;
/**
*
* @description
* @export
* @param {number[]} msg the value to pad
* @param {number} length the number of bytes the output should be
* @param {boolean} right whether to start padding form the left or right (optional, default false)
* @returns {number[]}
*/
export function setLength(msg: number[], length: number, right: boolean): number[];
/**
*
* @description Left Pads an Array or Buffer with leading zeros till it has length bytes. Or it truncates the beginning if it exceeds.
* @export
* @param {Buffer} msg the value to pad
* @param {number} length the number of bytes the output should be
* @param {boolean} right whether to start padding form the left or right (optional, default false)
* @returns {Buffer}
*/
export function setLengthLeft(msg: Buffer, length: number, right: boolean): Buffer;
/**
*
* @description
* @export
* @param {number[]} msg he value to pad
* @param {number} length the number of bytes the output should be
* @param {boolean} right whether to start padding form the left or right (optional, default false)
* @returns {number[]}
*/
export function setLengthLeft(msg: number[], length: number, right: boolean): number[];
/**
*
* @description Right Pads an Array or Buffer with leading zeros till it has length bytes. Or it truncates the beginning if it exceeds.
* @export
* @param {Buffer} msg the value to pad
* @param {number} length the number of bytes the output should be
* @returns {Buffer}
*/
export function setLengthRight(msg: Buffer, length: number): Buffer;
/**
*
* @description Right Pads an Array or Buffer with leading zeros till it has length bytes. Or it truncates the beginning if it exceeds.
* @export
* @param {number[]} msg the value to pad
* @param {number} length the number of bytes the output should be
* @returns {number[]}
*/
export function setLengthRight(msg: number[], length: number): number[];
/**
*
* @description Trims leading zeros from a Buffer or an Array
* @export
* @param {Buffer} a
* @returns {Buffer}
*/
export function unpad(a: Buffer): Buffer;
/**
*
* @description Trims leading zeros from a Buffer or an Array
* @export
* @param {number[]} a
* @returns {number[]}
*/
export function unpad(a: number[]): number[];
/**
*
* @description Trims leading zeros from a Buffer or an Array
* @export
* @param {string} a
* @returns {string}
*/
export function unpad(a: string): string;
/**
*
* @description Attempts to turn a value into a Buffer. As input it supports Buffer, String, Number, null/undefined, BN and other objects with a toArray() method.
* @export
* @param {*} v the value
* @returns {Buffer}
*/
export function toBuffer(v: any): Buffer;
/**
*
* @description Converts a Buffer to a Number
* @export
* @param {(Buffer | BN)} buf
* @returns {number}
*/
export function bufferToInt(buf: Buffer | BN): number;
/**
*
* @description Converts a Buffer into a hex String
* @export
* @param {(Buffer | BN)} buf
* @returns {string}
*/
export function bufferToHex(buf: Buffer | BN): string;
/**
*
* @description Interprets a Buffer as a signed integer and returns a BN. Assumes 256-bit numbers.
* @export
* @param {(Buffer | BN)} num
* @returns {BN}
*/
export function fromSigned(num: Buffer | BN): BN;
/**
*
* @description Converts a BN to an unsigned integer and returns it as a Buffer. Assumes 256-bit numbers.
* @export
* @param {BN} num
* @returns {Buffer}
*/
export function toUnsigned(num: BN): Buffer;
/**
*
* @description Creates SHA-3 hash of the input
* @export
* @param {(Buffer | string | number | number[])} a the input data
* @param {number} [bits] the SHA width (optional, default 256)
* @returns {Buffer}
*/
export function sha3(a: Buffer | string | number | number[], bits?: number): Buffer;
/**
*
* @description Creates SHA256 hash of the input
* @export
* @param {(Buffer | string | number | number[])} a the input data
* @returns {Buffer}
*/
export function sha256(a: Buffer | string | number | number[]): Buffer;
/**
*
* @description Creates RIPEMD160 hash of the input
* @export
* @param {(Buffer | string | number | number[])} a the input data
* @param {boolean} [padded] whether it should be padded to 256 bits or not
* @returns {Buffer}
*/
export function ripemd160(a: Buffer | string | number | number[], padded?: boolean): Buffer;
/**
*
* @description Creates SHA-3 hash of the RLP encoded version of the input
* @export
* @param {(Buffer | string | number | number[])} a the input data
* @returns {Buffer}
*/
export function rlphash(a: Buffer | string | number | number[]): Buffer;
/**
*
* @description Checks if the private key satisfies the rules of the curve secp256k1.
* @export
* @param {Buffer} privateKey
* @returns {boolean}
*/
export function isValidPrivate(privateKey: Buffer): boolean;
/**
*
* @description Checks if the public key satisfies the rules of the curve secp256k1 and the requirements of Ethereum.
* @export
* @param {Buffer} publicKey The two points of an uncompressed key, unless sanitize is enabled
* @param {boolean} [sanitize] Accept public keys in other formats (optional, default false)
* @returns {boolean}
*/
export function isValidPublic(publicKey: Buffer, sanitize?: boolean): boolean;
/**
*
* @description Returns the ethereum address of a given public key. Accepts "Ethereum public keys" and SEC1 encoded keys.
* @export
* @param {Buffer} publicKey The two points of an uncompressed key, unless sanitize is enabled
* @param {boolean} [sanitize] Accept public keys in other formats (optional, default false)
* @returns {Buffer}
*/
export function pubToAddress(publicKey: Buffer, sanitize?: boolean): Buffer;
/**
*
* @description Returns the ethereum address of a given public key. Accepts "Ethereum public keys" and SEC1 encoded keys.
* @export
* @param {Buffer} publicKey The two points of an uncompressed key, unless sanitize is enabled
* @param {boolean} [sanitize] Accept public keys in other formats (optional, default false)
* @returns {Buffer}
*/
export function publicToAddress(publicKey: Buffer, sanitize?: boolean): Buffer;
/**
*
* @description the max integer that this VM can handle (a BN)
* @export
* @param {Buffer} privateKey
* @returns {Buffer}
*/
export function privateToPublic(privateKey: Buffer): Buffer;
/**
*
* @description Converts a public key to the Ethereum format.
* @export
* @param {Buffer} publicKey
* @returns {Buffer}
*/
export function importPublic(publicKey: Buffer): Buffer;
/**
*
* @description ECDSA sign
* @export
* @param {Buffer} message
* @param {Buffer} privateKey
* @returns {Signature}
*/
export function ecsign(message: Buffer, privateKey: Buffer): Signature;
/**
*
* @description Returns the keccak-256 hash of message, prefixed with the header used by the eth_sign RPC call. The output of this function can be fed into ecsign to produce the same signature as the eth_sign call for a given message, or fed to ecrecover along with a signature to recover the public key used to produce the signature.
* @export
* @param {(Buffer | string)} message
* @returns {Buffer}
*/
export function hashPersonalMessage(message: Buffer | string): Buffer;
/**
*
* @description ECDSA public key recovery from signature
* @export
* @param {Buffer} msgHash
* @param {number} v
* @param {Buffer} r
* @param {Buffer} s
* @returns {Buffer}
*/
export function ecrecover(msgHash: Buffer, v: number, r: Buffer, s: Buffer): Buffer;
/**
*
* @description Convert signature parameters into the format of eth_sign RPC method
* @export
* @param {number} v
* @param {Buffer} r
* @param {Buffer} s
* @returns {string}
*/
export function toRpcSig(v: number, r: Buffer, s: Buffer): string;
/**
*
* @description Convert signature format of the eth_sign RPC method to signature parameters NOTE: all because of a bug in geth: https://github.com/ethereum/go-ethereum/issues/2053
* @export
* @param {string} sig
* @returns {Signature}
*/
export function fromRpcSig(sig: string): Signature;
/**
*
* @description Returns the ethereum address of a given private key
* @export
* @param {Buffer} privateKey A private key must be 256 bits wide
* @returns {Buffer}
*/
export function privateToAddress(privateKey: Buffer): Buffer;
/**
*
* @description Checks if the address is a valid. Accepts checksummed addresses too
* @export
* @param {string} address
* @returns {boolean}
*/
export function isValidAddress(address: string): boolean;
/**
*
* @description Returns a checksummed address
* @export
* @param {string} address
* @returns {string}
*/
export function toChecksumAddress(address: string): string;
/**
*
* @description Checks if the address is a valid checksummed address
* @export
* @param {string} address
* @returns {boolean}
*/
export function isValidChecksumAddress(address: string): boolean;
/**
*
* @description Generates an address of a newly created contract
* @export
* @param {(Buffer | string)} from the address which is creating this new address
* @param {(number | string | number[] | Buffer)} nonce the nonce of the from account
* @returns {Buffer}
*/
export function generateAddress(
from: Buffer | string,
nonce: number | string | number[] | Buffer
): Buffer;
/**
*
* @description Returns true if the supplied address belongs to a precompiled account
* @export
* @param {(Buffer | string)} address
* @returns {boolean}
*/
export function isPrecompiled(address: Buffer | string): boolean;
/**
*
* @description Adds "0x" to a given String if it does not already start with "0x"
* @export
* @param {string} str
* @returns {string}
*/
export function addHexPrefix(str: string): string;
/**
*
* @description Validate ECDSA signature
* @export
* @param {number} v
* @param {(Buffer | string)} r
* @param {(Buffer | string)} s
* @param {boolean} [homestead] (optional, default true)
* @returns {boolean}
*/
export function isValidSignature(
v: number,
r: Buffer | string,
s: Buffer | string,
homestead?: boolean
): boolean;
/**
*
* @description Converts a Buffer or Array to JSON
* @export
* @param {(Buffer | any[])} ba
* @returns {string}
*/
export function baToJSON(ba: Buffer | any[]): string;
}