forked from npm/cli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogout.js
59 lines (49 loc) · 1.61 KB
/
logout.js
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
const log = require('npmlog')
const getAuth = require('npm-registry-fetch/auth.js')
const npmFetch = require('npm-registry-fetch')
const BaseCommand = require('./base-command.js')
class Logout extends BaseCommand {
/* istanbul ignore next - see test/lib/load-all-commands.js */
static get description () {
return 'Log out of the registry'
}
/* istanbul ignore next - see test/lib/load-all-commands.js */
static get name () {
return 'logout'
}
/* istanbul ignore next - see test/lib/load-all-commands.js */
static get params () {
return [
'registry',
'scope',
]
}
exec (args, cb) {
this.logout(args).then(() => cb()).catch(cb)
}
async logout (args) {
const registry = this.npm.config.get('registry')
const scope = this.npm.config.get('scope')
const regRef = scope ? `${scope}:registry` : 'registry'
const reg = this.npm.config.get(regRef) || registry
const auth = getAuth(reg, this.npm.flatOptions)
if (auth.token) {
log.verbose('logout', `clearing token for ${reg}`)
await npmFetch(`/-/user/token/${encodeURIComponent(auth.token)}`, {
...this.npm.flatOptions,
method: 'DELETE',
ignoreBody: true,
})
} else if (auth.isBasicAuth)
log.verbose('logout', `clearing user credentials for ${reg}`)
else {
const msg = `not logged in to ${reg}, so can't log out!`
throw Object.assign(new Error(msg), { code: 'ENEEDAUTH' })
}
if (scope)
this.npm.config.delete(regRef, 'user')
this.npm.config.clearCredentialsByURI(reg)
await this.npm.config.save('user')
}
}
module.exports = Logout