Merge pull request #27 from embark-framework/feat/eip1102
feat: allow end user to enable ethereum manually
This commit is contained in:
commit
24609ccbb9
|
@ -1,6 +1,7 @@
|
||||||
import {reduce} from './async'
|
import {reduce} from './async'
|
||||||
|
|
||||||
let Blockchain = {};
|
let Blockchain = {};
|
||||||
|
let contracts = [];
|
||||||
|
|
||||||
function isNewWeb3_1() {
|
function isNewWeb3_1() {
|
||||||
return (typeof(web3.version) === "string");
|
return (typeof(web3.version) === "string");
|
||||||
|
@ -32,7 +33,9 @@ Blockchain.connect = function(connectionList, opts, doneCb) {
|
||||||
const connectWeb3 = async (next) => {
|
const connectWeb3 = async (next) => {
|
||||||
if (window.ethereum) {
|
if (window.ethereum) {
|
||||||
try {
|
try {
|
||||||
|
if (Blockchain.autoEnable) {
|
||||||
await ethereum.enable();
|
await ethereum.enable();
|
||||||
|
}
|
||||||
web3.setProvider(ethereum);
|
web3.setProvider(ethereum);
|
||||||
return checkConnect(next);
|
return checkConnect(next);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
@ -88,6 +91,19 @@ Blockchain.connect = function(connectionList, opts, doneCb) {
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Blockchain.enableEthereum = function() {
|
||||||
|
if (window.ethereum) {
|
||||||
|
return ethereum.enable().then((accounts) => {
|
||||||
|
web3.setProvider(ethereum);
|
||||||
|
web3.eth.defaultAccount = accounts[0];
|
||||||
|
contracts.forEach(contract => {
|
||||||
|
contract.options.from = web3.eth.defaultAccount;
|
||||||
|
})
|
||||||
|
return accounts;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
Blockchain.execWhenReady = function(cb) {
|
Blockchain.execWhenReady = function(cb) {
|
||||||
if (this.done) {
|
if (this.done) {
|
||||||
return cb(this.err);
|
return cb(this.err);
|
||||||
|
@ -125,8 +141,12 @@ let Contract = function (options) {
|
||||||
|
|
||||||
if (Contract.isNewWeb3(this.web3)) {
|
if (Contract.isNewWeb3(this.web3)) {
|
||||||
ContractClass = new this.web3.eth.Contract(this.abi, this.address);
|
ContractClass = new this.web3.eth.Contract(this.abi, this.address);
|
||||||
|
contracts.push(ContractClass);
|
||||||
ContractClass.options.data = this.code;
|
ContractClass.options.data = this.code;
|
||||||
ContractClass.options.from = this.from || this.web3.eth.defaultAccount;
|
const from = this.from || this.web3.eth.defaultAccount
|
||||||
|
if (from) {
|
||||||
|
ContractClass.options.from = from
|
||||||
|
}
|
||||||
ContractClass.abi = ContractClass.options.abi;
|
ContractClass.abi = ContractClass.options.abi;
|
||||||
ContractClass.address = this.address;
|
ContractClass.address = this.address;
|
||||||
ContractClass.gas = this.gas;
|
ContractClass.gas = this.gas;
|
||||||
|
@ -137,7 +157,9 @@ let Contract = function (options) {
|
||||||
if(!ContractClass.currentProvider){
|
if(!ContractClass.currentProvider){
|
||||||
ContractClass.setProvider(web3.currentProvider);
|
ContractClass.setProvider(web3.currentProvider);
|
||||||
}
|
}
|
||||||
|
if (web3.eth.defaultAccount) {
|
||||||
ContractClass.options.from = web3.eth.defaultAccount;
|
ContractClass.options.from = web3.eth.defaultAccount;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ContractClass._jsonInterface.forEach((abi) => {
|
ContractClass._jsonInterface.forEach((abi) => {
|
||||||
|
|
|
@ -7,6 +7,9 @@ import Utils from './utils';
|
||||||
var EmbarkJS = {
|
var EmbarkJS = {
|
||||||
onReady: function (cb) {
|
onReady: function (cb) {
|
||||||
Blockchain.execWhenReady(cb);
|
Blockchain.execWhenReady(cb);
|
||||||
|
},
|
||||||
|
enableEthereum: function () {
|
||||||
|
return Blockchain.enableEthereum();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue