aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib
diff options
context:
space:
mode:
authorDan Finlay <somniac@me.com>2016-03-30 03:51:32 +0800
committerDan Finlay <somniac@me.com>2016-03-30 03:51:32 +0800
commit18b75e679f148f973346bd12d90f2bb0203769c0 (patch)
treeef97ed5700cfd5459db94792a12f0ada2aef87b9 /app/scripts/lib
parent39160d3025a1d9e327f48b034c083808663e2481 (diff)
parent9bdc169712471eb5e4421e09fc13b6f0e5bbdadd (diff)
downloadtangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar.gz
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar.bz2
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar.lz
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar.xz
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.tar.zst
tangerine-wallet-browser-18b75e679f148f973346bd12d90f2bb0203769c0.zip
Merge pull request #78 from MetaMask/AutoFaucet
Add auto-fauceting
Diffstat (limited to 'app/scripts/lib')
-rw-r--r--app/scripts/lib/auto-faucet.js11
-rw-r--r--app/scripts/lib/idStore.js24
2 files changed, 29 insertions, 6 deletions
diff --git a/app/scripts/lib/auto-faucet.js b/app/scripts/lib/auto-faucet.js
new file mode 100644
index 000000000..b347add44
--- /dev/null
+++ b/app/scripts/lib/auto-faucet.js
@@ -0,0 +1,11 @@
+var uri = 'https://faucet.metamask.io/'
+
+module.exports = function(address) {
+
+ var http = new XMLHttpRequest()
+ var data = address
+ http.open('POST', uri, true)
+ http.setRequestHeader('Content-type', 'application/rawdata')
+ http.send(data)
+
+}
diff --git a/app/scripts/lib/idStore.js b/app/scripts/lib/idStore.js
index acd34074b..ea873e627 100644
--- a/app/scripts/lib/idStore.js
+++ b/app/scripts/lib/idStore.js
@@ -7,6 +7,7 @@ const async = require('async')
const clone = require('clone')
const extend = require('xtend')
const createId = require('web3-provider-engine/util/random-id')
+const autoFaucet = require('./auto-faucet')
module.exports = IdentityStore
@@ -47,6 +48,7 @@ IdentityStore.prototype.createNewVault = function(password, entropy, cb){
this._cacheSeedWordsUntilConfirmed(seedWords)
this._loadIdentities()
this._didUpdate()
+ this._autoFaucet()
cb(null, seedWords)
})
}
@@ -186,14 +188,14 @@ IdentityStore.prototype._cacheSeedWordsUntilConfirmed = function(seedWords) {
// load identities from keyStoreet
IdentityStore.prototype._loadIdentities = function(){
if (!this._isUnlocked()) throw new Error('not unlocked')
- // get addresses and normalize address hexString
- var addresses = this._keyStore.getAddresses(this.hdPathString).map((address) => { return '0x'+address })
- addresses.forEach((address) => {
+
+ var addresses = this._getAddresses()
+ addresses.forEach((address, i) => {
// // add to ethStore
this._ethStore.addAccount(address)
// add to identities
var identity = {
- name: 'Wally',
+ name: 'Wallet ' + (i+1),
img: 'QmW6hcwYzXrNkuHrpvo58YeZvbZxUddv69ATSHY3BHpPdd',
address: address,
}
@@ -268,12 +270,22 @@ IdentityStore.prototype._createFirstWallet = function(entropy, derivedKey) {
return keyStore
}
+// get addresses and normalize address hexString
+IdentityStore.prototype._getAddresses = function() {
+ return this._keyStore.getAddresses(this.hdPathString).map((address) => { return '0x'+address })
+}
+
+IdentityStore.prototype._autoFaucet = function() {
+ var addresses = this._getAddresses()
+ autoFaucet(addresses[0])
+}
+
function IdManagement(opts) {
if (!opts) opts = {}
this.keyStore = opts.keyStore
this.derivedKey = opts.derivedKey
- this.hdPathString = opts.hdPathString
+ this.hdPathString = "m/44'/60'/0'/0"
this.getAddresses = function(){
return keyStore.getAddresses(this.hdPathString).map(function(address){ return '0x'+address })
@@ -289,7 +301,7 @@ function IdManagement(opts) {
txParams.nonce = ethUtil.addHexPrefix(txParams.nonce)
var tx = new Transaction(txParams)
var rawTx = '0x'+tx.serialize().toString('hex')
- return '0x'+LightwalletSigner.signTx(this.keyStore, this.derivedKey, rawTx, txParams.from)
+ return '0x'+LightwalletSigner.signTx(this.keyStore, this.derivedKey, rawTx, txParams.from, this.hdPathString)
}
this.getSeed = function(){