PATH:
usr
/
lib
/
node_modules
/
npm
/
lib
/
utils
const log = require('./log-shim') async function otplease (npm, opts, fn) { try { return await fn(opts) } catch (err) { if (!process.stdin.isTTY || !process.stdout.isTTY) { throw err } if (isWebOTP(err)) { log.disableProgress() const webAuth = require('./web-auth') const openUrlPrompt = require('./open-url-prompt') const openerPromise = (url, emitter) => openUrlPrompt( npm, url, 'Authenticate your account at', 'Press ENTER to open in the browser...', emitter ) const otp = await webAuth(openerPromise, err.body.authUrl, err.body.doneUrl, opts) return await fn({ ...opts, otp }) } if (isClassicOTP(err)) { const readUserInfo = require('./read-user-info.js') const otp = await readUserInfo.otp('This operation requires a one-time password.\nEnter OTP:') return await fn({ ...opts, otp }) } throw err } } function isWebOTP (err) { if (!err.code === 'EOTP' || !err.body) { return false } return err.body.authUrl && err.body.doneUrl } function isClassicOTP (err) { return err.code === 'EOTP' || (err.code === 'E401' && /one-time pass/.test(err.body)) } module.exports = otplease
[-] ping.js
[edit]
[-] explain-eresolve.js
[edit]
[-] completion.sh
[edit]
[-] otplease.js
[edit]
[-] log-file.js
[edit]
[-] audit-error.js
[edit]
[-] format-search-stream.js
[edit]
[-] exit-handler.js
[edit]
[-] pulse-till-done.js
[edit]
[-] tar.js
[edit]
[-] open-url.js
[edit]
[-] web-auth.js
[edit]
[+]
..
[-] reify-finish.js
[edit]
[-] read-user-info.js
[edit]
[-] ansi-trim.js
[edit]
[-] get-identity.js
[edit]
[-] explain-dep.js
[edit]
[-] open-url-prompt.js
[edit]
[-] replace-info.js
[edit]
[-] display.js
[edit]
[-] reify-output.js
[edit]
[-] validate-lockfile.js
[edit]
[-] is-windows.js
[edit]
[-] cmd-list.js
[edit]
[-] format-bytes.js
[edit]
[+]
config
[+]
completion
[-] log-shim.js
[edit]
[-] did-you-mean.js
[edit]
[-] queryable.js
[edit]
[-] timers.js
[edit]
[-] npm-usage.js
[edit]
[-] error-message.js
[edit]
[-] update-notifier.js
[edit]