forked from zkat/pacote
-
Notifications
You must be signed in to change notification settings - Fork 0
/
packument.js
29 lines (26 loc) · 822 Bytes
/
packument.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
'use strict'
const fetchPackument = require('./lib/fetch').packument
const optCheck = require('./lib/util/opt-check')
const pinflight = require('promise-inflight')
const npa = require('npm-package-arg')
module.exports = packument
function packument (spec, opts) {
opts = optCheck(opts)
spec = npa(spec, opts.where)
const label = [
spec.name,
spec.saveSpec || spec.fetchSpec,
spec.type,
opts.cache,
opts.registry,
opts.scope
].join(':')
const startTime = Date.now()
return pinflight(label, () => {
return fetchPackument(spec, opts)
}).then(p => {
const elapsedTime = Date.now() - startTime
opts.log.silly('pacote', `${spec.registry ? 'registry' : spec.type} packument for ${spec.name}@${spec.saveSpec || spec.fetchSpec} fetched in ${elapsedTime}ms`)
return p
})
}