Server IP : 162.0.209.157 / Your IP : 3.141.25.100 [ Web Server : LiteSpeed System : Linux premium178.web-hosting.com 4.18.0-513.24.1.lve.2.el8.x86_64 #1 SMP Fri May 24 12:42:50 UTC 2024 x86_64 User : balaoqob ( 2395) PHP Version : 8.0.30 Disable Function : NONE Domains : 1 Domains MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /usr/lib/node_modules/npm/lib/ |
Upload File : |
'use strict' const BB = require('bluebird') const npmConfig = require('./config/figgy-config.js') const fetch = require('libnpm/fetch') const figgyPudding = require('figgy-pudding') const npm = require('./npm.js') const output = require('./utils/output.js') const WhoamiConfig = figgyPudding({ json: {}, registry: {} }) module.exports = whoami whoami.usage = 'npm whoami [--registry <registry>]\n(just prints username according to given registry)' function whoami ([spec], silent, cb) { // FIXME: need tighter checking on this, but is a breaking change if (typeof cb !== 'function') { cb = silent silent = false } const opts = WhoamiConfig(npmConfig()) return BB.try(() => { // First, check if we have a user/pass-based auth const registry = opts.registry if (!registry) throw new Error('no default registry set') return npm.config.getCredentialsByURI(registry) }).then(({username, token}) => { if (username) { return username } else if (token) { return fetch.json('/-/whoami', opts.concat({ spec })).then(({username}) => { if (username) { return username } else { throw Object.assign(new Error( 'Your auth token is no longer valid. Please log in again.' ), {code: 'ENEEDAUTH'}) } }) } else { // At this point, if they have a credentials object, it doesn't have a // token or auth in it. Probably just the default registry. throw Object.assign(new Error( 'This command requires you to be logged in.' ), {code: 'ENEEDAUTH'}) } }).then(username => { if (silent) { } else if (opts.json) { output(JSON.stringify(username)) } else { output(username) } return username }).nodeify(cb) }