Current File : //usr/lib/node_modules/npm/lib/config/figgy-config.js |
'use strict'
const BB = require('bluebird')
const crypto = require('crypto')
const figgyPudding = require('figgy-pudding')
const log = require('npmlog')
const npm = require('../npm.js')
const pack = require('../pack.js')
const path = require('path')
const npmSession = npm.session = crypto.randomBytes(8).toString('hex')
log.verbose('npm-session', npmSession)
const SCOPE_REGISTRY_REGEX = /@.*:registry$/gi
const NpmConfig = figgyPudding({}, {
other (key) {
return key.match(SCOPE_REGISTRY_REGEX)
}
})
let baseConfig
module.exports = mkConfig
function mkConfig (...providers) {
if (!baseConfig) {
baseConfig = NpmConfig(npm.config, {
// Add some non-npm-config opts by hand.
cache: path.join(npm.config.get('cache'), '_cacache'),
// NOTE: npm has some magic logic around color distinct from the config
// value, so we have to override it here
color: !!npm.color,
dirPacker: pack.packGitDep,
hashAlgorithm: 'sha1',
includeDeprecated: false,
log,
'npm-session': npmSession,
'project-scope': npm.projectScope,
refer: npm.referer,
dmode: npm.modes.exec,
fmode: npm.modes.file,
umask: npm.modes.umask,
npmVersion: npm.version,
tmp: npm.tmp,
Promise: BB
})
const ownerStats = calculateOwner()
if (ownerStats.uid != null || ownerStats.gid != null) {
baseConfig = baseConfig.concat(ownerStats)
}
}
let conf = baseConfig.concat(...providers)
// Adapt some other configs if missing
if (npm.config.get('prefer-online') === undefined) {
conf = conf.concat({
'prefer-online': npm.config.get('cache-max') <= 0
})
}
if (npm.config.get('prefer-online') === undefined) {
conf = conf.concat({
'prefer-online': npm.config.get('cache-min') >= 9999
})
}
return conf
}
let effectiveOwner
function calculateOwner () {
if (!effectiveOwner) {
effectiveOwner = { uid: 0, gid: 0 }
// Pretty much only on windows
if (!process.getuid) {
return effectiveOwner
}
effectiveOwner.uid = +process.getuid()
effectiveOwner.gid = +process.getgid()
if (effectiveOwner.uid === 0) {
if (process.env.SUDO_UID) effectiveOwner.uid = +process.env.SUDO_UID
if (process.env.SUDO_GID) effectiveOwner.gid = +process.env.SUDO_GID
}
}
return effectiveOwner
}