2017-10-25 20:20:05 -04:00
/ * *
* Incomplete -- Provider - engine needs its own typings
* /
declare module 'ethereumjs-wallet/provider-engine' {
import { IPublicKeyOnlyWallet , IFullWallet } from 'ethereumjs-wallet' ;
class WalletSubprovider {
constructor ( wallet : IPublicKeyOnlyWallet | IFullWallet , opts? : object ) ;
}
}
2017-10-27 16:30:06 -04:00
declare module 'ethereumjs-wallet/thirdparty' {
import {
IPublicKeyOnlyWallet ,
IFullWallet ,
IEtherWalletLocked ,
IEtherWalletUnlocked
} from 'ethereumjs-wallet' ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a brain wallet used by Ether . Camp
* @param input
* @param password
* /
2017-10-27 16:30:06 -04:00
function fromEtherCamp ( passphrase : string ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a wallet generated by EtherWallet
* @param input
* @param password
* /
2017-10-27 16:30:06 -04:00
function fromEtherWallet (
input : IEtherWalletLocked | IEtherWalletUnlocked | string ,
password : string
) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a wallet from a KryptoKit seed
* @param entropy
* @param seed
* /
2017-10-27 16:30:06 -04:00
function fromKryptoKit ( entropy : string , seed : string ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a brain wallet used by Quorum Wallet
* @param passphrase
* @param userid
* /
2017-10-27 16:30:06 -04:00
function fromQuorumWallet ( passphrase : string , userid : string ) : IFullWallet ;
}
2017-10-25 20:20:05 -04:00
declare module 'ethereumjs-wallet/hdkey' {
import { Buffer } from 'buffer' ;
import { IPublicKeyOnlyWallet , IFullWallet } from 'ethereumjs-wallet' ;
interface IHDNodePublic {
/ * *
* @description return a BIP32 extended public key ( xpub )
* /
publicExtendedKey ( ) : string ;
/ * *
* @description derive a node based on a path ( e . g . m / 44 '/0' / 0 / 1 )
* /
derivePath ( path : string ) : IHDNodePublic ;
/ * *
* @description derive a node based on a child index
* /
2018-03-07 18:36:05 -05:00
deriveChild ( index : any ) : IHDNodePublic ;
2017-10-25 20:20:05 -04:00
/ * *
2017-11-29 15:14:57 -08:00
* @description return a Wallet instance
2017-10-25 20:20:05 -04:00
* /
getWallet ( ) : IPublicKeyOnlyWallet ;
}
/ * *
2017-11-29 15:14:57 -08:00
*
*
2017-10-25 20:20:05 -04:00
* @interface IHDNodePrivate
* /
interface IHDNodePrivate {
/ * *
* @description return a BIP32 extended private key ( xprv )
* /
privateExtendedKey ( ) : string ;
/ * *
* @description return a BIP32 extended public key ( xpub )
* /
publicExtendedKey ( ) : string ;
/ * *
* @description derive a node based on a path ( e . g . m / 44 '/0' / 0 / 1 )
* /
derivePath ( path : string ) : IHDNodePrivate | IHDNodePublic ;
/ * *
* @description derive a node based on a child index
* /
2018-03-07 18:36:05 -05:00
deriveChild ( index : any ) : IHDNodePrivate | IHDNodePublic ;
2017-10-25 20:20:05 -04:00
/ * *
2017-11-29 15:14:57 -08:00
* @description return a Wallet instance
2017-10-25 20:20:05 -04:00
* /
getWallet ( ) : IFullWallet ;
}
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a seed
* /
2017-10-25 20:20:05 -04:00
function fromMasterSeed ( seed : Buffer ) : IHDNodePrivate ;
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a BIP32 extended private or public key
* /
2017-10-25 20:20:05 -04:00
function fromExtendedKey ( key : string ) : IHDNodePrivate | IHDNodePublic ;
}
declare module 'ethereumjs-wallet' {
import { Buffer } from 'buffer' ;
interface IPresaleWallet {
encseed : string ;
ethaddr : string ;
btcaddr : string ;
email : string ;
}
interface IKdfParams {
dklen : number ;
salt : string ; // Random salt for the kdf. Size must match the requirements of the KDF (key derivation function). Random number generated via crypto.getRandomBytes if nothing is supplied.
}
interface IScryptKdfParams extends IKdfParams {
n : number ; // Iteration count. Defaults to 262144.
r : number ; // Block size for the underlying hash. Defaults to 8.
p : number ; // Parallelization factor. Defaults to 1.
}
interface IPbkdf2KdfParams extends IKdfParams {
prf : 'hmac-sha256' ;
c : number ;
}
interface IV1Wallet {
Version : 1 ;
Crypto : {
KeyHeader : {
Kdf : 'scrypt' ;
KdfParams : {
N : number ;
R : number ;
P : number ;
DkLen : number ;
} ;
} ;
MAC : string ;
CipherText : string ;
Salt : string ;
IV : string ;
} ;
}
interface IV3Wallet {
version : 3 ;
id : string ;
address : string ;
2018-02-02 01:01:30 -05:00
crypto : {
2017-10-25 20:20:05 -04:00
ciphertext : string ;
2018-02-02 01:01:30 -05:00
cipherparams : {
2017-10-25 20:20:05 -04:00
iv : string ;
} ;
cipher : string | 'aes-128-ctr' ;
kdf : 'scrypt' | 'pbkdf2' ;
2018-02-02 01:01:30 -05:00
kdfparams : IScryptKdfParams | IPbkdf2KdfParams ;
2017-10-25 20:20:05 -04:00
mac : string ;
} ;
}
interface IEtherWalletLocked {
private : string ;
encrypted : true ;
address : string ;
locked : true ;
}
interface IEtherWalletUnlocked {
private : string ;
locked : false ;
encrypted : false ;
address : string ;
}
interface IV3Options {
salt? : Buffer ; // Random salt for the kdf. Size must match the requirements of the KDF (key derivation function). Random number generated via crypto.getRandomBytes if nothing is supplied.
iv? : Buffer ; // Initialization vector for the cipher. Size must match the requirements of the cipher. Random number generated via crypto.getRandomBytes if nothing is supplied.
kdf? : string ; // The key derivation function, see below.
dklen? : number ; // Derived key length. For certain cipher settings, this must match the block sizes of those.
uuid? : Buffer ; // UUID. One is randomly generated.
cipher? : string | 'aes-128-ctr' | 'aes-128-cbc' ; // The cipher to use. Names must match those of supported by OpenSSL, e.g. aes-128-ctr or aes-128-cbc.
/* pbkdf2 */
c? : number ; // Number of iterations. Defaults to 262144.
/* scrypt */
n? : number ; // Iteration count. Defaults to 262144.
r? : number ; // Block size for the underlying hash. Defaults to 8.
p? : number ; // Parallelization factor. Defaults to 1.
}
class IPublicKeyOnlyWallet {
_pubKey : string ;
/ * *
* @description return the public key
* /
getPublicKey ( ) : Buffer ; //only returns uncompressed Ethereum-style public keys.
/ * *
* @description return the public key
* /
getPublicKeyString ( ) : string ;
/ * *
* @description return the address
* /
getAddress ( ) : Buffer ;
/ * *
2017-11-29 15:14:57 -08:00
*
2017-10-25 20:20:05 -04:00
* @description return the address
* /
getAddressString ( ) : string ;
/ * *
* @description return the address with checksum
* /
getChecksumAddressString ( ) : string ;
/ * *
* @description return the suggested filename for V3 keystores
* /
getV3Filename ( timestamp? : number ) : string ;
}
class IFullWallet extends IPublicKeyOnlyWallet {
_privKey : string ;
/ * *
* @description return the private key
* /
getPrivateKey ( ) : Buffer ;
/ * *
* @description return the private key
* /
getPrivateKeyString ( ) : string ;
/ * *
* @description return the wallet as a JSON string ( Version 3 of the Ethereum wallet format )
* /
toV3 ( password : string , options? : IV3Options ) : IV3Wallet ;
}
/ * *
2017-11-29 15:14:57 -08:00
*
* @param icap
* @description create an instance based on a new random key ( setting icap to true will generate an address suitable for the ICAP Direct mode
* /
2017-10-25 20:20:05 -04:00
function generate ( icap? : boolean ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
*
* @param pattern
* @description create an instance where the address is valid against the supplied pattern ( this will be very slow )
* /
2017-10-25 20:20:05 -04:00
function generateVanityAddress ( pattern : string | RegExp ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a raw private key
* @param input
*
* /
2017-10-25 20:20:05 -04:00
function fromPrivateKey ( input : Buffer ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a BIP32 extended private key ( xprv )
* @param input
* /
2017-10-25 20:20:05 -04:00
function fromExtendedPrivateKey ( input : Buffer ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a public key ( certain methods will not be available )
* @param input
* @param nonStrict
* /
2017-12-18 18:29:26 -05:00
function fromPublicKey ( input : Buffer , nonStrict? : boolean ) : IPublicKeyOnlyWallet ;
2017-10-25 20:20:05 -04:00
/ * *
2017-11-29 15:14:57 -08:00
* @description create an instance based on a BIP32 extended public key ( xpub )
* @param input
* /
2017-10-25 20:20:05 -04:00
function fromExtendedPublicKey ( input : string ) : IPublicKeyOnlyWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a wallet ( Version 1 of the Ethereum wallet format )
* @param input
* @param password
* /
2017-10-25 20:20:05 -04:00
function fromV1 ( input : IV1Wallet | string , password : string ) : IFullWallet ;
/ * *
2017-11-29 15:14:57 -08:00
* @description import a wallet ( Version 3 of the Ethereum wallet format ) . Set nonStrict true to accept files with mixed - caps .
* @param input
* @param password
* @param nonStrict
* /
2017-12-18 18:29:26 -05:00
function fromV3 ( input : IV3Wallet | string , password : string , nonStrict : boolean ) : IFullWallet ;
2017-10-25 20:20:05 -04:00
/ * *
2017-11-29 15:14:57 -08:00
* @description import an Ethereum Pre Sale wallet
* @param input
* @param password
* /
2017-12-18 18:29:26 -05:00
function fromEthSale ( input : IPresaleWallet | string , password : string ) : IFullWallet ;
2017-10-25 20:20:05 -04:00
}