summaryrefslogtreecommitdiff
path: root/deps/node/deps/npm/node_modules/pacote/lib/util
diff options
context:
space:
mode:
Diffstat (limited to 'deps/node/deps/npm/node_modules/pacote/lib/util')
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/cache-key.js6
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/finished.js17
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/git.js272
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/opt-check.js47
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/pack-dir.js44
-rw-r--r--deps/node/deps/npm/node_modules/pacote/lib/util/proclog.js23
6 files changed, 0 insertions, 409 deletions
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/cache-key.js b/deps/node/deps/npm/node_modules/pacote/lib/util/cache-key.js
deleted file mode 100644
index 157e60b0..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/cache-key.js
+++ /dev/null
@@ -1,6 +0,0 @@
-'use strict'
-
-module.exports = cacheKey
-function cacheKey (type, identifier) {
- return ['pacote', type, identifier].join(':')
-}
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/finished.js b/deps/node/deps/npm/node_modules/pacote/lib/util/finished.js
deleted file mode 100644
index 6dadc8b5..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/finished.js
+++ /dev/null
@@ -1,17 +0,0 @@
-'use strict'
-
-const BB = require('bluebird')
-
-module.exports = function (child, hasExitCode = false) {
- return BB.fromNode(function (cb) {
- child.on('error', cb)
- child.on(hasExitCode ? 'close' : 'end', function (exitCode) {
- if (exitCode === undefined || exitCode === 0) {
- cb()
- } else {
- let err = new Error('exited with error code: ' + exitCode)
- cb(err)
- }
- })
- })
-}
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/git.js b/deps/node/deps/npm/node_modules/pacote/lib/util/git.js
deleted file mode 100644
index 997404dd..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/git.js
+++ /dev/null
@@ -1,272 +0,0 @@
-'use strict'
-
-const BB = require('bluebird')
-
-const cp = require('child_process')
-const execFileAsync = BB.promisify(cp.execFile, {
- multiArgs: true
-})
-const finished = require('./finished')
-const LRU = require('lru-cache')
-const optCheck = require('./opt-check')
-const osenv = require('osenv')
-const path = require('path')
-const pinflight = require('promise-inflight')
-const promiseRetry = require('promise-retry')
-const uniqueFilename = require('unique-filename')
-const which = BB.promisify(require('which'))
-const semver = require('semver')
-
-const GOOD_ENV_VARS = new Set([
- 'GIT_ASKPASS',
- 'GIT_EXEC_PATH',
- 'GIT_PROXY_COMMAND',
- 'GIT_SSH',
- 'GIT_SSH_COMMAND',
- 'GIT_SSL_CAINFO',
- 'GIT_SSL_NO_VERIFY'
-])
-
-const GIT_TRANSIENT_ERRORS = [
- 'remote error: Internal Server Error',
- 'The remote end hung up unexpectedly',
- 'Connection timed out',
- 'Operation timed out',
- 'Failed to connect to .* Timed out',
- 'Connection reset by peer',
- 'SSL_ERROR_SYSCALL',
- 'The requested URL returned error: 503'
-].join('|')
-
-const GIT_TRANSIENT_ERROR_RE = new RegExp(GIT_TRANSIENT_ERRORS)
-
-function shouldRetry (error) {
- return GIT_TRANSIENT_ERROR_RE.test(error)
-}
-
-const GIT_ = 'GIT_'
-let GITENV
-function gitEnv () {
- if (GITENV) { return GITENV }
- const tmpDir = path.join(osenv.tmpdir(), 'pacote-git-template-tmp')
- const tmpName = uniqueFilename(tmpDir, 'git-clone')
- GITENV = {
- GIT_ASKPASS: 'echo',
- GIT_TEMPLATE_DIR: tmpName
- }
- Object.keys(process.env).forEach(k => {
- if (GOOD_ENV_VARS.has(k) || !k.startsWith(GIT_)) {
- GITENV[k] = process.env[k]
- }
- })
- return GITENV
-}
-
-let GITPATH
-try {
- GITPATH = which.sync('git')
-} catch (e) {}
-
-module.exports.clone = fullClone
-function fullClone (repo, committish, target, opts) {
- opts = optCheck(opts)
- const gitArgs = ['clone', '--mirror', '-q', repo, path.join(target, '.git')]
- if (process.platform === 'win32') {
- gitArgs.push('--config', 'core.longpaths=true')
- }
- return execGit(gitArgs, { cwd: target }, opts).then(() => {
- return execGit(['init'], { cwd: target }, opts)
- }).then(() => {
- return execGit(['checkout', committish || 'HEAD'], { cwd: target }, opts)
- }).then(() => {
- return updateSubmodules(target, opts)
- }).then(() => headSha(target, opts))
-}
-
-module.exports.shallow = shallowClone
-function shallowClone (repo, branch, target, opts) {
- opts = optCheck(opts)
- const gitArgs = ['clone', '--depth=1', '-q']
- if (branch) {
- gitArgs.push('-b', branch)
- }
- gitArgs.push(repo, target)
- if (process.platform === 'win32') {
- gitArgs.push('--config', 'core.longpaths=true')
- }
- return execGit(gitArgs, {
- cwd: target
- }, opts).then(() => {
- return updateSubmodules(target, opts)
- }).then(() => headSha(target, opts))
-}
-
-function updateSubmodules (localRepo, opts) {
- const gitArgs = ['submodule', 'update', '-q', '--init', '--recursive']
- return execGit(gitArgs, {
- cwd: localRepo
- }, opts)
-}
-
-function headSha (repo, opts) {
- opts = optCheck(opts)
- return execGit(['rev-parse', '--revs-only', 'HEAD'], { cwd: repo }, opts).spread(stdout => {
- return stdout.trim()
- })
-}
-
-const CARET_BRACES = '^{}'
-const REVS = new LRU({
- max: 100,
- maxAge: 5 * 60 * 1000
-})
-module.exports.revs = revs
-function revs (repo, opts) {
- opts = optCheck(opts)
- const cached = REVS.get(repo)
- if (cached) {
- return BB.resolve(cached)
- }
- return pinflight(`ls-remote:${repo}`, () => {
- return spawnGit(['ls-remote', '-h', '-t', repo], {
- env: gitEnv()
- }, opts).then((stdout) => {
- return stdout.split('\n').reduce((revs, line) => {
- const split = line.split(/\s+/, 2)
- if (split.length < 2) { return revs }
- const sha = split[0].trim()
- const ref = split[1].trim().match(/(?:refs\/[^/]+\/)?(.*)/)[1]
- if (!ref) { return revs } // ???
- if (ref.endsWith(CARET_BRACES)) { return revs } // refs/tags/x^{} crap
- const type = refType(line)
- const doc = { sha, ref, type }
-
- revs.refs[ref] = doc
- // We can check out shallow clones on specific SHAs if we have a ref
- if (revs.shas[sha]) {
- revs.shas[sha].push(ref)
- } else {
- revs.shas[sha] = [ref]
- }
-
- if (type === 'tag') {
- const match = ref.match(/v?(\d+\.\d+\.\d+(?:[-+].+)?)$/)
- if (match && semver.valid(match[1], true)) {
- revs.versions[semver.clean(match[1], true)] = doc
- }
- }
-
- return revs
- }, { versions: {}, 'dist-tags': {}, refs: {}, shas: {} })
- }, err => {
- err.message = `Error while executing:\n${GITPATH} ls-remote -h -t ${repo}\n\n${err.stderr}\n${err.message}`
- throw err
- }).then(revs => {
- if (revs.refs.HEAD) {
- const HEAD = revs.refs.HEAD
- Object.keys(revs.versions).forEach(v => {
- if (v.sha === HEAD.sha) {
- revs['dist-tags'].HEAD = v
- if (!revs.refs.latest) {
- revs['dist-tags'].latest = revs.refs.HEAD
- }
- }
- })
- }
- REVS.set(repo, revs)
- return revs
- })
- })
-}
-
-module.exports._exec = execGit
-function execGit (gitArgs, gitOpts, opts) {
- opts = optCheck(opts)
- return checkGit(opts).then(gitPath => {
- return promiseRetry((retry, number) => {
- if (number !== 1) {
- opts.log.silly('pacote', 'Retrying git command: ' + gitArgs.join(' ') + ' attempt # ' + number)
- }
- return execFileAsync(gitPath, gitArgs, mkOpts(gitOpts, opts)).catch((err) => {
- if (shouldRetry(err)) {
- retry(err)
- } else {
- throw err
- }
- })
- }, opts.retry != null ? opts.retry : {
- retries: opts['fetch-retries'],
- factor: opts['fetch-retry-factor'],
- maxTimeout: opts['fetch-retry-maxtimeout'],
- minTimeout: opts['fetch-retry-mintimeout']
- })
- })
-}
-
-module.exports._spawn = spawnGit
-function spawnGit (gitArgs, gitOpts, opts) {
- opts = optCheck(opts)
- return checkGit(opts).then(gitPath => {
- return promiseRetry((retry, number) => {
- if (number !== 1) {
- opts.log.silly('pacote', 'Retrying git command: ' + gitArgs.join(' ') + ' attempt # ' + number)
- }
- const child = cp.spawn(gitPath, gitArgs, mkOpts(gitOpts, opts))
-
- let stdout = ''
- let stderr = ''
- child.stdout.on('data', d => { stdout += d })
- child.stderr.on('data', d => { stderr += d })
-
- return finished(child, true).catch(err => {
- if (shouldRetry(stderr)) {
- retry(err)
- } else {
- err.stderr = stderr
- throw err
- }
- }).then(() => {
- return stdout
- })
- }, opts.retry)
- })
-}
-
-function mkOpts (_gitOpts, opts) {
- const gitOpts = {
- env: gitEnv()
- }
- if (+opts.uid && !isNaN(opts.uid)) {
- gitOpts.uid = +opts.uid
- }
- if (+opts.gid && !isNaN(opts.gid)) {
- gitOpts.gid = +opts.gid
- }
- Object.assign(gitOpts, _gitOpts)
- return gitOpts
-}
-
-function checkGit (opts) {
- if (opts.git) {
- return BB.resolve(opts.git)
- } else if (!GITPATH) {
- const err = new Error('No git binary found in $PATH')
- err.code = 'ENOGIT'
- return BB.reject(err)
- } else {
- return BB.resolve(GITPATH)
- }
-}
-
-const REFS_TAGS = 'refs/tags/'
-const REFS_HEADS = 'refs/heads/'
-const HEAD = 'HEAD'
-function refType (ref) {
- return ref.indexOf(REFS_TAGS) !== -1
- ? 'tag'
- : ref.indexOf(REFS_HEADS) !== -1
- ? 'branch'
- : ref.endsWith(HEAD)
- ? 'head'
- : 'other'
-}
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/opt-check.js b/deps/node/deps/npm/node_modules/pacote/lib/util/opt-check.js
deleted file mode 100644
index e6afc21c..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/opt-check.js
+++ /dev/null
@@ -1,47 +0,0 @@
-'use strict'
-
-const figgyPudding = require('figgy-pudding')
-const logger = require('./proclog.js')
-
-const AUTH_REGEX = /^(?:.*:)?(token|_authToken|username|_password|password|email|always-auth|_auth|otp)$/
-const SCOPE_REGISTRY_REGEX = /@.*:registry$/gi
-module.exports = figgyPudding({
- annotate: {},
- cache: {},
- defaultTag: 'tag',
- dirPacker: {},
- dmode: {},
- 'enjoy-by': 'enjoyBy',
- enjoyBy: {},
- fmode: {},
- 'fetch-retries': { default: 2 },
- 'fetch-retry-factor': { default: 10 },
- 'fetch-retry-maxtimeout': { default: 60000 },
- 'fetch-retry-mintimeout': { default: 10000 },
- fullMetadata: 'full-metadata',
- 'full-metadata': { default: false },
- gid: {},
- git: {},
- includeDeprecated: { default: true },
- 'include-deprecated': 'includeDeprecated',
- integrity: {},
- log: { default: logger },
- memoize: {},
- offline: {},
- preferOffline: 'prefer-offline',
- 'prefer-offline': {},
- preferOnline: 'prefer-online',
- 'prefer-online': {},
- registry: { default: 'https://registry.npmjs.org/' },
- resolved: {},
- retry: {},
- scope: {},
- tag: { default: 'latest' },
- uid: {},
- umask: {},
- where: {}
-}, {
- other (key) {
- return key.match(AUTH_REGEX) || key.match(SCOPE_REGISTRY_REGEX)
- }
-})
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/pack-dir.js b/deps/node/deps/npm/node_modules/pacote/lib/util/pack-dir.js
deleted file mode 100644
index 157a9a82..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/pack-dir.js
+++ /dev/null
@@ -1,44 +0,0 @@
-'use strict'
-
-const BB = require('bluebird')
-
-const cacache = require('cacache')
-const cacheKey = require('./cache-key')
-const optCheck = require('./opt-check')
-const packlist = require('npm-packlist')
-const pipe = BB.promisify(require('mississippi').pipe)
-const tar = require('tar')
-
-module.exports = packDir
-function packDir (manifest, label, dir, target, opts) {
- opts = optCheck(opts)
-
- const packer = opts.dirPacker
- ? BB.resolve(opts.dirPacker(manifest, dir))
- : mkPacker(dir)
-
- if (!opts.cache) {
- return packer.then(packer => pipe(packer, target))
- } else {
- const cacher = cacache.put.stream(
- opts.cache, cacheKey('packed-dir', label), opts
- ).on('integrity', i => {
- target.emit('integrity', i)
- })
- return packer.then(packer => BB.all([
- pipe(packer, cacher),
- pipe(packer, target)
- ]))
- }
-}
-
-function mkPacker (dir) {
- return packlist({ path: dir }).then(files => {
- return tar.c({
- cwd: dir,
- gzip: true,
- portable: true,
- prefix: 'package/'
- }, files)
- })
-}
diff --git a/deps/node/deps/npm/node_modules/pacote/lib/util/proclog.js b/deps/node/deps/npm/node_modules/pacote/lib/util/proclog.js
deleted file mode 100644
index e4a2bf8a..00000000
--- a/deps/node/deps/npm/node_modules/pacote/lib/util/proclog.js
+++ /dev/null
@@ -1,23 +0,0 @@
-'use strict'
-
-const LEVELS = [
- 'notice',
- 'error',
- 'warn',
- 'info',
- 'verbose',
- 'http',
- 'silly',
- 'pause',
- 'resume'
-]
-
-const logger = {}
-for (const level of LEVELS) {
- logger[level] = log(level)
-}
-module.exports = logger
-
-function log (level) {
- return (category, ...args) => process.emit('log', level, category, ...args)
-}