SILENT KILLERPanel

Current Path: > > lib > node_modules > npm > lib


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //lib/node_modules/npm/lib

NameTypeSizeLast ModifiedActions
auth Directory - -
config Directory - -
doctor Directory - -
install Directory - -
search Directory - -
utils Directory - -
access.js File 5672 bytes March 10 2021 14:36:36.
adduser.js File 1337 bytes March 10 2021 14:36:36.
audit.js File 10811 bytes March 10 2021 14:36:36.
bin.js File 515 bytes March 10 2021 14:36:36.
bugs.js File 864 bytes March 10 2021 14:36:35.
build.js File 4545 bytes March 10 2021 14:36:36.
cache.js File 4773 bytes March 10 2021 14:36:36.
ci.js File 1341 bytes March 10 2021 14:36:36.
completion.js File 7278 bytes March 10 2021 14:36:36.
config.js File 7612 bytes March 10 2021 14:36:36.
dedupe.js File 4999 bytes March 10 2021 14:36:35.
deprecate.js File 2157 bytes March 10 2021 14:36:35.
dist-tag.js File 4204 bytes March 10 2021 14:36:36.
docs.js File 1063 bytes March 10 2021 14:36:36.
doctor.js File 4075 bytes March 10 2021 14:36:35.
edit.js File 1407 bytes March 10 2021 14:36:36.
explore.js File 1709 bytes March 10 2021 14:36:36.
fetch-package-metadata.js File 4064 bytes March 10 2021 14:36:36.
fetch-package-metadata.md File 1811 bytes March 10 2021 14:36:36.
fund.js File 5026 bytes March 10 2021 14:36:36.
get.js File 235 bytes March 10 2021 14:36:36.
help-search.js File 5777 bytes March 10 2021 14:36:36.
help.js File 6507 bytes March 10 2021 14:36:36.
hook.js File 4727 bytes March 10 2021 14:36:35.
init.js File 2805 bytes March 10 2021 14:36:36.
install-ci-test.js File 486 bytes March 10 2021 14:36:36.
install-test.js File 507 bytes March 10 2021 14:36:36.
install.js File 37345 bytes March 10 2021 14:36:36.
link.js File 5739 bytes March 10 2021 14:36:36.
logout.js File 1289 bytes March 10 2021 14:36:36.
ls.js File 16480 bytes March 10 2021 14:36:36.
npm.js File 14719 bytes March 10 2021 14:36:36.
org.js File 4276 bytes March 10 2021 14:36:36.
outdated.js File 12572 bytes March 10 2021 14:36:35.
owner.js File 6754 bytes March 10 2021 14:36:36.
pack.js File 12068 bytes March 10 2021 14:36:36.
ping.js File 1141 bytes March 10 2021 14:36:36.
prefix.js File 330 bytes March 10 2021 14:36:36.
profile.js File 11401 bytes March 10 2021 14:36:36.
prune.js File 2281 bytes March 10 2021 14:36:36.
publish.js File 5264 bytes March 10 2021 14:36:36.
rebuild.js File 2143 bytes March 10 2021 14:36:36.
repo.js File 1471 bytes March 10 2021 14:36:35.
restart.js File 64 bytes March 10 2021 14:36:36.
root.js File 320 bytes March 10 2021 14:36:35.
run-script.js File 5540 bytes March 10 2021 14:36:36.
search.js File 3442 bytes March 10 2021 14:36:36.
set.js File 276 bytes March 10 2021 14:36:36.
shrinkwrap.js File 10056 bytes March 10 2021 14:36:36.
star.js File 2157 bytes March 10 2021 14:36:36.
stars.js File 1054 bytes March 10 2021 14:36:36.
start.js File 62 bytes March 10 2021 14:36:36.
stop.js File 61 bytes March 10 2021 14:36:36.
substack.js File 509 bytes March 10 2021 14:36:36.
team.js File 4724 bytes March 10 2021 14:36:36.
test.js File 374 bytes March 10 2021 14:36:36.
token.js File 6818 bytes March 10 2021 14:36:36.
unbuild.js File 4374 bytes March 10 2021 14:36:36.
uninstall.js File 2261 bytes March 10 2021 14:36:35.
unpublish.js File 3594 bytes March 10 2021 14:36:36.
update.js File 2213 bytes March 10 2021 14:36:36.
version.js File 10029 bytes March 10 2021 14:36:36.
view.js File 15473 bytes March 10 2021 14:36:36.
visnup.js File 4104 bytes March 10 2021 14:36:35.
whoami.js File 1809 bytes March 10 2021 14:36:36.
xmas.js File 1663 bytes March 10 2021 14:36:35.

Reading File: //lib/node_modules/npm/lib/version.js

'use strict'
const BB = require('bluebird')

const assert = require('assert')
const chain = require('slide').chain
const detectIndent = require('detect-indent')
const detectNewline = require('detect-newline')
const fs = require('graceful-fs')
const readFile = BB.promisify(require('graceful-fs').readFile)
const git = require('./utils/git.js')
const lifecycle = require('./utils/lifecycle.js')
const log = require('npmlog')
const npm = require('./npm.js')
const output = require('./utils/output.js')
const parseJSON = require('./utils/parse-json.js')
const path = require('path')
const semver = require('semver')
const stringifyPackage = require('stringify-package')
const writeFileAtomic = require('write-file-atomic')

version.usage = 'npm version [<newversion> | major | minor | patch | premajor | preminor | prepatch | prerelease [--preid=<prerelease-id>] | from-git]' +
                '\n(run in package dir)\n' +
                "'npm -v' or 'npm --version' to print npm version " +
                '(' + npm.version + ')\n' +
                "'npm view <pkg> version' to view a package's " +
                'published version\n' +
                "'npm ls' to inspect current package/dependency versions"

// npm version <newver>
module.exports = version
function version (args, silent, cb_) {
  if (typeof cb_ !== 'function') {
    cb_ = silent
    silent = false
  }
  if (args.length > 1) return cb_(version.usage)

  readPackage(function (er, data, indent, newline) {
    if (!args.length) return dump(data, cb_)

    if (er) {
      log.error('version', 'No valid package.json found')
      return cb_(er)
    }

    if (args[0] === 'from-git') {
      retrieveTagVersion(silent, data, cb_)
    } else {
      var newVersion = semver.valid(args[0])
      if (!newVersion) newVersion = semver.inc(data.version, args[0], npm.config.get('preid'))
      if (!newVersion) return cb_(version.usage)
      persistVersion(newVersion, silent, data, cb_)
    }
  })
}

function retrieveTagVersion (silent, data, cb_) {
  chain([
    verifyGit,
    parseLastGitTag
  ], function (er, results) {
    if (er) return cb_(er)
    var localData = {
      hasGit: true,
      existingTag: true
    }

    var version = results[results.length - 1]
    persistVersion(version, silent, data, localData, cb_)
  })
}

function parseLastGitTag (cb) {
  var options = { env: process.env }
  git.whichAndExec(['describe', '--abbrev=0'], options, function (er, stdout) {
    if (er) {
      if (er.message.indexOf('No names found') !== -1) return cb(new Error('No tags found'))
      return cb(er)
    }

    var tag = stdout.trim()
    var prefix = npm.config.get('tag-version-prefix')
    // Strip the prefix from the start of the tag:
    if (tag.indexOf(prefix) === 0) tag = tag.slice(prefix.length)
    var version = semver.valid(tag)
    if (!version) return cb(new Error(tag + ' is not a valid version'))
    cb(null, version)
  })
}

function persistVersion (newVersion, silent, data, localData, cb_) {
  if (typeof localData === 'function') {
    cb_ = localData
    localData = {}
  }

  if (!npm.config.get('allow-same-version') && data.version === newVersion) {
    return cb_(new Error('Version not changed, might want --allow-same-version'))
  }
  data.version = newVersion
  var lifecycleData = Object.create(data)
  lifecycleData._id = data.name + '@' + newVersion

  var where = npm.prefix
  chain([
    !localData.hasGit && [checkGit, localData],
    [lifecycle, lifecycleData, 'preversion', where],
    [updatePackage, newVersion, silent],
    [lifecycle, lifecycleData, 'version', where],
    [commit, localData, newVersion],
    [lifecycle, lifecycleData, 'postversion', where]
  ], cb_)
}

function readPackage (cb) {
  var packagePath = path.join(npm.localPrefix, 'package.json')
  fs.readFile(packagePath, 'utf8', function (er, data) {
    if (er) return cb(new Error(er))
    var indent
    var newline
    try {
      indent = detectIndent(data).indent
      newline = detectNewline(data)
      data = JSON.parse(data)
    } catch (e) {
      er = e
      data = null
    }
    cb(er, data, indent, newline)
  })
}

function updatePackage (newVersion, silent, cb_) {
  function cb (er) {
    if (!er && !silent) output('v' + newVersion)
    cb_(er)
  }

  readPackage(function (er, data, indent, newline) {
    if (er) return cb(new Error(er))
    data.version = newVersion
    write(data, 'package.json', indent, newline, cb)
  })
}

function commit (localData, newVersion, cb) {
  updateShrinkwrap(newVersion, function (er, hasShrinkwrap, hasLock) {
    if (er || !localData.hasGit) return cb(er)
    localData.hasShrinkwrap = hasShrinkwrap
    localData.hasPackageLock = hasLock
    _commit(newVersion, localData, cb)
  })
}

const SHRINKWRAP = 'npm-shrinkwrap.json'
const PKGLOCK = 'package-lock.json'

function readLockfile (name) {
  return readFile(
    path.join(npm.localPrefix, name), 'utf8'
  ).catch({code: 'ENOENT'}, () => null)
}

function updateShrinkwrap (newVersion, cb) {
  BB.join(
    readLockfile(SHRINKWRAP),
    readLockfile(PKGLOCK),
    (shrinkwrap, lockfile) => {
      if (!shrinkwrap && !lockfile) {
        return cb(null, false, false)
      }
      const file = shrinkwrap ? SHRINKWRAP : PKGLOCK
      let data
      let indent
      let newline
      try {
        data = parseJSON(shrinkwrap || lockfile)
        indent = detectIndent(shrinkwrap || lockfile).indent
        newline = detectNewline(shrinkwrap || lockfile)
      } catch (err) {
        log.error('version', `Bad ${file} data.`)
        return cb(err)
      }
      data.version = newVersion
      write(data, file, indent, newline, (err) => {
        if (err) {
          log.error('version', `Failed to update version in ${file}`)
          return cb(err)
        } else {
          return cb(null, !!shrinkwrap, !!lockfile)
        }
      })
    }
  )
}

function dump (data, cb) {
  var v = {}

  if (data && data.name && data.version) v[data.name] = data.version
  v.npm = npm.version
  Object.keys(process.versions).sort().forEach(function (k) {
    v[k] = process.versions[k]
  })

  if (npm.config.get('json')) v = JSON.stringify(v, null, 2)

  output(v)
  cb()
}

function statGitFolder (cb) {
  fs.stat(path.join(npm.localPrefix, '.git'), cb)
}

function callGitStatus (cb) {
  git.whichAndExec(
    [ 'status', '--porcelain' ],
    { env: process.env },
    cb
  )
}

function cleanStatusLines (stdout) {
  var lines = stdout.trim().split('\n').filter(function (line) {
    return line.trim() && !line.match(/^\?\? /)
  }).map(function (line) {
    return line.trim()
  })

  return lines
}

function verifyGit (cb) {
  function checkStatus (er) {
    if (er) return cb(er)
    callGitStatus(checkStdout)
  }

  function checkStdout (er, stdout) {
    if (er) return cb(er)
    var lines = cleanStatusLines(stdout)
    if (lines.length > 0) {
      return cb(new Error(
        'Git working directory not clean.\n' + lines.join('\n')
      ))
    }

    cb()
  }

  statGitFolder(checkStatus)
}

function checkGit (localData, cb) {
  statGitFolder(function (er) {
    var doGit = !er && npm.config.get('git-tag-version')
    if (!doGit) {
      if (er && npm.config.get('git-tag-version')) log.verbose('version', 'error checking for .git', er)
      log.verbose('version', 'not tagging in git')
      return cb(null, false)
    }

    // check for git
    callGitStatus(function (er, stdout) {
      if (er && er.code === 'ENOGIT') {
        log.warn(
          'version',
          'This is a Git checkout, but the git command was not found.',
          'npm could not create a Git tag for this release!'
        )
        return cb(null, false)
      }

      var lines = cleanStatusLines(stdout)
      if (lines.length && !npm.config.get('force')) {
        return cb(new Error(
          'Git working directory not clean.\n' + lines.join('\n')
        ))
      }
      localData.hasGit = true
      cb(null, true)
    })
  })
}

module.exports.buildCommitArgs = buildCommitArgs
function buildCommitArgs (args) {
  const add = []
  args = args || []
  if (args[0] === 'commit') args.shift()
  if (!npm.config.get('commit-hooks')) add.push('-n')
  if (npm.config.get('allow-same-version')) add.push('--allow-empty')
  return ['commit', ...add, ...args]
}

module.exports.buildTagFlags = buildTagFlags
function buildTagFlags () {
  return '-'.concat(
    npm.config.get('sign-git-tag') ? 's' : '',
    npm.config.get('allow-same-version') ? 'f' : '',
    'm'
  )
}

function _commit (version, localData, cb) {
  const options = { env: process.env }
  const message = npm.config.get('message').replace(/%s/g, version)
  const signCommit = npm.config.get('sign-git-commit')
  const commitArgs = buildCommitArgs([
    'commit',
    ...(signCommit ? ['-S', '-m'] : ['-m']),
    message
  ])

  stagePackageFiles(localData, options).then(() => {
    return git.exec(commitArgs, options)
  }).then(() => {
    if (!localData.existingTag) {
      return git.exec([
        'tag', npm.config.get('tag-version-prefix') + version,
        buildTagFlags(), message
      ], options)
    }
  }).nodeify(cb)
}

function stagePackageFiles (localData, options) {
  return addLocalFile('package.json', options, false).then(() => {
    if (localData.hasShrinkwrap) {
      return addLocalFile('npm-shrinkwrap.json', options, true)
    } else if (localData.hasPackageLock) {
      return addLocalFile('package-lock.json', options, true)
    }
  })
}

function addLocalFile (file, options, ignoreFailure) {
  const p = git.exec(['add', path.join(npm.localPrefix, file)], options)
  return ignoreFailure
    ? p.catch(() => {})
    : p
}

function write (data, file, indent, newline, cb) {
  assert(data && typeof data === 'object', 'must pass data to version write')
  assert(typeof file === 'string', 'must pass filename to write to version write')

  log.verbose('version.write', 'data', data, 'to', file)
  writeFileAtomic(
    path.join(npm.localPrefix, file),
    stringifyPackage(data, indent, newline),
    cb
  )
}

SILENT KILLER Tool