1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
var url = require('url')
var log = require('npmlog')
var npa = require('npm-package-arg')
var config
module.exports = mapToRegistry
function mapToRegistry (name, config, cb) {
log.silly('mapToRegistry', 'name', name)
var registry
// the name itself takes precedence
var data = npa(name)
if (data.scope) {
// the name is definitely scoped, so escape now
name = name.replace('/', '%2f')
log.silly('mapToRegistry', 'scope (from package name)', data.scope)
registry = config.get(data.scope + ':registry')
if (!registry) {
log.verbose('mapToRegistry', 'no registry URL found in name for scope', data.scope)
}
}
// ...then --scope=@scope or --scope=scope
var scope = config.get('scope')
if (!registry && scope) {
// I'm an enabler, sorry
if (scope.charAt(0) !== '@') scope = '@' + scope
log.silly('mapToRegistry', 'scope (from config)', scope)
registry = config.get(scope + ':registry')
if (!registry) {
log.verbose('mapToRegistry', 'no registry URL found in config for scope', scope)
}
}
// ...and finally use the default registry
if (!registry) {
log.silly('mapToRegistry', 'using default registry')
registry = config.get('registry')
}
log.silly('mapToRegistry', 'registry', registry)
var auth = config.getCredentialsByURI(registry)
// normalize registry URL so resolution doesn't drop a piece of registry URL
var normalized = registry.slice(-1) !== '/' ? registry + '/' : registry
var uri
log.silly('mapToRegistry', 'data', data)
if (data.type === 'remote') {
uri = data.fetchSpec
} else {
uri = url.resolve(normalized, name)
}
log.silly('mapToRegistry', 'uri', uri)
cb(null, uri, scopeAuth(uri, registry, auth), normalized)
}
function scopeAuth (uri, registry, auth) {
var cleaned = {
scope: auth.scope,
email: auth.email,
alwaysAuth: auth.alwaysAuth,
token: undefined,
username: undefined,
password: undefined,
auth: undefined
}
var requestHost
var registryHost
if (auth.token || auth.auth || (auth.username && auth.password)) {
requestHost = url.parse(uri).hostname
registryHost = url.parse(registry).hostname
if (requestHost === registryHost) {
cleaned.token = auth.token
cleaned.auth = auth.auth
cleaned.username = auth.username
cleaned.password = auth.password
} else if (auth.alwaysAuth) {
log.verbose('scopeAuth', 'alwaysAuth set for', registry)
cleaned.token = auth.token
cleaned.auth = auth.auth
cleaned.username = auth.username
cleaned.password = auth.password
} else {
log.silly('scopeAuth', uri, "doesn't share host with registry", registry)
}
if (!config) config = require('../npm').config
if (config.get('otp')) cleaned.otp = config.get('otp')
}
return cleaned
}
|