mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-27 11:24:46 +00:00
a00269507c
* Progress commit -- ethereumjs-wallet typings * Add hdkey module + better wallet typing * Add provider-engine typings * Add jsdoc descriptions for hdkey constructor methods * Fix missing return type * Fix another missing return * Make provider engine options optional * Add priv/pubkey members to wallet instance * Turn into SFC + Use ethereumjs-lib * Use proper interface naming for V3Wallet * Switch to ethereumjs-wallet * Switch to ethereumjs-wallet and refactor using NewTabLink * Use proper interface naming for V3Wallet * Use proper interface naming for PublicKeyOnlyWallet * Strip out wallet classes for ethereumjs-wallet, stuff wallet types in privkey for now * Seperate wallets into deterministic and non-deterministic, change IWallet and deterministic wallets to adhere to getAddressString * Fix broken test, remove scryptsy * Fix broken test, re-add scryptsy to make this PR pass * Remove uuid from deps and keystore test * Add ethereumjs-wallet to DLL * Wrap mnemonic wallet * Fix definition module for thirdparty wallets * Fix MewV1 wallet not loading due to wrong library * Fix tsc error * Decrease n-factor to 1024, checksum address of keystore * Fix isKeystorePassRequired * Fix tsc errors * Merge package lock * Update package lock * regenerate lock file * Lock typescript to 2.5.2 * Merge develop
68 lines
2.3 KiB
TypeScript
68 lines
2.3 KiB
TypeScript
import Big from 'bignumber.js';
|
|
import EthTx from 'ethereumjs-tx';
|
|
import { addHexPrefix } from 'ethereumjs-util';
|
|
import { RawTransaction } from 'libs/transaction';
|
|
import { stripHexPrefixAndLower } from 'libs/values';
|
|
import TrezorConnect from 'vendor/trezor-connect';
|
|
import { DeterministicWallet } from './deterministic';
|
|
import { IWallet } from '../IWallet';
|
|
export class TrezorWallet extends DeterministicWallet implements IWallet {
|
|
public signRawTransaction(tx: RawTransaction): Promise<string> {
|
|
return new Promise((resolve, reject) => {
|
|
(TrezorConnect as any).ethereumSignTx(
|
|
// Args
|
|
this.getPath(),
|
|
// stripHexPrefixAndLower identical to ethFuncs.getNakedAddress
|
|
stripHexPrefixAndLower(tx.nonce),
|
|
stripHexPrefixAndLower(tx.gasPrice.toString()),
|
|
stripHexPrefixAndLower(tx.gasLimit.toString()),
|
|
stripHexPrefixAndLower(tx.to),
|
|
stripHexPrefixAndLower(tx.value),
|
|
stripHexPrefixAndLower(tx.data),
|
|
tx.chainId,
|
|
// Callback
|
|
result => {
|
|
if (!result.success) {
|
|
return reject(new Error(result.error));
|
|
}
|
|
|
|
// TODO: Explain what's going on here? Add tests? Adapted from:
|
|
// https://github.com/kvhnuke/etherwallet/blob/v3.10.2.6/app/scripts/uiFuncs.js#L24
|
|
const txToSerialize = {
|
|
...tx,
|
|
v: addHexPrefix(new Big(result.v).toString(16)),
|
|
r: addHexPrefix(result.r),
|
|
s: addHexPrefix(result.s)
|
|
};
|
|
const eTx = new EthTx(txToSerialize);
|
|
const signedTx = addHexPrefix(eTx.serialize().toString('hex'));
|
|
resolve(signedTx);
|
|
}
|
|
);
|
|
});
|
|
}
|
|
|
|
public signMessage = () =>
|
|
Promise.reject(new Error('Signing via Trezor not yet supported.'));
|
|
|
|
// works, but returns a signature that can only be verified with a Trezor device
|
|
/*
|
|
public signMessage = (message: string): Promise<string> => {
|
|
return new Promise((resolve, reject) => {
|
|
(TrezorConnect as any).ethereumSignMessage(
|
|
this.getPath(),
|
|
message,
|
|
response => {
|
|
if (response.success) {
|
|
resolve(addHexPrefix(response.signature))
|
|
} else{
|
|
console.error(response.error)
|
|
reject(response.error)
|
|
}
|
|
}
|
|
)
|
|
})
|
|
}
|
|
*/
|
|
}
|