redibox-hook-job
Advanced tools
Comparing version 1.2.3 to 1.2.4
@@ -252,7 +252,11 @@ 'use strict'; | ||
if (job.options.noBind || this.options.noBind) { | ||
return handler(job).then(handleOK, handleError).catch(handleError); | ||
try { | ||
if (job.options.noBind || this.options.noBind) { | ||
return handler(job).then(handleOK, handleError).catch(handleError); | ||
} | ||
return handler.bind(job, job)(job).then(handleOK, handleError).catch(handleError); | ||
} catch (e) { | ||
return handleError(e); | ||
} | ||
return handler.bind(job, job)(job).then(handleOK, handleError).catch(handleError); | ||
} | ||
@@ -495,2 +499,2 @@ | ||
exports.default = Queue; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/queue.js"],"names":[],"mappings":"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","file":"queue.js","sourcesContent":["import Job from './job';\nimport Promise from 'bluebird';\nimport defaults from './defaults';\nimport EventEmitter from 'eventemitter3';\nimport { deepGet, isObject, getTimeStamp, tryJSONParse } from 'redibox';\n\nexport default class Queue extends EventEmitter {\n\n  /**\n   *\n   * @param options\n   * @param core\n   * @returns {Queue}\n   */\n  constructor(options, core) {\n    super();\n    this.core = core;\n    this.client = core.client;\n    this.paused = false;\n    this.started = false;\n    this.throttled = false;\n    this.log = this.core.log;\n    this.name = options.name;\n    this.handler = options.handler || null;\n    this.options = Object.assign({}, defaults.queue, options || {});\n    this.core.createClient('block', this).then(() => {\n      this.log.verbose(`Blocking client for queue '${this.name}' is ready. Starting queue processor.`);\n      this.beginWorking();\n    });\n  }\n\n  /**\n   *\n   * @returns {*}\n   */\n  destroy() {\n    const keys = [\n      'id', 'jobs', 'stallTime', 'stalling', 'waiting', 'active', 'succeeded', 'failed',\n    ].map(key => this.toKey(key));\n    return this.client.del(...keys);\n  }\n\n  /**\n   *\n   * @returns {Promise}\n   */\n  checkHealth() {\n    return this\n      .client.multi()\n      .llen(this.toKey('waiting'))\n      .llen(this.toKey('active'))\n      .scard(this.toKey('succeeded'))\n      .scard(this.toKey('failed'))\n      .then(results => { /* eslint arrow-body-style: 0 */\n        return {\n          waiting: results[0][1],\n          active: results[1][1],\n          succeeded: results[2][1],\n          failed: results[3][1],\n        };\n      });\n  }\n\n  /**\n   *\n   * @returns {Promise}\n   */\n  _getNextJob() {\n    this.log.verbose(`Getting next job for queue '${this.name}'.`);\n    return this.clients.block.brpoplpush(\n      this.toKey('waiting'),\n      this.toKey('active'), 0\n    ).then(jobId =>\n      Job.fromId(this, jobId).then(job => {\n        return job;\n      })\n    );\n  }\n\n  /**\n   *\n   * @param job\n   * @param jobError\n   * @private\n   */\n  _logJobFailure(job, jobError) {\n    if (process.env.KUBERNETES_PORT || process.env.KUBERNETES_SERVICE_HOST) {\n      /* eslint no-console: 0 */\n      console.log(JSON.stringify({\n        level: 'error',\n        type: 'redibox_job_failure',\n        data: {\n          runs: job.data.runs,\n          queue: this.name,\n          stack: jobError.stack ? jobError.stack.split('\\n').slice(0, 5) : [],\n        },\n      }));\n    } else {\n      this.log.error('');\n      this.log.error('--------------- RDB JOB ERROR/FAILURE ---------------');\n      this.log.error(`Job: ${job.data.runs}` || this.name);\n      if (jobError.stack) {\n        this.log.error(jobError.stack.split('\\n').slice(0, 5));\n      }\n      this.log.error(jobError);\n      this.log.error('------------------------------------------------------');\n      this.log.error('');\n    }\n  }\n\n  /**\n   *\n   * @param job\n   * @returns {Promise}\n   */\n  _runJob(job) {\n    if (!job || !job.data) return Promise.resolve();\n    const runs = job.data && job.data.runs && Array.isArray(job.data.runs) ? job.data.runs[0] : job.data.runs;\n    const handler = (typeof this.handler === 'string' ?\n        deepGet(global, this.handler) : this.handler) || deepGet(global, runs);\n\n    let preventStallingTimeout;\n    let handled = false;\n\n    // Handle an \"OK\" response from the promise\n    const handleOK = data => {\n      // silently ignore any multiple calls\n      if (handled) return void 0;\n\n      clearTimeout(preventStallingTimeout);\n      handled = true;\n\n      // set the data back to internal data\n      if (job._internalData) {\n        job.data = job._internalData;\n      }\n\n      // only relay to next job if user did not resolve 'false' on current job\n      if (job.type === 'relay' && data !== false) return this._finishRelayJob(null, data, job);\n      return this._finishSingleJob(null, data, job);\n    };\n\n    // Handle any errors returned\n    const handleError = jobError => {\n      clearTimeout(preventStallingTimeout);\n\n      // silently ignore any multiple calls\n      if (handled) {\n        return void 0;\n      }\n\n      handled = true;\n\n      // set the data back to internal job data\n      if (job._internalData) {\n        job.data = job._internalData;\n      }\n\n      // only log the error if no notifyFailure pubsub set\n      if ((!job.data.initialJob || !job.data.initialJob.options.notifyFailure) && !Array.isArray(job.data.runs)) {\n        this._logJobFailure(job, jobError);\n      }\n\n      if (job.type === 'relay') return this._finishRelayJob(jobError, null, job);\n      return this._finishSingleJob(jobError, null, job);\n    };\n\n    const preventStalling = () => {\n      this.client.srem(this.toKey('stalling'), job.id, () => {\n        if (!handled) {\n          preventStallingTimeout = setTimeout(preventStalling, this.options.stallInterval / 2);\n        }\n      });\n    };\n\n    if (!handler) {\n      return handleError(\n        new Error(\n          `\"${job.data.runs || 'No Job Handler Specified'}\" was not found. Skipping job. To fix this\n             you must either specify a handler function via queue.process() or provide a valid handler\n             node global path in your job options 'handler', e.g. if you had a global function in\n            'global.sails.services.myservice' you'd specify the handler as 'sails.services.myservice.myHandler'.`\n        )\n      );\n    }\n\n    preventStalling(); // start stalling monitor\n\n    job._internalData = job.data;\n    job.data = job.data.data || job.data;\n\n    if (job.options.timeout) {\n      setTimeout(handleError.bind(null, Error(`Job ${job.id} timed out (${job.options.timeout}ms)`)), job.options.timeout);\n    }\n\n    if (job.options.noBind || this.options.noBind) {\n      return handler(job).then(handleOK, handleError).catch(handleError);\n    }\n\n    return handler.bind(job, job)(job).then(handleOK, handleError).catch(handleError);\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @returns {{job: {id: *, worker_id: (*|String|string), status: string}, error: *, output: *}}\n   * @private\n   */\n  _createJobEvent(error, data, job) {\n    return {\n      job: {\n        id: job.id,\n        worker_id: this.core.id,\n        status: error ? 'failed' : 'succeeded',\n        ...job.data,\n      },\n      error,\n      output: data,\n    };\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @param multi\n   * @private\n   */\n  _updateJobStatus(error, data, job, multi) {\n    const status = error ? 'failed' : 'succeeded';\n\n    multi.lrem(this.toKey('active'), 0, job.id);\n    multi.srem(this.toKey('stalling'), job.id);\n\n    if (status === 'failed') {\n      if (job.options.retries > 0) {\n        job.options.retries = job.options.retries - 1;\n        job.status = 'retrying';\n        multi.hset(this.toKey('jobs'), job.id, job.toData());\n        multi.lpush(this.toKey('waiting'), job.id);\n      } else {\n        job.status = 'failed';\n        multi.hdel(this.toKey('jobs'), job.id);\n        // TODO track failures and their data somewhere else for reviewing\n        // multi.hset(this.toKey('jobs'), job.id, job.toData());\n        // multi.sadd(this.toKey('failed'), job.id);\n      }\n    } else {\n      job.status = 'succeeded';\n      multi.hdel(this.toKey('jobs'), job.id);\n      // TODO track successes and their data somewhere else for reviewing\n      // multi.hset(this.toKey('jobs'), job.id, job.toData());\n      // multi.sadd(this.toKey('succeeded'), job.id);\n    }\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @returns {Promise}\n   */\n  _finishSingleJob(error, data, job) {\n    const multi = this.client.multi();\n    const status = error ? 'failed' : 'succeeded';\n    this._updateJobStatus(error, data, job, multi);\n\n    // emit success or failure event if we have listeners\n    if (error && job.options.notifyFailure) {\n      this.core.pubsub.publish(job.options.notifyFailure, this._createJobEvent(error, data, job));\n    } else if (job.options.notifySuccess) {\n      this.core.pubsub.publish(job.options.notifySuccess, this._createJobEvent(error, data, job));\n    }\n\n    return new Promise((resolve, reject) => {\n      multi.exec(errMulti => {\n        if (errMulti) return reject(errMulti);\n        return resolve({ status, result: error || data });\n      });\n    });\n  }\n\n  /**\n   * Completes a multi job or continues to the next stage.\n   * @param error\n   * @param data\n   * @param job\n   * @returns {Promise}\n   * @private\n   */\n  _finishRelayJob(error, data, job) {\n    let nextQueue = this.name;\n    const nextJob = job.data.runs[0];\n    const multi = this.client.multi();\n    const currentJob = job.data.runs.shift();\n    const status = error ? 'failed' : 'succeeded';\n\n    // keep a record of the first job in this relay instance\n    if (!job.data.initialJob) {\n      job.data.initialJob = tryJSONParse(job.toData());\n    }\n\n    // keep a record of the first queue in this relay instance\n    if (!job.data.initialQueue) {\n      job.data.initialQueue = this.name;\n    }\n\n    this._updateJobStatus(error, data, job, multi);\n\n    // check if we need to relay to another job\n    if (!(job.data.runs.length === 0 || !!error)) {\n      if (isObject(nextJob)) {\n        nextQueue = nextJob.queue;\n        job.data.runs[0] = nextJob.runs;\n      } else if (job.data.initialQueue) {\n        nextQueue = job.data.initialQueue;\n      }\n\n      // add some debug data for the next job\n      // so it can tell where the relay originated from\n      job.data.from_job = currentJob;\n      job.data.from_queue = this.name;\n      job.data.from_timestamp = getTimeStamp();\n      // relay resolved data\n      job.data.data = data;\n\n      return new Promise((resolve, reject) => {\n        return this.core.hooks.job.create(nextQueue, job.data).then(() => {\n          multi.exec(errMulti => {\n            if (errMulti) return reject(errMulti);\n            return resolve({ status, result: error || data });\n          });\n        });\n      });\n    }\n\n    // we've just finished the last job in the relay\n    // emit success or failure event if we have listeners\n    if (error && job.data.initialJob.options.notifyFailure) {\n      this.core.pubsub.publish(job.data.initialJob.options.notifyFailure, this._createJobEvent(error, data, job));\n    } else if (job.data.initialJob.options.notifySuccess) {\n      this.core.pubsub.publish(job.data.initialJob.options.notifySuccess, this._createJobEvent(error, data, job));\n    }\n\n    return new Promise((resolve, reject) => {\n      return multi.exec(errMulti => {\n        if (errMulti) return reject(errMulti);\n        return resolve({ status, result: error || data });\n      });\n    });\n  }\n\n  /**\n   *\n   * @private\n   */\n  _onLocalTickComplete = () => {\n    this.running--;\n    this.queued--;\n    if (!this.options.throttle) return setImmediate(this._queueTick);\n\n    return this.client.throttle(\n      this.toKey('throttle'),\n      this.options.throttle.limit,\n      this.options.throttle.seconds\n    ).then(throttle => {\n      const shouldThrottle = throttle[0] === 1;\n      if (!shouldThrottle) {\n        this.throttled = false;\n        return setImmediate(this._queueTick);\n      }\n\n      this.throttled = true;\n      const timeRemaining = (throttle[2] === 0 ? 1 : throttle[2]);\n      this.log.verbose(`'${this.name}' queue  reached it's throttle limit, resuming in ${timeRemaining} seconds.`);\n      return setTimeout(this._queueTick, timeRemaining * 1000);\n    }).catch(this._queueTick);\n  };\n\n  /**\n   *\n   * @param error\n   * @private\n   */\n  _onLocalTickError = (error) => {\n    this.queued--;\n    this.log.error(error);\n    setImmediate(this._queueTick);\n  };\n\n  _throttleQueue = () => {\n\n  };\n\n  /**\n   *\n   * @returns {*}\n   * @private\n   */\n  _queueTick = () => {\n    if (this.paused || !this.options.enabled) {\n      return void 0;\n    }\n    this.queued++;\n    return this\n      ._getNextJob()\n      .then(job => {\n        this.running++;\n        // queue more jobs if within limit\n        if ((this.running + this.queued) < this.options.concurrency) {\n          // concurrency is a little pointless right now if we're throttling jobs\n          if (!this.options.throttle) setImmediate(this._queueTick);\n        }\n\n        return this._runJob(job).then(this._onLocalTickComplete).catch(this._onLocalTickComplete);\n      }).catch(this._onLocalTickError);\n  };\n\n  /**\n   *\n   * @private\n   */\n  _restartProcessing = () => {\n    this.clients.block.once('ready', this._queueTick);\n  };\n\n  /**\n   * Start the queue.\n   */\n  beginWorking() {\n    if (this.started || !this.options.enabled) {\n      this.log.info(`Queue ${this.name} is currently disabled.`);\n      return void 0;\n    }\n\n    this.queued = 0;\n    this.running = 0;\n    this.started = true;\n\n    this.log.verbose(`Queue '${this.name}' - started with a concurrency of ${this.options.concurrency}.`);\n\n    this.clients.block.once('error', this._restartProcessing);\n    this.clients.block.once('close', this._restartProcessing);\n\n    this.checkStalledJobs().then(() => {\n      this.log.verbose('checkStalledJobs completed');\n    }).catch(() => {\n    });\n\n    return this._queueTick();\n  }\n\n  /**\n   *\n   * @returns {*}\n   */\n  checkStalledJobs() {\n    this.log.verbose('checkStalledJobs');\n    return this.client.checkstalledjobs(\n      this.toKey('stallTime'),\n      this.toKey('stalling'),\n      this.toKey('waiting'),\n      this.toKey('active'),\n      getTimeStamp(),\n      this.options.stallInterval\n    ).then(() => {\n      if (!this.options.enabled || this.paused) return Promise.resolve();\n      return Promise.delay(this.options.stallInterval).then(this.checkStalledJobs);\n    });\n  }\n\n  /**\n   *\n   * @param str\n   * @returns {*}\n   */\n  toKey(str) {\n    if (this.core.cluster.isCluster()) {\n      return `${this.options.keyPrefix}:{${this.name}}:${str}`;\n    }\n    return `${this.options.keyPrefix}:${this.name}:${str}`;\n  }\n\n  /**\n   * Add the eventPrefix to an event name\n   * @param eventName\n   * @returns {string}\n   */\n  toEventName = eventName => `queue:${this.name}:${eventName}`;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/queue.js"],"names":[],"mappings":"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","file":"queue.js","sourcesContent":["import Job from './job';\nimport Promise from 'bluebird';\nimport defaults from './defaults';\nimport EventEmitter from 'eventemitter3';\nimport { deepGet, isObject, getTimeStamp, tryJSONParse } from 'redibox';\n\nexport default class Queue extends EventEmitter {\n\n  /**\n   *\n   * @param options\n   * @param core\n   * @returns {Queue}\n   */\n  constructor(options, core) {\n    super();\n    this.core = core;\n    this.client = core.client;\n    this.paused = false;\n    this.started = false;\n    this.throttled = false;\n    this.log = this.core.log;\n    this.name = options.name;\n    this.handler = options.handler || null;\n    this.options = Object.assign({}, defaults.queue, options || {});\n    this.core.createClient('block', this).then(() => {\n      this.log.verbose(`Blocking client for queue '${this.name}' is ready. Starting queue processor.`);\n      this.beginWorking();\n    });\n  }\n\n  /**\n   *\n   * @returns {*}\n   */\n  destroy() {\n    const keys = [\n      'id', 'jobs', 'stallTime', 'stalling', 'waiting', 'active', 'succeeded', 'failed',\n    ].map(key => this.toKey(key));\n    return this.client.del(...keys);\n  }\n\n  /**\n   *\n   * @returns {Promise}\n   */\n  checkHealth() {\n    return this\n      .client.multi()\n      .llen(this.toKey('waiting'))\n      .llen(this.toKey('active'))\n      .scard(this.toKey('succeeded'))\n      .scard(this.toKey('failed'))\n      .then(results => { /* eslint arrow-body-style: 0 */\n        return {\n          waiting: results[0][1],\n          active: results[1][1],\n          succeeded: results[2][1],\n          failed: results[3][1],\n        };\n      });\n  }\n\n  /**\n   *\n   * @returns {Promise}\n   */\n  _getNextJob() {\n    this.log.verbose(`Getting next job for queue '${this.name}'.`);\n    return this.clients.block.brpoplpush(\n      this.toKey('waiting'),\n      this.toKey('active'), 0\n    ).then(jobId =>\n      Job.fromId(this, jobId).then(job => {\n        return job;\n      })\n    );\n  }\n\n  /**\n   *\n   * @param job\n   * @param jobError\n   * @private\n   */\n  _logJobFailure(job, jobError) {\n    if (process.env.KUBERNETES_PORT || process.env.KUBERNETES_SERVICE_HOST) {\n      /* eslint no-console: 0 */\n      console.log(JSON.stringify({\n        level: 'error',\n        type: 'redibox_job_failure',\n        data: {\n          runs: job.data.runs,\n          queue: this.name,\n          stack: jobError.stack ? jobError.stack.split('\\n').slice(0, 5) : [],\n        },\n      }));\n    } else {\n      this.log.error('');\n      this.log.error('--------------- RDB JOB ERROR/FAILURE ---------------');\n      this.log.error(`Job: ${job.data.runs}` || this.name);\n      if (jobError.stack) {\n        this.log.error(jobError.stack.split('\\n').slice(0, 5));\n      }\n      this.log.error(jobError);\n      this.log.error('------------------------------------------------------');\n      this.log.error('');\n    }\n  }\n\n  /**\n   *\n   * @param job\n   * @returns {Promise}\n   */\n  _runJob(job) {\n    if (!job || !job.data) return Promise.resolve();\n    const runs = job.data && job.data.runs && Array.isArray(job.data.runs) ? job.data.runs[0] : job.data.runs;\n    const handler = (typeof this.handler === 'string' ?\n        deepGet(global, this.handler) : this.handler) || deepGet(global, runs);\n\n    let preventStallingTimeout;\n    let handled = false;\n\n    // Handle an \"OK\" response from the promise\n    const handleOK = data => {\n      // silently ignore any multiple calls\n      if (handled) return void 0;\n\n      clearTimeout(preventStallingTimeout);\n      handled = true;\n\n      // set the data back to internal data\n      if (job._internalData) {\n        job.data = job._internalData;\n      }\n\n      // only relay to next job if user did not resolve 'false' on current job\n      if (job.type === 'relay' && data !== false) return this._finishRelayJob(null, data, job);\n      return this._finishSingleJob(null, data, job);\n    };\n\n    // Handle any errors returned\n    const handleError = jobError => {\n      clearTimeout(preventStallingTimeout);\n\n      // silently ignore any multiple calls\n      if (handled) {\n        return void 0;\n      }\n\n      handled = true;\n\n      // set the data back to internal job data\n      if (job._internalData) {\n        job.data = job._internalData;\n      }\n\n      // only log the error if no notifyFailure pubsub set\n      if ((!job.data.initialJob || !job.data.initialJob.options.notifyFailure) && !Array.isArray(job.data.runs)) {\n        this._logJobFailure(job, jobError);\n      }\n\n      if (job.type === 'relay') return this._finishRelayJob(jobError, null, job);\n      return this._finishSingleJob(jobError, null, job);\n    };\n\n    const preventStalling = () => {\n      this.client.srem(this.toKey('stalling'), job.id, () => {\n        if (!handled) {\n          preventStallingTimeout = setTimeout(preventStalling, this.options.stallInterval / 2);\n        }\n      });\n    };\n\n    if (!handler) {\n      return handleError(\n        new Error(\n          `\"${job.data.runs || 'No Job Handler Specified'}\" was not found. Skipping job. To fix this\n             you must either specify a handler function via queue.process() or provide a valid handler\n             node global path in your job options 'handler', e.g. if you had a global function in\n            'global.sails.services.myservice' you'd specify the handler as 'sails.services.myservice.myHandler'.`\n        )\n      );\n    }\n\n    preventStalling(); // start stalling monitor\n\n    job._internalData = job.data;\n    job.data = job.data.data || job.data;\n\n    if (job.options.timeout) {\n      setTimeout(handleError.bind(null, Error(`Job ${job.id} timed out (${job.options.timeout}ms)`)), job.options.timeout);\n    }\n\n    try {\n      if (job.options.noBind || this.options.noBind) {\n        return handler(job).then(handleOK, handleError).catch(handleError);\n      }\n\n      return handler.bind(job, job)(job).then(handleOK, handleError).catch(handleError);\n    } catch (e) {\n      return handleError(e);\n    }\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @returns {{job: {id: *, worker_id: (*|String|string), status: string}, error: *, output: *}}\n   * @private\n   */\n  _createJobEvent(error, data, job) {\n    return {\n      job: {\n        id: job.id,\n        worker_id: this.core.id,\n        status: error ? 'failed' : 'succeeded',\n        ...job.data,\n      },\n      error,\n      output: data,\n    };\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @param multi\n   * @private\n   */\n  _updateJobStatus(error, data, job, multi) {\n    const status = error ? 'failed' : 'succeeded';\n\n    multi.lrem(this.toKey('active'), 0, job.id);\n    multi.srem(this.toKey('stalling'), job.id);\n\n    if (status === 'failed') {\n      if (job.options.retries > 0) {\n        job.options.retries = job.options.retries - 1;\n        job.status = 'retrying';\n        multi.hset(this.toKey('jobs'), job.id, job.toData());\n        multi.lpush(this.toKey('waiting'), job.id);\n      } else {\n        job.status = 'failed';\n        multi.hdel(this.toKey('jobs'), job.id);\n        // TODO track failures and their data somewhere else for reviewing\n        // multi.hset(this.toKey('jobs'), job.id, job.toData());\n        // multi.sadd(this.toKey('failed'), job.id);\n      }\n    } else {\n      job.status = 'succeeded';\n      multi.hdel(this.toKey('jobs'), job.id);\n      // TODO track successes and their data somewhere else for reviewing\n      // multi.hset(this.toKey('jobs'), job.id, job.toData());\n      // multi.sadd(this.toKey('succeeded'), job.id);\n    }\n  }\n\n  /**\n   *\n   * @param error\n   * @param data\n   * @param job\n   * @returns {Promise}\n   */\n  _finishSingleJob(error, data, job) {\n    const multi = this.client.multi();\n    const status = error ? 'failed' : 'succeeded';\n    this._updateJobStatus(error, data, job, multi);\n\n    // emit success or failure event if we have listeners\n    if (error && job.options.notifyFailure) {\n      this.core.pubsub.publish(job.options.notifyFailure, this._createJobEvent(error, data, job));\n    } else if (job.options.notifySuccess) {\n      this.core.pubsub.publish(job.options.notifySuccess, this._createJobEvent(error, data, job));\n    }\n\n    return new Promise((resolve, reject) => {\n      multi.exec(errMulti => {\n        if (errMulti) return reject(errMulti);\n        return resolve({ status, result: error || data });\n      });\n    });\n  }\n\n  /**\n   * Completes a multi job or continues to the next stage.\n   * @param error\n   * @param data\n   * @param job\n   * @returns {Promise}\n   * @private\n   */\n  _finishRelayJob(error, data, job) {\n    let nextQueue = this.name;\n    const nextJob = job.data.runs[0];\n    const multi = this.client.multi();\n    const currentJob = job.data.runs.shift();\n    const status = error ? 'failed' : 'succeeded';\n\n    // keep a record of the first job in this relay instance\n    if (!job.data.initialJob) {\n      job.data.initialJob = tryJSONParse(job.toData());\n    }\n\n    // keep a record of the first queue in this relay instance\n    if (!job.data.initialQueue) {\n      job.data.initialQueue = this.name;\n    }\n\n    this._updateJobStatus(error, data, job, multi);\n\n    // check if we need to relay to another job\n    if (!(job.data.runs.length === 0 || !!error)) {\n      if (isObject(nextJob)) {\n        nextQueue = nextJob.queue;\n        job.data.runs[0] = nextJob.runs;\n      } else if (job.data.initialQueue) {\n        nextQueue = job.data.initialQueue;\n      }\n\n      // add some debug data for the next job\n      // so it can tell where the relay originated from\n      job.data.from_job = currentJob;\n      job.data.from_queue = this.name;\n      job.data.from_timestamp = getTimeStamp();\n      // relay resolved data\n      job.data.data = data;\n\n      return new Promise((resolve, reject) => {\n        return this.core.hooks.job.create(nextQueue, job.data).then(() => {\n          multi.exec(errMulti => {\n            if (errMulti) return reject(errMulti);\n            return resolve({ status, result: error || data });\n          });\n        });\n      });\n    }\n\n    // we've just finished the last job in the relay\n    // emit success or failure event if we have listeners\n    if (error && job.data.initialJob.options.notifyFailure) {\n      this.core.pubsub.publish(job.data.initialJob.options.notifyFailure, this._createJobEvent(error, data, job));\n    } else if (job.data.initialJob.options.notifySuccess) {\n      this.core.pubsub.publish(job.data.initialJob.options.notifySuccess, this._createJobEvent(error, data, job));\n    }\n\n    return new Promise((resolve, reject) => {\n      return multi.exec(errMulti => {\n        if (errMulti) return reject(errMulti);\n        return resolve({ status, result: error || data });\n      });\n    });\n  }\n\n  /**\n   *\n   * @private\n   */\n  _onLocalTickComplete = () => {\n    this.running--;\n    this.queued--;\n    if (!this.options.throttle) return setImmediate(this._queueTick);\n\n    return this.client.throttle(\n      this.toKey('throttle'),\n      this.options.throttle.limit,\n      this.options.throttle.seconds\n    ).then(throttle => {\n      const shouldThrottle = throttle[0] === 1;\n      if (!shouldThrottle) {\n        this.throttled = false;\n        return setImmediate(this._queueTick);\n      }\n\n      this.throttled = true;\n      const timeRemaining = (throttle[2] === 0 ? 1 : throttle[2]);\n      this.log.verbose(`'${this.name}' queue  reached it's throttle limit, resuming in ${timeRemaining} seconds.`);\n      return setTimeout(this._queueTick, timeRemaining * 1000);\n    }).catch(this._queueTick);\n  };\n\n  /**\n   *\n   * @param error\n   * @private\n   */\n  _onLocalTickError = (error) => {\n    this.queued--;\n    this.log.error(error);\n    setImmediate(this._queueTick);\n  };\n\n  _throttleQueue = () => {\n\n  };\n\n  /**\n   *\n   * @returns {*}\n   * @private\n   */\n  _queueTick = () => {\n    if (this.paused || !this.options.enabled) {\n      return void 0;\n    }\n    this.queued++;\n    return this\n      ._getNextJob()\n      .then(job => {\n        this.running++;\n        // queue more jobs if within limit\n        if ((this.running + this.queued) < this.options.concurrency) {\n          // concurrency is a little pointless right now if we're throttling jobs\n          if (!this.options.throttle) setImmediate(this._queueTick);\n        }\n\n        return this._runJob(job).then(this._onLocalTickComplete).catch(this._onLocalTickComplete);\n      }).catch(this._onLocalTickError);\n  };\n\n  /**\n   *\n   * @private\n   */\n  _restartProcessing = () => {\n    this.clients.block.once('ready', this._queueTick);\n  };\n\n  /**\n   * Start the queue.\n   */\n  beginWorking() {\n    if (this.started || !this.options.enabled) {\n      this.log.info(`Queue ${this.name} is currently disabled.`);\n      return void 0;\n    }\n\n    this.queued = 0;\n    this.running = 0;\n    this.started = true;\n\n    this.log.verbose(`Queue '${this.name}' - started with a concurrency of ${this.options.concurrency}.`);\n\n    this.clients.block.once('error', this._restartProcessing);\n    this.clients.block.once('close', this._restartProcessing);\n\n    this.checkStalledJobs().then(() => {\n      this.log.verbose('checkStalledJobs completed');\n    }).catch(() => {\n    });\n\n    return this._queueTick();\n  }\n\n  /**\n   *\n   * @returns {*}\n   */\n  checkStalledJobs() {\n    this.log.verbose('checkStalledJobs');\n    return this.client.checkstalledjobs(\n      this.toKey('stallTime'),\n      this.toKey('stalling'),\n      this.toKey('waiting'),\n      this.toKey('active'),\n      getTimeStamp(),\n      this.options.stallInterval\n    ).then(() => {\n      if (!this.options.enabled || this.paused) return Promise.resolve();\n      return Promise.delay(this.options.stallInterval).then(this.checkStalledJobs);\n    });\n  }\n\n  /**\n   *\n   * @param str\n   * @returns {*}\n   */\n  toKey(str) {\n    if (this.core.cluster.isCluster()) {\n      return `${this.options.keyPrefix}:{${this.name}}:${str}`;\n    }\n    return `${this.options.keyPrefix}:${this.name}:${str}`;\n  }\n\n  /**\n   * Add the eventPrefix to an event name\n   * @param eventName\n   * @returns {string}\n   */\n  toEventName = eventName => `queue:${this.name}:${eventName}`;\n}\n"]} |
{ | ||
"name": "redibox-hook-job", | ||
"description": "Advanced redibox powered jobs and queues", | ||
"version": "1.2.3", | ||
"version": "1.2.4", | ||
"main": "lib/index.js", | ||
@@ -6,0 +6,0 @@ "author": "Mike Diarmid", |
151022
2056