npmc
Version:
a package manager for JavaScript
83 lines (77 loc) • 2.77 kB
JavaScript
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')
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 profile.login(username, password, {registry: registry, auth: auth}).catch((err) => {
if (err.code === 'EOTP') throw err
return profile.adduser(username, email, password, {registry: registry})
}).catch((err) => {
if (err.code === 'EOTP' && !auth.otp) {
return read.otp('Authenicator 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.alwaysAuth = npm.config.get('always-auth')
}
log.info('login', '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)
}
module.exports.adduser = function adduser (creds, registry, scope, cb) {
let username = creds.username || ''
let password = creds.password || ''
let email = creds.email || ''
const 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.adduser(username, email, password, {registry: registry})
}).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)
}