mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 12:04:21 +00:00
414 lines
12 KiB
TypeScript
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;
|
|
}
|