|
|
|
/* global localStorage */
|
|
|
|
import { PluginEngine, IframePlugin } from '@remixproject/engine'
|
|
|
|
import { EventEmitter } from 'events'
|
|
|
|
import { PermissionHandler } from './app/ui/persmission-handler'
|
|
|
|
|
|
|
|
const requiredModules = [ // services + layout views + system views
|
|
|
|
'compilerArtefacts', 'compilerMetadata', 'contextualListener', 'sourceHighlighters', 'offsetToLineColumnConverter', 'network', 'theme', 'fileManager', 'contentImport',
|
|
|
|
'mainPanel', 'hiddenPanel', 'sidePanel', 'menuicons', 'fileExplorers',
|
|
|
|
'terminal', 'settings', 'pluginManager']
|
|
|
|
|
|
|
|
export class RemixAppManager extends PluginEngine {
|
|
|
|
|
|
|
|
constructor (plugins) {
|
|
|
|
super(plugins)
|
|
|
|
this.permissionHandler = new PermissionHandler()
|
|
|
|
this.event = new EventEmitter()
|
|
|
|
this.registered = {}
|
|
|
|
}
|
|
|
|
|
|
|
|
onActivated (plugin) {
|
|
|
|
localStorage.setItem('workspace', JSON.stringify(this.actives))
|
|
|
|
this.event.emit('activate', plugin.name)
|
|
|
|
}
|
|
|
|
|
|
|
|
getAll () {
|
|
|
|
return Object.keys(this.registered).map((p) => {
|
|
|
|
return this.registered[p]
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
getOne (name) {
|
|
|
|
return this.registered[name]
|
|
|
|
}
|
|
|
|
|
|
|
|
getIds () {
|
|
|
|
return Object.keys(this.registered)
|
|
|
|
}
|
|
|
|
|
|
|
|
onDeactivated (plugin) {
|
|
|
|
localStorage.setItem('workspace', JSON.stringify(this.actives))
|
|
|
|
this.event.emit('deactivate', plugin.name)
|
|
|
|
}
|
|
|
|
|
|
|
|
onRegistration (plugin) {
|
|
|
|
if (!this.registered) this.registered = {}
|
|
|
|
this.registered[plugin.name] = plugin
|
|
|
|
this.event.emit('added', plugin.name)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO check whether this can be removed
|
|
|
|
ensureActivated (apiName) {
|
|
|
|
if (!this.isActive(apiName)) this.activateOne(apiName)
|
|
|
|
this.event.emit('ensureActivated', apiName)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO check whether this can be removed
|
|
|
|
ensureDeactivated (apiName) {
|
|
|
|
if (this.isActive(apiName)) this.deactivateOne(apiName)
|
|
|
|
this.event.emit('ensureDeactivated', apiName)
|
|
|
|
}
|
|
|
|
|
|
|
|
deactivateOne (name) {
|
|
|
|
if (requiredModules.includes(name)) return
|
|
|
|
super.deactivateOne(name)
|
|
|
|
}
|
|
|
|
|
|
|
|
isRequired (name) {
|
|
|
|
return requiredModules.includes(name)
|
|
|
|
}
|
|
|
|
|
|
|
|
registeredPlugins () {
|
|
|
|
const vyper = {
|
|
|
|
name: 'vyper',
|
|
|
|
displayName: 'Vyper',
|
|
|
|
events: ['compilationFinished'],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'fileManager': ['currentFileChanged']
|
|
|
|
},
|
|
|
|
url: 'https://remix-vyper-plugin.surge.sh',
|
|
|
|
description: 'Compile vyper contracts',
|
|
|
|
kind: 'compile',
|
|
|
|
icon: '',
|
|
|
|
location: 'sidePanel'
|
|
|
|
}
|
|
|
|
const pipeline = {
|
|
|
|
name: 'pipeline',
|
|
|
|
displayName: 'Pipeline',
|
|
|
|
events: [],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'solidity': ['compilationFinished']
|
|
|
|
},
|
|
|
|
url: 'https://pipeline-alpha.pipeos.one',
|
|
|
|
description: 'Visual IDE for contracts and dapps',
|
|
|
|
icon: '',
|
|
|
|
location: 'mainPanel'
|
|
|
|
}
|
|
|
|
const etherscan = {
|
|
|
|
name: 'etherscan',
|
|
|
|
displayName: 'Etherscan - Contract verification',
|
|
|
|
events: [],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'solidity': ['compilationFinished']
|
|
|
|
},
|
|
|
|
url: 'https://remix-etherscan-plugin.surge.sh',
|
|
|
|
description: 'Verify Solidity contract code using Etherscan API',
|
|
|
|
icon: '',
|
|
|
|
location: 'sidePanel'
|
|
|
|
}
|
|
|
|
const ethdoc = {
|
|
|
|
name: 'solidityDocMd',
|
|
|
|
displayName: 'Solidity documentation generator',
|
|
|
|
events: [],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'solidity': ['compilationFinished']
|
|
|
|
},
|
|
|
|
url: 'https://remix-ethdoc-plugin.surge.sh',
|
|
|
|
description: 'Generate Solidity documentation (as md) using Natspec',
|
|
|
|
icon: '',
|
|
|
|
location: 'sidePanel'
|
|
|
|
}
|
|
|
|
const mythx = {
|
|
|
|
name: 'remythx',
|
|
|
|
displayName: 'MythX Security Verification',
|
|
|
|
events: [],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'solidity': ['compilationFinished']
|
|
|
|
},
|
|
|
|
version: '0.1.0-beta',
|
|
|
|
url: 'https://remix-mythx-plugin.surge.sh',
|
|
|
|
description: 'Perform Static and Dynamic Security Analysis using the MythX Cloud Service',
|
|
|
|
icon: 'https://remix-mythx-plugin.surge.sh/logo.png',
|
|
|
|
location: 'sidePanel',
|
|
|
|
documentation: 'https://github.com/aquiladev/remix-mythx-plugin/blob/master/README.md'
|
|
|
|
}
|
|
|
|
const provable = {
|
|
|
|
name: 'provable',
|
|
|
|
displayName: 'Provable - oracle service',
|
|
|
|
events: [],
|
|
|
|
methods: [],
|
|
|
|
notifications: {
|
|
|
|
'udapp': ['newTransaction'],
|
|
|
|
'network': ['providerChanged']
|
|
|
|
},
|
|
|
|
url: 'https://remix-plugin.provable.xyz',
|
|
|
|
documentation: 'https://docs.oraclize.it/#development-tools-remix-ide-provable-plugin',
|
|
|
|
description: 'request real-world data for your contracts',
|
|
|
|
icon: '',
|
|
|
|
location: 'sidePanel'
|
|
|
|
}
|
|
|
|
return [
|
|
|
|
new IframePlugin(pipeline),
|
|
|
|
new IframePlugin(vyper),
|
|
|
|
new IframePlugin(etherscan),
|
|
|
|
new IframePlugin(ethdoc),
|
|
|
|
new IframePlugin(mythx),
|
|
|
|
new IframePlugin(provable)
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|