mascara: linting and code clean up

feature/default_network_editable
frankiebee 7 years ago
parent 2dba03ffc5
commit 7a9e2aa4f0
  1. 63
      mascara/src/background.js
  2. 4
      mascara/src/proxy.js
  3. 6
      mascara/src/ui.js

@ -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) {
@ -97,7 +85,8 @@ function setupController (initState, client) {
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,
}) })

Loading…
Cancel
Save