mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
mascara: linting and code clean up
This commit is contained in:
parent
2dba03ffc5
commit
7a9e2aa4f0
@ -5,7 +5,7 @@ const serveBundle = require('./util').serveBundle
|
|||||||
module.exports = createMetamascaraServer
|
module.exports = createMetamascaraServer
|
||||||
|
|
||||||
|
|
||||||
function createMetamascaraServer(){
|
function createMetamascaraServer () {
|
||||||
|
|
||||||
// start bundlers
|
// start bundlers
|
||||||
const metamascaraBundle = createBundle(__dirname + '/../src/mascara.js')
|
const metamascaraBundle = createBundle(__dirname + '/../src/mascara.js')
|
||||||
@ -17,13 +17,13 @@ function createMetamascaraServer(){
|
|||||||
const server = express()
|
const server = express()
|
||||||
// ui window
|
// ui window
|
||||||
serveBundle(server, '/ui.js', uiBundle)
|
serveBundle(server, '/ui.js', uiBundle)
|
||||||
server.use(express.static(__dirname+'/../ui/'))
|
server.use(express.static(__dirname + '/../ui/'))
|
||||||
server.use(express.static(__dirname+'/../../dist/chrome'))
|
server.use(express.static(__dirname + '/../../dist/chrome'))
|
||||||
// metamascara
|
// metamascara
|
||||||
serveBundle(server, '/metamascara.js', metamascaraBundle)
|
serveBundle(server, '/metamascara.js', metamascaraBundle)
|
||||||
// proxy
|
// proxy
|
||||||
serveBundle(server, '/proxy/proxy.js', proxyBundle)
|
serveBundle(server, '/proxy/proxy.js', proxyBundle)
|
||||||
server.use('/proxy/', express.static(__dirname+'/../proxy'))
|
server.use('/proxy/', express.static(__dirname + '/../proxy'))
|
||||||
// background
|
// background
|
||||||
serveBundle(server, '/background.js', backgroundBuild)
|
serveBundle(server, '/background.js', backgroundBuild)
|
||||||
|
|
||||||
|
@ -7,14 +7,14 @@ module.exports = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function serveBundle(server, path, bundle){
|
function serveBundle (server, path, bundle) {
|
||||||
server.get(path, function(req, res){
|
server.get(path, function (req, res) {
|
||||||
res.setHeader('Content-Type', 'application/javascript; charset=UTF-8')
|
res.setHeader('Content-Type', 'application/javascript; charset=UTF-8')
|
||||||
res.send(bundle.latest)
|
res.send(bundle.latest)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
function createBundle(entryPoint){
|
function createBundle (entryPoint) {
|
||||||
|
|
||||||
var bundleContainer = {}
|
var bundleContainer = {}
|
||||||
|
|
||||||
@ -30,8 +30,8 @@ function createBundle(entryPoint){
|
|||||||
|
|
||||||
return bundleContainer
|
return bundleContainer
|
||||||
|
|
||||||
function bundle() {
|
function bundle () {
|
||||||
bundler.bundle(function(err, result){
|
bundler.bundle(function (err, result) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(`Bundle failed! (${entryPoint})`)
|
console.log(`Bundle failed! (${entryPoint})`)
|
||||||
console.error(err)
|
console.error(err)
|
||||||
|
@ -1,44 +1,37 @@
|
|||||||
global.window = global
|
global.window = global
|
||||||
const self = global
|
|
||||||
const pipe = require('pump')
|
|
||||||
|
|
||||||
const SwGlobalListener = require('sw-stream/lib/sw-global-listener.js')
|
const SwGlobalListener = require('sw-stream/lib/sw-global-listener.js')
|
||||||
const connectionListener = new SwGlobalListener(self)
|
const connectionListener = new SwGlobalListener(global)
|
||||||
const setupMultiplex = require('../../app/scripts/lib/stream-utils.js').setupMultiplex
|
const setupMultiplex = require('../../app/scripts/lib/stream-utils.js').setupMultiplex
|
||||||
const PortStream = require('../../app/scripts/lib/port-stream.js')
|
|
||||||
|
|
||||||
const DbController = require('idb-global')
|
const DbController = require('idb-global')
|
||||||
|
|
||||||
const SwPlatform = require('../../app/scripts/platforms/sw')
|
const SwPlatform = require('../../app/scripts/platforms/sw')
|
||||||
const MetamaskController = require('../../app/scripts/metamask-controller')
|
const MetamaskController = require('../../app/scripts/metamask-controller')
|
||||||
const extension = {} //require('../../app/scripts/lib/extension')
|
|
||||||
|
|
||||||
const storeTransform = require('obs-store/lib/transform')
|
|
||||||
const Migrator = require('../../app/scripts/lib/migrator/')
|
const Migrator = require('../../app/scripts/lib/migrator/')
|
||||||
const migrations = require('../../app/scripts/migrations/')
|
const migrations = require('../../app/scripts/migrations/')
|
||||||
const firstTimeState = require('../../app/scripts/first-time-state')
|
const firstTimeState = require('../../app/scripts/first-time-state')
|
||||||
|
|
||||||
const STORAGE_KEY = 'metamask-config'
|
const STORAGE_KEY = 'metamask-config'
|
||||||
const METAMASK_DEBUG = process.env.METAMASK_DEBUG
|
const METAMASK_DEBUG = process.env.METAMASK_DEBUG
|
||||||
let popupIsOpen = false
|
global.metamaskPopupIsOpen = false
|
||||||
let connectedClientCount = 0
|
|
||||||
|
|
||||||
const log = require('loglevel')
|
const log = require('loglevel')
|
||||||
global.log = log
|
global.log = log
|
||||||
log.setDefaultLevel(METAMASK_DEBUG ? 'debug' : 'warn')
|
log.setDefaultLevel(METAMASK_DEBUG ? 'debug' : 'warn')
|
||||||
|
|
||||||
self.addEventListener('install', function(event) {
|
global.addEventListener('install', function (event) {
|
||||||
event.waitUntil(self.skipWaiting())
|
event.waitUntil(global.skipWaiting())
|
||||||
})
|
})
|
||||||
self.addEventListener('activate', function(event) {
|
global.addEventListener('activate', function (event) {
|
||||||
event.waitUntil(self.clients.claim())
|
event.waitUntil(global.clients.claim())
|
||||||
})
|
})
|
||||||
|
|
||||||
console.log('inside:open')
|
console.log('inside:open')
|
||||||
|
|
||||||
|
|
||||||
// // state persistence
|
// // state persistence
|
||||||
let diskStore
|
|
||||||
const dbController = new DbController({
|
const dbController = new DbController({
|
||||||
key: STORAGE_KEY,
|
key: STORAGE_KEY,
|
||||||
})
|
})
|
||||||
@ -47,23 +40,18 @@ loadStateFromPersistence()
|
|||||||
.then(() => console.log('MetaMask initialization complete.'))
|
.then(() => console.log('MetaMask initialization complete.'))
|
||||||
.catch((err) => console.error('WHILE SETTING UP:', err))
|
.catch((err) => console.error('WHILE SETTING UP:', err))
|
||||||
|
|
||||||
// initialization flow
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// State and Persistence
|
// State and Persistence
|
||||||
//
|
//
|
||||||
function loadStateFromPersistence() {
|
async function loadStateFromPersistence () {
|
||||||
// migrations
|
// migrations
|
||||||
let migrator = new Migrator({ migrations })
|
const migrator = new Migrator({ migrations })
|
||||||
const initialState = migrator.generateInitialState(firstTimeState)
|
const initialState = migrator.generateInitialState(firstTimeState)
|
||||||
dbController.initialState = initialState
|
dbController.initialState = initialState
|
||||||
return dbController.open()
|
const versionedData = await dbController.open()
|
||||||
.then((versionedData) => migrator.migrateData(versionedData))
|
const migratedData = await migrator.migrateData(versionedData)
|
||||||
.then((versionedData) => {
|
await dbController.put(migratedData)
|
||||||
dbController.put(versionedData)
|
return migratedData.data
|
||||||
return Promise.resolve(versionedData)
|
|
||||||
})
|
|
||||||
.then((versionedData) => Promise.resolve(versionedData.data))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function setupController (initState, client) {
|
function setupController (initState, client) {
|
||||||
@ -89,15 +77,16 @@ function setupController (initState, client) {
|
|||||||
controller.store.subscribe((state) => {
|
controller.store.subscribe((state) => {
|
||||||
versionifyData(state)
|
versionifyData(state)
|
||||||
.then((versionedData) => dbController.put(versionedData))
|
.then((versionedData) => dbController.put(versionedData))
|
||||||
.catch((err) => {console.error(err)})
|
.catch((err) => { console.error(err) })
|
||||||
})
|
})
|
||||||
function versionifyData(state) {
|
function versionifyData (state) {
|
||||||
return dbController.get()
|
return dbController.get()
|
||||||
.then((rawData) => {
|
.then((rawData) => {
|
||||||
return Promise.resolve({
|
return Promise.resolve({
|
||||||
data: state,
|
data: state,
|
||||||
meta: rawData.meta,
|
meta: rawData.meta,
|
||||||
})}
|
})
|
||||||
|
}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,7 +96,6 @@ function setupController (initState, client) {
|
|||||||
|
|
||||||
connectionListener.on('remote', (portStream, messageEvent) => {
|
connectionListener.on('remote', (portStream, messageEvent) => {
|
||||||
console.log('REMOTE CONECTION FOUND***********')
|
console.log('REMOTE CONECTION FOUND***********')
|
||||||
connectedClientCount += 1
|
|
||||||
connectRemote(portStream, messageEvent.data.context)
|
connectRemote(portStream, messageEvent.data.context)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -116,7 +104,7 @@ function setupController (initState, client) {
|
|||||||
if (isMetaMaskInternalProcess) {
|
if (isMetaMaskInternalProcess) {
|
||||||
// communication with popup
|
// communication with popup
|
||||||
controller.setupTrustedCommunication(connectionStream, 'MetaMask')
|
controller.setupTrustedCommunication(connectionStream, 'MetaMask')
|
||||||
popupIsOpen = true
|
global.metamaskPopupIsOpen = true
|
||||||
} else {
|
} else {
|
||||||
// communication with page
|
// communication with page
|
||||||
setupUntrustedCommunication(connectionStream, context)
|
setupUntrustedCommunication(connectionStream, context)
|
||||||
@ -131,24 +119,19 @@ function setupController (initState, client) {
|
|||||||
controller.setupPublicConfig(mx.createStream('publicConfig'))
|
controller.setupPublicConfig(mx.createStream('publicConfig'))
|
||||||
}
|
}
|
||||||
|
|
||||||
function setupTrustedCommunication (connectionStream, originDomain) {
|
|
||||||
// setup multiplexing
|
|
||||||
var mx = setupMultiplex(connectionStream)
|
|
||||||
// connect features
|
|
||||||
controller.setupProviderConnection(mx.createStream('provider'), originDomain)
|
|
||||||
}
|
|
||||||
//
|
//
|
||||||
// User Interface setup
|
// User Interface setup
|
||||||
//
|
//
|
||||||
return Promise.resolve()
|
return Promise.resolve()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
// // this will be useful later but commented out for linting for now (liiiinting)
|
||||||
|
// function sendMessageToAllClients (message) {
|
||||||
|
// global.clients.matchAll().then(function (clients) {
|
||||||
|
// clients.forEach(function (client) {
|
||||||
|
// client.postMessage(message)
|
||||||
|
// })
|
||||||
|
// })
|
||||||
|
// }
|
||||||
|
|
||||||
function sendMessageToAllClients (message) {
|
|
||||||
self.clients.matchAll().then(function(clients) {
|
|
||||||
clients.forEach(function(client) {
|
|
||||||
client.postMessage(message)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
function noop () {}
|
function noop () {}
|
||||||
|
@ -2,7 +2,7 @@ const createParentStream = require('iframe-stream').ParentStream
|
|||||||
const SWcontroller = require('client-sw-ready-event/lib/sw-client.js')
|
const SWcontroller = require('client-sw-ready-event/lib/sw-client.js')
|
||||||
const SwStream = require('sw-stream/lib/sw-stream.js')
|
const SwStream = require('sw-stream/lib/sw-stream.js')
|
||||||
|
|
||||||
let intervalDelay = Math.floor(Math.random() * (30000 - 1000)) + 1000
|
const intervalDelay = Math.floor(Math.random() * (30000 - 1000)) + 1000
|
||||||
const background = new SWcontroller({
|
const background = new SWcontroller({
|
||||||
fileName: '/background.js',
|
fileName: '/background.js',
|
||||||
letBeIdle: false,
|
letBeIdle: false,
|
||||||
@ -12,7 +12,7 @@ const background = new SWcontroller({
|
|||||||
|
|
||||||
const pageStream = createParentStream()
|
const pageStream = createParentStream()
|
||||||
background.on('ready', () => {
|
background.on('ready', () => {
|
||||||
let swStream = SwStream({
|
const swStream = SwStream({
|
||||||
serviceWorker: background.controller,
|
serviceWorker: background.controller,
|
||||||
context: 'dapp',
|
context: 'dapp',
|
||||||
})
|
})
|
||||||
|
@ -17,17 +17,17 @@ var name = 'popup'
|
|||||||
window.METAMASK_UI_TYPE = name
|
window.METAMASK_UI_TYPE = name
|
||||||
window.METAMASK_PLATFORM_TYPE = 'mascara'
|
window.METAMASK_PLATFORM_TYPE = 'mascara'
|
||||||
|
|
||||||
let intervalDelay = Math.floor(Math.random() * (30000 - 1000)) + 1000
|
const intervalDelay = Math.floor(Math.random() * (30000 - 1000)) + 1000
|
||||||
|
|
||||||
const background = new SWcontroller({
|
const background = new SWcontroller({
|
||||||
fileName: '/background.js',
|
fileName: '/background.js',
|
||||||
letBeIdle: false,
|
letBeIdle: false,
|
||||||
intervalDelay,
|
intervalDelay,
|
||||||
wakeUpInterval: 20000
|
wakeUpInterval: 20000,
|
||||||
})
|
})
|
||||||
// Setup listener for when the service worker is read
|
// Setup listener for when the service worker is read
|
||||||
const connectApp = function (readSw) {
|
const connectApp = function (readSw) {
|
||||||
let connectionStream = SwStream({
|
const connectionStream = SwStream({
|
||||||
serviceWorker: background.controller,
|
serviceWorker: background.controller,
|
||||||
context: name,
|
context: name,
|
||||||
})
|
})
|
||||||
@ -57,7 +57,7 @@ background.on('updatefound', windowReload)
|
|||||||
|
|
||||||
background.startWorker()
|
background.startWorker()
|
||||||
|
|
||||||
function windowReload() {
|
function windowReload () {
|
||||||
if (window.METAMASK_SKIP_RELOAD) return
|
if (window.METAMASK_SKIP_RELOAD) return
|
||||||
window.location.reload()
|
window.location.reload()
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user