$50 GRAYBYTE WORDPRESS FILE MANAGER $53

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 172.67.162.162 | ADMIN IP 216.73.217.83
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/alt-nodejs24/root/usr/lib/node_modules/npm/lib/commands/

HOME
Current File : /opt/alt/alt-nodejs24/root/usr/lib/node_modules/npm/lib/commands//outdated.js
const { resolve } = require('node:path')
const { stripVTControlCharacters } = require('node:util')
const pacote = require('pacote')
const table = require('text-table')
const npa = require('npm-package-arg')
const pickManifest = require('npm-pick-manifest')
const { output } = require('proc-log')
const localeCompare = require('@isaacs/string-locale-compare')('en')
const ArboristWorkspaceCmd = require('../arborist-cmd.js')

const safeNpa = (spec) => {
  try {
    return npa(spec)
  } catch {
    return null
  }
}

// This string is load bearing and is shared with Arborist
const MISSING = 'MISSING'

class Outdated extends ArboristWorkspaceCmd {
  static description = 'Check for outdated packages'
  static name = 'outdated'
  static usage = ['[<package-spec> ...]']
  static params = [
    'all',
    'json',
    'long',
    'parseable',
    'global',
    'workspace',
    'before',
  ]

  #tree
  #list = []
  #edges = new Set()
  #filterSet

  async exec (args) {
    const Arborist = require('@npmcli/arborist')
    const arb = new Arborist({
      ...this.npm.flatOptions,
      path: this.npm.global ? resolve(this.npm.globalDir, '..') : this.npm.prefix,
    })
    this.#tree = await arb.loadActual()

    if (this.workspaceNames?.length) {
      this.#filterSet = arb.workspaceDependencySet(
        this.#tree,
        this.workspaceNames,
        this.npm.flatOptions.includeWorkspaceRoot
      )
    } else if (!this.npm.flatOptions.workspacesEnabled) {
      this.#filterSet = arb.excludeWorkspacesDependencySet(this.#tree)
    }

    if (args.length) {
      for (const arg of args) {
        // specific deps
        this.#getEdges(this.#tree.inventory.query('name', arg), 'edgesIn')
      }
    } else {
      if (this.npm.config.get('all')) {
        // all deps in tree
        this.#getEdges(this.#tree.inventory.values(), 'edgesOut')
      }
      // top-level deps
      this.#getEdges()
    }

    await Promise.all([...this.#edges].map((e) => this.#getOutdatedInfo(e)))

    // sorts list alphabetically by name and then dependent
    const outdated = this.#list
      .sort((a, b) => localeCompare(a.name, b.name) || localeCompare(a.dependent, b.dependent))

    if (outdated.length) {
      process.exitCode = 1
    }

    if (this.npm.config.get('json')) {
      output.buffer(this.#json(outdated))
      return
    }

    const res = this.npm.config.get('parseable')
      ? this.#parseable(outdated)
      : this.#pretty(outdated)

    if (res) {
      output.standard(res)
    }
  }

  #getEdges (nodes, type) {
    // when no nodes are provided then it should only read direct deps from the root node and its workspaces direct dependencies
    if (!nodes) {
      this.#getEdgesOut(this.#tree)
      this.#getWorkspacesEdges()
      return
    }

    for (const node of nodes) {
      if (type === 'edgesOut') {
        this.#getEdgesOut(node)
      } else {
        this.#getEdgesIn(node)
      }
    }
  }

  #getEdgesIn (node) {
    for (const edge of node.edgesIn) {
      this.#trackEdge(edge)
    }
  }

  #getEdgesOut (node) {
    // TODO: normalize usage of edges and avoid looping through nodes here
    const edges = this.npm.global ? node.children.values() : node.edgesOut.values()
    for (const edge of edges) {
      this.#trackEdge(edge)
    }
  }

  #trackEdge (edge) {
    if (edge.from && this.#filterSet?.size > 0 && !this.#filterSet.has(edge.from.target)) {
      return
    }
    this.#edges.add(edge)
  }

  #getWorkspacesEdges () {
    if (this.npm.global) {
      return
    }

    for (const edge of this.#tree.edgesOut.values()) {
      if (edge?.to?.target?.isWorkspace) {
        this.#getEdgesOut(edge.to.target)
      }
    }
  }

  async #getPackument (spec) {
    return pacote.packument(spec, {
      ...this.npm.flatOptions,
      fullMetadata: this.npm.config.get('long'),
      preferOnline: true,
    })
  }

  async #getOutdatedInfo (edge) {
    const alias = safeNpa(edge.spec)?.subSpec
    const spec = npa(alias ? alias.name : edge.name)
    const node = edge.to || edge
    const { path, location, package: { version: current } = {} } = node

    const type = edge.optional ? 'optionalDependencies'
      : edge.peer ? 'peerDependencies'
      : edge.dev ? 'devDependencies'
      : 'dependencies'

    for (const omitType of this.npm.flatOptions.omit) {
      if (node[omitType]) {
        return
      }
    }

    // deps different from prod not currently on disk are not included in the output
    if (edge.error === MISSING && type !== 'dependencies') {
      return
    }

    // if it's not a range, version, or tag, skip it
    if (!safeNpa(`${edge.name}@${edge.spec}`)?.registry) {
      return null
    }

    try {
      const packument = await this.#getPackument(spec)
      const expected = alias ? alias.fetchSpec : edge.spec
      const wanted = pickManifest(packument, expected, this.npm.flatOptions)
      const latest = pickManifest(packument, '*', this.npm.flatOptions)
      if (!current || current !== wanted.version || wanted.version !== latest.version) {
        this.#list.push({
          name: alias ? edge.spec.replace('npm', edge.name) : edge.name,
          path,
          type,
          current,
          location,
          wanted: wanted.version,
          latest: latest.version,
          workspaceDependent: edge.from?.isWorkspace ? edge.from.pkgid : null,
          dependedByLocation: edge.from?.name
            ? edge.from?.location
            : 'global',
          dependent: edge.from?.name ?? 'global',
          homepage: packument.homepage,
        })
      }
    } catch (err) {
      // silently catch and ignore ETARGET, E403 & E404 errors
      // deps are just skipped
      if (!['ETARGET', 'E404', 'E404'].includes(err.code)) {
        throw err
      }
    }
  }

  // formatting functions

  #pretty (list) {
    if (!list.length) {
      return
    }

    const long = this.npm.config.get('long')
    const { bold, yellow, red, cyan, blue } = this.npm.chalk

    return table([
      [
        'Package',
        'Current',
        'Wanted',
        'Latest',
        'Location',
        'Depended by',
        ...long ? ['Package Type', 'Homepage', 'Depended By Location'] : [],
      ].map(h => bold.underline(h)),
      ...list.map((d) => [
        d.current === d.wanted ? yellow(d.name) : red(d.name),
        d.current ?? 'MISSING',
        cyan(d.wanted),
        blue(d.latest),
        d.location ?? '-',
        d.workspaceDependent ? blue(d.workspaceDependent) : d.dependent,
        ...long ? [d.type, blue(d.homepage ?? ''), d.dependedByLocation] : [],
      ]),
    ], {
      align: ['l', 'r', 'r', 'r', 'l'],
      stringLength: s => stripVTControlCharacters(s).length,
    })
  }

  // --parseable creates output like this:
  // <fullpath>:<name@wanted>:<name@installed>:<name@latest>:<dependedby>
  #parseable (list) {
    return list.map(d => [
      d.path,
      `${d.name}@${d.wanted}`,
      d.current ? `${d.name}@${d.current}` : 'MISSING',
      `${d.name}@${d.latest}`,
      d.dependent,
      ...this.npm.config.get('long') ? [d.type, d.homepage, d.dependedByLocation] : [],
    ].join(':')).join('\n')
  }

  #json (list) {
    // TODO(BREAKING_CHANGE): this should just return an array.
    // It's a list and turning it into an object with keys is lossy since multiple items in the list could have the same key. For now we hack that by only changing top level values into arrays if they have multiple outdated items
    return list.reduce((acc, d) => {
      const dep = {
        current: d.current,
        wanted: d.wanted,
        latest: d.latest,
        dependent: d.dependent,
        location: d.path,
        ...this.npm.config.get('long') ? {
          type: d.type,
          homepage: d.homepage,
          dependedByLocation: d.dependedByLocation } : {},
      }
      acc[d.name] = acc[d.name]
        // If this item already has an outdated dep then we turn it into an array
        ? (Array.isArray(acc[d.name]) ? acc[d.name] : [acc[d.name]]).concat(dep)
        : dep
      return acc
    }, {})
  }
}

module.exports = Outdated

Current_dir [ NOT WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
14 May 2026 8.36 AM
root / root
0755
trust
--
14 May 2026 8.36 AM
root / root
0755
access.js
6.165 KB
24 Apr 2026 3.56 PM
root / root
0644
adduser.js
1.29 KB
24 Apr 2026 3.56 PM
root / root
0644
audit.js
3.172 KB
24 Apr 2026 3.56 PM
root / root
0644
bugs.js
0.827 KB
24 Apr 2026 3.56 PM
root / root
0644
cache.js
11.479 KB
24 Apr 2026 3.56 PM
root / root
0644
ci.js
4.237 KB
24 Apr 2026 3.56 PM
root / root
0644
completion.js
10.825 KB
24 Apr 2026 3.56 PM
root / root
0644
config.js
11.478 KB
24 Apr 2026 3.56 PM
root / root
0644
dedupe.js
1.416 KB
24 Apr 2026 3.56 PM
root / root
0644
deprecate.js
2.43 KB
24 Apr 2026 3.56 PM
root / root
0644
diff.js
7.919 KB
24 Apr 2026 3.56 PM
root / root
0644
dist-tag.js
5.497 KB
24 Apr 2026 3.56 PM
root / root
0644
docs.js
0.438 KB
24 Apr 2026 3.56 PM
root / root
0644
doctor.js
9.986 KB
24 Apr 2026 3.56 PM
root / root
0644
edit.js
1.724 KB
24 Apr 2026 3.56 PM
root / root
0644
exec.js
3.394 KB
24 Apr 2026 3.56 PM
root / root
0644
explain.js
3.546 KB
24 Apr 2026 3.56 PM
root / root
0644
explore.js
2.107 KB
24 Apr 2026 3.56 PM
root / root
0644
find-dupes.js
0.564 KB
24 Apr 2026 3.56 PM
root / root
0644
fund.js
6.38 KB
24 Apr 2026 3.56 PM
root / root
0644
get.js
0.525 KB
24 Apr 2026 3.56 PM
root / root
0644
help-search.js
5.529 KB
24 Apr 2026 3.56 PM
root / root
0644
help.js
3.644 KB
24 Apr 2026 3.56 PM
root / root
0644
init.js
7.018 KB
24 Apr 2026 3.56 PM
root / root
0644
install-ci-test.js
0.301 KB
24 Apr 2026 3.56 PM
root / root
0644
install-test.js
0.296 KB
24 Apr 2026 3.56 PM
root / root
0644
install.js
5.099 KB
24 Apr 2026 3.56 PM
root / root
0644
link.js
5.238 KB
24 Apr 2026 3.56 PM
root / root
0644
ll.js
0.229 KB
24 Apr 2026 3.56 PM
root / root
0644
login.js
1.287 KB
24 Apr 2026 3.56 PM
root / root
0644
logout.js
1.419 KB
24 Apr 2026 3.56 PM
root / root
0644
ls.js
18.031 KB
24 Apr 2026 3.56 PM
root / root
0644
org.js
3.959 KB
24 Apr 2026 3.56 PM
root / root
0644
outdated.js
7.921 KB
24 Apr 2026 3.56 PM
root / root
0644
owner.js
5.951 KB
24 Apr 2026 3.56 PM
root / root
0644
pack.js
2.767 KB
24 Apr 2026 3.56 PM
root / root
0644
ping.js
0.853 KB
24 Apr 2026 3.56 PM
root / root
0644
pkg.js
3.581 KB
24 Apr 2026 3.56 PM
root / root
0644
prefix.js
0.302 KB
24 Apr 2026 3.56 PM
root / root
0644
profile.js
10.3 KB
24 Apr 2026 3.56 PM
root / root
0644
prune.js
0.752 KB
24 Apr 2026 3.56 PM
root / root
0644
publish.js
9.471 KB
24 Apr 2026 3.56 PM
root / root
0644
query.js
3.75 KB
24 Apr 2026 3.56 PM
root / root
0644
rebuild.js
2.15 KB
24 Apr 2026 3.56 PM
root / root
0644
repo.js
1.244 KB
24 Apr 2026 3.56 PM
root / root
0644
restart.js
0.296 KB
24 Apr 2026 3.56 PM
root / root
0644
root.js
0.288 KB
24 Apr 2026 3.56 PM
root / root
0644
run.js
6.267 KB
24 Apr 2026 3.56 PM
root / root
0644
sbom.js
4.471 KB
24 Apr 2026 3.56 PM
root / root
0644
search.js
1.833 KB
24 Apr 2026 3.56 PM
root / root
0644
set.js
0.617 KB
24 Apr 2026 3.56 PM
root / root
0644
shrinkwrap.js
2.628 KB
24 Apr 2026 3.56 PM
root / root
0644
star.js
1.875 KB
24 Apr 2026 3.56 PM
root / root
0644
stars.js
1.033 KB
24 Apr 2026 3.56 PM
root / root
0644
start.js
0.286 KB
24 Apr 2026 3.56 PM
root / root
0644
stop.js
0.281 KB
24 Apr 2026 3.56 PM
root / root
0644
team.js
4.332 KB
24 Apr 2026 3.56 PM
root / root
0644
test.js
0.281 KB
24 Apr 2026 3.56 PM
root / root
0644
token.js
7.962 KB
24 Apr 2026 3.56 PM
root / root
0644
undeprecate.js
0.295 KB
24 Apr 2026 3.56 PM
root / root
0644
uninstall.js
1.486 KB
24 Apr 2026 3.56 PM
root / root
0644
unpublish.js
5.242 KB
24 Apr 2026 3.56 PM
root / root
0644
unstar.js
0.179 KB
24 Apr 2026 3.56 PM
root / root
0644
update.js
1.692 KB
24 Apr 2026 3.56 PM
root / root
0644
version.js
3.536 KB
24 Apr 2026 3.56 PM
root / root
0644
view.js
13.479 KB
24 Apr 2026 3.56 PM
root / root
0644
whoami.js
0.515 KB
24 Apr 2026 3.56 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF Static GIF