import log from 'loglevel' import extension from 'extensionizer' /** * Returns a middleware that intercepts `wallet_registerOnboarding` messages * @param {{ location: string, tabId: number, registerOnboarding: Function }} opts - The middleware options * @returns {(req: any, res: any, next: Function, end: Function) => void} */ function createOnboardingMiddleware ({ location, tabId, registerOnboarding }) { return async function originMiddleware (req, res, next, end) { try { if (req.method !== 'wallet_registerOnboarding') { next() return } if (tabId && tabId !== extension.tabs.TAB_ID_NONE) { await registerOnboarding(location, tabId) } else { log.debug(`'wallet_registerOnboarding' message from ${location} ignored due to missing tabId`) } res.result = true end() } catch (error) { end(error) } } } export default createOnboardingMiddleware