/* 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' , 'editor' , 'offsetToLineColumnConverter' , 'network' , 'theme' , 'fileManager' , 'contentImport' ,
'mainPanel' , 'hiddenPanel' , 'sidePanel' , 'menuicons' , 'fileExplorers' ,
'terminal' , 'settings' , 'pluginManager' ]
const settings = {
permissionHandler : new PermissionHandler ( ) ,
autoActivate : false ,
natives : [ 'vyper' , 'workshops' , 'ethdoc' , 'etherscan' ] // Force iframe plugin to be seen as native
}
export class RemixAppManager extends PluginEngine {
constructor ( plugins ) {
super ( plugins , settings )
this . event = new EventEmitter ( )
this . donotAutoReload = [ 'remixd' ] // that would be a bad practice to force loading some plugins at page load.
this . registered = { }
}
onActivated ( plugin ) {
if ( ! this . donotAutoReload . includes ( plugin . name ) ) {
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 : 'compiler' ,
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' ,
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'
}
const threeBox = {
name : 'box' ,
displayName : '3Box Spaces' ,
description : 'A decentralized storage for everything that happen on Remix' ,
methods : [ 'login' , 'isEnabled' , 'getUserAddress' , 'openSpace' , 'closeSpace' , 'isSpaceOpened' , 'getSpacePrivateValue' , 'setSpacePrivateValue' , 'getSpacePublicValue' , 'setSpacePublicValue' , 'getSpacePublicData' ] ,
events : [ ] ,
version : '0.1.0-beta' ,
url : 'https://remix-3box.surge.sh' ,
icon : 'https://raw.githubusercontent.com/3box/3box-dapp/master/public/3Box3.png' ,
location : 'sidePanel'
}
const remixWorkshop = {
name : 'workshops' ,
displayName : 'Remix Workshops' ,
description : 'Learn Ethereum with Remix !' ,
methods : [ ] ,
events : [ ] ,
version : '0.1.0-alpha' ,
url : 'https://remix-plugin-workshops.surge.sh' ,
icon : 'https://image.flaticon.com/icons/svg/1570/1570493.svg' ,
location : 'sidePanel'
}
const debugPlugin = {
name : 'debugPlugin' ,
displayName : 'Debug Tools for Remix plugins' ,
description : 'Easily test and debug your plugins !' ,
methods : [ 'sayHello' , 'sayMyName' , 'sayOurNames' ] , // test calls with 0, 1, and 2 args
events : [ ] ,
version : '0.1.0-alpha' ,
url : 'https://remix-debug-a.surge.sh' ,
icon : 'https://remix-debug-a.surge.sh/icon.png' ,
location : 'sidePanel'
}
const libraTools = {
name : 'libratools' ,
displayName : 'Libra and Move Tools' ,
events : [ ] ,
methods : [ ] ,
url : 'https://libra.pipeos.one' ,
description : 'Create, compile, deploy and interact with Libra modules and scripts' ,
icon : ' data : image / svg + xml ; base64 , PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8 + CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgoKPHN2ZwogICB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iCiAgIHhtbG5zOmNjPSJodHRwOi8vY3JlYXRpdmVjb21tb25zLm9yZy9ucyMiCiAgIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyIKICAgeG1sbnM6c3ZnPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxuczpzb2RpcG9kaT0iaHR0cDovL3NvZGlwb2RpLnNvdXJjZWZvcmdlLm5ldC9EVEQvc29kaXBvZGktMC5kdGQiCiAgIHhtbG5zOmlua3NjYXBlPSJodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy9uYW1lc3BhY2VzL2lua3NjYXBlIgogICB3aWR0aD0iMTAyNCIKICAgaGVpZ2h0PSIxMDI0IgogICB2aWV3Qm94PSIwIDAgMjcwLjkzMzMzIDI3MC45MzMzMyIKICAgdmVyc2lvbj0iMS4xIgogICBpZD0ic3ZnOCIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi4yIDVjM2U4MGQsIDIwMTctMDgtMDYiCiAgIHNvZGlwb2RpOmRvY25hbWU9ImxpYnJhLnN2ZyI + CiAgPGRlZnMKICAgICBpZD0iZGVmczIiIC8 + CiAgPHNvZGlwb2RpOm5hbWVkdmlldwogICAgIGlkPSJiYXNlIgogICAgIHBhZ2Vjb2xvcj0iI2ZmZmZmZiIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBib3JkZXJvcGFjaXR5PSIxLjAiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAuMCIKICAgICBpbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOnpvb209IjAuNzczNDM3NSIKICAgICBpbmtzY2FwZTpjeD0iNTEyIgogICAgIGlua3NjYXBlOmN5PSI1MTIiCiAgICAgaW5rc2NhcGU6ZG9jdW1lbnQtdW5pdHM9InB4IgogICAgIGlua3NjYXBlOmN1cnJlbnQtbGF5ZXI9ImxheWVyMSIKICAgICBzaG93Z3JpZD0iZmFsc2UiCiAgICAgdW5pdHM9InB4IgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iMTY1MiIKICAgICBpbmtzY2FwZTp3aW5kb3ctaGVpZ2h0PSIxMDA1IgogICAgIGlua3NjYXBlOndpbmRvdy14PSIwIgogICAgIGlua3NjYXBlOndpbmRvdy15PSIxIgogICAgIGlua3NjYXBlOndpbmRvdy1tYXhpbWl6ZWQ9IjEiIC8 + CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhNSI + CiAgICA8cmRmOlJERj4KICAgICAgPGNjOldvcmsKICAgICAgICAgcmRmOmFib3V0PSIiPgogICAgICAgIDxkYzpmb3JtYXQ + aW1hZ2Uvc3ZnK3htbDwvZGM6Zm9ybWF0PgogICAgICAgIDxkYzp0eXBlCiAgICAgICAgICAgcmRmOnJlc291cmNlPSJodHRwOi8vcHVybC5vcmcvZGMvZGNtaXR5cGUvU3RpbGxJbWFnZSIgLz4KICAgICAgICA8ZGM6dGl0bGU + PC9kYzp0aXRsZT4KICAgICAgPC9jYzpXb3JrPgogICAgPC9yZGY6UkRGPgogIDwvbWV0YWRhdGE + CiAgPGcKICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICBpbmtzY2FwZTpncm91cG1vZGU9ImxheWVyIgogICAgIGlkPSJsYXllcjEiCiAgICAgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCwtMjYuMDY2NzEpIj4KICAgIDxnCiAgICAgICBpZD0iZzk3MCIKICAgICAgIHRyYW5zZm9ybT0ibWF0cml4KDAuODQzMTI1MjMsMCwwLDAuODQzMTI1MjMsMjEuMjUxMzAxLDI1LjM0MDUxMykiPgogICAgICA8cGF0aAogICAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNzc2MiCiAgICAgICAgIGlua3NjYXBlOmNvbm5lY3Rvci1jdXJ2YXR1cmU9IjAiCiAgICAgICAgIGlkPSJwYXRoOTQ3IgogICAgICAgICBkPSJtIDQwLjc4NjQ0MywxMDcuNzM2MTcgYyAwLDAgMTkuMzI4MzA0LC0zNi44NDk4MzEgNDguOTMwMzg1LC0zNi44NDk4MzEgMjkuNjAyMDgyLDAgNjIuODI4ODkyLDI5LjYwMjA3MSA5Mi40MzA5ODIsMjkuNjAyMDcxIDI5LjYwMjA4LDAgNDcuNzI1NzksLTM4LjY2MzkzNSA0Ny43MjU3OSwtMzguNjYzOTM1IgogICAgICAgICBzdHlsZT0ib3BhY2l0eToxO2ZpbGw6bm9uZTtmaWxsLXJ1bGU6ZXZlbm9kZDtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MjcuNDg3NjQyMjk7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW1pdGVybGltaXQ6NDtzdHJva2UtZGFzaGFycmF5Om5vbmU7c3Ryb2tlLW9wYWNpdHk6MSIgLz4KICAgICAgPHBhdGgKICAgICAgICAgc3R5bGU9Im9wYWNpdHk6MTtmaWxsOm5vbmU7ZmlsbC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjI3LjQ4NzY0MjI5O3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1taXRlcmxpbWl0OjQ7c3Ryb2tlLWRhc2hhcnJheTpub25lO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICAgIGQ9Im0gNDAuNzg2NDQzLDE4NC4xNTc4NSBjIDAsMCAxOS4zMjgzMDQsLTM2Ljg0OTgyIDQ4LjkzMDM4NywtMzYuODQ5ODIgMjkuNjAyMDgsMCA2Mi44Mjg5LDI5LjYwMjA3IDkyLjQzMDk4LDI5LjYwMjA3IDI5LjYwMjA4LDAgNDcuNzI1NzksLTM4LjY2Mzk0IDQ3LjcyNTc5LC0zOC42NjM5NCIKICAgICAgICAgaWQ9InVzZTk1MSIKICAgICAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICAgICAgc29kaXBvZGk6bm9kZXR5cGVzPSJjc3NjIiAvPgogICAgICA8cGF0aAogICAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNzc2MiCiAgICAgICAgIGlua3NjYXBlOmNvbm5lY3Rvci1jdXJ2YXR1cmU9IjAiCiAgICAgICAgIGlkPSJ1c2U5NTUiCiAgICAgICAgIGQ9Im0gNDAuNzg2NDQzLDI2MC41Nzk1NSBjIDAsMCAxOS4zMjgzMDYsLTM2Ljg0OTgzIDQ4LjkzMDM4NywtMzYuODQ5ODMgMjkuNjAyMDgsMCA2Mi44Mjg5LDI5LjYwMjA3IDkyLjQzMDk4LDI5LjYwMjA3IDI5LjYwMjA4LDAgNDcuNzI1NzksLTM4LjY2MzkzIDQ3LjcyNTc5LC0zOC42NjM5MyIKICAgICAgICAgc3R5bGU9Im9wYWNpdHk6MTtmaWxsOm5vbmU7ZmlsbC1ydWxl
location : 'sidePanel'
}
const oneClickDapp = {
name : 'oneClickDapp' ,
displayName : 'One Click Dapp' ,
events : [ ] ,
methods : [ ] ,
version : '0.1.0' ,
notifications : {
solidity : [ 'compilationFinished' ]
} ,
url : 'https://remix-one-click-dapp.surge.sh' ,
description : 'A free tool to generate smart contract interfaces.' ,
documentation : 'https://github.com/pi0neerpat/remix-plugin-one-click-dapp' ,
icon : 'https://remix-one-click-dapp.surge.sh/icon.png' ,
location : 'sidePanel'
}
const gasProfiler = {
name : 'gasProfiler' ,
displayName : 'Gas Profiler' ,
events : [ ] ,
methods : [ ] ,
version : '0.1.0-alpha' ,
url : 'https://remix-gas-profiler.surge.sh' ,
description : 'Profile gas costs' ,
icon : 'https://res.cloudinary.com/key-solutions/image/upload/v1565781702/gas-profiler_nxmsal.png' ,
location : 'sidePanel'
}
const flattener = {
name : 'flattener' ,
displayName : 'Flattener' ,
events : [ ] ,
methods : [ ] ,
version : '0.1.0' ,
url : 'https://remix-flattener.netlify.com' ,
description : 'Flattens compiled smart contracts' ,
documentation : 'https://github.com/Destiner/remix-flattener' ,
icon : 'https://remix-flattener.netlify.com/logo.svg' ,
location : 'sidePanel'
}
const ethpm = {
name : 'ethPM' ,
displayName : 'ethPM' ,
events : [ ] ,
methods : [ ] ,
notifications : {
solidity : [ 'compilationFinished' ]
} ,
url : 'https://ethpm.surge.sh' ,
description : 'Generate and import ethPM packages.' ,
documentation : 'https://docs.ethpm.com/ethpm-developer-guide/ethpm-and-remix-ide' ,
icon : 'https://ethpm.surge.sh/ethpmlogo.png' ,
location : 'mainPanel'
}
const zokrates = {
name : 'Zokrates' ,
displayName : 'ZoKrates' ,
description : 'ZoKrates will compile your program to an intermediate representation and run a trusted setup protocol to generate proving and verifying keys.' ,
methods : [ ] ,
events : [ ] ,
version : '0.1.0-alpha' ,
url : 'https://zokrates.blockchain-it.hr' ,
icon : 'https://zokrates.blockchain-it.hr/zokrates.svg' ,
location : 'sidePanel'
}
return [
new IframePlugin ( pipeline ) ,
new IframePlugin ( vyper ) ,
new IframePlugin ( etherscan ) ,
new IframePlugin ( ethdoc ) ,
new IframePlugin ( mythx ) ,
new IframePlugin ( provable ) ,
new IframePlugin ( threeBox ) ,
new IframePlugin ( remixWorkshop ) ,
new IframePlugin ( debugPlugin ) ,
new IframePlugin ( libraTools ) ,
new IframePlugin ( oneClickDapp ) ,
new IframePlugin ( gasProfiler ) ,
new IframePlugin ( flattener ) ,
new IframePlugin ( ethpm ) ,
new IframePlugin ( zokrates )
]
}
}