12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- 'use strict'
- const read = require('../utils/read-user-info.js')
- const profile = require('libnpm/profile')
- const log = require('npmlog')
- const figgyPudding = require('figgy-pudding')
- const npmConfig = require('../config/figgy-config.js')
- const output = require('../utils/output.js')
- const openUrl = require('../utils/open-url')
- const openerPromise = (url) => new Promise((resolve, reject) => {
- openUrl(url, 'to complete your login please visit', (er) => er ? reject(er) : resolve())
- })
- const loginPrompter = (creds) => {
- const opts = { log: log }
- return read.username('Username:', creds.username, opts).then((u) => {
- creds.username = u
- return read.password('Password:', creds.password)
- }).then((p) => {
- creds.password = p
- return read.email('Email: (this IS public) ', creds.email, opts)
- }).then((e) => {
- creds.email = e
- return creds
- })
- }
- const LoginOpts = figgyPudding({
- 'always-auth': {},
- creds: {},
- log: {default: () => log},
- registry: {},
- scope: {}
- })
- module.exports.login = (creds = {}, registry, scope, cb) => {
- const opts = LoginOpts(npmConfig()).concat({scope, registry, creds})
- login(opts).then((newCreds) => cb(null, newCreds)).catch(cb)
- }
- function login (opts) {
- return profile.login(openerPromise, loginPrompter, opts)
- .catch((err) => {
- if (err.code === 'EOTP') throw err
- const u = opts.creds.username
- const p = opts.creds.password
- const e = opts.creds.email
- if (!(u && p && e)) throw err
- return profile.adduserCouch(u, e, p, opts)
- })
- .catch((err) => {
- if (err.code !== 'EOTP') throw err
- return read.otp(
- 'Enter one-time password from your authenticator app: '
- ).then(otp => {
- const u = opts.creds.username
- const p = opts.creds.password
- return profile.loginCouch(u, p, opts.concat({otp}))
- })
- }).then((result) => {
- const newCreds = {}
- if (result && result.token) {
- newCreds.token = result.token
- } else {
- newCreds.username = opts.creds.username
- newCreds.password = opts.creds.password
- newCreds.email = opts.creds.email
- newCreds.alwaysAuth = opts['always-auth']
- }
- const usermsg = opts.creds.username ? ' user ' + opts.creds.username : ''
- opts.log.info('login', 'Authorized' + usermsg)
- const scopeMessage = opts.scope ? ' to scope ' + opts.scope : ''
- const userout = opts.creds.username ? ' as ' + opts.creds.username : ''
- output('Logged in%s%s on %s.', userout, scopeMessage, opts.registry)
- return newCreds
- })
- }
|