mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 20:14:12 +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
82 lines
2.4 KiB
TypeScript
82 lines
2.4 KiB
TypeScript
import Ledger3 from 'vendor/ledger3';
|
|
import LedgerEth from 'vendor/ledger-eth';
|
|
import EthTx from 'ethereumjs-tx';
|
|
import { addHexPrefix, rlp } from 'ethereumjs-util';
|
|
import { DeterministicWallet } from './deterministic';
|
|
import { IWallet } from '../IWallet';
|
|
import { RawTransaction } from 'libs/transaction';
|
|
|
|
export class LedgerWallet extends DeterministicWallet implements IWallet {
|
|
private ledger: any;
|
|
private ethApp: any;
|
|
|
|
constructor(address: string, dPath: string, index: number) {
|
|
super(address, dPath, index);
|
|
this.ledger = new Ledger3('w0w');
|
|
this.ethApp = new LedgerEth(this.ledger);
|
|
}
|
|
|
|
// modeled after
|
|
// https://github.com/kvhnuke/etherwallet/blob/3f7ff809e5d02d7ea47db559adaca1c930025e24/app/scripts/uiFuncs.js#L58
|
|
public signRawTransaction(rawTx: RawTransaction): Promise<string> {
|
|
return new Promise((resolve, reject) => {
|
|
const eTx = new EthTx({
|
|
...rawTx,
|
|
v: Buffer.from([rawTx.chainId]),
|
|
r: 0,
|
|
s: 0
|
|
});
|
|
|
|
this.ethApp.signTransaction(
|
|
this.getPath(),
|
|
rlp.encode(eTx.raw).toString('hex'),
|
|
(result, error) => {
|
|
if (error) {
|
|
return reject(this.ethApp.getError(error));
|
|
}
|
|
|
|
const txToSerialize = {
|
|
...rawTx,
|
|
v: addHexPrefix(result.v),
|
|
r: addHexPrefix(result.r),
|
|
s: addHexPrefix(result.s)
|
|
};
|
|
|
|
const serializedTx = new EthTx(txToSerialize)
|
|
.serialize()
|
|
.toString('hex');
|
|
|
|
resolve(addHexPrefix(serializedTx));
|
|
}
|
|
);
|
|
});
|
|
}
|
|
|
|
// modeled after
|
|
// https://github.com/kvhnuke/etherwallet/blob/3f7ff809e5d02d7ea47db559adaca1c930025e24/app/scripts/controllers/signMsgCtrl.js#L53
|
|
public signMessage(msg: string): Promise<string> {
|
|
return new Promise((resolve, reject) => {
|
|
const msgHex = Buffer.from(msg).toString('hex');
|
|
|
|
this.ethApp.signPersonalMessage_async(
|
|
this.getPath(),
|
|
msgHex,
|
|
async (signed, error) => {
|
|
if (error) {
|
|
return reject(this.ethApp.getError(error));
|
|
}
|
|
|
|
try {
|
|
const combined = signed.r + signed.s + signed.v;
|
|
const combinedHex = combined.toString('hex');
|
|
const signature = addHexPrefix(combinedHex);
|
|
resolve(signature);
|
|
} catch (err) {
|
|
reject(err);
|
|
}
|
|
}
|
|
);
|
|
});
|
|
}
|
|
}
|