PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /proc/self/root/opt/alt/alt-nodejs18/root/usr/lib/node_modules/npm/lib/utils/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : //proc/self/root/opt/alt/alt-nodejs18/root/usr/lib/node_modules/npm/lib/utils/otplease.js

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)) {
      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 err.body.authUrl && err.body.doneUrl
  }
  return false
}

function isClassicOTP (err) {
  return err.code === 'EOTP' || (err.code === 'E401' && /one-time pass/.test(err.body))
}

module.exports = otplease