aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/scripts/lib/idmgmt.js39
-rw-r--r--app/scripts/lib/stream-provider.js2
2 files changed, 33 insertions, 8 deletions
diff --git a/app/scripts/lib/idmgmt.js b/app/scripts/lib/idmgmt.js
index b13116a45..795418bb9 100644
--- a/app/scripts/lib/idmgmt.js
+++ b/app/scripts/lib/idmgmt.js
@@ -11,6 +11,10 @@ module.exports = IdentityManager
var provider = null
var pubsub = new EventEmitter()
+pubsub.on('block', function(){
+ updateIdentities()
+})
+
function IdentityManager(opts){
opts = opts || {}
providerEngine = opts.providerEngine
@@ -32,24 +36,41 @@ function IdentityManager(opts){
}
}
+// plugin popup
+IdentityManager.prototype.getState = getState
+IdentityManager.prototype.subscribe = subscribe
+IdentityManager.prototype.submitPassword = submitPassword
+IdentityManager.prototype.setSelectedAddress = setSelectedAddress
+IdentityManager.prototype.signTransaction = signTransaction
+IdentityManager.prototype.setLocked = setLocked
+// eth rpc
+IdentityManager.prototype.getAccounts = getAccounts
+IdentityManager.prototype.confirmTransaction = confirmTransaction
+// etc
+IdentityManager.prototype.newBlock = newBlock
+IdentityManager.prototype.setProvider = setProvider
+
+
+
function setProvider(_provider){
provider = _provider
}
function newBlock(block){
pubsub.emit('block', block)
- updateIdentities()
}
// on new block, update our accounts (but only if we're unlocked)
function subscribe(cb){
pubsub.on('block', sendUpdateState)
+ // we're not unsubbing
+ // this causes errors and potentially breaks shit
+ // we should emit on change instead
+ // and background should handle unsubbing
function sendUpdateState(){
if (!isUnlocked()) return
- updateIdentities(function(){
- var state = _getState()
- cb(state)
- })
+ var state = _getState()
+ cb(state)
}
}
@@ -152,7 +173,11 @@ function updateIdentity(address, cb){
function getTxCount(address, cb){
provider.sendAsync(createPayload({
method: 'eth_getTransactionCount',
- params: [address],
+ // we actually want the pending txCount
+ // but pending is broken in provider-engine
+ // https://github.com/MetaMask/provider-engine/issues/11
+ // params: [address, 'pending'],
+ params: [address, 'latest'],
}), function(err, res){
if (err) return cb(err)
if (res.error) return cb(res.error)
@@ -163,7 +188,7 @@ function getTxCount(address, cb){
function getAccountBalance(address, cb){
provider.sendAsync(createPayload({
method: 'eth_getBalance',
- params: [address],
+ params: [address, 'latest'],
}), function(err, res){
if (err) return cb(err)
if (res.error) return cb(res.error)
diff --git a/app/scripts/lib/stream-provider.js b/app/scripts/lib/stream-provider.js
index b0a922397..5a77979ee 100644
--- a/app/scripts/lib/stream-provider.js
+++ b/app/scripts/lib/stream-provider.js
@@ -17,7 +17,7 @@ function StreamProvider(){
// public
StreamProvider.prototype.send = function(payload){
- throw new Error('StreamProvider - does not support synchronous RPC calls')
+ throw new Error('StreamProvider - does not support synchronous RPC calls. called: "'+payload.method+'"')
}
StreamProvider.prototype.sendAsync = function(payload, callback){