mirror of
https://github.com/nodejs/node.git
synced 2025-05-16 12:34:33 +00:00

PR-URL: https://github.com/nodejs/node/pull/14235 Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Yuta Hiroto <hello@about-hiroppy.com> Reviewed-By: Gibson Fahnestock <gibfahn@gmail.com> Reviewed-By: Tobias Nießen <tniessen@tnie.de> Reviewed-By: James M Snell <jasnell@gmail.com>
73 lines
2.0 KiB
JavaScript
73 lines
2.0 KiB
JavaScript
var assert = require('assert')
|
|
|
|
var toNerfDart = require('./nerf-dart.js')
|
|
|
|
module.exports = getCredentialsByURI
|
|
|
|
function getCredentialsByURI (uri) {
|
|
assert(uri && typeof uri === 'string', 'registry URL is required')
|
|
var nerfed = toNerfDart(uri)
|
|
var defnerf = toNerfDart(this.get('registry'))
|
|
|
|
// hidden class micro-optimization
|
|
var c = {
|
|
scope: nerfed,
|
|
token: undefined,
|
|
password: undefined,
|
|
username: undefined,
|
|
email: undefined,
|
|
auth: undefined,
|
|
alwaysAuth: undefined
|
|
}
|
|
|
|
// used to override scope matching for tokens as well as legacy auth
|
|
if (this.get(nerfed + ':always-auth') !== undefined) {
|
|
var val = this.get(nerfed + ':always-auth')
|
|
c.alwaysAuth = val === 'false' ? false : !!val
|
|
} else if (this.get('always-auth') !== undefined) {
|
|
c.alwaysAuth = this.get('always-auth')
|
|
}
|
|
|
|
if (this.get(nerfed + ':_authToken')) {
|
|
c.token = this.get(nerfed + ':_authToken')
|
|
// the bearer token is enough, don't confuse things
|
|
return c
|
|
}
|
|
|
|
// Handle the old-style _auth=<base64> style for the default
|
|
// registry, if set.
|
|
var authDef = this.get('_auth')
|
|
var userDef = this.get('username')
|
|
var passDef = this.get('_password')
|
|
if (authDef && !(userDef && passDef)) {
|
|
authDef = new Buffer(authDef, 'base64').toString()
|
|
authDef = authDef.split(':')
|
|
userDef = authDef.shift()
|
|
passDef = authDef.join(':')
|
|
}
|
|
|
|
if (this.get(nerfed + ':_password')) {
|
|
c.password = new Buffer(this.get(nerfed + ':_password'), 'base64').toString('utf8')
|
|
} else if (nerfed === defnerf && passDef) {
|
|
c.password = passDef
|
|
}
|
|
|
|
if (this.get(nerfed + ':username')) {
|
|
c.username = this.get(nerfed + ':username')
|
|
} else if (nerfed === defnerf && userDef) {
|
|
c.username = userDef
|
|
}
|
|
|
|
if (this.get(nerfed + ':email')) {
|
|
c.email = this.get(nerfed + ':email')
|
|
} else if (this.get('email')) {
|
|
c.email = this.get('email')
|
|
}
|
|
|
|
if (c.username && c.password) {
|
|
c.auth = new Buffer(c.username + ':' + c.password).toString('base64')
|
|
}
|
|
|
|
return c
|
|
}
|