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/publish.js

'use strict'

const BB = require('bluebird')

const cacache = require('cacache')
const figgyPudding = require('figgy-pudding')
const libpub = require('libnpm/publish')
const libunpub = require('libnpm/unpublish')
const lifecycle = BB.promisify(require('./utils/lifecycle.js'))
const log = require('npmlog')
const npa = require('libnpm/parse-arg')
const npmConfig = require('./config/figgy-config.js')
const output = require('./utils/output.js')
const otplease = require('./utils/otplease.js')
const pack = require('./pack')
const { tarball, extract } = require('libnpm')
const path = require('path')
const readFileAsync = BB.promisify(require('graceful-fs').readFile)
const readJson = BB.promisify(require('read-package-json'))
const semver = require('semver')
const statAsync = BB.promisify(require('graceful-fs').stat)

publish.usage = 'npm publish [<tarball>|<folder>] [--tag <tag>] [--access <public|restricted>] [--dry-run]' +
                "\n\nPublishes '.' if no argument supplied" +
                '\n\nSets tag `latest` if no --tag specified'

publish.completion = function (opts, cb) {
  // publish can complete to a folder with a package.json
  // or a tarball, or a tarball url.
  // for now, not yet implemented.
  return cb()
}

const PublishConfig = figgyPudding({
  dryRun: 'dry-run',
  'dry-run': { default: false },
  force: { default: false },
  json: { default: false },
  Promise: { default: () => Promise },
  tag: { default: 'latest' },
  tmp: {}
})

module.exports = publish
function publish (args, isRetry, cb) {
  if (typeof cb !== 'function') {
    cb = isRetry
    isRetry = false
  }
  if (args.length === 0) args = ['.']
  if (args.length !== 1) return cb(publish.usage)

  log.verbose('publish', args)

  const opts = PublishConfig(npmConfig())
  const t = opts.tag.trim()
  if (semver.validRange(t)) {
    return cb(new Error('Tag name must not be a valid SemVer range: ' + t))
  }

  return publish_(args[0], opts)
    .then((tarball) => {
      const silent = log.level === 'silent'
      if (!silent && opts.json) {
        output(JSON.stringify(tarball, null, 2))
      } else if (!silent) {
        output(`+ ${tarball.id}`)
      }
    })
    .nodeify(cb)
}

function publish_ (arg, opts) {
  return statAsync(arg).then((stat) => {
    if (stat.isDirectory()) {
      return stat
    } else {
      const err = new Error('not a directory')
      err.code = 'ENOTDIR'
      throw err
    }
  }).then(() => {
    return publishFromDirectory(arg, opts)
  }, (err) => {
    if (err.code !== 'ENOENT' && err.code !== 'ENOTDIR') {
      throw err
    } else {
      return publishFromPackage(arg, opts)
    }
  })
}

function publishFromDirectory (arg, opts) {
  // All this readJson is because any of the given scripts might modify the
  // package.json in question, so we need to refresh after every step.
  let contents
  return pack.prepareDirectory(arg).then(() => {
    return readJson(path.join(arg, 'package.json'))
  }).then((pkg) => {
    return lifecycle(pkg, 'prepublishOnly', arg)
  }).then(() => {
    return readJson(path.join(arg, 'package.json'))
  }).then((pkg) => {
    return cacache.tmp.withTmp(opts.tmp, {tmpPrefix: 'fromDir'}, (tmpDir) => {
      const target = path.join(tmpDir, 'package.tgz')
      return pack.packDirectory(pkg, arg, target, null, true)
        .tap((c) => { contents = c })
        .then((c) => !opts.json && pack.logContents(c))
        .then(() => upload(pkg, false, target, opts))
    })
  }).then(() => {
    return readJson(path.join(arg, 'package.json'))
  }).tap((pkg) => {
    return lifecycle(pkg, 'publish', arg)
  }).tap((pkg) => {
    return lifecycle(pkg, 'postpublish', arg)
  })
    .then(() => contents)
}

function publishFromPackage (arg, opts) {
  return cacache.tmp.withTmp(opts.tmp, {tmpPrefix: 'fromPackage'}, tmp => {
    const extracted = path.join(tmp, 'package')
    const target = path.join(tmp, 'package.json')
    return tarball.toFile(arg, target, opts)
      .then(() => extract(arg, extracted, opts))
      .then(() => readJson(path.join(extracted, 'package.json')))
      .then((pkg) => {
        return BB.resolve(pack.getContents(pkg, target))
          .tap((c) => !opts.json && pack.logContents(c))
          .tap(() => upload(pkg, false, target, opts))
      })
  })
}

function upload (pkg, isRetry, cached, opts) {
  if (!opts.dryRun) {
    return readFileAsync(cached).then(tarball => {
      return otplease(opts, opts => {
        return libpub(pkg, tarball, opts)
      }).catch(err => {
        if (
          err.code === 'EPUBLISHCONFLICT' &&
          opts.force &&
          !isRetry
        ) {
          log.warn('publish', 'Forced publish over ' + pkg._id)
          return otplease(opts, opts => libunpub(
            npa.resolve(pkg.name, pkg.version), opts
          )).finally(() => {
            // ignore errors.  Use the force.  Reach out with your feelings.
            return otplease(opts, opts => {
              return upload(pkg, true, tarball, opts)
            }).catch(() => {
              // but if it fails again, then report the first error.
              throw err
            })
          })
        } else {
          throw err
        }
      })
    })
  } else {
    return opts.Promise.resolve(true)
  }
}

SILENT KILLER Tool