X7ROOT File Manager
Current Path:
/opt/alt/alt-nodejs16/root/usr/lib/node_modules/npm/lib/commands
opt
/
alt
/
alt-nodejs16
/
root
/
usr
/
lib
/
node_modules
/
npm
/
lib
/
commands
/
ðŸ“
..
📄
access.js
(5.45 KB)
📄
adduser.js
(2.2 KB)
📄
audit.js
(11.95 KB)
📄
bin.js
(729 B)
📄
birthday.js
(508 B)
📄
bugs.js
(815 B)
📄
cache.js
(7.08 KB)
📄
ci.js
(3.63 KB)
📄
completion.js
(8.91 KB)
📄
config.js
(8.11 KB)
📄
dedupe.js
(1.37 KB)
📄
deprecate.js
(2.06 KB)
📄
diff.js
(8.1 KB)
📄
dist-tag.js
(5.47 KB)
📄
docs.js
(447 B)
📄
doctor.js
(9.22 KB)
📄
edit.js
(2 KB)
📄
exec.js
(2.44 KB)
📄
explain.js
(3.55 KB)
📄
explore.js
(2.33 KB)
📄
find-dupes.js
(602 B)
📄
fund.js
(6.37 KB)
📄
get.js
(524 B)
📄
help-search.js
(5.62 KB)
📄
help.js
(4.53 KB)
📄
hook.js
(3.93 KB)
📄
init.js
(6.81 KB)
📄
install-ci-test.js
(377 B)
📄
install-test.js
(374 B)
📄
install.js
(5.11 KB)
📄
link.js
(5.02 KB)
📄
ll.js
(234 B)
📄
logout.js
(1.34 KB)
📄
ls.js
(16.94 KB)
📄
org.js
(4.2 KB)
📄
outdated.js
(8.84 KB)
📄
owner.js
(5.88 KB)
📄
pack.js
(2.36 KB)
📄
ping.js
(874 B)
📄
pkg.js
(3.47 KB)
📄
prefix.js
(343 B)
📄
profile.js
(11.25 KB)
📄
prune.js
(779 B)
📄
publish.js
(6.33 KB)
📄
query.js
(2.81 KB)
📄
rebuild.js
(2.16 KB)
📄
repo.js
(1.24 KB)
📄
restart.js
(351 B)
📄
root.js
(298 B)
📄
run-script.js
(6.9 KB)
📄
search.js
(2.72 KB)
📄
set-script.js
(2.63 KB)
📄
set.js
(572 B)
📄
shrinkwrap.js
(2.64 KB)
📄
star.js
(1.87 KB)
📄
stars.js
(1.03 KB)
📄
start.js
(341 B)
📄
stop.js
(336 B)
📄
team.js
(4.44 KB)
📄
test.js
(336 B)
📄
token.js
(6.79 KB)
📄
uninstall.js
(1.52 KB)
📄
unpublish.js
(4.51 KB)
📄
unstar.js
(182 B)
📄
update.js
(1.7 KB)
📄
version.js
(3.6 KB)
📄
view.js
(14.38 KB)
📄
whoami.js
(514 B)
Editing: fund.js
const archy = require('archy') const Arborist = require('@npmcli/arborist') const chalk = require('chalk') const pacote = require('pacote') const semver = require('semver') const npa = require('npm-package-arg') const { depth } = require('treeverse') const { readTree: getFundingInfo, normalizeFunding, isValidFunding } = require('libnpmfund') const completion = require('../utils/completion/installed-deep.js') const openUrl = require('../utils/open-url.js') const ArboristWorkspaceCmd = require('../arborist-cmd.js') const getPrintableName = ({ name, version }) => { const printableVersion = version ? `@${version}` : '' return `${name}${printableVersion}` } class Fund extends ArboristWorkspaceCmd { static description = 'Retrieve funding information' static name = 'fund' static params = ['json', 'browser', 'unicode', 'workspace', 'which'] static usage = ['[<package-spec>]'] // TODO /* istanbul ignore next */ async completion (opts) { return completion(this.npm, opts) } async exec (args) { const spec = args[0] const numberArg = this.npm.config.get('which') const fundingSourceNumber = numberArg && parseInt(numberArg, 10) const badFundingSourceNumber = numberArg !== null && (String(fundingSourceNumber) !== numberArg || fundingSourceNumber < 1) if (badFundingSourceNumber) { const err = new Error( '`npm fund [<@scope>/]<pkg> [--which=fundingSourceNumber]` must be given a positive integer' ) err.code = 'EFUNDNUMBER' throw err } if (this.npm.global) { const err = new Error('`npm fund` does not support global packages') err.code = 'EFUNDGLOBAL' throw err } const where = this.npm.prefix const arb = new Arborist({ ...this.npm.flatOptions, path: where }) const tree = await arb.loadActual() if (spec) { await this.openFundingUrl({ path: where, tree, spec, fundingSourceNumber, }) return } // TODO: add !workspacesEnabled option handling to libnpmfund const fundingInfo = getFundingInfo(tree, { ...this.flatOptions, workspaces: this.workspaceNames, }) if (this.npm.config.get('json')) { this.npm.output(this.printJSON(fundingInfo)) } else { this.npm.output(this.printHuman(fundingInfo)) } } printJSON (fundingInfo) { return JSON.stringify(fundingInfo, null, 2) } printHuman (fundingInfo) { const color = this.npm.color const unicode = this.npm.config.get('unicode') const seenUrls = new Map() const tree = obj => archy(obj, '', { unicode }) const result = depth({ tree: fundingInfo, // composes human readable package name // and creates a new archy item for readable output visit: ({ name, version, funding }) => { const [fundingSource] = [].concat(normalizeFunding(funding)).filter(isValidFunding) const { url } = fundingSource || {} const pkgRef = getPrintableName({ name, version }) let item = { label: pkgRef, } if (url) { item.label = tree({ label: color ? chalk.bgBlack.white(url) : url, nodes: [pkgRef], }).trim() // stacks all packages together under the same item if (seenUrls.has(url)) { item = seenUrls.get(url) item.label += `, ${pkgRef}` return null } else { seenUrls.set(url, item) } } return item }, // puts child nodes back into returned archy // output while also filtering out missing items leave: (item, children) => { if (item) { item.nodes = children.filter(Boolean) } return item }, // turns tree-like object return by libnpmfund // into children to be properly read by treeverse getChildren: node => Object.keys(node.dependencies || {}).map(key => ({ name: key, ...node.dependencies[key], })), }) const res = tree(result) return color ? chalk.reset(res) : res } async openFundingUrl ({ path, tree, spec, fundingSourceNumber }) { const arg = npa(spec, path) const retrievePackageMetadata = () => { if (arg.type === 'directory') { if (tree.path === arg.fetchSpec) { // matches cwd, e.g: npm fund . return tree.package } else { // matches any file path within current arborist inventory for (const item of tree.inventory.values()) { if (item.path === arg.fetchSpec) { return item.package } } } } else { // tries to retrieve a package from arborist inventory // by matching resulted package name from the provided spec const [item] = [...tree.inventory.query('name', arg.name)] .filter(i => semver.valid(i.package.version)) .sort((a, b) => semver.rcompare(a.package.version, b.package.version)) if (item) { return item.package } } } const { funding } = retrievePackageMetadata() || (await pacote.manifest(arg, this.npm.flatOptions).catch(() => ({}))) const validSources = [].concat(normalizeFunding(funding)).filter(isValidFunding) const matchesValidSource = validSources.length === 1 || (fundingSourceNumber > 0 && fundingSourceNumber <= validSources.length) if (matchesValidSource) { const index = fundingSourceNumber ? fundingSourceNumber - 1 : 0 const { type, url } = validSources[index] const typePrefix = type ? `${type} funding` : 'Funding' const msg = `${typePrefix} available at the following URL` return openUrl(this.npm, url, msg) } else if (validSources.length && !(fundingSourceNumber >= 1)) { validSources.forEach(({ type, url }, i) => { const typePrefix = type ? `${type} funding` : 'Funding' const msg = `${typePrefix} available at the following URL` this.npm.output(`${i + 1}: ${msg}: ${url}`) }) this.npm.output( /* eslint-disable-next-line max-len */ 'Run `npm fund [<@scope>/]<pkg> --which=1`, for example, to open the first funding URL listed in that package' ) } else { const noFundingError = new Error(`No valid funding method available for: ${spec}`) noFundingError.code = 'ENOFUND' throw noFundingError } } } module.exports = Fund
Upload File
Create Folder