summaryrefslogtreecommitdiff
path: root/deps/npm/lib/hook.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/lib/hook.js')
-rw-r--r--deps/npm/lib/hook.js203
1 files changed, 110 insertions, 93 deletions
diff --git a/deps/npm/lib/hook.js b/deps/npm/lib/hook.js
index b0552c7474..54aea9f1e9 100644
--- a/deps/npm/lib/hook.js
+++ b/deps/npm/lib/hook.js
@@ -2,129 +2,146 @@
const BB = require('bluebird')
-const crypto = require('crypto')
-const hookApi = require('libnpmhook')
-const log = require('npmlog')
-const npm = require('./npm.js')
+const hookApi = require('libnpm/hook')
+const npmConfig = require('./config/figgy-config.js')
const output = require('./utils/output.js')
+const otplease = require('./utils/otplease.js')
const pudding = require('figgy-pudding')
const relativeDate = require('tiny-relative-date')
const Table = require('cli-table3')
-const usage = require('./utils/usage.js')
const validate = require('aproba')
-hook.usage = usage([
+hook.usage = [
'npm hook add <pkg> <url> <secret> [--type=<type>]',
'npm hook ls [pkg]',
'npm hook rm <id>',
'npm hook update <id> <url> <secret>'
-])
+].join('\n')
hook.completion = (opts, cb) => {
validate('OF', [opts, cb])
return cb(null, []) // fill in this array with completion values
}
-const npmSession = crypto.randomBytes(8).toString('hex')
-const hookConfig = pudding()
-function config () {
- return hookConfig({
- refer: npm.refer,
- projectScope: npm.projectScope,
- log,
- npmSession
- }, npm.config)
+const HookConfig = pudding({
+ json: {},
+ loglevel: {},
+ parseable: {},
+ silent: {},
+ unicode: {}
+})
+
+function UsageError () {
+ throw Object.assign(new Error(hook.usage), {code: 'EUSAGE'})
}
-module.exports = (args, cb) => BB.try(() => hook(args)).nodeify(cb)
+module.exports = (args, cb) => BB.try(() => hook(args)).then(
+ val => cb(null, val),
+ err => err.code === 'EUSAGE' ? cb(err.message) : cb(err)
+)
function hook (args) {
- switch (args[0]) {
- case 'add':
- return add(args[1], args[2], args[3])
- case 'ls':
- return ls(args[1])
- case 'rm':
- return rm(args[1])
- case 'update':
- case 'up':
- return update(args[1], args[2], args[3])
- }
+ return otplease(npmConfig(), opts => {
+ opts = HookConfig(opts)
+ switch (args[0]) {
+ case 'add':
+ return add(args[1], args[2], args[3], opts)
+ case 'ls':
+ return ls(args[1], opts)
+ case 'rm':
+ return rm(args[1], opts)
+ case 'update':
+ case 'up':
+ return update(args[1], args[2], args[3], opts)
+ default:
+ UsageError()
+ }
+ })
}
-function add (pkg, uri, secret) {
- return hookApi.add(pkg, uri, secret, config())
- .then((hook) => {
- if (npm.config.get('json')) {
- output(JSON.stringify(hook, null, 2))
- } else {
- output(`+ ${hookName(hook)} ${
- npm.config.get('unicode') ? ' ➜ ' : ' -> '
- } ${hook.endpoint}`)
- }
- })
+function add (pkg, uri, secret, opts) {
+ return hookApi.add(pkg, uri, secret, opts).then(hook => {
+ if (opts.json) {
+ output(JSON.stringify(hook, null, 2))
+ } else if (opts.parseable) {
+ output(Object.keys(hook).join('\t'))
+ output(Object.keys(hook).map(k => hook[k]).join('\t'))
+ } else if (!opts.silent && opts.loglevel !== 'silent') {
+ output(`+ ${hookName(hook)} ${
+ opts.unicode ? ' ➜ ' : ' -> '
+ } ${hook.endpoint}`)
+ }
+ })
}
-function ls (pkg) {
- return hookApi.ls(pkg, config())
- .then((hooks) => {
- if (npm.config.get('json')) {
- output(JSON.stringify(hooks, null, 2))
- } else if (!hooks.length) {
- output("You don't have any hooks configured yet.")
+function ls (pkg, opts) {
+ return hookApi.ls(opts.concat({package: pkg})).then(hooks => {
+ if (opts.json) {
+ output(JSON.stringify(hooks, null, 2))
+ } else if (opts.parseable) {
+ output(Object.keys(hooks[0]).join('\t'))
+ hooks.forEach(hook => {
+ output(Object.keys(hook).map(k => hook[k]).join('\t'))
+ })
+ } else if (!hooks.length) {
+ output("You don't have any hooks configured yet.")
+ } else if (!opts.silent && opts.loglevel !== 'silent') {
+ if (hooks.length === 1) {
+ output('You have one hook configured.')
} else {
- if (hooks.length === 1) {
- output('You have one hook configured.')
- } else {
- output(`You have ${hooks.length} hooks configured.`)
- }
- const table = new Table({head: ['id', 'target', 'endpoint']})
- hooks.forEach((hook) => {
+ output(`You have ${hooks.length} hooks configured.`)
+ }
+ const table = new Table({head: ['id', 'target', 'endpoint']})
+ hooks.forEach((hook) => {
+ table.push([
+ {rowSpan: 2, content: hook.id},
+ hookName(hook),
+ hook.endpoint
+ ])
+ if (hook.last_delivery) {
table.push([
- {rowSpan: 2, content: hook.id},
- hookName(hook),
- hook.endpoint
+ {
+ colSpan: 1,
+ content: `triggered ${relativeDate(hook.last_delivery)}`
+ },
+ hook.response_code
])
- if (hook.last_delivery) {
- table.push([
- {
- colSpan: 1,
- content: `triggered ${relativeDate(hook.last_delivery)}`
- },
- hook.response_code
- ])
- } else {
- table.push([{colSpan: 2, content: 'never triggered'}])
- }
- })
- output(table.toString())
- }
- })
+ } else {
+ table.push([{colSpan: 2, content: 'never triggered'}])
+ }
+ })
+ output(table.toString())
+ }
+ })
}
-function rm (id) {
- return hookApi.rm(id, config())
- .then((hook) => {
- if (npm.config.get('json')) {
- output(JSON.stringify(hook, null, 2))
- } else {
- output(`- ${hookName(hook)} ${
- npm.config.get('unicode') ? ' ✘ ' : ' X '
- } ${hook.endpoint}`)
- }
- })
+function rm (id, opts) {
+ return hookApi.rm(id, opts).then(hook => {
+ if (opts.json) {
+ output(JSON.stringify(hook, null, 2))
+ } else if (opts.parseable) {
+ output(Object.keys(hook).join('\t'))
+ output(Object.keys(hook).map(k => hook[k]).join('\t'))
+ } else if (!opts.silent && opts.loglevel !== 'silent') {
+ output(`- ${hookName(hook)} ${
+ opts.unicode ? ' ✘ ' : ' X '
+ } ${hook.endpoint}`)
+ }
+ })
}
-function update (id, uri, secret) {
- return hookApi.update(id, uri, secret, config())
- .then((hook) => {
- if (npm.config.get('json')) {
- output(JSON.stringify(hook, null, 2))
- } else {
- output(`+ ${hookName(hook)} ${
- npm.config.get('unicode') ? ' ➜ ' : ' -> '
- } ${hook.endpoint}`)
- }
- })
+function update (id, uri, secret, opts) {
+ return hookApi.update(id, uri, secret, opts).then(hook => {
+ if (opts.json) {
+ output(JSON.stringify(hook, null, 2))
+ } else if (opts.parseable) {
+ output(Object.keys(hook).join('\t'))
+ output(Object.keys(hook).map(k => hook[k]).join('\t'))
+ } else if (!opts.silent && opts.loglevel !== 'silent') {
+ output(`+ ${hookName(hook)} ${
+ opts.unicode ? ' ➜ ' : ' -> '
+ } ${hook.endpoint}`)
+ }
+ })
}
function hookName (hook) {