aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/scripts/background.js4
-rw-r--r--app/scripts/lib/idmgmt.js58
2 files changed, 52 insertions, 10 deletions
diff --git a/app/scripts/background.js b/app/scripts/background.js
index 3de152d0a..112791e02 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -12,7 +12,7 @@ var wallet = new IdentityManager()
var zeroClient = MetaMaskProvider({
rpcUrl: 'https://rawtestrpc.metamask.io/',
getAccounts: wallet.getAccounts.bind(wallet),
- sendTransaction: wallet.confirmTransaction.bind(wallet),
+ signTransaction: wallet.addUnconfirmedTransaction.bind(wallet),
})
wallet.setProvider(zeroClient)
@@ -44,7 +44,7 @@ function handleInternalCommunication(remotePort){
signTransaction: wallet.signTransaction.bind(wallet),
setLocked: wallet.setLocked.bind(wallet),
getAccounts: wallet.getAccounts.bind(wallet),
- confirmTransaction: wallet.confirmTransaction.bind(wallet),
+ signTransaction: wallet.signTransaction.bind(wallet),
newBlock: wallet.newBlock.bind(wallet),
setProvider: wallet.setProvider.bind(wallet),
})
diff --git a/app/scripts/lib/idmgmt.js b/app/scripts/lib/idmgmt.js
index 3d0303406..73a6a4bf6 100644
--- a/app/scripts/lib/idmgmt.js
+++ b/app/scripts/lib/idmgmt.js
@@ -3,14 +3,17 @@ const EventEmitter = require('events').EventEmitter
const async = require('async')
const KeyStore = require('eth-lightwallet').keystore
const createPayload = require('web3-provider-engine/util/create-payload')
-var selectedAddress = null
-var identities = {}
+const Transaction = require('ethereumjs-tx')
module.exports = IdentityManager
+var selectedAddress = null
+var identities = {}
+var unconfTxs = {}
+
var provider = null
-var pubsub = new EventEmitter()
+var defaultPassword = 'test'
@@ -30,7 +33,7 @@ IdentityManager.prototype.signTransaction = signTransaction
IdentityManager.prototype.setLocked = setLocked
// eth rpc
IdentityManager.prototype.getAccounts = getAccounts
-IdentityManager.prototype.confirmTransaction = confirmTransaction
+IdentityManager.prototype.addUnconfirmedTransaction = addUnconfirmedTransaction
// etc
IdentityManager.prototype.newBlock = newBlock
IdentityManager.prototype.setProvider = setProvider
@@ -56,6 +59,7 @@ function _getState(cb){
var result = {
isUnlocked: unlocked,
identities: unlocked ? getIdentities() : {},
+ unconfTxs: unlocked ? unconfTxs() : {},
selectedAddress: selectedAddress,
}
return result
@@ -144,7 +148,6 @@ IdentityManager.prototype.updateIdentity = function(address, cb){
var identity = identities[address]
identity.balance = result[0]
identity.txCount = result[1]
- console.log('updated!')
self.emit('update', _getState())
cb()
})
@@ -193,12 +196,52 @@ function tryPassword(password, cb){
cb()
}
-function confirmTransaction(txParams, cb){
- console.log('confirmTransaction:', txParams)
+function addUnconfirmedTransaction(txParams, cb){
+ var time = (new Date()).getTime()
+ var id = time
+ unconfTxs[id] = {
+ txParams: txParams,
+ time: time,
+ }
+ console.log('addUnconfirmedTransaction:', txParams)
+
+ // temp - just sign the tx
+ // otherwise we need to keep the cb around
+ signTransaction(id, cb)
}
function signTransaction(txParams, cb){
console.log('signTransaction:', txParams)
+ try {
+ // console.log('signing tx:', txParams)
+ var tx = new Transaction({
+ nonce: txParams.nonce,
+ to: txParams.to,
+ value: txParams.value,
+ data: txParams.input,
+ gasPrice: txParams.gasPrice,
+ gasLimit: txParams.gas,
+ })
+
+ var keyStore = getKeyStore()
+ var serializedTx = keystore.signTx(tx.serialize(), defaultPassword, selectedAddress)
+ tx.sign(privateKey)
+
+ // // deserialize and dump values to confirm configuration
+ // var verifyTx = new Transaction(tx.serialize())
+ // console.log('signed transaction:', {
+ // to: '0x'+verifyTx.to.toString('hex'),
+ // from: '0x'+verifyTx.from.toString('hex'),
+ // nonce: '0x'+verifyTx.nonce.toString('hex'),
+ // value: (ethUtil.bufferToInt(verifyTx.value)/1e18)+' ether',
+ // data: '0x'+verifyTx.data.toString('hex'),
+ // gasPrice: '0x'+verifyTx.gasPrice.toString('hex'),
+ // gasLimit: '0x'+verifyTx.gasLimit.toString('hex'),
+ // })
+ cb(null, serializedTx)
+ } catch (err) {
+ cb(err)
+ }
}
var keyStore = null
@@ -211,7 +254,6 @@ function getKeyStore(password){
keyStore = KeyStore.deserialize(serializedKeystore)
// first time here
} else {
- var defaultPassword = 'test'
console.log('creating new keystore with default password:', defaultPassword)
var secretSeed = KeyStore.generateRandomSeed()
keyStore = new KeyStore(secretSeed, defaultPassword)