diff --git a/apps/remix-ide/src/app/tabs/network-module.js b/apps/remix-ide/src/app/tabs/network-module.js
index cb3e465044..58668123ff 100644
--- a/apps/remix-ide/src/app/tabs/network-module.js
+++ b/apps/remix-ide/src/app/tabs/network-module.js
@@ -1,5 +1,6 @@
import { Plugin } from '@remixproject/engine'
import * as packageJson from '../../../../../package.json'
+import { Web3 } from 'web3'
export const profile = {
name: 'network',
@@ -59,8 +60,12 @@ export class NetworkModule extends Plugin {
}
/** Add a custom network to the list of available networks */
- addNetwork (customNetwork) {
- this.blockchain.addProvider(customNetwork)
+ addNetwork (network) { // { name, url }
+ if (network.url === 'ipc') {
+ this.blockchain.addProvider({ name: network.name, provider: new Web3.providers.IpcProvider() })
+ } else {
+ this.blockchain.addProvider({ name: network.name, provider: new Web3.providers.HttpProvider(network.url) })
+ }
}
/** Remove a network to the list of availble networks */
diff --git a/apps/remix-ide/src/app/tabs/runTab/settings.js b/apps/remix-ide/src/app/tabs/runTab/settings.js
index 692828e25e..e22a3c0064 100644
--- a/apps/remix-ide/src/app/tabs/runTab/settings.js
+++ b/apps/remix-ide/src/app/tabs/runTab/settings.js
@@ -156,7 +156,7 @@ class SettingsUI {
setDropdown (selectExEnv) {
this.selectExEnv = selectExEnv
- this.blockchain.event.register('addProvider', (network) => {
+ const addProvider = (network) => {
selectExEnv.appendChild(yo``)
- addTooltip(`${network.name} [${network.url}] added`)
- })
+ addTooltip(yo`${network.name} provider added ${network.url ? `- ${network.url}` : ''}`)
+ }
- this.blockchain.event.register('removeProvider', (name) => {
+ const removeProvider = (name) => {
var env = selectExEnv.querySelector(`option[value="${name}"]`)
if (env) {
selectExEnv.removeChild(env)
- addTooltip(`${name} removed`)
+ addTooltip(yo`${name} provider removed`)
}
- })
+ }
+ this.blockchain.event.register('addProvider', provider => addProvider(provider))
+ this.blockchain.event.register('removeProvider', name => removeProvider(name))
selectExEnv.addEventListener('change', (event) => {
let context = selectExEnv.options[selectExEnv.selectedIndex].value
diff --git a/apps/remix-ide/src/app/udapp/run-tab.js b/apps/remix-ide/src/app/udapp/run-tab.js
index 4c1978bf87..e6a40b5f15 100644
--- a/apps/remix-ide/src/app/udapp/run-tab.js
+++ b/apps/remix-ide/src/app/udapp/run-tab.js
@@ -201,6 +201,28 @@ export class RunTab extends LibraryPlugin {
this.renderDropdown(this.udappUI, this.fileManager, this.compilersArtefacts, this.config, this.editor, this.logCallback)
this.renderRecorder(this.udappUI, this.fileManager, this.config, this.logCallback)
this.renderRecorderCard()
+
+ this.on('manager', 'pluginDeactivated', profile => {
+ if (profile.kind === 'provider') this.blockchain.removeProvider(profile.name)
+ })
+ this.on('manager', 'pluginActivated', profile => {
+ if (profile.kind === 'provider') {
+ ((profile, app) => {
+ const web3Provider = {
+ sendAsync (payload, callback) {
+ app.call(profile.name, 'sendAsync', payload)
+ .then(result => {
+ callback(null, result)
+ })
+ .catch(e => {
+ callback(e)
+ })
+ }
+ }
+ this.blockchain.addProvider({ name: profile.displayName, provider: web3Provider })
+ })(profile, this)
+ }
+ })
return this.renderContainer()
}
}
diff --git a/apps/remix-ide/src/blockchain/blockchain.js b/apps/remix-ide/src/blockchain/blockchain.js
index 5cace4f97d..cf57531072 100644
--- a/apps/remix-ide/src/blockchain/blockchain.js
+++ b/apps/remix-ide/src/blockchain/blockchain.js
@@ -67,7 +67,8 @@ class Blockchain {
getCurrentProvider () {
const provider = this.getProvider()
- return this.providers[provider]
+ if (this.providers[provider]) return this.providers[provider]
+ return this.providers.web3 // default to the common type of provider
}
/** Return the list of accounts */
@@ -285,11 +286,11 @@ class Blockchain {
this.resetEnvironment()
}
- addNetwork (customNetwork) {
- this.executionContext.addProvider(customNetwork)
+ addProvider (provider) {
+ this.executionContext.addProvider(provider)
}
- removeNetwork (name) {
+ removeProvider (name) {
this.executionContext.removeProvider(name)
}
diff --git a/apps/remix-ide/src/remixAppManager.js b/apps/remix-ide/src/remixAppManager.js
index e866bc2641..bd14021538 100644
--- a/apps/remix-ide/src/remixAppManager.js
+++ b/apps/remix-ide/src/remixAppManager.js
@@ -20,7 +20,7 @@ export function canActivate (name) {
export class RemixAppManager extends PluginManager {
- constructor (plugins) {
+ constructor () {
super()
this.event = new EventEmitter()
this.pluginsDirectory = 'https://raw.githubusercontent.com/ethereum/remix-plugins-directory/master/build/metadata.json'
@@ -94,7 +94,18 @@ export class RemixAppManager extends PluginManager {
async registeredPlugins () {
const res = await fetch(this.pluginsDirectory)
- const plugins = await res.json()
+ let plugins = await res.json()
+ plugins.push({
+ 'name': 'walletconnect',
+ 'kind': 'provider',
+ 'displayName': 'Wallet Connect',
+ 'events': [],
+ 'methods': ['sendAsync'],
+ 'url': 'ipfs://QmWYfY6CGyU29LFw4QVSpwzfHxGh5kg4Tc5QNMA8ZYoHks',
+ 'description': 'Use your mobile wallet for transaction',
+ 'icon': '',
+ 'location': 'mainPanel'
+ })
return plugins.map(plugin => new IframePlugin(plugin))
}
}
diff --git a/libs/remix-lib/src/execution/execution-context.js b/libs/remix-lib/src/execution/execution-context.js
index f1875a209a..1170cd174d 100644
--- a/libs/remix-lib/src/execution/execution-context.js
+++ b/libs/remix-lib/src/execution/execution-context.js
@@ -110,6 +110,7 @@ function ExecutionContext () {
let executionContext = null
+ this.currentProviderName = null
this.blockGasLimitDefault = 4300000
this.blockGasLimit = this.blockGasLimitDefault
this.customNetWorks = {}
@@ -174,13 +175,14 @@ function ExecutionContext () {
this.removeProvider = (name) => {
if (name && this.customNetWorks[name]) {
+ if (this.currentProviderName === name) this.setContext('vm', null)
delete this.customNetWorks[name]
this.event.trigger('removeProvider', [name])
}
}
this.addProvider = (network) => {
- if (network && network.name && network.url) {
+ if (network && network.name && !this.customNetWorks[network.name]) {
this.customNetWorks[network.name] = network
this.event.trigger('addProvider', [network])
}
@@ -205,9 +207,11 @@ function ExecutionContext () {
this.executionContextChange = (context, endPointUrl, confirmCb, infoCb, cb) => {
if (!cb) cb = () => {}
-
+ if (!confirmCb) confirmCb = () => {}
+ if (!infoCb) infoCb = () => {}
if (context === 'vm') {
executionContext = context
+ this.currentProviderName = context
vms[currentFork].stateManager.revert(() => {
vms[currentFork].stateManager.checkpoint(() => {})
})
@@ -222,6 +226,7 @@ function ExecutionContext () {
} else {
this.askPermission()
executionContext = context
+ this.currentProviderName = context
web3.setProvider(injectedProvider)
this._updateBlockGasLimit()
this.event.trigger('contextChanged', ['injected'])
@@ -234,8 +239,11 @@ function ExecutionContext () {
}
if (this.customNetWorks[context]) {
- var provider = this.customNetWorks[context]
- setProviderFromEndpoint(provider.url, 'web3', () => { cb() })
+ var network = this.customNetWorks[context]
+ this.setProviderFromEndpoint(network.provider, network.name, (error) => {
+ if (error) infoCb(error)
+ cb()
+ })
}
}
@@ -269,29 +277,26 @@ function ExecutionContext () {
// TODO: remove this when this function is moved
const self = this
- // TODO: not used here anymore and needs to be moved
- function setProviderFromEndpoint (endpoint, context, cb) {
+
+ this.setProviderFromEndpoint = (endpoint, context, cb) => {
const oldProvider = web3.currentProvider
- if (endpoint === 'ipc') {
- web3.setProvider(new web3.providers.IpcProvider())
- } else {
- web3.setProvider(new web3.providers.HttpProvider(endpoint))
- }
+ web3.setProvider(endpoint)
+
web3.eth.net.isListening((err, isConnected) => {
if (!err && isConnected) {
executionContext = context
+ this.currentProviderName = context
self._updateBlockGasLimit()
- self.event.trigger('contextChanged', ['web3'])
+ self.event.trigger('contextChanged', [context])
self.event.trigger('web3EndpointChanged')
cb()
} else {
web3.setProvider(oldProvider)
- cb('Not possible to connect to the Web3 provider. Make sure the provider is running and a connection is open (via IPC or RPC).')
+ cb('Not possible to connect to the Web3 provider. Make sure the provider is running, a connection is open (via IPC or RPC) or that the provider plugin is properly configured.')
}
})
}
- this.setProviderFromEndpoint = setProviderFromEndpoint
this.txDetailsLink = (network, hash) => {
if (transactionDetailsLinks[network]) {
diff --git a/libs/remix-lib/src/execution/txRunner.js b/libs/remix-lib/src/execution/txRunner.js
index f778ceb388..32c625d94d 100644
--- a/libs/remix-lib/src/execution/txRunner.js
+++ b/libs/remix-lib/src/execution/txRunner.js
@@ -177,6 +177,11 @@ class TxRunner {
})
}
this.executionContext.web3().eth.estimateGas(tx, (err, gasEstimation) => {
+ console.log(err, gasEstimation)
+ if (err && err.message.indexOf('Invalid JSON RPC response') !== -1) {
+ // https://github.com/WalletConnect/walletconnect-monorepo/issues/334
+ err = 'Gas estimation failed because of an unknown internal error. This may indicated that the transaction will fail.'
+ }
gasEstimationForceSend(err, () => {
// callback is called whenever no error
tx.gas = !gasEstimation ? gasLimit : gasEstimation
diff --git a/workspace.json b/workspace.json
index d81084a528..686fb9b3eb 100644
--- a/workspace.json
+++ b/workspace.json
@@ -23,7 +23,7 @@
"styles": [],
"scripts": [],
"webpackConfig": "apps/remix-ide/webpack.config.js",
- "maxWorkers": 2
+ "maxWorkers": 1
},
"configurations": {
"production": {