diff options
author | Dan Finlay <flyswatter@users.noreply.github.com> | 2017-01-17 04:20:39 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-17 04:20:39 +0800 |
commit | c05b783466c792789e321e5012e6e4fed6908abd (patch) | |
tree | 871c43750e3d3c2ebf8e096f2a5ecee0e65cfbd4 /app | |
parent | ac6a2b4b61f34d3a60fc7cab926d390e172ed276 (diff) | |
parent | 053066b57ff73b4858cf9180748bf57495c47e62 (diff) | |
download | tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar.gz tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar.bz2 tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar.lz tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar.xz tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.tar.zst tangerine-wallet-browser-c05b783466c792789e321e5012e6e4fed6908abd.zip |
Merge pull request #1007 from MetaMask/simple-keystore-fix
keyring - simple - fix address generation
Diffstat (limited to 'app')
-rw-r--r-- | app/scripts/keyrings/simple.js | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/app/scripts/keyrings/simple.js b/app/scripts/keyrings/simple.js index 9717f1c45..6b16137ae 100644 --- a/app/scripts/keyrings/simple.js +++ b/app/scripts/keyrings/simple.js @@ -35,12 +35,12 @@ class SimpleKeyring extends EventEmitter { newWallets.push(Wallet.generate()) } this.wallets = this.wallets.concat(newWallets) - const hexWallets = newWallets.map(w => w.getAddress().toString('hex')) + const hexWallets = newWallets.map(w => ethUtil.bufferToHex(w.getAddress())) return Promise.resolve(hexWallets) } getAccounts () { - return Promise.resolve(this.wallets.map(w => w.getAddress().toString('hex'))) + return Promise.resolve(this.wallets.map(w => ethUtil.bufferToHex(w.getAddress()))) } // tx is an instance of the ethereumjs-transaction class. @@ -54,6 +54,7 @@ class SimpleKeyring extends EventEmitter { // For eth_sign, we need to sign transactions: signMessage (withAccount, data) { const wallet = this._getWalletForAccount(withAccount) + const message = ethUtil.removeHexPrefix(data) var privKey = wallet.getPrivateKey() var msgSig = ethUtil.ecsign(new Buffer(message, 'hex'), privKey) @@ -70,7 +71,9 @@ class SimpleKeyring extends EventEmitter { /* PRIVATE METHODS */ _getWalletForAccount (account) { - return this.wallets.find(w => w.getAddress().toString('hex') === account) + let wallet = this.wallets.find(w => ethUtil.bufferToHex(w.getAddress()) === account) + if (!wallet) throw new Error('Simple Keyring - Unable to find matching address.') + return wallet } } |