????JFIF??x?x????'
| Server IP : 104.21.30.238 / Your IP : 216.73.216.87 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././././opt/alt/alt-nodejs9/root/usr/lib/node_modules/npm/lib/auth/ |
Upload File : |
'use strict'
const read = require('../utils/read-user-info.js')
const profile = require('npm-profile')
const log = require('npmlog')
const npm = require('../npm.js')
const output = require('../utils/output.js')
const pacoteOpts = require('../config/pacote')
const fetchOpts = require('../config/fetch-opts')
module.exports.login = function login (creds, registry, scope, cb) {
let username = creds.username || ''
let password = creds.password || ''
let email = creds.email || ''
const auth = {}
if (npm.config.get('otp')) auth.otp = npm.config.get('otp')
return read.username('Username:', username, {log: log}).then((u) => {
username = u
return read.password('Password: ', password)
}).then((p) => {
password = p
return read.email('Email: (this IS public) ', email, {log: log})
}).then((e) => {
email = e
return profile.login(username, password, {registry: registry, auth: auth}).catch((err) => {
if (err.code === 'EOTP') throw err
return profile.adduser(username, email, password, {
registry: registry,
opts: fetchOpts.fromPacote(pacoteOpts())
})
}).catch((err) => {
if (err.code === 'EOTP' && !auth.otp) {
return read.otp('Authenticator provided OTP:').then((otp) => {
auth.otp = otp
return profile.login(username, password, {registry: registry, auth: auth})
})
} else {
throw err
}
})
}).then((result) => {
const newCreds = {}
if (result && result.token) {
newCreds.token = result.token
} else {
newCreds.username = username
newCreds.password = password
newCreds.email = email
newCreds.alwaysAuth = npm.config.get('always-auth')
}
log.info('adduser', 'Authorized user %s', username)
const scopeMessage = scope ? ' to scope ' + scope : ''
output('Logged in as %s%s on %s.', username, scopeMessage, registry)
cb(null, newCreds)
}).catch(cb)
}