@lowerdeck/cron 1.0.5 → 1.0.6
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.
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.module.js +1 -1
- package/dist/index.module.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/package.json +2 -2
- package/src/index.ts +2 -1
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var e=require("@lowerdeck/execution-context"),r=require("@lowerdeck/id"),n=require("@lowerdeck/redis"),
|
|
1
|
+
var e=require("@lowerdeck/execution-context"),r=require("@lowerdeck/id"),n=require("@lowerdeck/redis"),o=require("@lowerdeck/sentry"),t=require("bullmq"),c=o.getSentry(),i=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},u=new Set;exports.createCron=function(o,a){if(u.has(o.name))throw new Error("Cron with name "+o.name+" already exists");var s=n.parseRedisUrl(o.redisUrl);process.env.QUEUE_DEBUG_LOGGING&&console.log("Creating cron with connection",o.redisUrl,s);var l=new t.Queue("Cr0N_"+o.name,{connection:s,defaultJobOptions:{removeOnComplete:!0,removeOnFail:{age:86400}}});return{start:function(){try{return i("Starting cron job "+o.name+" to run every "+o.cron+" using bullmq"),Promise.resolve(l.upsertJobScheduler("cron",{pattern:o.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var n=new t.Worker(l.name,function(){try{return e.provideExecutionContext(e.createExecutionContext({type:"scheduled",contextId:r.generateCustomId("cron_"),cron:o.cron,name:o.name}),function(){try{return i("Running cron job "+o.name),Promise.resolve(function(e,r){try{var n=Promise.resolve(a()).then(function(){})}catch(e){return r(e)}return n&&n.then?n.then(void 0,r):n}(0,function(e){throw c.captureException(e,{tags:{cronName:o.name}}),e}))}catch(e){return Promise.reject(e)}}),Promise.resolve()}catch(e){return Promise.reject(e)}},{connection:s,concurrency:1});return{close:n.close.bind(n)}})}catch(e){return Promise.reject(e)}}}};
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n if (process.env.QUEUE_DEBUG_LOGGING)\n console.log('Creating cron with connection', opts.redisUrl, connection);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n concurrency: 1\n }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["Sentry","getSentry","log","_console","console","apply","concat","slice","call","arguments","seenNames","Set","opts","handler","has","name","Error","connection","parseRedisUrl","redisUrl","process","env","QUEUE_DEBUG_LOGGING","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","age","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","concurrency","close","bind"],"mappings":"0JAOIA,EAASC,EAASA,YAElBC,EAAM,WAAH,IAAAC,EAAsB,OAAAA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAAC,GAAAA,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,uBAEI,SACtBC,EAKAC,GAEA,GAAIH,EAAUI,IAAIF,EAAKG,MACrB,MAAU,IAAAC,MAAK,kBAAmBJ,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAaA,cAACN,EAAKO,UAChCC,QAAQC,IAAIC,qBACdlB,QAAQF,IAAI,gCAAiCU,EAAKO,SAAUF,GAC9D,IAAIM,EAAQ,IAAIC,EAAKA,MAASZ,QAAAA,EAAKG,KAAQ,CACzCE,WAAAA,EACAQ,kBAAmB,CACjBC,kBAAkB,EAClBC,aAAc,CACZC,IAAK,UAKX,MAAO,CACLC,MAAK,WAAA,IAC0E,OAA7E3B,EAAG,qBAAsBU,EAAKG,KAAI,iBAAiBH,EAAKkB,KAAI,iBAAiBC,QAAAC,QAEvET,EAAMU,mBACV,OACA,CACEC,QAAStB,EAAKkB,MAEhB,CACElB,KAAM,CACJuB,2BAA2B,EAC3BT,kBAAkB,EAClBC,cAAc,EACdS,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EAAAA,OACfhB,EAAMR,KAAI,WAAA,IAuBN,OArBFyB,EAAuBA,wBACrBC,EAAsBA,uBAAC,CACrBC,KAAM,YACNC,UAAWC,EAAgBA,iBAAC,SAC5Bd,KAAMlB,EAAKkB,KACXf,KAAMH,EAAKG,OACX,WAAA,IAEqC,OAArCb,sBAAwBU,EAAKG,MAAQgB,QAAAC,gCAEjCD,QAAAC,QACInB,KAASwB,KACjB,uEAJqCQ,CAEjC,EAEKC,SAAAA,GAMP,MALA9C,EAAO+C,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUrC,EAAKG,QAGb+B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EAAA,CAAA,GACDnB,QAAAC,SACJ,CAAC,MAAAkB,UAAAnB,QAAAoB,OAAAD,EAAA,CAAA,EACD,CACEjC,WAAAA,EACAmC,YAAa,IAIjB,MAAO,CACLC,MAAOf,EAAOe,MAAMC,KAAKhB,GACzB,EACJ,CAAC,MAAAY,GAAAnB,OAAAA,QAAAoB,OAAAD,KAEL"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAWnD,eAAO,IAAI,UAAU,GACnB,MAAM;IACJ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;CAClB,EACD,SAAS,MAAM,OAAO,CAAC,IAAI,CAAC,KAC3B,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAWnD,eAAO,IAAI,UAAU,GACnB,MAAM;IACJ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;CAClB,EACD,SAAS,MAAM,OAAO,CAAC,IAAI,CAAC,KAC3B,eA0EF,CAAC"}
|
package/dist/index.module.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{provideExecutionContext as e,createExecutionContext as r}from"@lowerdeck/execution-context";import{generateCustomId as n}from"@lowerdeck/id";import{parseRedisUrl as o}from"@lowerdeck/redis";import{getSentry as t}from"@lowerdeck/sentry";import{Queue as c,Worker as i}from"bullmq";var
|
|
1
|
+
import{provideExecutionContext as e,createExecutionContext as r}from"@lowerdeck/execution-context";import{generateCustomId as n}from"@lowerdeck/id";import{parseRedisUrl as o}from"@lowerdeck/redis";import{getSentry as t}from"@lowerdeck/sentry";import{Queue as c,Worker as i}from"bullmq";var a=t(),m=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},l=new Set,s=function(t,s){if(l.has(t.name))throw new Error("Cron with name "+t.name+" already exists");var u=o(t.redisUrl);process.env.QUEUE_DEBUG_LOGGING&&console.log("Creating cron with connection",t.redisUrl,u);var p=new c("Cr0N_"+t.name,{connection:u,defaultJobOptions:{removeOnComplete:!0,removeOnFail:{age:86400}}});return{start:function(){try{return m("Starting cron job "+t.name+" to run every "+t.cron+" using bullmq"),Promise.resolve(p.upsertJobScheduler("cron",{pattern:t.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var o=new i(p.name,function(){try{return e(r({type:"scheduled",contextId:n("cron_"),cron:t.cron,name:t.name}),function(){try{return m("Running cron job "+t.name),Promise.resolve(function(e,r){try{var n=Promise.resolve(s()).then(function(){})}catch(e){return r(e)}return n&&n.then?n.then(void 0,r):n}(0,function(e){throw a.captureException(e,{tags:{cronName:t.name}}),e}))}catch(e){return Promise.reject(e)}}),Promise.resolve()}catch(e){return Promise.reject(e)}},{connection:u,concurrency:1});return{close:o.close.bind(o)}})}catch(e){return Promise.reject(e)}}}};export{s as createCron};
|
|
2
2
|
//# sourceMappingURL=index.module.js.map
|
package/dist/index.module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.module.js","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n
|
|
1
|
+
{"version":3,"file":"index.module.js","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n if (process.env.QUEUE_DEBUG_LOGGING)\n console.log('Creating cron with connection', opts.redisUrl, connection);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n concurrency: 1\n }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["Sentry","getSentry","log","_console","console","apply","concat","slice","call","arguments","seenNames","Set","createCron","opts","handler","has","name","Error","connection","parseRedisUrl","redisUrl","process","env","QUEUE_DEBUG_LOGGING","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","age","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","concurrency","close","bind"],"mappings":"8RAOA,IAAIA,EAASC,IAETC,EAAM,WAAH,IAAAC,EAAsB,OAAAA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAAC,GAAAA,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,IAETC,EAAa,SACtBC,EAKAC,GAEA,GAAIJ,EAAUK,IAAIF,EAAKG,MACrB,MAAU,IAAAC,MAAK,kBAAmBJ,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAcN,EAAKO,UAChCC,QAAQC,IAAIC,qBACdnB,QAAQF,IAAI,gCAAiCW,EAAKO,SAAUF,GAC9D,IAAIM,EAAQ,IAAIC,EAAcZ,QAAAA,EAAKG,KAAQ,CACzCE,WAAAA,EACAQ,kBAAmB,CACjBC,kBAAkB,EAClBC,aAAc,CACZC,IAAK,UAKX,MAAO,CACLC,MAAK,WAAA,IAC0E,OAA7E5B,EAAG,qBAAsBW,EAAKG,KAAI,iBAAiBH,EAAKkB,KAAI,iBAAiBC,QAAAC,QAEvET,EAAMU,mBACV,OACA,CACEC,QAAStB,EAAKkB,MAEhB,CACElB,KAAM,CACJuB,2BAA2B,EAC3BT,kBAAkB,EAClBC,cAAc,EACdS,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EACfhB,EAAMR,KAAI,WAAA,IAuBN,OArBFyB,EACEC,EAAuB,CACrBC,KAAM,YACNC,UAAWC,EAAiB,SAC5Bd,KAAMlB,EAAKkB,KACXf,KAAMH,EAAKG,OACX,WAAA,IAEqC,OAArCd,sBAAwBW,EAAKG,MAAQgB,QAAAC,gCAEjCD,QAAAC,QACInB,KAASwB,KACjB,uEAJqCQ,CAEjC,EAEKC,SAAAA,GAMP,MALA/C,EAAOgD,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUrC,EAAKG,QAGb+B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EAAA,CAAA,GACDnB,QAAAC,SACJ,CAAC,MAAAkB,UAAAnB,QAAAoB,OAAAD,EAAA,CAAA,EACD,CACEjC,WAAAA,EACAmC,YAAa,IAIjB,MAAO,CACLC,MAAOf,EAAOe,MAAMC,KAAKhB,GACzB,EACJ,CAAC,MAAAY,GAAAnB,OAAAA,QAAAoB,OAAAD,KAEL"}
|
package/dist/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@lowerdeck/execution-context"),require("@lowerdeck/id"),require("@lowerdeck/redis"),require("@lowerdeck/sentry"),require("bullmq")):"function"==typeof define&&define.amd?define(["exports","@lowerdeck/execution-context","@lowerdeck/id","@lowerdeck/redis","@lowerdeck/sentry","bullmq"],r):r((e||self).cron={},e.executionContext,e.id,e.redis,e.sentry,e.bullmq)}(this,function(e,r,n,o,t,c){var i=t.getSentry(),u=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},l=new Set;e.createCron=function(e,t){if(l.has(e.name))throw new Error("Cron with name "+e.name+" already exists");var
|
|
1
|
+
!function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@lowerdeck/execution-context"),require("@lowerdeck/id"),require("@lowerdeck/redis"),require("@lowerdeck/sentry"),require("bullmq")):"function"==typeof define&&define.amd?define(["exports","@lowerdeck/execution-context","@lowerdeck/id","@lowerdeck/redis","@lowerdeck/sentry","bullmq"],r):r((e||self).cron={},e.executionContext,e.id,e.redis,e.sentry,e.bullmq)}(this,function(e,r,n,o,t,c){var i=t.getSentry(),u=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},l=new Set;e.createCron=function(e,t){if(l.has(e.name))throw new Error("Cron with name "+e.name+" already exists");var s=o.parseRedisUrl(e.redisUrl);process.env.QUEUE_DEBUG_LOGGING&&console.log("Creating cron with connection",e.redisUrl,s);var a=new c.Queue("Cr0N_"+e.name,{connection:s,defaultJobOptions:{removeOnComplete:!0,removeOnFail:{age:86400}}});return{start:function(){try{return u("Starting cron job "+e.name+" to run every "+e.cron+" using bullmq"),Promise.resolve(a.upsertJobScheduler("cron",{pattern:e.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var o=new c.Worker(a.name,function(){try{return r.provideExecutionContext(r.createExecutionContext({type:"scheduled",contextId:n.generateCustomId("cron_"),cron:e.cron,name:e.name}),function(){try{return u("Running cron job "+e.name),Promise.resolve(function(e,r){try{var n=Promise.resolve(t()).then(function(){})}catch(e){return r(e)}return n&&n.then?n.then(void 0,r):n}(0,function(r){throw i.captureException(r,{tags:{cronName:e.name}}),r}))}catch(e){return Promise.reject(e)}}),Promise.resolve()}catch(e){return Promise.reject(e)}},{connection:s,concurrency:1});return{close:o.close.bind(o)}})}catch(e){return Promise.reject(e)}}}}});
|
|
2
2
|
//# sourceMappingURL=index.umd.js.map
|
package/dist/index.umd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n
|
|
1
|
+
{"version":3,"file":"index.umd.js","sources":["../src/index.ts"],"sourcesContent":["import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';\nimport { generateCustomId } from '@lowerdeck/id';\nimport { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { getSentry } from '@lowerdeck/sentry';\nimport { Queue, Worker } from 'bullmq';\n\nlet Sentry = getSentry();\n\nlet log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);\n\nlet seenNames = new Set<string>();\n\nexport let createCron = (\n opts: {\n name: string;\n cron: string;\n redisUrl: string;\n },\n handler: () => Promise<void>\n): IQueueProcessor => {\n if (seenNames.has(opts.name)) {\n throw new Error(`Cron with name ${opts.name} already exists`);\n }\n\n let connection = parseRedisUrl(opts.redisUrl);\n if (process.env.QUEUE_DEBUG_LOGGING)\n console.log('Creating cron with connection', opts.redisUrl, connection);\n let queue = new Queue(`Cr0N_${opts.name}`, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: {\n age: 60 * 60 * 24 // 1 day\n }\n }\n });\n\n return {\n start: async () => {\n log(`Starting cron job ${opts.name} to run every ${opts.cron} using bullmq`);\n\n await queue.upsertJobScheduler(\n 'cron',\n {\n pattern: opts.cron\n },\n {\n opts: {\n removeDependencyOnFailure: true,\n removeOnComplete: true,\n removeOnFail: true,\n keepLogs: 0\n }\n }\n );\n\n let worker = new Worker(\n queue.name,\n async () => {\n provideExecutionContext(\n createExecutionContext({\n type: 'scheduled',\n contextId: generateCustomId('cron_'),\n cron: opts.cron,\n name: opts.name\n }),\n async () => {\n log(`Running cron job ${opts.name}`);\n\n try {\n await handler();\n } catch (err) {\n Sentry.captureException(err, {\n tags: {\n cronName: opts.name\n }\n });\n throw err;\n }\n }\n );\n },\n {\n connection,\n concurrency: 1\n }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["Sentry","getSentry","log","_console","console","apply","concat","slice","call","arguments","seenNames","Set","opts","handler","has","name","Error","connection","parseRedisUrl","redisUrl","process","env","QUEUE_DEBUG_LOGGING","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","age","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","concurrency","close","bind"],"mappings":"qgBAOA,IAAIA,EAASC,EAASA,YAElBC,EAAM,WAAH,IAAAC,EAAsB,OAAAA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAAC,GAAAA,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,iBAEI,SACtBC,EAKAC,GAEA,GAAIH,EAAUI,IAAIF,EAAKG,MACrB,MAAU,IAAAC,MAAK,kBAAmBJ,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAaA,cAACN,EAAKO,UAChCC,QAAQC,IAAIC,qBACdlB,QAAQF,IAAI,gCAAiCU,EAAKO,SAAUF,GAC9D,IAAIM,EAAQ,IAAIC,EAAKA,MAASZ,QAAAA,EAAKG,KAAQ,CACzCE,WAAAA,EACAQ,kBAAmB,CACjBC,kBAAkB,EAClBC,aAAc,CACZC,IAAK,UAKX,MAAO,CACLC,MAAK,WAAA,IAC0E,OAA7E3B,EAAG,qBAAsBU,EAAKG,KAAI,iBAAiBH,EAAKkB,KAAI,iBAAiBC,QAAAC,QAEvET,EAAMU,mBACV,OACA,CACEC,QAAStB,EAAKkB,MAEhB,CACElB,KAAM,CACJuB,2BAA2B,EAC3BT,kBAAkB,EAClBC,cAAc,EACdS,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EAAAA,OACfhB,EAAMR,KAAI,WAAA,IAuBN,OArBFyB,EAAuBA,wBACrBC,EAAsBA,uBAAC,CACrBC,KAAM,YACNC,UAAWC,EAAgBA,iBAAC,SAC5Bd,KAAMlB,EAAKkB,KACXf,KAAMH,EAAKG,OACX,WAAA,IAEqC,OAArCb,sBAAwBU,EAAKG,MAAQgB,QAAAC,gCAEjCD,QAAAC,QACInB,KAASwB,KACjB,uEAJqCQ,CAEjC,EAEKC,SAAAA,GAMP,MALA9C,EAAO+C,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUrC,EAAKG,QAGb+B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EAAA,CAAA,GACDnB,QAAAC,SACJ,CAAC,MAAAkB,UAAAnB,QAAAoB,OAAAD,EAAA,CAAA,EACD,CACEjC,WAAAA,EACAmC,YAAa,IAIjB,MAAO,CACLC,MAAOf,EAAOe,MAAMC,KAAKhB,GACzB,EACJ,CAAC,MAAAY,GAAAnB,OAAAA,QAAAoB,OAAAD,KAEL"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lowerdeck/cron",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.6",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"dependencies": {
|
|
33
33
|
"@lowerdeck/execution-context": "^1.0.2",
|
|
34
34
|
"@lowerdeck/id": "^1.0.5",
|
|
35
|
-
"@lowerdeck/queue": "^1.0.
|
|
35
|
+
"@lowerdeck/queue": "^1.0.6",
|
|
36
36
|
"@lowerdeck/redis": "^1.0.3",
|
|
37
37
|
"@lowerdeck/sentry": "^1.0.2",
|
|
38
38
|
"bullmq": "^5.34.3"
|
package/src/index.ts
CHANGED
|
@@ -24,6 +24,8 @@ export let createCron = (
|
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
let connection = parseRedisUrl(opts.redisUrl);
|
|
27
|
+
if (process.env.QUEUE_DEBUG_LOGGING)
|
|
28
|
+
console.log('Creating cron with connection', opts.redisUrl, connection);
|
|
27
29
|
let queue = new Queue(`Cr0N_${opts.name}`, {
|
|
28
30
|
connection,
|
|
29
31
|
defaultJobOptions: {
|
|
@@ -81,7 +83,6 @@ export let createCron = (
|
|
|
81
83
|
},
|
|
82
84
|
{
|
|
83
85
|
connection,
|
|
84
|
-
|
|
85
86
|
concurrency: 1
|
|
86
87
|
}
|
|
87
88
|
);
|