@supergrowthai/tq 1.0.6 → 1.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../../packages/utils/dist/server.mjs","../src/core/TaskStore.ts","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_baseSlice.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/eq.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_freeGlobal.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_root.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_Symbol.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_getRawTag.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_objectToString.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_baseGetTag.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isObject.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isFunction.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isLength.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isArrayLike.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_isIndex.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_isIterateeCall.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_trimmedEndIndex.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/_baseTrim.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isObjectLike.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/isSymbol.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/toNumber.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/toFinite.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/toInteger.js","../../../node_modules/.bun/lodash@4.17.21/node_modules/lodash/chunk.js","../src/utils/disposable-lock.ts","../src/core/TaskRunner.ts","../src/core/environment.ts","../src/core/TaskHandler.ts","../src/core/TaskQueuesManager.ts","../src/providers/ConsoleHealthProvider.ts"],"sourcesContent":["import { Logger, LogLevel } from \"./client.mjs\";\nclass LockManager {\n constructor(cacheProvider, options) {\n this.cacheProvider = cacheProvider;\n this.acquireLocks = /* @__PURE__ */ new Map();\n this.logger = new Logger(\"MetricsCollector\", LogLevel.INFO);\n this.cacheProvider = cacheProvider;\n this.prefix = options?.prefix || \"lock:\";\n this.defaultTimeout = options?.defaultTimeout || 30 * 60;\n if (options?.debugLogs)\n this.logger.setLogLevel(LogLevel.INFO);\n }\n /**\n * Check if a resource is locked\n */\n async isLocked(resourceId) {\n this.logger.debug(\"isLocked\" + resourceId);\n const exists = await this.cacheProvider.get(this.getKey(resourceId));\n return !!exists;\n }\n /**\n * Filter out locked resources from an array\n */\n async filterLocked(resources, getResourceId) {\n if (!resources.length) return [];\n const lockChecks = resources.map((resource) => this.isLocked(getResourceId(resource)));\n const lockResults = await Promise.all(lockChecks);\n return resources.filter((_, index) => !lockResults[index]);\n }\n /**\n * Acquire a lock\n * @returns true if lock was acquired, false if already locked\n */\n async acquire(resourceId, timeout = this.defaultTimeout) {\n this.logger.debug(\"Acquire\" + resourceId);\n const existingLock = this.acquireLocks.get(resourceId);\n if (existingLock) {\n await existingLock;\n return false;\n }\n const lockPromise = this.acquireInternal(resourceId, timeout);\n this.acquireLocks.set(resourceId, lockPromise);\n try {\n return await lockPromise;\n } finally {\n this.acquireLocks.delete(resourceId);\n }\n }\n /**\n * Release a lock\n */\n async release(resourceId) {\n this.logger.debug(\"Release\" + resourceId);\n const key = this.getKey(resourceId);\n await this.cacheProvider.del(key);\n }\n async acquireInternal(resourceId, timeout) {\n if (await this.isLocked(resourceId)) return false;\n const key = this.getKey(resourceId);\n const result = await this.cacheProvider.set(key, \"1\", timeout);\n return result === \"OK\" || result === \"1\" || result === 1;\n }\n getKey(resourceId) {\n return `${this.prefix}${resourceId}`;\n }\n}\nclass ShutdownManager {\n constructor() {\n this.sigintListeners = [];\n this.sigint = {\n register: (listener) => this.sigintListeners.push(listener)\n };\n this.sigtermListeners = [];\n this.sigterm = {\n register: (listener) => this.sigtermListeners.push(listener)\n };\n this.sigquitListeners = [];\n this.sigquit = {\n register: (listener) => this.sigquitListeners.push(listener)\n };\n this.shuttingDown = false;\n this._runListeners = async (listeners) => {\n for (const listener of listeners) {\n try {\n await listener();\n } catch (err) {\n console.error(\"Error during shutdown task:\", err);\n }\n }\n };\n process.on(\"SIGINT\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGINT received. Running shutdown tasks...\");\n this._runListeners(this.sigintListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n process.on(\"SIGTERM\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGTERM received. Running shutdown tasks...\");\n this._runListeners(this.sigtermListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n process.on(\"SIGQUIT\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGQUIT received. Running shutdown tasks...\");\n this._runListeners(this.sigquitListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n }\n}\nexport {\n LockManager,\n LogLevel,\n Logger,\n ShutdownManager\n};\n//# sourceMappingURL=server.mjs.map\n","import type {CronTask, ITaskStorageAdapter} from \"../adapters\";\nimport {getEnvironmentQueueName} from \"@supergrowthai/mq\";\n\nclass TaskStore<ID> {\n\n constructor(private databaseAdapter: ITaskStorageAdapter<ID>) {\n }\n\n /**\n * Adds multiple tasks to the scheduled queue\n */\n async addTasksToScheduled(tasks: CronTask<ID>[]): Promise<CronTask<ID>[]> {\n if (!tasks.length) return [];\n\n const transformedTasks = tasks.map((task) => ({\n id: task.id,\n type: task.type,\n queue_id: getEnvironmentQueueName(task.queue_id),\n payload: task.payload,\n execute_at: task.execute_at,\n expires_at: task.expires_at,\n status: 'scheduled' as const,\n task_group: task.task_group,\n task_hash: task.task_hash,\n retries: task.retries || 0,\n retry_after: task.retry_after,\n execution_stats: task.execution_stats,\n created_at: task.created_at || new Date(),\n updated_at: task.updated_at || new Date(),\n processing_started_at: task.processing_started_at || new Date(),\n force_store: task.force_store\n })) as CronTask<ID>[];\n\n return await this.databaseAdapter.addTasksToScheduled(transformedTasks);\n }\n\n /**\n * Gets mature tasks that are ready to be processed\n * Implements a two-phase approach:\n * 1. Reset stale processing tasks\n * 2. Fetch and mark new mature tasks\n */\n async getMatureTasks(timestamp: number): Promise<CronTask<ID>[]> {\n return await this.databaseAdapter.getMatureTasks(timestamp);\n }\n\n /**\n * Marks tasks as processing with current timestamp\n */\n async markTasksAsProcessing(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsProcessing(tasks, new Date());\n }\n\n /**\n * Marks tasks as executed/completed\n */\n async markTasksAsExecuted(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsExecuted(tasks);\n }\n\n /**\n * Marks tasks as failed and increments retry count\n */\n async markTasksAsFailed(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsFailed(tasks);\n }\n\n /**\n * Marks tasks as successful/completed\n */\n async markTasksAsSuccess(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsExecuted(tasks);\n }\n\n /**\n * Marks tasks as ignored with proper task context\n */\n async markTasksAsIgnored(tasks: CronTask<ID>[]): Promise<void> {\n const updatedTasks = tasks.map(task => ({\n ...task,\n execution_stats: {\n ...(task.execution_stats || {}),\n error: 'No executor found for task type',\n ignored_reason: 'unknown_executor',\n ignored_at: new Date()\n }\n }));\n\n await this.databaseAdapter.markTasksAsIgnored(updatedTasks);\n }\n\n /**\n * Updates multiple tasks with specific updates\n */\n async updateTasks(updates: Array<{ id: ID; updates: Partial<CronTask<ID>> }>): Promise<void> {\n await this.databaseAdapter.updateTasks(updates);\n }\n\n /**\n * Gets tasks by their IDs\n */\n async getTasksByIds(taskIds: ID[]): Promise<CronTask<ID>[]> {\n return await this.databaseAdapter.getTasksByIds(taskIds);\n }\n\n /**\n * Gets cleanup statistics\n */\n async getCleanupStats(): Promise<{ orphanedTasks: number; expiredTasks: number }> {\n return await this.databaseAdapter.getCleanupStats();\n }\n\n /**\n * Cleans up orphaned and expired tasks\n */\n async cleanupTasks(): Promise<void> {\n const twoDaysAgo = new Date(Date.now() - 2 * 24 * 60 * 60 * 1000);\n const now = new Date();\n\n await this.databaseAdapter.cleanupTasks(twoDaysAgo, now);\n }\n\n /**\n * Updates tasks for retry with new execution time and retry count\n */\n async updateTasksForRetry(tasks: CronTask<ID>[]): Promise<void> {\n const updates = tasks.map(task => ({\n id: task.id as ID,\n updates: {\n execute_at: task.execute_at,\n status: task.status,\n execution_stats: task.execution_stats,\n updated_at: new Date()\n }\n }));\n\n await this.databaseAdapter.updateTasks(updates);\n }\n\n}\n\nexport {TaskStore};","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nmodule.exports = baseSlice;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n}\n\nmodule.exports = isIterateeCall;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nmodule.exports = toFinite;\n","var toFinite = require('./toFinite');\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nmodule.exports = toInteger;\n","var baseSlice = require('./_baseSlice'),\n isIterateeCall = require('./_isIterateeCall'),\n toInteger = require('./toInteger');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n nativeMax = Math.max;\n\n/**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\nfunction chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n}\n\nmodule.exports = chunk;\n","import {LockManager} from \"@supergrowthai/utils\";\n\n/**\n * A batch of locks that implements AsyncDisposable for use with `await using`.\n * Automatically releases all acquired locks when the scope exits, even on error.\n *\n * @example\n * ```typescript\n * await using locks = new DisposableLockBatch(lockManager);\n * await locks.acquire('task-1');\n * await locks.acquire('task-2');\n * // ... do work ...\n * // locks automatically released here, even if an error is thrown\n * ```\n *\n * @since Node.js 22+ (Explicit Resource Management)\n */\nexport class DisposableLockBatch implements AsyncDisposable {\n private readonly lockIds: string[] = [];\n private disposed = false;\n\n constructor(\n private readonly lockManager: LockManager,\n private readonly onError?: (lockId: string, error: unknown) => void\n ) {\n }\n\n /**\n * Get the list of currently held lock IDs\n */\n get heldLocks(): readonly string[] {\n return this.lockIds;\n }\n\n /**\n * Number of locks currently held\n */\n get size(): number {\n return this.lockIds.length;\n }\n\n /**\n * Acquire a lock and track it for automatic release\n */\n async acquire(lockId: string, timeout?: number): Promise<boolean> {\n if (this.disposed) {\n throw new Error('Cannot acquire lock on disposed DisposableLockBatch');\n }\n\n const acquired = await this.lockManager.acquire(lockId, timeout);\n if (acquired) {\n this.lockIds.push(lockId);\n }\n return acquired;\n }\n\n /**\n * AsyncDisposable implementation - releases all locks\n */\n async [Symbol.asyncDispose](): Promise<void> {\n if (this.disposed) return;\n this.disposed = true;\n\n await Promise.all(\n this.lockIds.map(lockId =>\n this.lockManager.release(lockId).catch(err => {\n if (this.onError) {\n this.onError(lockId, err);\n }\n })\n )\n );\n }\n}\n","import chunk from \"lodash/chunk\";\nimport {Logger, LogLevel} from \"@supergrowthai/utils/server\";\nimport {tId} from \"../utils/task-id-gen.js\";\nimport {DisposableLockBatch} from \"../utils/disposable-lock.js\";\nimport {TaskType} from \"../types.js\";\nimport {ActionResults, Actions} from \"./Actions.js\";\nimport {AsyncActions} from \"./async/AsyncActions.js\";\nimport {CronTask} from \"../adapters\";\nimport {IMessageQueue} from \"@supergrowthai/mq\";\nimport {CacheProvider} from \"memoose-js\";\nimport {LockManager} from \"@supergrowthai/utils\";\nimport {TaskQueuesManager} from \"./TaskQueuesManager\";\nimport {TaskStore} from \"./TaskStore\";\nimport {IAsyncTaskManager} from \"./async/async-task-manager\";\nimport type {ITaskLifecycleProvider, TaskContext, TaskHandlerLifecycleConfig, TaskTiming} from \"./lifecycle.js\";\n\nexport interface AsyncTask<ID> {\n task: CronTask<ID>;\n promise: Promise<void>;\n startTime: number;\n actions: AsyncActions<ID>;\n}\n\nexport class TaskRunner<ID> {\n private readonly logger: Logger;\n private lockManager: LockManager;\n private readonly taskStartTimes = new Map<string, number>();\n\n constructor(\n private messageQueue: IMessageQueue<ID>,\n private taskQueue: TaskQueuesManager<ID>,\n private taskStore: TaskStore<ID>,\n cacheProvider: CacheProvider<any>,\n private generateId: () => ID,\n private lifecycleProvider?: ITaskLifecycleProvider,\n private lifecycleConfig?: TaskHandlerLifecycleConfig\n ) {\n this.logger = new Logger('TaskRunner', LogLevel.INFO);\n this.lockManager = new LockManager(cacheProvider, {\n prefix: \"task_lock_\",\n defaultTimeout: 30 * 60\n });\n }\n\n // ============ Lifecycle Helpers ============\n\n async run(\n taskRunnerId: string,\n tasksRaw: Array<CronTask<ID>>,\n asyncTaskManager?: IAsyncTaskManager,\n abortSignal?: AbortSignal\n ): Promise<ActionResults<ID> & { asyncTasks: AsyncTask<ID>[] }> {\n this.logger.info(`[${taskRunnerId}] Starting task runner`);\n this.logger.info(`[${taskRunnerId}] Processing ${tasksRaw.length} provided tasks`);\n\n if (abortSignal?.aborted) {\n this.logger.info(`[${taskRunnerId}] AbortSignal already aborted, returning empty results`);\n return {successTasks: [], failedTasks: [], newTasks: [], ignoredTasks: [], asyncTasks: []};\n }\n\n const tasks = await this.lockManager.filterLocked(tasksRaw, tId);\n\n this.logger.info(`[${taskRunnerId}] Found ${tasks.length} not locked tasks to process`);\n\n // Use DisposableLockBatch with await using for automatic lock cleanup\n // This ensures locks are ALWAYS released, even on exceptions or early returns\n await using locks = new DisposableLockBatch(\n this.lockManager,\n (lockId, err) => this.logger.error(`[${taskRunnerId}] Failed to release lock ${lockId}:`, err)\n );\n\n for (const task of tasks) {\n await locks.acquire(tId(task));\n }\n\n const groupedTasksObject = tasks\n .reduce((acc: Record<TaskType, CronTask<ID>[]>, task) => {\n acc[task.type] = acc[task.type] || [];\n acc[task.type].push(task);\n return acc;\n }, {} as Record<TaskType, CronTask<ID>[]>);\n\n const groupedTasksArray = (Object.keys(groupedTasksObject) as unknown as TaskType[]).reduce((acc: {\n type: TaskType,\n tasks: CronTask<ID>[]\n }[], type: TaskType) => {\n acc.push({type, tasks: groupedTasksObject[type]})\n return acc;\n }, [] as { type: TaskType, tasks: CronTask<ID>[] }[]);\n\n this.logger.info(`[${taskRunnerId}] Task groups: ${groupedTasksArray.map(g => `${g.type}: ${g.tasks.length}`).join(', ')}`);\n\n const actions = new Actions<ID>(taskRunnerId);\n const asyncTasks: AsyncTask<ID>[] = [];\n const processedTaskIds = new Set<string>();\n\n for (let i = 0; i < groupedTasksArray.length; i++) {\n if (abortSignal?.aborted) {\n this.logger.info(`[${taskRunnerId}] AbortSignal detected, stopping task group processing`);\n break;\n }\n\n const taskGroup = groupedTasksArray[i];\n const firstTask = taskGroup.tasks[0];\n if (!firstTask) {\n this.logger.warn(`[${taskRunnerId}] No tasks found for type: ${taskGroup.type}`);\n continue;\n }\n const executor = this.taskQueue.getExecutor(firstTask.queue_id, taskGroup.type);\n if (!executor) {\n this.logger.warn(`[${taskRunnerId}] No executor found for type: ${taskGroup.type} in queue ${firstTask.queue_id}`);\n for (const task of taskGroup.tasks) {\n const taskWithId: CronTask<ID> = task.id\n ? task\n : {...task, id: this.generateId()};\n actions.addIgnoredTask(taskWithId);\n }\n continue;\n }\n\n if (executor.asyncConfig?.handoffTimeout && asyncTaskManager && !asyncTaskManager.canAcceptTask()) {\n this.logger.warn(`[${taskRunnerId}] Async queue full, rescheduling ${taskGroup.tasks.length} ${taskGroup.type} tasks for 3 min later`);\n\n const rescheduledTasks = taskGroup.tasks.map(task => ({\n ...task,\n execute_at: new Date(Date.now() + 180000),\n status: 'scheduled' as const\n }));\n\n await this.taskStore.updateTasksForRetry(rescheduledTasks);\n continue;\n }\n\n // Track that we're processing this task group\n taskGroup.tasks.forEach(task => processedTaskIds.add(tId(task)));\n\n this.logger.info(`[${taskRunnerId}] Processing ${taskGroup.tasks.length} tasks of type: ${taskGroup.type}`);\n\n if (executor.multiple) {\n await executor.onTasks(taskGroup.tasks as any[], actions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTasks failed: ${err}`))\n } else {\n if (executor.parallel) {\n const chunks = chunk(taskGroup.tasks, executor.chunkSize) as CronTask<ID>[][];\n this.logger.info(`[${taskRunnerId}] Processing in parallel chunks of ${executor.chunkSize}`);\n for (const taskChunk of chunks) {\n // Emit onTaskStarted for all tasks in chunk\n for (const task of taskChunk) {\n this.emitTaskStarted(task, taskRunnerId);\n }\n\n const chunkPromises: Promise<void>[] = [];\n for (let j = 0; j < taskChunk.length; j++) {\n const taskActions = actions.forkForTask(taskChunk[j]);\n chunkPromises.push(executor.onTask(taskChunk[j], taskActions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`)));\n }\n await Promise.all(chunkPromises);\n\n // Emit completion events for all tasks in chunk\n for (const task of taskChunk) {\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n }\n }\n } else {\n const timeoutMs = executor.asyncConfig?.handoffTimeout;\n\n for (let j = 0; j < taskGroup.tasks.length; j++) {\n const task = taskGroup.tasks[j];\n\n if (!timeoutMs) {\n // Emit onTaskStarted\n this.emitTaskStarted(task, taskRunnerId);\n\n const taskActions = actions.forkForTask(task);\n await executor.onTask(task, taskActions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`));\n\n // Emit completion event based on result\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n } else {\n // Emit onTaskStarted for async-capable tasks\n this.emitTaskStarted(task, taskRunnerId);\n\n const startTime = Date.now();\n let isTimedOut = false;\n\n const taskActions = actions.forkForTask(task);\n\n const taskPromise = executor.onTask(task, taskActions).catch(err => {\n this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`);\n });\n\n let timeoutId: NodeJS.Timeout | undefined;\n const timeoutPromise = new Promise<'~~~timeout'>(resolve => {\n timeoutId = setTimeout(() => {\n isTimedOut = true;\n resolve('~~~timeout');\n }, timeoutMs);\n\n // Support early cancellation via AbortSignal\n // Note: In real usage, this would come from the task execution context\n // For now, this is a foundation for future AbortSignal integration\n });\n\n const result = await Promise.race([taskPromise, timeoutPromise]);\n\n // Clear the timeout to prevent memory leak\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n\n if (result !== '~~~timeout') {\n // Task completed before timeout - emit lifecycle event\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n }\n\n if (result === '~~~timeout') {\n this.logger.info(`[${taskRunnerId}] Task ${tId(task)} (${task.type}) exceeded ${timeoutMs}ms, marking for async handoff`);\n\n if (!asyncTaskManager) {\n throw new Error(`Task ${task.type} exceeded timeout but AsyncTaskManager not initialized!`);\n }\n\n if (!task.id) {\n this.logger.error(`[${taskRunnerId}] Cannot hand off task without id (type: ${task.type}). Task will continue but won't be tracked.`);\n } else {\n const asyncActions = new AsyncActions<ID>(this.messageQueue, this.taskStore, this.taskQueue, actions, task, this.generateId);\n\n const asyncPromise = taskPromise\n .finally(async () => {\n try {\n await asyncActions.onPromiseFulfilled();\n } catch (err) {\n this.logger.error(`[${taskRunnerId}] Failed to execute async actions for task ${tId(task)}:`, err);\n }\n });\n\n asyncTasks.push({\n task,\n promise: asyncPromise,\n startTime,\n actions: asyncActions\n });\n }\n }\n }\n }\n }\n }\n }\n\n const asyncTaskIds = asyncTasks.map(at => tId(at.task));\n const results = actions.extractSyncResults(asyncTaskIds);\n\n this.logger.info(`[${taskRunnerId}] Completing run - Success: ${results.successTasks.length}, Failed: ${results.failedTasks.length}, New: ${results.newTasks.length}, Async: ${asyncTasks.length}, Ignored: ${results.ignoredTasks.length}`);\n\n // Locks are automatically released by DisposableLockBatch via await using\n return {...results, asyncTasks};\n }\n\n private emitLifecycleEvent<T>(\n callback: ((ctx: T) => void | Promise<void>) | undefined,\n ctx: T\n ): void {\n if (!callback) return;\n\n try {\n const result = callback(ctx);\n if (result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n }\n } catch (err) {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n }\n }\n\n private buildTaskContext(task: CronTask<ID>, workerId?: string): TaskContext {\n const retryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number')\n ? task.execution_stats.retry_count\n : 0;\n const executor = this.taskQueue.getExecutor(task.queue_id, task.type);\n const maxRetries = task.retries ?? executor?.default_retries ?? 0;\n const payload = task.payload as Record<string, unknown>;\n\n return {\n task_id: task.id?.toString() || tId(task),\n task_hash: payload?.task_hash as string | undefined,\n task_type: task.type,\n queue_id: task.queue_id,\n payload: this.lifecycleConfig?.include_payload ? payload : {},\n attempt: retryCount + 1,\n max_retries: maxRetries,\n scheduled_at: task.created_at || new Date(),\n worker_id: workerId\n };\n }\n\n private emitTaskStarted(task: CronTask<ID>, workerId: string): void {\n const startedAt = Date.now();\n this.taskStartTimes.set(tId(task), startedAt);\n\n if (this.lifecycleProvider?.onTaskStarted) {\n const ctx = this.buildTaskContext(task, workerId);\n const queuedDuration = startedAt - (task.created_at?.getTime() || startedAt);\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskStarted,\n {\n ...ctx,\n started_at: new Date(startedAt),\n queued_duration_ms: queuedDuration\n }\n );\n }\n }\n\n private emitTaskCompleted(task: CronTask<ID>, workerId: string, result?: unknown): void {\n const completedAt = Date.now();\n const startedAt = this.taskStartTimes.get(tId(task)) || completedAt;\n this.taskStartTimes.delete(tId(task));\n\n if (this.lifecycleProvider?.onTaskCompleted) {\n const ctx = this.buildTaskContext(task, workerId);\n const timing: TaskTiming = {\n queued_duration_ms: startedAt - (task.created_at?.getTime() || startedAt),\n processing_duration_ms: completedAt - startedAt,\n total_duration_ms: completedAt - (task.created_at?.getTime() || completedAt)\n };\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskCompleted,\n {...ctx, timing, result}\n );\n }\n }\n\n private emitTaskFailed(task: CronTask<ID>, workerId: string, error: Error, willRetry: boolean, nextAttemptAt?: Date): void {\n const completedAt = Date.now();\n const startedAt = this.taskStartTimes.get(tId(task)) || completedAt;\n this.taskStartTimes.delete(tId(task));\n\n if (this.lifecycleProvider?.onTaskFailed) {\n const ctx = this.buildTaskContext(task, workerId);\n const timing: TaskTiming = {\n queued_duration_ms: startedAt - (task.created_at?.getTime() || startedAt),\n processing_duration_ms: completedAt - startedAt,\n total_duration_ms: completedAt - (task.created_at?.getTime() || completedAt)\n };\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskFailed,\n {...ctx, timing, error, will_retry: willRetry, next_attempt_at: nextAttemptAt}\n );\n }\n }\n}","import {getEnvironmentQueueName, QueueName} from \"@supergrowthai/mq\";\n\n/**\n * Gets all queue names for the current environment\n * @returns Array of full queue names including environment suffix\n */\nexport function getEnabledQueues(): QueueName[] {\n let enabledQueues: QueueName[] = process.env.ENABLED_QUEUES ? JSON.parse(process.env.ENABLED_QUEUES!) : [];\n\n if (enabledQueues.length === 0) throw new Error('No queues enabled');\n\n return enabledQueues.map(getEnvironmentQueueName);\n}\n","import {TaskStore} from \"./TaskStore.js\";\nimport {LockManager, Logger, LogLevel} from \"@supergrowthai/utils\"\nimport {TaskRunner} from \"./TaskRunner.js\";\nimport {getEnabledQueues} from \"./environment.js\";\nimport moment from \"moment\";\nimport type {MessageConsumer} from \"@supergrowthai/mq\";\nimport {IMessageQueue, QueueName} from \"@supergrowthai/mq\";\nimport {ProcessedTaskResult} from \"./task-processor-types.js\";\nimport {CronTask, ITaskStorageAdapter} from \"../adapters\";\nimport type {CacheProvider} from \"memoose-js\";\nimport {TaskQueuesManager} from \"./TaskQueuesManager\";\nimport {IAsyncTaskManager} from \"./async/async-task-manager\";\nimport {\n DiscardedTaskInfo,\n ITaskNotificationProvider,\n TaskErrorInfo,\n TaskQueueStats\n} from \"./ITaskNotificationProvider.js\";\nimport type {\n ITaskLifecycleProvider,\n IWorkerLifecycleProvider,\n TaskContext,\n TaskHandlerConfig,\n WorkerInfo,\n WorkerStats\n} from \"./lifecycle.js\";\nimport * as os from \"os\";\n\nconst METRICS_KEY_PREFIX = 'task_metrics:';\nconst DISCARDED_TASKS_KEY = `${METRICS_KEY_PREFIX}discarded_tasks`;\nconst STATS_THRESHOLD = parseInt(process.env.TQ_STATS_THRESHOLD || '1000');\nconst FAILURE_THRESHOLD = parseInt(process.env.TQ_STATS_FAILURE_THRESHOLD || '100');\nconst INSTANCE_ID = process.env.INSTANCE_ID || 'unknown';\n\n\nexport class TaskHandler<ID> {\n private readonly logger: Logger;\n private taskRunner: TaskRunner<ID>;\n private readonly taskStore: TaskStore<ID>;\n private matureTaskTimer: NodeJS.Timeout | null = null;\n private heartbeatTimer: NodeJS.Timeout | null = null;\n private readonly config: TaskHandlerConfig;\n\n // Worker info\n private readonly workerId: string;\n private readonly workerStartedAt: Date;\n private enabledQueues: string[] = [];\n private workerStarted = false;\n\n // Worker stats\n private workerStats: WorkerStats = {\n tasks_processed: 0,\n tasks_succeeded: 0,\n tasks_failed: 0,\n avg_processing_ms: 0,\n current_task: undefined\n };\n private totalProcessingMs = 0;\n\n private readonly queueStats = new Map<QueueName, {\n success: number;\n failed: number;\n async: number;\n ignored: number;\n }>();\n\n constructor(\n private messageQueue: IMessageQueue<ID>,\n private taskQueuesManager: TaskQueuesManager<ID>,\n private databaseAdapter: ITaskStorageAdapter<ID>,\n private cacheAdapter: CacheProvider<any>,\n private asyncTaskManager?: IAsyncTaskManager<ID>,\n private notificationProvider?: ITaskNotificationProvider,\n config?: TaskHandlerConfig\n ) {\n this.logger = new Logger('TaskHandler', LogLevel.INFO);\n this.config = config || {};\n\n // Initialize worker identity\n this.workerId = `${os.hostname()}-${process.pid}-${Date.now()}`;\n this.workerStartedAt = new Date();\n\n this.taskStore = new TaskStore<ID>(databaseAdapter);\n this.taskRunner = new TaskRunner<ID>(\n messageQueue,\n taskQueuesManager,\n this.taskStore,\n this.cacheAdapter,\n databaseAdapter.generateId.bind(databaseAdapter),\n this.config.lifecycleProvider,\n this.config.lifecycle\n );\n }\n\n // ============ Lifecycle Event Helpers ============\n\n private get lifecycleProvider(): ITaskLifecycleProvider | undefined {\n return this.config.lifecycleProvider;\n }\n\n private get workerProvider(): IWorkerLifecycleProvider | undefined {\n return this.config.workerProvider;\n }\n\n async addTasks(tasks: CronTask<ID>[]) {\n const diffedItems = tasks.reduce(\n (acc, {force_store, ...task}) => {\n const currentTime = new Date();\n const executeTime = task.execute_at;\n const timeDifference = (executeTime.getTime() - currentTime.getTime()) / 1000 / 60;\n\n const queue = task.queue_id;\n if (timeDifference > 2 || force_store) {\n acc.future[queue] = acc.future[queue] || [];\n acc.future[queue].push(task);\n } else {\n acc.immediate[queue] = acc.immediate[queue] || [];\n acc.immediate[queue].push(task);\n }\n\n return acc;\n },\n {\n future: {} as { [key in QueueName]: CronTask<ID>[] },\n immediate: {} as { [key in QueueName]: CronTask<ID>[] },\n }\n );\n\n const iQueues = Object.keys(diffedItems.immediate) as unknown as QueueName[];\n for (let i = 0; i < iQueues.length; i++) {\n const queue = iQueues[i];\n const queueTasks: CronTask<ID>[] = diffedItems.immediate[queue]\n .map((task) => {\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n const shouldStoreOnFailure = executor?.store_on_failure ?? false;\n const id = shouldStoreOnFailure ? {id: this.databaseAdapter.generateId(),} : {}\n return ({...id, ...task});\n });\n\n await this.messageQueue.addMessages(queue, queueTasks as unknown as CronTask<ID>[]);\n\n // Emit onTaskScheduled for each task\n if (this.lifecycleProvider?.onTaskScheduled) {\n for (const task of queueTasks) {\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskScheduled,\n this.buildTaskContext(task)\n );\n }\n }\n }\n\n const fQueues = Object.keys(diffedItems.future) as unknown as QueueName[];\n for (let i = 0; i < fQueues.length; i++) {\n const queue = fQueues[i];\n const queueTasks: CronTask<ID>[] = diffedItems.future[queue]\n .map((task) => {\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n const shouldStoreOnFailure = executor?.store_on_failure ?? false;\n const id = shouldStoreOnFailure ? {id: this.databaseAdapter.generateId(),} : {}\n return ({...id, ...task});\n });\n await this.taskStore.addTasksToScheduled(queueTasks);\n\n // Emit onTaskScheduled for each task\n if (this.lifecycleProvider?.onTaskScheduled) {\n for (const task of queueTasks) {\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskScheduled,\n this.buildTaskContext(task)\n );\n }\n }\n }\n }\n\n async postProcessTasks({\n failedTasks: failedTasksRaw,\n newTasks,\n successTasks\n }: ProcessedTaskResult<ID>) {\n const tasksToRetry: CronTask<ID>[] = [];\n const finalFailedTasks: CronTask<ID>[] = [];\n let discardedTasksCount = 0;\n\n // Maximum retry delay cap to prevent unbounded delays\n const MAX_RETRY_DELAY_MS = 5 * 60 * 1000; // 5 minutes\n\n for (const task of failedTasksRaw) {\n const taskRetryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number') ? task.execution_stats.retry_count : 0;\n const taskRetryAfter = task.retry_after || 2000;\n const calculatedDelay = taskRetryAfter * Math.pow(taskRetryCount + 1, 2);\n const retryAfter = Math.min(calculatedDelay, MAX_RETRY_DELAY_MS);\n const executeAt = Date.now() + retryAfter;\n const maxRetries = this.getRetryCount(task);\n\n if (task.id && taskRetryCount < maxRetries) {\n tasksToRetry.push({\n ...task,\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n });\n } else if (task.id) {\n finalFailedTasks.push(task);\n } else if (taskRetryCount < maxRetries) {\n const shouldStoreOnFailure = this.taskQueuesManager.getExecutor(task.queue_id, task.type)?.store_on_failure;\n if (shouldStoreOnFailure) {\n tasksToRetry.push({\n ...task,\n id: this.databaseAdapter.generateId(),\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n });\n } else {\n await this.addTasks([{\n ...task,\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n }]);\n }\n } else {\n discardedTasksCount++;\n this.logger.info(`Discarding task of type ${task.type} after ${taskRetryCount} retries`);\n\n // Emit onTaskExhausted for discarded tasks\n if (this.lifecycleProvider?.onTaskExhausted) {\n const ctx = this.buildTaskContext(task);\n const errorMessage = task.execution_stats?.last_error as string || 'Task exhausted all retries';\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskExhausted,\n {\n ...ctx,\n timing: {\n queued_duration_ms: 0,\n processing_duration_ms: 0,\n total_duration_ms: Date.now() - (task.created_at?.getTime() || Date.now())\n },\n error: new Error(errorMessage),\n total_attempts: taskRetryCount + 1\n }\n );\n }\n }\n }\n\n if (discardedTasksCount > 0) {\n await this.trackDiscardedTasks(discardedTasksCount);\n }\n\n if (tasksToRetry.length > 0) {\n await this.taskStore.updateTasksForRetry(tasksToRetry);\n }\n\n if (newTasks.length > 0) {\n await this.addTasks(newTasks);\n }\n\n if (finalFailedTasks.length > 0) {\n await this.taskStore.markTasksAsFailed(finalFailedTasks);\n }\n\n if (successTasks.length > 0) {\n await this.taskStore.markTasksAsSuccess(successTasks);\n }\n }\n\n startConsumingTasks(streamName: QueueName, abortSignal?: AbortSignal) {\n return this.messageQueue.consumeMessagesStream(streamName, async (id, tasks) => {\n if (abortSignal?.aborted) {\n this.logger.info(`AbortSignal detected, skipping processing of ${tasks.length} tasks for stream ${streamName}`);\n return {failedTasks: [], newTasks: [], successTasks: [], asyncTasks: [], ignoredTasks: []};\n }\n\n const batchStartTime = Date.now();\n const taskTypes = [...new Set(tasks.map(t => t.type))];\n\n // Emit batch started\n if (this.workerProvider?.onBatchStarted) {\n this.emitLifecycleEvent(\n this.workerProvider.onBatchStarted,\n {\n ...this.buildWorkerInfo(),\n batch_size: tasks.length,\n task_types: taskTypes\n }\n );\n }\n\n this.logger.debug(`Processing ${tasks.length} tasks for stream ${streamName}`);\n const {\n failedTasks,\n newTasks,\n successTasks,\n asyncTasks,\n ignoredTasks\n } = await this.taskRunner.run(id, tasks, this.asyncTaskManager, abortSignal)\n .catch(err => {\n this.logger.error(\"Failed to execute tasks?\", err);\n return {failedTasks: [], newTasks: [], successTasks: [], asyncTasks: [], ignoredTasks: []}\n });\n\n if (asyncTasks.length > 0 && !this.asyncTaskManager) {\n throw new Error(\"Async tasks detected but AsyncTaskManager not initialized!\");\n }\n if (asyncTasks.length > 0) {\n this.logger.info(`Handling ${asyncTasks.length} async tasks for stream ${streamName}`);\n for (const asyncTask of asyncTasks) {\n const accepted = this.asyncTaskManager!.handoffTask(asyncTask.task, asyncTask.promise);\n if (!accepted) {\n this.logger.warn(`Async queue full, requeueing task ${asyncTask.task.id} with 30s delay`);\n await this.addTasks([{\n ...asyncTask.task,\n execute_at: new Date(Date.now() + 30000)\n }]);\n }\n }\n }\n\n if (ignoredTasks.length > 0) {\n this.logger.warn(`Storing ${ignoredTasks.length} ignored tasks with no executor for stream ${streamName}`);\n await this.taskStore.markTasksAsIgnored(ignoredTasks)\n .catch(err => {\n this.logger.error(\"Failed to mark tasks as ignored\", err)\n });\n }\n\n await this.postProcessTasks({failedTasks, newTasks, successTasks})\n .catch(err => {\n this.logger.error(\"Failed to postProcessTasks\", err)\n })\n\n if (!this.queueStats.has(streamName)) {\n this.queueStats.set(streamName, {\n success: 0,\n failed: 0,\n async: 0,\n ignored: 0\n });\n }\n const stats = this.queueStats.get(streamName)!;\n stats.success += successTasks.length;\n stats.failed += failedTasks.length;\n stats.async += asyncTasks.length;\n stats.ignored += ignoredTasks.length;\n\n await this.reportQueueStats(streamName);\n\n // Update worker stats\n const batchDuration = Date.now() - batchStartTime;\n this.updateWorkerStats(successTasks.length, failedTasks.length, batchDuration);\n\n // Emit batch completed\n if (this.workerProvider?.onBatchCompleted) {\n this.emitLifecycleEvent(\n this.workerProvider.onBatchCompleted,\n {\n ...this.buildWorkerInfo(),\n batch_size: tasks.length,\n succeeded: successTasks.length,\n failed: failedTasks.length,\n duration_ms: batchDuration\n }\n );\n }\n\n this.logger.debug(`Completed processing for stream ${streamName}: ${successTasks.length} succeeded, ${failedTasks.length} failed, ${newTasks.length} new tasks, ${ignoredTasks.length} ignored`);\n return {failedTasks, newTasks, successTasks, asyncTasks, ignoredTasks};\n }, abortSignal);\n }\n\n taskProcessServer(abortSignal?: AbortSignal) {\n const queues = getEnabledQueues();\n this.enabledQueues = queues;\n\n // Emit worker started event\n if (!this.workerStarted) {\n this.workerStarted = true;\n this.emitWorkerStarted();\n this.startHeartbeat();\n }\n\n for (let i = 0; i < queues.length; i++) {\n this.logger.info(`Starting consumer for queue: ${queues[i]}`);\n this.startConsumingTasks(queues[i], abortSignal);\n }\n this.logger.info('Starting mature tasks processor');\n this.processMatureTasks(abortSignal);\n\n // Handle worker shutdown\n abortSignal?.addEventListener('abort', () => {\n this.stopHeartbeat();\n this.emitWorkerStopped('shutdown');\n });\n }\n\n private buildWorkerInfo(): WorkerInfo {\n return {\n worker_id: this.workerId,\n hostname: os.hostname(),\n pid: process.pid,\n started_at: this.workerStartedAt,\n enabled_queues: this.enabledQueues\n };\n }\n\n private emitWorkerStarted(): void {\n if (!this.workerProvider?.onWorkerStarted) return;\n this.emitLifecycleEvent(this.workerProvider.onWorkerStarted, this.buildWorkerInfo());\n }\n\n private emitWorkerStopped(reason: 'shutdown' | 'error' | 'idle_timeout'): void {\n if (!this.workerProvider?.onWorkerStopped) return;\n this.emitLifecycleEvent(\n this.workerProvider.onWorkerStopped,\n {\n ...this.buildWorkerInfo(),\n reason,\n final_stats: {...this.workerStats}\n }\n );\n }\n\n private emitWorkerHeartbeat(): void {\n if (!this.workerProvider?.onWorkerHeartbeat) return;\n\n const memUsage = process.memoryUsage();\n this.emitLifecycleEvent(\n this.workerProvider.onWorkerHeartbeat,\n {\n ...this.buildWorkerInfo(),\n stats: {...this.workerStats},\n memory_usage_mb: memUsage.heapUsed / 1024 / 1024\n }\n );\n }\n\n private startHeartbeat(): void {\n if (this.heartbeatTimer) return;\n\n const intervalMs = this.config.lifecycle?.heartbeat_interval_ms || 5000;\n this.heartbeatTimer = setInterval(() => {\n this.emitWorkerHeartbeat();\n }, intervalMs);\n }\n\n private stopHeartbeat(): void {\n if (this.heartbeatTimer) {\n clearInterval(this.heartbeatTimer);\n this.heartbeatTimer = null;\n }\n }\n\n private updateWorkerStats(succeeded: number, failed: number, processingMs: number): void {\n this.workerStats.tasks_processed += succeeded + failed;\n this.workerStats.tasks_succeeded += succeeded;\n this.workerStats.tasks_failed += failed;\n this.totalProcessingMs += processingMs;\n\n if (this.workerStats.tasks_processed > 0) {\n this.workerStats.avg_processing_ms = this.totalProcessingMs / this.workerStats.tasks_processed;\n }\n }\n\n private emitLifecycleEvent<T>(\n callback: ((ctx: T) => void | Promise<void>) | undefined,\n ctx: T\n ): void {\n if (!callback) return;\n\n try {\n const result = callback(ctx);\n if (this.config.lifecycle?.mode === 'sync' && result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n } else if (result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n }\n } catch (err) {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n }\n }\n\n processMatureTasks(abortSignal?: AbortSignal) {\n const LOCK_ID = 'mature_task_lock_:task_processor';\n\n if (this.matureTaskTimer) clearInterval(this.matureTaskTimer);\n\n if (abortSignal?.aborted) {\n this.logger.info('AbortSignal already aborted, not starting mature task processing');\n return;\n }\n\n this.matureTaskTimer = setInterval(async () => {\n if (abortSignal?.aborted) {\n this.logger.info('AbortSignal detected, stopping mature task processing');\n if (this.matureTaskTimer) clearInterval(this.matureTaskTimer);\n return;\n }\n const lockManager = new LockManager(this.cacheAdapter, {prefix: 'mature_task_lock_:'});\n\n if (await lockManager.isLocked('task_processor')) {\n this.logger.info('Mature task runner locked');\n return;\n }\n\n try {\n const acquired = await lockManager.acquire('task_processor', 20);\n if (!acquired) {\n this.logger.info('Could not acquire lock for mature task processing');\n return;\n }\n\n const matureTasks = await this.taskStore.getMatureTasks(Date.now());\n this.logger.debug(`Found ${matureTasks.length} mature tasks to process`);\n await this.addTasks(matureTasks);\n } catch (error) {\n this.logger.error(`Error processing tasks: ${error}`);\n } finally {\n await lockManager.release('task_processor');\n }\n\n }, 5000);\n\n // Clean up interval when aborted\n abortSignal?.addEventListener('abort', () => {\n this.logger.info('AbortSignal received, cleaning up mature task timer and sending final stats');\n if (this.matureTaskTimer) {\n clearInterval(this.matureTaskTimer);\n this.matureTaskTimer = null;\n }\n this.sendFinalStats()\n .catch(err => {\n this.logger.error(`Failed to send final stats during shutdown: ${err}`);\n });\n });\n }\n\n private buildTaskContext(task: CronTask<ID>): TaskContext {\n const maxRetries = this.getRetryCount(task);\n const retryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number')\n ? task.execution_stats.retry_count\n : 0;\n const payload = task.payload as Record<string, unknown>;\n\n return {\n task_id: task.id?.toString() || '',\n task_hash: payload?.task_hash as string | undefined,\n task_type: task.type,\n queue_id: task.queue_id,\n payload: this.config.lifecycle?.include_payload ? payload : {},\n attempt: retryCount + 1,\n max_retries: maxRetries,\n scheduled_at: task.created_at || new Date()\n };\n }\n\n processBatch(queueId: QueueName, processor: MessageConsumer<ID>, limit?: number, abortSignal?: AbortSignal): Promise<void> {\n if (abortSignal?.aborted) {\n this.logger.info(`AbortSignal already aborted, skipping batch processing for queue ${queueId}`);\n return Promise.resolve();\n }\n return this.messageQueue.consumeMessagesBatch(queueId, processor, limit);\n }\n\n private async trackDiscardedTasks(count: number) {\n try {\n const now = moment.utc();\n const hourKey = `${DISCARDED_TASKS_KEY}:${now.format('YYYY-MM-DD-HH')}`;\n\n if (!this.cacheAdapter) throw new Error('Cache adapter not initialized');\n const currentHourCountStr = await this.cacheAdapter.get(hourKey) || '0';\n const currentHourCount = parseInt(currentHourCountStr, 10);\n const newCount = currentHourCount + count;\n\n await this.cacheAdapter.set(hourKey, newCount.toString(), 25 * 3600);\n\n let total = 0;\n try {\n if (Math.random() < 0.1) {\n for (let i = 0; i < 24; i++) {\n const hourOffset = moment.utc().subtract(i, 'hours');\n const pastHourKey = `${DISCARDED_TASKS_KEY}:${hourOffset.format('YYYY-MM-DD-HH')}`;\n const pastHourCountStr = await this.cacheAdapter.get(pastHourKey) || '0';\n total += parseInt(pastHourCountStr, 10);\n }\n this.logger.info(`Added ${count} discarded tasks to metrics. Last 24h total: ${total}`);\n } else {\n this.logger.info(`Added ${count} discarded tasks to current hour metrics.`);\n }\n\n // Notify provider if available\n if (this.notificationProvider?.onTasksDiscarded) {\n const discardedInfo: DiscardedTaskInfo = {count, last24HourTotal: total > 0 ? total : undefined};\n try {\n await this.notificationProvider.onTasksDiscarded(discardedInfo);\n } catch (err) {\n this.logger.error(`Notification provider error for discarded tasks: ${err}`);\n }\n }\n } catch (error) {\n this.logger.info(`Added ${count} discarded tasks to current hour metrics.`);\n\n // Still notify provider about the count even if metrics failed\n if (this.notificationProvider?.onTasksDiscarded) {\n const discardedInfo: DiscardedTaskInfo = {count};\n try {\n await this.notificationProvider.onTasksDiscarded(discardedInfo);\n } catch (err) {\n this.logger.error(`Notification provider error for discarded tasks: ${err}`);\n }\n }\n }\n } catch (error) {\n this.logger.error(`Failed to track discarded tasks: ${error}`);\n\n // Try to notify provider about the error\n if (this.notificationProvider?.onTaskError) {\n const errorInfo: TaskErrorInfo = {\n error: `Failed to track discarded tasks: ${error}`,\n context: 'trackDiscardedTasks'\n };\n this.notificationProvider.onTaskError(errorInfo).catch(() => {\n // Ignore notification errors to prevent infinite loops\n });\n }\n }\n }\n\n private getRetryCount(task: CronTask<ID>): number {\n if (typeof task.retries === 'number') return task.retries;\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n return executor?.default_retries ?? 0;\n }\n\n private async reportQueueStats(queueName: QueueName, forceSend: boolean = false): Promise<void> {\n const stats = this.queueStats.get(queueName);\n if (!stats) return;\n\n const total = stats.success + stats.failed + stats.async + stats.ignored;\n if (total === 0) return;\n\n if (!forceSend && total < STATS_THRESHOLD && stats.failed < FAILURE_THRESHOLD) return;\n\n try {\n if (this.notificationProvider?.onQueueStats) {\n const queueStats: TaskQueueStats = {\n queueName,\n success: stats.success,\n failed: stats.failed,\n async: stats.async,\n ignored: stats.ignored,\n instanceId: INSTANCE_ID\n };\n await this.notificationProvider.onQueueStats(queueStats);\n }\n this.logger.info(`Sent stats for ${queueName}`);\n } catch (err) {\n this.logger.error(`Failed to send stats: ${err}`);\n }\n\n if (!forceSend) {\n stats.success = 0;\n stats.failed = 0;\n stats.async = 0;\n stats.ignored = 0;\n }\n }\n\n private async sendFinalStats(): Promise<void> {\n for (const queueName of this.queueStats.keys()) {\n await this.reportQueueStats(queueName, true);\n }\n\n if (this.queueStats.size === 0) {\n try {\n if (this.notificationProvider?.onFinalStats) {\n await this.notificationProvider.onFinalStats([]);\n }\n this.logger.info('Sent final TQ stats (no tasks)');\n } catch (err) {\n this.logger.error(`Failed to send final stats: ${err}`);\n }\n }\n }\n}","import {getEnvironmentQueueName, IMessageQueue, MessageType, QueueName} from \"@supergrowthai/mq\";\nimport {TaskExecutor} from \"./base/interfaces\";\nimport {Logger, LogLevel} from \"@supergrowthai/utils\";\n\nconst logger = new Logger('TaskQueuesManager', LogLevel.INFO);\n\nclass TaskQueuesManager<ID> {\n queueTaskExecutorMap: Map<QueueName, Map<MessageType, TaskExecutor<ID>>> = new Map();\n\n constructor(private messageQueue: IMessageQueue<ID>) {\n }\n\n /**\n * Registers a task executor with a message queue and queue name\n * @param queueName The name of the queue\n * @param taskType The type of task\n * @param executor The executor for the task\n */\n register<T extends MessageType>(queueName: QueueName, taskType: T, executor: TaskExecutor<ID, T>): void {\n queueName = getEnvironmentQueueName(queueName)\n // Ensure the queue is registered with the message queue\n this.messageQueue.register(queueName);\n\n // Initialize the map for this queue if it doesn't exist\n if (!this.queueTaskExecutorMap.has(queueName)) {\n this.queueTaskExecutorMap.set(queueName, new Map());\n }\n\n // Register the executor for this task type\n const queueMap = this.queueTaskExecutorMap.get(queueName)!;\n queueMap.set(taskType, executor);\n\n logger.info(`Registered task executor for ${taskType} on queue ${queueName}`);\n }\n\n /**\n * Gets the task executor for a specific queue and task type\n * @param queueName The name of the queue\n * @param taskType The type of task\n * @returns The executor for the task\n */\n getExecutor<T extends MessageType>(queueName: QueueName, taskType: T): TaskExecutor<ID, T> | undefined {\n queueName = getEnvironmentQueueName(queueName)\n const queueMap = this.queueTaskExecutorMap.get(queueName);\n if (!queueMap) {\n return undefined;\n }\n return queueMap.get(taskType);\n }\n\n /**\n * Gets all registered queues\n * @returns Array of queue names\n */\n getQueues(): QueueName[] {\n return Array.from(this.queueTaskExecutorMap.keys());\n }\n\n /**\n * Gets all task types for a specific queue\n * @param queueName The name of the queue\n * @returns Array of task types\n */\n getTaskTypesForQueue(queueName: QueueName): MessageType[] {\n queueName = getEnvironmentQueueName(queueName)\n const queueMap = this.queueTaskExecutorMap.get(queueName);\n if (!queueMap) {\n return [];\n }\n return Array.from(queueMap.keys());\n }\n}\n\nexport {TaskQueuesManager}","/**\n * Console Health Provider - Reference Implementation\n *\n * A simple health provider that logs all lifecycle events to console.\n * This can be used as a starting point for custom health providers.\n *\n * Usage:\n * ```typescript\n * import { ConsoleHealthProvider } from '@supergrowthai/tq/providers';\n *\n * const healthProvider = new ConsoleHealthProvider();\n *\n * const taskHandler = new TaskHandler(\n * messageQueue,\n * taskQueuesManager,\n * databaseAdapter,\n * cacheProvider,\n * asyncTaskManager,\n * notificationProvider,\n * {\n * lifecycleProvider: healthProvider,\n * workerProvider: healthProvider,\n * lifecycle: {\n * mode: 'async',\n * heartbeat_interval_ms: 5000\n * }\n * }\n * );\n * ```\n */\n\nimport type {\n ITaskLifecycleProvider,\n IWorkerLifecycleProvider,\n TaskContext,\n TaskTiming,\n WorkerInfo,\n WorkerStats\n} from \"../core/lifecycle.js\";\n\nexport class ConsoleHealthProvider implements ITaskLifecycleProvider, IWorkerLifecycleProvider {\n private readonly prefix: string;\n\n constructor(prefix: string = '[Health]') {\n this.prefix = prefix;\n }\n\n // ============ Task Lifecycle ============\n\n onTaskScheduled(ctx: TaskContext): void {\n console.log(`${this.prefix} Task scheduled: ${ctx.task_type} (${ctx.task_id}) in queue ${ctx.queue_id}`);\n }\n\n onTaskStarted(ctx: TaskContext & { started_at: Date; queued_duration_ms: number }): void {\n console.log(`${this.prefix} Task started: ${ctx.task_type} (${ctx.task_id}) - queued for ${ctx.queued_duration_ms}ms`);\n }\n\n onTaskCompleted(ctx: TaskContext & { timing: TaskTiming; result?: unknown }): void {\n console.log(\n `${this.prefix} Task completed: ${ctx.task_type} (${ctx.task_id}) - ` +\n `processing: ${ctx.timing.processing_duration_ms}ms, total: ${ctx.timing.total_duration_ms}ms`\n );\n }\n\n onTaskFailed(ctx: TaskContext & {\n timing: TaskTiming;\n error: Error;\n will_retry: boolean;\n next_attempt_at?: Date\n }): void {\n console.log(\n `${this.prefix} Task failed: ${ctx.task_type} (${ctx.task_id}) - ` +\n `error: ${ctx.error.message}, will_retry: ${ctx.will_retry}`\n );\n }\n\n onTaskExhausted(ctx: TaskContext & { timing: TaskTiming; error: Error; total_attempts: number }): void {\n console.log(\n `${this.prefix} Task exhausted: ${ctx.task_type} (${ctx.task_id}) - ` +\n `total attempts: ${ctx.total_attempts}, error: ${ctx.error.message}`\n );\n }\n\n onTaskCancelled(ctx: TaskContext & { reason: string }): void {\n console.log(`${this.prefix} Task cancelled: ${ctx.task_type} (${ctx.task_id}) - reason: ${ctx.reason}`);\n }\n\n // ============ Worker Lifecycle ============\n\n onWorkerStarted(info: WorkerInfo): void {\n console.log(\n `${this.prefix} Worker started: ${info.worker_id} on ${info.hostname} (PID: ${info.pid}) - ` +\n `queues: [${info.enabled_queues.join(', ')}]`\n );\n }\n\n onWorkerHeartbeat(info: WorkerInfo & { stats: WorkerStats; memory_usage_mb: number }): void {\n console.log(\n `${this.prefix} Worker heartbeat: ${info.worker_id} - ` +\n `processed: ${info.stats.tasks_processed}, success: ${info.stats.tasks_succeeded}, ` +\n `failed: ${info.stats.tasks_failed}, avg: ${info.stats.avg_processing_ms.toFixed(2)}ms, ` +\n `memory: ${info.memory_usage_mb.toFixed(2)}MB`\n );\n }\n\n onWorkerStopped(info: WorkerInfo & {\n reason: 'shutdown' | 'error' | 'idle_timeout';\n final_stats: WorkerStats\n }): void {\n console.log(\n `${this.prefix} Worker stopped: ${info.worker_id} - reason: ${info.reason} - ` +\n `final stats: ${info.final_stats.tasks_processed} processed, ` +\n `${info.final_stats.tasks_succeeded} succeeded, ${info.final_stats.tasks_failed} failed`\n );\n }\n\n onBatchStarted(info: WorkerInfo & { batch_size: number; task_types: string[] }): void {\n console.log(\n `${this.prefix} Batch started: ${info.batch_size} tasks - types: [${info.task_types.join(', ')}]`\n );\n }\n\n onBatchCompleted(info: WorkerInfo & {\n batch_size: number;\n succeeded: number;\n failed: number;\n duration_ms: number\n }): void {\n console.log(\n `${this.prefix} Batch completed: ${info.batch_size} tasks in ${info.duration_ms}ms - ` +\n `succeeded: ${info.succeeded}, failed: ${info.failed}`\n );\n }\n}\n"],"names":["Logger","LogLevel","getEnvironmentQueueName","global","require$$0","Symbol","require$$1","require$$2","require$$3","chunk","tId","Actions","AsyncActions","os.hostname"],"mappings":"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","x_google_ignoreList":[2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23]}
1
+ {"version":3,"file":"index.cjs","sources":["../../../packages/utils/dist/server.mjs","../src/core/TaskStore.ts","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_baseSlice.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/eq.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_freeGlobal.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_root.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_Symbol.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_getRawTag.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_objectToString.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_baseGetTag.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isObject.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isFunction.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isLength.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isArrayLike.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_isIndex.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_isIterateeCall.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_trimmedEndIndex.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/_baseTrim.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isObjectLike.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/isSymbol.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/toNumber.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/toFinite.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/toInteger.js","../../../node_modules/.bun/lodash@4.17.23/node_modules/lodash/chunk.js","../src/utils/disposable-lock.ts","../src/core/TaskRunner.ts","../src/core/environment.ts","../src/core/TaskHandler.ts","../src/core/TaskQueuesManager.ts","../src/providers/ConsoleHealthProvider.ts"],"sourcesContent":["import { Logger, LogLevel } from \"./client.mjs\";\nclass LockManager {\n constructor(cacheProvider, options) {\n this.cacheProvider = cacheProvider;\n this.acquireLocks = /* @__PURE__ */ new Map();\n this.logger = new Logger(\"MetricsCollector\", LogLevel.INFO);\n this.cacheProvider = cacheProvider;\n this.prefix = options?.prefix || \"lock:\";\n this.defaultTimeout = options?.defaultTimeout || 30 * 60;\n if (options?.debugLogs)\n this.logger.setLogLevel(LogLevel.INFO);\n }\n /**\n * Check if a resource is locked\n */\n async isLocked(resourceId) {\n this.logger.debug(\"isLocked\" + resourceId);\n const exists = await this.cacheProvider.get(this.getKey(resourceId));\n return !!exists;\n }\n /**\n * Filter out locked resources from an array\n */\n async filterLocked(resources, getResourceId) {\n if (!resources.length) return [];\n const lockChecks = resources.map((resource) => this.isLocked(getResourceId(resource)));\n const lockResults = await Promise.all(lockChecks);\n return resources.filter((_, index) => !lockResults[index]);\n }\n /**\n * Acquire a lock\n * @returns true if lock was acquired, false if already locked\n */\n async acquire(resourceId, timeout = this.defaultTimeout) {\n this.logger.debug(\"Acquire\" + resourceId);\n const existingLock = this.acquireLocks.get(resourceId);\n if (existingLock) {\n await existingLock;\n return false;\n }\n const lockPromise = this.acquireInternal(resourceId, timeout);\n this.acquireLocks.set(resourceId, lockPromise);\n try {\n return await lockPromise;\n } finally {\n this.acquireLocks.delete(resourceId);\n }\n }\n /**\n * Release a lock\n */\n async release(resourceId) {\n this.logger.debug(\"Release\" + resourceId);\n const key = this.getKey(resourceId);\n await this.cacheProvider.del(key);\n }\n async acquireInternal(resourceId, timeout) {\n if (await this.isLocked(resourceId)) return false;\n const key = this.getKey(resourceId);\n const result = await this.cacheProvider.set(key, \"1\", timeout);\n return result === \"OK\" || result === \"1\" || result === 1;\n }\n getKey(resourceId) {\n return `${this.prefix}${resourceId}`;\n }\n}\nclass ShutdownManager {\n constructor() {\n this.sigintListeners = [];\n this.sigint = {\n register: (listener) => this.sigintListeners.push(listener)\n };\n this.sigtermListeners = [];\n this.sigterm = {\n register: (listener) => this.sigtermListeners.push(listener)\n };\n this.sigquitListeners = [];\n this.sigquit = {\n register: (listener) => this.sigquitListeners.push(listener)\n };\n this.shuttingDown = false;\n this._runListeners = async (listeners) => {\n for (const listener of listeners) {\n try {\n await listener();\n } catch (err) {\n console.error(\"Error during shutdown task:\", err);\n }\n }\n };\n process.on(\"SIGINT\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGINT received. Running shutdown tasks...\");\n this._runListeners(this.sigintListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n process.on(\"SIGTERM\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGTERM received. Running shutdown tasks...\");\n this._runListeners(this.sigtermListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n process.on(\"SIGQUIT\", () => {\n if (this.shuttingDown) return;\n this.shuttingDown = true;\n console.log(\"\\nSIGQUIT received. Running shutdown tasks...\");\n this._runListeners(this.sigquitListeners).then(() => {\n console.log(\"Shutdown tasks completed.\");\n process.exit(0);\n }).catch((err) => {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n });\n });\n }\n}\nexport {\n LockManager,\n LogLevel,\n Logger,\n ShutdownManager\n};\n//# sourceMappingURL=server.mjs.map\n","import type {CronTask, ITaskStorageAdapter} from \"../adapters\";\nimport {getEnvironmentQueueName} from \"@supergrowthai/mq\";\n\nclass TaskStore<ID> {\n\n constructor(private databaseAdapter: ITaskStorageAdapter<ID>) {\n }\n\n /**\n * Adds multiple tasks to the scheduled queue\n */\n async addTasksToScheduled(tasks: CronTask<ID>[]): Promise<CronTask<ID>[]> {\n if (!tasks.length) return [];\n\n const transformedTasks = tasks.map((task) => ({\n id: task.id,\n type: task.type,\n queue_id: getEnvironmentQueueName(task.queue_id),\n payload: task.payload,\n execute_at: task.execute_at,\n expires_at: task.expires_at,\n status: 'scheduled' as const,\n task_group: task.task_group,\n task_hash: task.task_hash,\n retries: task.retries || 0,\n retry_after: task.retry_after,\n execution_stats: task.execution_stats,\n created_at: task.created_at || new Date(),\n updated_at: task.updated_at || new Date(),\n processing_started_at: task.processing_started_at || new Date(),\n force_store: task.force_store\n })) as CronTask<ID>[];\n\n return await this.databaseAdapter.addTasksToScheduled(transformedTasks);\n }\n\n /**\n * Gets mature tasks that are ready to be processed\n * Implements a two-phase approach:\n * 1. Reset stale processing tasks\n * 2. Fetch and mark new mature tasks\n */\n async getMatureTasks(timestamp: number): Promise<CronTask<ID>[]> {\n return await this.databaseAdapter.getMatureTasks(timestamp);\n }\n\n /**\n * Marks tasks as processing with current timestamp\n */\n async markTasksAsProcessing(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsProcessing(tasks, new Date());\n }\n\n /**\n * Marks tasks as executed/completed\n */\n async markTasksAsExecuted(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsExecuted(tasks);\n }\n\n /**\n * Marks tasks as failed and increments retry count\n */\n async markTasksAsFailed(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsFailed(tasks);\n }\n\n /**\n * Marks tasks as successful/completed\n */\n async markTasksAsSuccess(tasks: CronTask<ID>[]): Promise<void> {\n await this.databaseAdapter.markTasksAsExecuted(tasks);\n }\n\n /**\n * Marks tasks as ignored with proper task context\n */\n async markTasksAsIgnored(tasks: CronTask<ID>[]): Promise<void> {\n const updatedTasks = tasks.map(task => ({\n ...task,\n execution_stats: {\n ...(task.execution_stats || {}),\n error: 'No executor found for task type',\n ignored_reason: 'unknown_executor',\n ignored_at: new Date()\n }\n }));\n\n await this.databaseAdapter.markTasksAsIgnored(updatedTasks);\n }\n\n /**\n * Updates multiple tasks with specific updates\n */\n async updateTasks(updates: Array<{ id: ID; updates: Partial<CronTask<ID>> }>): Promise<void> {\n await this.databaseAdapter.updateTasks(updates);\n }\n\n /**\n * Gets tasks by their IDs\n */\n async getTasksByIds(taskIds: ID[]): Promise<CronTask<ID>[]> {\n return await this.databaseAdapter.getTasksByIds(taskIds);\n }\n\n /**\n * Gets cleanup statistics\n */\n async getCleanupStats(): Promise<{ orphanedTasks: number; expiredTasks: number }> {\n return await this.databaseAdapter.getCleanupStats();\n }\n\n /**\n * Cleans up orphaned and expired tasks\n */\n async cleanupTasks(): Promise<void> {\n const twoDaysAgo = new Date(Date.now() - 2 * 24 * 60 * 60 * 1000);\n const now = new Date();\n\n await this.databaseAdapter.cleanupTasks(twoDaysAgo, now);\n }\n\n /**\n * Updates tasks for retry with new execution time and retry count\n */\n async updateTasksForRetry(tasks: CronTask<ID>[]): Promise<void> {\n const updates = tasks.map(task => ({\n id: task.id as ID,\n updates: {\n execute_at: task.execute_at,\n status: task.status,\n execution_stats: task.execution_stats,\n updated_at: new Date()\n }\n }));\n\n await this.databaseAdapter.updateTasks(updates);\n }\n\n}\n\nexport {TaskStore};","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nmodule.exports = baseSlice;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n}\n\nmodule.exports = isIterateeCall;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nmodule.exports = toFinite;\n","var toFinite = require('./toFinite');\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nmodule.exports = toInteger;\n","var baseSlice = require('./_baseSlice'),\n isIterateeCall = require('./_isIterateeCall'),\n toInteger = require('./toInteger');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n nativeMax = Math.max;\n\n/**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\nfunction chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n}\n\nmodule.exports = chunk;\n","import {LockManager} from \"@supergrowthai/utils\";\n\n/**\n * A batch of locks that implements AsyncDisposable for use with `await using`.\n * Automatically releases all acquired locks when the scope exits, even on error.\n *\n * @example\n * ```typescript\n * await using locks = new DisposableLockBatch(lockManager);\n * await locks.acquire('task-1');\n * await locks.acquire('task-2');\n * // ... do work ...\n * // locks automatically released here, even if an error is thrown\n * ```\n *\n * @since Node.js 22+ (Explicit Resource Management)\n */\nexport class DisposableLockBatch implements AsyncDisposable {\n private readonly lockIds: string[] = [];\n private disposed = false;\n\n constructor(\n private readonly lockManager: LockManager,\n private readonly onError?: (lockId: string, error: unknown) => void\n ) {\n }\n\n /**\n * Get the list of currently held lock IDs\n */\n get heldLocks(): readonly string[] {\n return this.lockIds;\n }\n\n /**\n * Number of locks currently held\n */\n get size(): number {\n return this.lockIds.length;\n }\n\n /**\n * Acquire a lock and track it for automatic release\n */\n async acquire(lockId: string, timeout?: number): Promise<boolean> {\n if (this.disposed) {\n throw new Error('Cannot acquire lock on disposed DisposableLockBatch');\n }\n\n const acquired = await this.lockManager.acquire(lockId, timeout);\n if (acquired) {\n this.lockIds.push(lockId);\n }\n return acquired;\n }\n\n /**\n * AsyncDisposable implementation - releases all locks\n */\n async [Symbol.asyncDispose](): Promise<void> {\n if (this.disposed) return;\n this.disposed = true;\n\n await Promise.all(\n this.lockIds.map(lockId =>\n this.lockManager.release(lockId).catch(err => {\n if (this.onError) {\n this.onError(lockId, err);\n }\n })\n )\n );\n }\n}\n","import chunk from \"lodash/chunk\";\nimport {Logger, LogLevel} from \"@supergrowthai/utils/server\";\nimport {tId} from \"../utils/task-id-gen.js\";\nimport {DisposableLockBatch} from \"../utils/disposable-lock.js\";\nimport {TaskType} from \"../types.js\";\nimport {ActionResults, Actions} from \"./Actions.js\";\nimport {AsyncActions} from \"./async/AsyncActions.js\";\nimport {CronTask} from \"../adapters\";\nimport {IMessageQueue} from \"@supergrowthai/mq\";\nimport {CacheProvider} from \"memoose-js\";\nimport {LockManager} from \"@supergrowthai/utils\";\nimport {TaskQueuesManager} from \"./TaskQueuesManager\";\nimport {TaskStore} from \"./TaskStore\";\nimport {IAsyncTaskManager} from \"./async/async-task-manager\";\nimport type {ITaskLifecycleProvider, TaskContext, TaskHandlerLifecycleConfig, TaskTiming} from \"./lifecycle.js\";\n\nexport interface AsyncTask<ID> {\n task: CronTask<ID>;\n promise: Promise<void>;\n startTime: number;\n actions: AsyncActions<ID>;\n}\n\nexport class TaskRunner<ID> {\n private readonly logger: Logger;\n private lockManager: LockManager;\n private readonly taskStartTimes = new Map<string, number>();\n\n constructor(\n private messageQueue: IMessageQueue<ID>,\n private taskQueue: TaskQueuesManager<ID>,\n private taskStore: TaskStore<ID>,\n cacheProvider: CacheProvider<any>,\n private generateId: () => ID,\n private lifecycleProvider?: ITaskLifecycleProvider,\n private lifecycleConfig?: TaskHandlerLifecycleConfig\n ) {\n this.logger = new Logger('TaskRunner', LogLevel.INFO);\n this.lockManager = new LockManager(cacheProvider, {\n prefix: \"task_lock_\",\n defaultTimeout: 30 * 60\n });\n }\n\n // ============ Lifecycle Helpers ============\n\n async run(\n taskRunnerId: string,\n tasksRaw: Array<CronTask<ID>>,\n asyncTaskManager?: IAsyncTaskManager,\n abortSignal?: AbortSignal\n ): Promise<ActionResults<ID> & { asyncTasks: AsyncTask<ID>[] }> {\n this.logger.info(`[${taskRunnerId}] Starting task runner`);\n this.logger.info(`[${taskRunnerId}] Processing ${tasksRaw.length} provided tasks`);\n\n if (abortSignal?.aborted) {\n this.logger.info(`[${taskRunnerId}] AbortSignal already aborted, returning empty results`);\n return {successTasks: [], failedTasks: [], newTasks: [], ignoredTasks: [], asyncTasks: []};\n }\n\n const tasks = await this.lockManager.filterLocked(tasksRaw, tId);\n\n this.logger.info(`[${taskRunnerId}] Found ${tasks.length} not locked tasks to process`);\n\n // Use DisposableLockBatch with await using for automatic lock cleanup\n // This ensures locks are ALWAYS released, even on exceptions or early returns\n await using locks = new DisposableLockBatch(\n this.lockManager,\n (lockId, err) => this.logger.error(`[${taskRunnerId}] Failed to release lock ${lockId}:`, err)\n );\n\n for (const task of tasks) {\n await locks.acquire(tId(task));\n }\n\n const groupedTasksObject = tasks\n .reduce((acc: Record<TaskType, CronTask<ID>[]>, task) => {\n acc[task.type] = acc[task.type] || [];\n acc[task.type].push(task);\n return acc;\n }, {} as Record<TaskType, CronTask<ID>[]>);\n\n const groupedTasksArray = (Object.keys(groupedTasksObject) as unknown as TaskType[]).reduce((acc: {\n type: TaskType,\n tasks: CronTask<ID>[]\n }[], type: TaskType) => {\n acc.push({type, tasks: groupedTasksObject[type]})\n return acc;\n }, [] as { type: TaskType, tasks: CronTask<ID>[] }[]);\n\n this.logger.info(`[${taskRunnerId}] Task groups: ${groupedTasksArray.map(g => `${g.type}: ${g.tasks.length}`).join(', ')}`);\n\n const actions = new Actions<ID>(taskRunnerId);\n const asyncTasks: AsyncTask<ID>[] = [];\n const processedTaskIds = new Set<string>();\n\n for (let i = 0; i < groupedTasksArray.length; i++) {\n if (abortSignal?.aborted) {\n this.logger.info(`[${taskRunnerId}] AbortSignal detected, stopping task group processing`);\n break;\n }\n\n const taskGroup = groupedTasksArray[i];\n const firstTask = taskGroup.tasks[0];\n if (!firstTask) {\n this.logger.warn(`[${taskRunnerId}] No tasks found for type: ${taskGroup.type}`);\n continue;\n }\n const executor = this.taskQueue.getExecutor(firstTask.queue_id, taskGroup.type);\n if (!executor) {\n this.logger.warn(`[${taskRunnerId}] No executor found for type: ${taskGroup.type} in queue ${firstTask.queue_id}`);\n for (const task of taskGroup.tasks) {\n const taskWithId: CronTask<ID> = task.id\n ? task\n : {...task, id: this.generateId()};\n actions.addIgnoredTask(taskWithId);\n }\n continue;\n }\n\n if (executor.asyncConfig?.handoffTimeout && asyncTaskManager && !asyncTaskManager.canAcceptTask()) {\n this.logger.warn(`[${taskRunnerId}] Async queue full, rescheduling ${taskGroup.tasks.length} ${taskGroup.type} tasks for 3 min later`);\n\n const rescheduledTasks = taskGroup.tasks.map(task => ({\n ...task,\n execute_at: new Date(Date.now() + 180000),\n status: 'scheduled' as const\n }));\n\n await this.taskStore.updateTasksForRetry(rescheduledTasks);\n continue;\n }\n\n // Track that we're processing this task group\n taskGroup.tasks.forEach(task => processedTaskIds.add(tId(task)));\n\n this.logger.info(`[${taskRunnerId}] Processing ${taskGroup.tasks.length} tasks of type: ${taskGroup.type}`);\n\n if (executor.multiple) {\n await executor.onTasks(taskGroup.tasks as any[], actions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTasks failed: ${err}`))\n } else {\n if (executor.parallel) {\n const chunks = chunk(taskGroup.tasks, executor.chunkSize) as CronTask<ID>[][];\n this.logger.info(`[${taskRunnerId}] Processing in parallel chunks of ${executor.chunkSize}`);\n for (const taskChunk of chunks) {\n // Emit onTaskStarted for all tasks in chunk\n for (const task of taskChunk) {\n this.emitTaskStarted(task, taskRunnerId);\n }\n\n const chunkPromises: Promise<void>[] = [];\n for (let j = 0; j < taskChunk.length; j++) {\n const taskActions = actions.forkForTask(taskChunk[j]);\n chunkPromises.push(executor.onTask(taskChunk[j], taskActions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`)));\n }\n await Promise.all(chunkPromises);\n\n // Emit completion events for all tasks in chunk\n for (const task of taskChunk) {\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n }\n }\n } else {\n const timeoutMs = executor.asyncConfig?.handoffTimeout;\n\n for (let j = 0; j < taskGroup.tasks.length; j++) {\n const task = taskGroup.tasks[j];\n\n if (!timeoutMs) {\n // Emit onTaskStarted\n this.emitTaskStarted(task, taskRunnerId);\n\n const taskActions = actions.forkForTask(task);\n await executor.onTask(task, taskActions).catch(err => this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`));\n\n // Emit completion event based on result\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n } else {\n // Emit onTaskStarted for async-capable tasks\n this.emitTaskStarted(task, taskRunnerId);\n\n const startTime = Date.now();\n let isTimedOut = false;\n\n const taskActions = actions.forkForTask(task);\n\n const taskPromise = executor.onTask(task, taskActions).catch(err => {\n this.logger.error(`[${taskRunnerId}] executor.onTask failed: ${err}`);\n });\n\n let timeoutId: NodeJS.Timeout | undefined;\n const timeoutPromise = new Promise<'~~~timeout'>(resolve => {\n timeoutId = setTimeout(() => {\n isTimedOut = true;\n resolve('~~~timeout');\n }, timeoutMs);\n\n // Support early cancellation via AbortSignal\n // Note: In real usage, this would come from the task execution context\n // For now, this is a foundation for future AbortSignal integration\n });\n\n const result = await Promise.race([taskPromise, timeoutPromise]);\n\n // Clear the timeout to prevent memory leak\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n\n if (result !== '~~~timeout') {\n // Task completed before timeout - emit lifecycle event\n const resultStatus = actions.getTaskResultStatus(tId(task));\n if (resultStatus === 'success') {\n this.emitTaskCompleted(task, taskRunnerId);\n } else if (resultStatus === 'fail') {\n const retryCount = (task.execution_stats?.retry_count as number) || 0;\n const maxRetries = task.retries ?? executor.default_retries ?? 0;\n const willRetry = retryCount < maxRetries;\n this.emitTaskFailed(task, taskRunnerId, new Error('Task failed'), willRetry);\n }\n }\n\n if (result === '~~~timeout') {\n this.logger.info(`[${taskRunnerId}] Task ${tId(task)} (${task.type}) exceeded ${timeoutMs}ms, marking for async handoff`);\n\n if (!asyncTaskManager) {\n throw new Error(`Task ${task.type} exceeded timeout but AsyncTaskManager not initialized!`);\n }\n\n if (!task.id) {\n this.logger.error(`[${taskRunnerId}] Cannot hand off task without id (type: ${task.type}). Task will continue but won't be tracked.`);\n } else {\n const asyncActions = new AsyncActions<ID>(this.messageQueue, this.taskStore, this.taskQueue, actions, task, this.generateId);\n\n const asyncPromise = taskPromise\n .finally(async () => {\n try {\n await asyncActions.onPromiseFulfilled();\n } catch (err) {\n this.logger.error(`[${taskRunnerId}] Failed to execute async actions for task ${tId(task)}:`, err);\n }\n });\n\n asyncTasks.push({\n task,\n promise: asyncPromise,\n startTime,\n actions: asyncActions\n });\n }\n }\n }\n }\n }\n }\n }\n\n const asyncTaskIds = asyncTasks.map(at => tId(at.task));\n const results = actions.extractSyncResults(asyncTaskIds);\n\n this.logger.info(`[${taskRunnerId}] Completing run - Success: ${results.successTasks.length}, Failed: ${results.failedTasks.length}, New: ${results.newTasks.length}, Async: ${asyncTasks.length}, Ignored: ${results.ignoredTasks.length}`);\n\n // Locks are automatically released by DisposableLockBatch via await using\n return {...results, asyncTasks};\n }\n\n private emitLifecycleEvent<T>(\n callback: ((ctx: T) => void | Promise<void>) | undefined,\n ctx: T\n ): void {\n if (!callback) return;\n\n try {\n const result = callback(ctx);\n if (result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n }\n } catch (err) {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n }\n }\n\n private buildTaskContext(task: CronTask<ID>, workerId?: string): TaskContext {\n const retryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number')\n ? task.execution_stats.retry_count\n : 0;\n const executor = this.taskQueue.getExecutor(task.queue_id, task.type);\n const maxRetries = task.retries ?? executor?.default_retries ?? 0;\n const payload = task.payload as Record<string, unknown>;\n\n return {\n task_id: task.id?.toString() || tId(task),\n task_hash: payload?.task_hash as string | undefined,\n task_type: task.type,\n queue_id: task.queue_id,\n payload: this.lifecycleConfig?.include_payload ? payload : {},\n attempt: retryCount + 1,\n max_retries: maxRetries,\n scheduled_at: task.created_at || new Date(),\n worker_id: workerId\n };\n }\n\n private emitTaskStarted(task: CronTask<ID>, workerId: string): void {\n const startedAt = Date.now();\n this.taskStartTimes.set(tId(task), startedAt);\n\n if (this.lifecycleProvider?.onTaskStarted) {\n const ctx = this.buildTaskContext(task, workerId);\n const queuedDuration = startedAt - (task.created_at?.getTime() || startedAt);\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskStarted,\n {\n ...ctx,\n started_at: new Date(startedAt),\n queued_duration_ms: queuedDuration\n }\n );\n }\n }\n\n private emitTaskCompleted(task: CronTask<ID>, workerId: string, result?: unknown): void {\n const completedAt = Date.now();\n const startedAt = this.taskStartTimes.get(tId(task)) || completedAt;\n this.taskStartTimes.delete(tId(task));\n\n if (this.lifecycleProvider?.onTaskCompleted) {\n const ctx = this.buildTaskContext(task, workerId);\n const timing: TaskTiming = {\n queued_duration_ms: startedAt - (task.created_at?.getTime() || startedAt),\n processing_duration_ms: completedAt - startedAt,\n total_duration_ms: completedAt - (task.created_at?.getTime() || completedAt)\n };\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskCompleted,\n {...ctx, timing, result}\n );\n }\n }\n\n private emitTaskFailed(task: CronTask<ID>, workerId: string, error: Error, willRetry: boolean, nextAttemptAt?: Date): void {\n const completedAt = Date.now();\n const startedAt = this.taskStartTimes.get(tId(task)) || completedAt;\n this.taskStartTimes.delete(tId(task));\n\n if (this.lifecycleProvider?.onTaskFailed) {\n const ctx = this.buildTaskContext(task, workerId);\n const timing: TaskTiming = {\n queued_duration_ms: startedAt - (task.created_at?.getTime() || startedAt),\n processing_duration_ms: completedAt - startedAt,\n total_duration_ms: completedAt - (task.created_at?.getTime() || completedAt)\n };\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskFailed,\n {...ctx, timing, error, will_retry: willRetry, next_attempt_at: nextAttemptAt}\n );\n }\n }\n}","import {getEnvironmentQueueName, QueueName} from \"@supergrowthai/mq\";\n\n/**\n * Gets all queue names for the current environment\n * @returns Array of full queue names including environment suffix\n */\nexport function getEnabledQueues(): QueueName[] {\n let enabledQueues: QueueName[] = process.env.ENABLED_QUEUES ? JSON.parse(process.env.ENABLED_QUEUES!) : [];\n\n if (enabledQueues.length === 0) throw new Error('No queues enabled');\n\n return enabledQueues.map(getEnvironmentQueueName);\n}\n","import {TaskStore} from \"./TaskStore.js\";\nimport {LockManager, Logger, LogLevel} from \"@supergrowthai/utils\"\nimport {TaskRunner} from \"./TaskRunner.js\";\nimport {getEnabledQueues} from \"./environment.js\";\nimport moment from \"moment\";\nimport type {MessageConsumer} from \"@supergrowthai/mq\";\nimport {IMessageQueue, QueueName} from \"@supergrowthai/mq\";\nimport {ProcessedTaskResult} from \"./task-processor-types.js\";\nimport {CronTask, ITaskStorageAdapter} from \"../adapters\";\nimport type {CacheProvider} from \"memoose-js\";\nimport {TaskQueuesManager} from \"./TaskQueuesManager\";\nimport {IAsyncTaskManager} from \"./async/async-task-manager\";\nimport {\n DiscardedTaskInfo,\n ITaskNotificationProvider,\n TaskErrorInfo,\n TaskQueueStats\n} from \"./ITaskNotificationProvider.js\";\nimport type {\n ITaskLifecycleProvider,\n IWorkerLifecycleProvider,\n TaskContext,\n TaskHandlerConfig,\n WorkerInfo,\n WorkerStats\n} from \"./lifecycle.js\";\nimport * as os from \"os\";\n\nconst METRICS_KEY_PREFIX = 'task_metrics:';\nconst DISCARDED_TASKS_KEY = `${METRICS_KEY_PREFIX}discarded_tasks`;\nconst STATS_THRESHOLD = parseInt(process.env.TQ_STATS_THRESHOLD || '1000');\nconst FAILURE_THRESHOLD = parseInt(process.env.TQ_STATS_FAILURE_THRESHOLD || '100');\nconst INSTANCE_ID = process.env.INSTANCE_ID || 'unknown';\n\n\nexport class TaskHandler<ID> {\n private readonly logger: Logger;\n private taskRunner: TaskRunner<ID>;\n private readonly taskStore: TaskStore<ID>;\n private matureTaskTimer: NodeJS.Timeout | null = null;\n private heartbeatTimer: NodeJS.Timeout | null = null;\n private readonly config: TaskHandlerConfig;\n\n // Worker info\n private readonly workerId: string;\n private readonly workerStartedAt: Date;\n private enabledQueues: string[] = [];\n private workerStarted = false;\n\n // Worker stats\n private workerStats: WorkerStats = {\n tasks_processed: 0,\n tasks_succeeded: 0,\n tasks_failed: 0,\n avg_processing_ms: 0,\n current_task: undefined\n };\n private totalProcessingMs = 0;\n\n private readonly queueStats = new Map<QueueName, {\n success: number;\n failed: number;\n async: number;\n ignored: number;\n }>();\n\n constructor(\n private messageQueue: IMessageQueue<ID>,\n private taskQueuesManager: TaskQueuesManager<ID>,\n private databaseAdapter: ITaskStorageAdapter<ID>,\n private cacheAdapter: CacheProvider<any>,\n private asyncTaskManager?: IAsyncTaskManager<ID>,\n private notificationProvider?: ITaskNotificationProvider,\n config?: TaskHandlerConfig\n ) {\n this.logger = new Logger('TaskHandler', LogLevel.INFO);\n this.config = config || {};\n\n // Initialize worker identity\n this.workerId = `${os.hostname()}-${process.pid}-${Date.now()}`;\n this.workerStartedAt = new Date();\n\n this.taskStore = new TaskStore<ID>(databaseAdapter);\n this.taskRunner = new TaskRunner<ID>(\n messageQueue,\n taskQueuesManager,\n this.taskStore,\n this.cacheAdapter,\n databaseAdapter.generateId.bind(databaseAdapter),\n this.config.lifecycleProvider,\n this.config.lifecycle\n );\n }\n\n // ============ Lifecycle Event Helpers ============\n\n private get lifecycleProvider(): ITaskLifecycleProvider | undefined {\n return this.config.lifecycleProvider;\n }\n\n private get workerProvider(): IWorkerLifecycleProvider | undefined {\n return this.config.workerProvider;\n }\n\n async addTasks(tasks: CronTask<ID>[]) {\n const diffedItems = tasks.reduce(\n (acc, {force_store, ...task}) => {\n const currentTime = new Date();\n const executeTime = task.execute_at;\n const timeDifference = (executeTime.getTime() - currentTime.getTime()) / 1000 / 60;\n\n const queue = task.queue_id;\n if (timeDifference > 2 || force_store) {\n acc.future[queue] = acc.future[queue] || [];\n acc.future[queue].push(task);\n } else {\n acc.immediate[queue] = acc.immediate[queue] || [];\n acc.immediate[queue].push(task);\n }\n\n return acc;\n },\n {\n future: {} as { [key in QueueName]: CronTask<ID>[] },\n immediate: {} as { [key in QueueName]: CronTask<ID>[] },\n }\n );\n\n const iQueues = Object.keys(diffedItems.immediate) as unknown as QueueName[];\n for (let i = 0; i < iQueues.length; i++) {\n const queue = iQueues[i];\n const queueTasks: CronTask<ID>[] = diffedItems.immediate[queue]\n .map((task) => {\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n const shouldStoreOnFailure = executor?.store_on_failure ?? false;\n const id = shouldStoreOnFailure ? {id: this.databaseAdapter.generateId(),} : {}\n return ({...id, ...task});\n });\n\n await this.messageQueue.addMessages(queue, queueTasks as unknown as CronTask<ID>[]);\n\n // Emit onTaskScheduled for each task\n if (this.lifecycleProvider?.onTaskScheduled) {\n for (const task of queueTasks) {\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskScheduled,\n this.buildTaskContext(task)\n );\n }\n }\n }\n\n const fQueues = Object.keys(diffedItems.future) as unknown as QueueName[];\n for (let i = 0; i < fQueues.length; i++) {\n const queue = fQueues[i];\n const queueTasks: CronTask<ID>[] = diffedItems.future[queue]\n .map((task) => {\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n const shouldStoreOnFailure = executor?.store_on_failure ?? false;\n const id = shouldStoreOnFailure ? {id: this.databaseAdapter.generateId(),} : {}\n return ({...id, ...task});\n });\n await this.taskStore.addTasksToScheduled(queueTasks);\n\n // Emit onTaskScheduled for each task\n if (this.lifecycleProvider?.onTaskScheduled) {\n for (const task of queueTasks) {\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskScheduled,\n this.buildTaskContext(task)\n );\n }\n }\n }\n }\n\n async postProcessTasks({\n failedTasks: failedTasksRaw,\n newTasks,\n successTasks\n }: ProcessedTaskResult<ID>) {\n const tasksToRetry: CronTask<ID>[] = [];\n const finalFailedTasks: CronTask<ID>[] = [];\n let discardedTasksCount = 0;\n\n // Maximum retry delay cap to prevent unbounded delays\n const MAX_RETRY_DELAY_MS = 5 * 60 * 1000; // 5 minutes\n\n for (const task of failedTasksRaw) {\n const taskRetryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number') ? task.execution_stats.retry_count : 0;\n const taskRetryAfter = task.retry_after || 2000;\n const calculatedDelay = taskRetryAfter * Math.pow(taskRetryCount + 1, 2);\n const retryAfter = Math.min(calculatedDelay, MAX_RETRY_DELAY_MS);\n const executeAt = Date.now() + retryAfter;\n const maxRetries = this.getRetryCount(task);\n\n if (task.id && taskRetryCount < maxRetries) {\n tasksToRetry.push({\n ...task,\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n });\n } else if (task.id) {\n finalFailedTasks.push(task);\n } else if (taskRetryCount < maxRetries) {\n const shouldStoreOnFailure = this.taskQueuesManager.getExecutor(task.queue_id, task.type)?.store_on_failure;\n if (shouldStoreOnFailure) {\n tasksToRetry.push({\n ...task,\n id: this.databaseAdapter.generateId(),\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n });\n } else {\n await this.addTasks([{\n ...task,\n status: 'scheduled',\n execute_at: new Date(executeAt),\n execution_stats: {\n ...(task.execution_stats || {}),\n retry_count: taskRetryCount + 1\n }\n }]);\n }\n } else {\n discardedTasksCount++;\n this.logger.info(`Discarding task of type ${task.type} after ${taskRetryCount} retries`);\n\n // Emit onTaskExhausted for discarded tasks\n if (this.lifecycleProvider?.onTaskExhausted) {\n const ctx = this.buildTaskContext(task);\n const errorMessage = task.execution_stats?.last_error as string || 'Task exhausted all retries';\n this.emitLifecycleEvent(\n this.lifecycleProvider.onTaskExhausted,\n {\n ...ctx,\n timing: {\n queued_duration_ms: 0,\n processing_duration_ms: 0,\n total_duration_ms: Date.now() - (task.created_at?.getTime() || Date.now())\n },\n error: new Error(errorMessage),\n total_attempts: taskRetryCount + 1\n }\n );\n }\n }\n }\n\n if (discardedTasksCount > 0) {\n await this.trackDiscardedTasks(discardedTasksCount);\n }\n\n if (tasksToRetry.length > 0) {\n await this.taskStore.updateTasksForRetry(tasksToRetry);\n }\n\n if (newTasks.length > 0) {\n await this.addTasks(newTasks);\n }\n\n if (finalFailedTasks.length > 0) {\n await this.taskStore.markTasksAsFailed(finalFailedTasks);\n }\n\n if (successTasks.length > 0) {\n await this.taskStore.markTasksAsSuccess(successTasks);\n }\n }\n\n startConsumingTasks(streamName: QueueName, abortSignal?: AbortSignal) {\n return this.messageQueue.consumeMessagesStream(streamName, async (id, tasks) => {\n if (abortSignal?.aborted) {\n this.logger.info(`AbortSignal detected, skipping processing of ${tasks.length} tasks for stream ${streamName}`);\n return {failedTasks: [], newTasks: [], successTasks: [], asyncTasks: [], ignoredTasks: []};\n }\n\n const batchStartTime = Date.now();\n const taskTypes = [...new Set(tasks.map(t => t.type))];\n\n // Emit batch started\n if (this.workerProvider?.onBatchStarted) {\n this.emitLifecycleEvent(\n this.workerProvider.onBatchStarted,\n {\n ...this.buildWorkerInfo(),\n batch_size: tasks.length,\n task_types: taskTypes\n }\n );\n }\n\n this.logger.debug(`Processing ${tasks.length} tasks for stream ${streamName}`);\n const {\n failedTasks,\n newTasks,\n successTasks,\n asyncTasks,\n ignoredTasks\n } = await this.taskRunner.run(id, tasks, this.asyncTaskManager, abortSignal)\n .catch(err => {\n this.logger.error(\"Failed to execute tasks?\", err);\n return {failedTasks: [], newTasks: [], successTasks: [], asyncTasks: [], ignoredTasks: []}\n });\n\n if (asyncTasks.length > 0 && !this.asyncTaskManager) {\n throw new Error(\"Async tasks detected but AsyncTaskManager not initialized!\");\n }\n if (asyncTasks.length > 0) {\n this.logger.info(`Handling ${asyncTasks.length} async tasks for stream ${streamName}`);\n for (const asyncTask of asyncTasks) {\n const accepted = this.asyncTaskManager!.handoffTask(asyncTask.task, asyncTask.promise);\n if (!accepted) {\n this.logger.warn(`Async queue full, requeueing task ${asyncTask.task.id} with 30s delay`);\n await this.addTasks([{\n ...asyncTask.task,\n execute_at: new Date(Date.now() + 30000)\n }]);\n }\n }\n }\n\n if (ignoredTasks.length > 0) {\n this.logger.warn(`Storing ${ignoredTasks.length} ignored tasks with no executor for stream ${streamName}`);\n await this.taskStore.markTasksAsIgnored(ignoredTasks)\n .catch(err => {\n this.logger.error(\"Failed to mark tasks as ignored\", err)\n });\n }\n\n await this.postProcessTasks({failedTasks, newTasks, successTasks})\n .catch(err => {\n this.logger.error(\"Failed to postProcessTasks\", err)\n })\n\n if (!this.queueStats.has(streamName)) {\n this.queueStats.set(streamName, {\n success: 0,\n failed: 0,\n async: 0,\n ignored: 0\n });\n }\n const stats = this.queueStats.get(streamName)!;\n stats.success += successTasks.length;\n stats.failed += failedTasks.length;\n stats.async += asyncTasks.length;\n stats.ignored += ignoredTasks.length;\n\n await this.reportQueueStats(streamName);\n\n // Update worker stats\n const batchDuration = Date.now() - batchStartTime;\n this.updateWorkerStats(successTasks.length, failedTasks.length, batchDuration);\n\n // Emit batch completed\n if (this.workerProvider?.onBatchCompleted) {\n this.emitLifecycleEvent(\n this.workerProvider.onBatchCompleted,\n {\n ...this.buildWorkerInfo(),\n batch_size: tasks.length,\n succeeded: successTasks.length,\n failed: failedTasks.length,\n duration_ms: batchDuration\n }\n );\n }\n\n this.logger.debug(`Completed processing for stream ${streamName}: ${successTasks.length} succeeded, ${failedTasks.length} failed, ${newTasks.length} new tasks, ${ignoredTasks.length} ignored`);\n return {failedTasks, newTasks, successTasks, asyncTasks, ignoredTasks};\n }, abortSignal);\n }\n\n taskProcessServer(abortSignal?: AbortSignal) {\n const queues = getEnabledQueues();\n this.enabledQueues = queues;\n\n // Emit worker started event\n if (!this.workerStarted) {\n this.workerStarted = true;\n this.emitWorkerStarted();\n this.startHeartbeat();\n }\n\n for (let i = 0; i < queues.length; i++) {\n this.logger.info(`Starting consumer for queue: ${queues[i]}`);\n this.startConsumingTasks(queues[i], abortSignal);\n }\n this.logger.info('Starting mature tasks processor');\n this.processMatureTasks(abortSignal);\n\n // Handle worker shutdown\n abortSignal?.addEventListener('abort', () => {\n this.stopHeartbeat();\n this.emitWorkerStopped('shutdown');\n });\n }\n\n private buildWorkerInfo(): WorkerInfo {\n return {\n worker_id: this.workerId,\n hostname: os.hostname(),\n pid: process.pid,\n started_at: this.workerStartedAt,\n enabled_queues: this.enabledQueues\n };\n }\n\n private emitWorkerStarted(): void {\n if (!this.workerProvider?.onWorkerStarted) return;\n this.emitLifecycleEvent(this.workerProvider.onWorkerStarted, this.buildWorkerInfo());\n }\n\n private emitWorkerStopped(reason: 'shutdown' | 'error' | 'idle_timeout'): void {\n if (!this.workerProvider?.onWorkerStopped) return;\n this.emitLifecycleEvent(\n this.workerProvider.onWorkerStopped,\n {\n ...this.buildWorkerInfo(),\n reason,\n final_stats: {...this.workerStats}\n }\n );\n }\n\n private emitWorkerHeartbeat(): void {\n if (!this.workerProvider?.onWorkerHeartbeat) return;\n\n const memUsage = process.memoryUsage();\n this.emitLifecycleEvent(\n this.workerProvider.onWorkerHeartbeat,\n {\n ...this.buildWorkerInfo(),\n stats: {...this.workerStats},\n memory_usage_mb: memUsage.heapUsed / 1024 / 1024\n }\n );\n }\n\n private startHeartbeat(): void {\n if (this.heartbeatTimer) return;\n\n const intervalMs = this.config.lifecycle?.heartbeat_interval_ms || 5000;\n this.heartbeatTimer = setInterval(() => {\n this.emitWorkerHeartbeat();\n }, intervalMs);\n }\n\n private stopHeartbeat(): void {\n if (this.heartbeatTimer) {\n clearInterval(this.heartbeatTimer);\n this.heartbeatTimer = null;\n }\n }\n\n private updateWorkerStats(succeeded: number, failed: number, processingMs: number): void {\n this.workerStats.tasks_processed += succeeded + failed;\n this.workerStats.tasks_succeeded += succeeded;\n this.workerStats.tasks_failed += failed;\n this.totalProcessingMs += processingMs;\n\n if (this.workerStats.tasks_processed > 0) {\n this.workerStats.avg_processing_ms = this.totalProcessingMs / this.workerStats.tasks_processed;\n }\n }\n\n private emitLifecycleEvent<T>(\n callback: ((ctx: T) => void | Promise<void>) | undefined,\n ctx: T\n ): void {\n if (!callback) return;\n\n try {\n const result = callback(ctx);\n if (this.config.lifecycle?.mode === 'sync' && result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n } else if (result instanceof Promise) {\n result.catch(err => {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n });\n }\n } catch (err) {\n this.logger.error(`[TQ] Lifecycle callback error: ${err}`);\n }\n }\n\n processMatureTasks(abortSignal?: AbortSignal) {\n const LOCK_ID = 'mature_task_lock_:task_processor';\n\n if (this.matureTaskTimer) clearInterval(this.matureTaskTimer);\n\n if (abortSignal?.aborted) {\n this.logger.info('AbortSignal already aborted, not starting mature task processing');\n return;\n }\n\n this.matureTaskTimer = setInterval(async () => {\n if (abortSignal?.aborted) {\n this.logger.info('AbortSignal detected, stopping mature task processing');\n if (this.matureTaskTimer) clearInterval(this.matureTaskTimer);\n return;\n }\n const lockManager = new LockManager(this.cacheAdapter, {prefix: 'mature_task_lock_:'});\n\n if (await lockManager.isLocked('task_processor')) {\n this.logger.info('Mature task runner locked');\n return;\n }\n\n try {\n const acquired = await lockManager.acquire('task_processor', 20);\n if (!acquired) {\n this.logger.info('Could not acquire lock for mature task processing');\n return;\n }\n\n const matureTasks = await this.taskStore.getMatureTasks(Date.now());\n this.logger.debug(`Found ${matureTasks.length} mature tasks to process`);\n await this.addTasks(matureTasks);\n } catch (error) {\n this.logger.error(`Error processing tasks: ${error}`);\n } finally {\n await lockManager.release('task_processor');\n }\n\n }, 5000);\n\n // Clean up interval when aborted\n abortSignal?.addEventListener('abort', () => {\n this.logger.info('AbortSignal received, cleaning up mature task timer and sending final stats');\n if (this.matureTaskTimer) {\n clearInterval(this.matureTaskTimer);\n this.matureTaskTimer = null;\n }\n this.sendFinalStats()\n .catch(err => {\n this.logger.error(`Failed to send final stats during shutdown: ${err}`);\n });\n });\n }\n\n private buildTaskContext(task: CronTask<ID>): TaskContext {\n const maxRetries = this.getRetryCount(task);\n const retryCount = (task.execution_stats && typeof task.execution_stats.retry_count === 'number')\n ? task.execution_stats.retry_count\n : 0;\n const payload = task.payload as Record<string, unknown>;\n\n return {\n task_id: task.id?.toString() || '',\n task_hash: payload?.task_hash as string | undefined,\n task_type: task.type,\n queue_id: task.queue_id,\n payload: this.config.lifecycle?.include_payload ? payload : {},\n attempt: retryCount + 1,\n max_retries: maxRetries,\n scheduled_at: task.created_at || new Date()\n };\n }\n\n processBatch(queueId: QueueName, processor: MessageConsumer<ID>, limit?: number, abortSignal?: AbortSignal): Promise<void> {\n if (abortSignal?.aborted) {\n this.logger.info(`AbortSignal already aborted, skipping batch processing for queue ${queueId}`);\n return Promise.resolve();\n }\n return this.messageQueue.consumeMessagesBatch(queueId, processor, limit);\n }\n\n private async trackDiscardedTasks(count: number) {\n try {\n const now = moment.utc();\n const hourKey = `${DISCARDED_TASKS_KEY}:${now.format('YYYY-MM-DD-HH')}`;\n\n if (!this.cacheAdapter) throw new Error('Cache adapter not initialized');\n const currentHourCountStr = await this.cacheAdapter.get(hourKey) || '0';\n const currentHourCount = parseInt(currentHourCountStr, 10);\n const newCount = currentHourCount + count;\n\n await this.cacheAdapter.set(hourKey, newCount.toString(), 25 * 3600);\n\n let total = 0;\n try {\n if (Math.random() < 0.1) {\n for (let i = 0; i < 24; i++) {\n const hourOffset = moment.utc().subtract(i, 'hours');\n const pastHourKey = `${DISCARDED_TASKS_KEY}:${hourOffset.format('YYYY-MM-DD-HH')}`;\n const pastHourCountStr = await this.cacheAdapter.get(pastHourKey) || '0';\n total += parseInt(pastHourCountStr, 10);\n }\n this.logger.info(`Added ${count} discarded tasks to metrics. Last 24h total: ${total}`);\n } else {\n this.logger.info(`Added ${count} discarded tasks to current hour metrics.`);\n }\n\n // Notify provider if available\n if (this.notificationProvider?.onTasksDiscarded) {\n const discardedInfo: DiscardedTaskInfo = {count, last24HourTotal: total > 0 ? total : undefined};\n try {\n await this.notificationProvider.onTasksDiscarded(discardedInfo);\n } catch (err) {\n this.logger.error(`Notification provider error for discarded tasks: ${err}`);\n }\n }\n } catch (error) {\n this.logger.info(`Added ${count} discarded tasks to current hour metrics.`);\n\n // Still notify provider about the count even if metrics failed\n if (this.notificationProvider?.onTasksDiscarded) {\n const discardedInfo: DiscardedTaskInfo = {count};\n try {\n await this.notificationProvider.onTasksDiscarded(discardedInfo);\n } catch (err) {\n this.logger.error(`Notification provider error for discarded tasks: ${err}`);\n }\n }\n }\n } catch (error) {\n this.logger.error(`Failed to track discarded tasks: ${error}`);\n\n // Try to notify provider about the error\n if (this.notificationProvider?.onTaskError) {\n const errorInfo: TaskErrorInfo = {\n error: `Failed to track discarded tasks: ${error}`,\n context: 'trackDiscardedTasks'\n };\n this.notificationProvider.onTaskError(errorInfo).catch(() => {\n // Ignore notification errors to prevent infinite loops\n });\n }\n }\n }\n\n private getRetryCount(task: CronTask<ID>): number {\n if (typeof task.retries === 'number') return task.retries;\n const executor = this.taskQueuesManager.getExecutor(task.queue_id, task.type);\n return executor?.default_retries ?? 0;\n }\n\n private async reportQueueStats(queueName: QueueName, forceSend: boolean = false): Promise<void> {\n const stats = this.queueStats.get(queueName);\n if (!stats) return;\n\n const total = stats.success + stats.failed + stats.async + stats.ignored;\n if (total === 0) return;\n\n if (!forceSend && total < STATS_THRESHOLD && stats.failed < FAILURE_THRESHOLD) return;\n\n try {\n if (this.notificationProvider?.onQueueStats) {\n const queueStats: TaskQueueStats = {\n queueName,\n success: stats.success,\n failed: stats.failed,\n async: stats.async,\n ignored: stats.ignored,\n instanceId: INSTANCE_ID\n };\n await this.notificationProvider.onQueueStats(queueStats);\n }\n this.logger.info(`Sent stats for ${queueName}`);\n } catch (err) {\n this.logger.error(`Failed to send stats: ${err}`);\n }\n\n if (!forceSend) {\n stats.success = 0;\n stats.failed = 0;\n stats.async = 0;\n stats.ignored = 0;\n }\n }\n\n private async sendFinalStats(): Promise<void> {\n for (const queueName of this.queueStats.keys()) {\n await this.reportQueueStats(queueName, true);\n }\n\n if (this.queueStats.size === 0) {\n try {\n if (this.notificationProvider?.onFinalStats) {\n await this.notificationProvider.onFinalStats([]);\n }\n this.logger.info('Sent final TQ stats (no tasks)');\n } catch (err) {\n this.logger.error(`Failed to send final stats: ${err}`);\n }\n }\n }\n}","import {getEnvironmentQueueName, IMessageQueue, MessageType, QueueName} from \"@supergrowthai/mq\";\nimport {TaskExecutor} from \"./base/interfaces\";\nimport {Logger, LogLevel} from \"@supergrowthai/utils\";\n\nconst logger = new Logger('TaskQueuesManager', LogLevel.INFO);\n\nclass TaskQueuesManager<ID> {\n queueTaskExecutorMap: Map<QueueName, Map<MessageType, TaskExecutor<ID>>> = new Map();\n\n constructor(private messageQueue: IMessageQueue<ID>) {\n }\n\n /**\n * Registers a task executor with a message queue and queue name\n * @param queueName The name of the queue\n * @param taskType The type of task\n * @param executor The executor for the task\n */\n register<T extends MessageType>(queueName: QueueName, taskType: T, executor: TaskExecutor<ID, T>): void {\n queueName = getEnvironmentQueueName(queueName)\n // Ensure the queue is registered with the message queue\n this.messageQueue.register(queueName);\n\n // Initialize the map for this queue if it doesn't exist\n if (!this.queueTaskExecutorMap.has(queueName)) {\n this.queueTaskExecutorMap.set(queueName, new Map());\n }\n\n // Register the executor for this task type\n const queueMap = this.queueTaskExecutorMap.get(queueName)!;\n queueMap.set(taskType, executor);\n\n logger.info(`Registered task executor for ${taskType} on queue ${queueName}`);\n }\n\n /**\n * Gets the task executor for a specific queue and task type\n * @param queueName The name of the queue\n * @param taskType The type of task\n * @returns The executor for the task\n */\n getExecutor<T extends MessageType>(queueName: QueueName, taskType: T): TaskExecutor<ID, T> | undefined {\n queueName = getEnvironmentQueueName(queueName)\n const queueMap = this.queueTaskExecutorMap.get(queueName);\n if (!queueMap) {\n return undefined;\n }\n return queueMap.get(taskType);\n }\n\n /**\n * Gets all registered queues\n * @returns Array of queue names\n */\n getQueues(): QueueName[] {\n return Array.from(this.queueTaskExecutorMap.keys());\n }\n\n /**\n * Gets all task types for a specific queue\n * @param queueName The name of the queue\n * @returns Array of task types\n */\n getTaskTypesForQueue(queueName: QueueName): MessageType[] {\n queueName = getEnvironmentQueueName(queueName)\n const queueMap = this.queueTaskExecutorMap.get(queueName);\n if (!queueMap) {\n return [];\n }\n return Array.from(queueMap.keys());\n }\n}\n\nexport {TaskQueuesManager}","/**\n * Console Health Provider - Reference Implementation\n *\n * A simple health provider that logs all lifecycle events to console.\n * This can be used as a starting point for custom health providers.\n *\n * Usage:\n * ```typescript\n * import { ConsoleHealthProvider } from '@supergrowthai/tq/providers';\n *\n * const healthProvider = new ConsoleHealthProvider();\n *\n * const taskHandler = new TaskHandler(\n * messageQueue,\n * taskQueuesManager,\n * databaseAdapter,\n * cacheProvider,\n * asyncTaskManager,\n * notificationProvider,\n * {\n * lifecycleProvider: healthProvider,\n * workerProvider: healthProvider,\n * lifecycle: {\n * mode: 'async',\n * heartbeat_interval_ms: 5000\n * }\n * }\n * );\n * ```\n */\n\nimport type {\n ITaskLifecycleProvider,\n IWorkerLifecycleProvider,\n TaskContext,\n TaskTiming,\n WorkerInfo,\n WorkerStats\n} from \"../core/lifecycle.js\";\n\nexport class ConsoleHealthProvider implements ITaskLifecycleProvider, IWorkerLifecycleProvider {\n private readonly prefix: string;\n\n constructor(prefix: string = '[Health]') {\n this.prefix = prefix;\n }\n\n // ============ Task Lifecycle ============\n\n onTaskScheduled(ctx: TaskContext): void {\n console.log(`${this.prefix} Task scheduled: ${ctx.task_type} (${ctx.task_id}) in queue ${ctx.queue_id}`);\n }\n\n onTaskStarted(ctx: TaskContext & { started_at: Date; queued_duration_ms: number }): void {\n console.log(`${this.prefix} Task started: ${ctx.task_type} (${ctx.task_id}) - queued for ${ctx.queued_duration_ms}ms`);\n }\n\n onTaskCompleted(ctx: TaskContext & { timing: TaskTiming; result?: unknown }): void {\n console.log(\n `${this.prefix} Task completed: ${ctx.task_type} (${ctx.task_id}) - ` +\n `processing: ${ctx.timing.processing_duration_ms}ms, total: ${ctx.timing.total_duration_ms}ms`\n );\n }\n\n onTaskFailed(ctx: TaskContext & {\n timing: TaskTiming;\n error: Error;\n will_retry: boolean;\n next_attempt_at?: Date\n }): void {\n console.log(\n `${this.prefix} Task failed: ${ctx.task_type} (${ctx.task_id}) - ` +\n `error: ${ctx.error.message}, will_retry: ${ctx.will_retry}`\n );\n }\n\n onTaskExhausted(ctx: TaskContext & { timing: TaskTiming; error: Error; total_attempts: number }): void {\n console.log(\n `${this.prefix} Task exhausted: ${ctx.task_type} (${ctx.task_id}) - ` +\n `total attempts: ${ctx.total_attempts}, error: ${ctx.error.message}`\n );\n }\n\n onTaskCancelled(ctx: TaskContext & { reason: string }): void {\n console.log(`${this.prefix} Task cancelled: ${ctx.task_type} (${ctx.task_id}) - reason: ${ctx.reason}`);\n }\n\n // ============ Worker Lifecycle ============\n\n onWorkerStarted(info: WorkerInfo): void {\n console.log(\n `${this.prefix} Worker started: ${info.worker_id} on ${info.hostname} (PID: ${info.pid}) - ` +\n `queues: [${info.enabled_queues.join(', ')}]`\n );\n }\n\n onWorkerHeartbeat(info: WorkerInfo & { stats: WorkerStats; memory_usage_mb: number }): void {\n console.log(\n `${this.prefix} Worker heartbeat: ${info.worker_id} - ` +\n `processed: ${info.stats.tasks_processed}, success: ${info.stats.tasks_succeeded}, ` +\n `failed: ${info.stats.tasks_failed}, avg: ${info.stats.avg_processing_ms.toFixed(2)}ms, ` +\n `memory: ${info.memory_usage_mb.toFixed(2)}MB`\n );\n }\n\n onWorkerStopped(info: WorkerInfo & {\n reason: 'shutdown' | 'error' | 'idle_timeout';\n final_stats: WorkerStats\n }): void {\n console.log(\n `${this.prefix} Worker stopped: ${info.worker_id} - reason: ${info.reason} - ` +\n `final stats: ${info.final_stats.tasks_processed} processed, ` +\n `${info.final_stats.tasks_succeeded} succeeded, ${info.final_stats.tasks_failed} failed`\n );\n }\n\n onBatchStarted(info: WorkerInfo & { batch_size: number; task_types: string[] }): void {\n console.log(\n `${this.prefix} Batch started: ${info.batch_size} tasks - types: [${info.task_types.join(', ')}]`\n );\n }\n\n onBatchCompleted(info: WorkerInfo & {\n batch_size: number;\n succeeded: number;\n failed: number;\n duration_ms: number\n }): void {\n console.log(\n `${this.prefix} Batch completed: ${info.batch_size} tasks in ${info.duration_ms}ms - ` +\n `succeeded: ${info.succeeded}, failed: ${info.failed}`\n );\n }\n}\n"],"names":["Logger","LogLevel","getEnvironmentQueueName","global","require$$0","Symbol","require$$1","require$$2","require$$3","chunk","tId","Actions","AsyncActions","os.hostname"],"mappings":"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","x_google_ignoreList":[2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23]}