@lowerdeck/cron 1.0.2 → 1.0.4
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 +14 -5
- package/src/index.ts +27 -2
- package/.turbo/turbo-build.log +0 -12
- package/.turbo/turbo-test.log +0 -11
- package/CHANGELOG.md +0 -19
- package/tsconfig.json +0 -11
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var e=require("@lowerdeck/
|
|
1
|
+
var e=require("@lowerdeck/execution-context"),r=require("@lowerdeck/id"),n=require("@lowerdeck/redis"),t=require("@lowerdeck/sentry"),o=require("bullmq"),c=t.getSentry(),i=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},u=new Set;exports.createCron=function(t,a){if(u.has(t.name))throw new Error("Cron with name "+t.name+" already exists");var s=n.parseRedisUrl(t.redisUrl),l=new o.Queue(t.name,{connection:s,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});return{start:function(){try{return i("Starting cron job "+t.name+" to run every "+t.cron+" using bullmq"),Promise.resolve(l.upsertJobScheduler("cron",{pattern:t.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var n=new o.Worker(t.name,function(){try{return e.provideExecutionContext(e.createExecutionContext({type:"scheduled",contextId:r.generateCustomId("cron_"),cron:t.cron,name:t.name}),function(){try{return i("Running cron job "+t.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:t.name}}),e}))}catch(e){return Promise.reject(e)}}),Promise.resolve()}catch(e){return Promise.reject(e)}},{connection:s});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 { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { Queue, Worker } from 'bullmq';\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(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.name,\n async () => {\n log(`Running cron job ${opts.name}`);\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 let queue = new Queue(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.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 { connection }\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","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","close","bind"],"mappings":"0JAOIA,EAASC,EAAAA,YAETC,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,MAAwBJ,kBAAAA,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAAA,cAAcN,EAAKO,UAChCC,EAAQ,IAAIC,EAAKA,MAACT,EAAKG,KAAM,CAC/BE,WAAAA,EACAK,kBAAmB,CACjBC,kBAAkB,EAClBC,cAAc,KAIlB,MAAO,CACLC,MAAK,WAAa,IAC6D,OAA7EvB,EAAyBU,qBAAAA,EAAKG,KAAI,iBAAiBH,EAAKc,KAAI,iBAAiBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EAAMA,OACrBvB,EAAKG,KACM,WAAA,IAsBP,OArBFqB,EAAAA,wBACEC,EAAsBA,uBAAC,CACrBC,KAAM,YACNC,UAAWC,mBAAiB,SAC5Bd,KAAMd,EAAKc,KACXX,KAAMH,EAAKG,sBAG0B,OAArCb,EAAwBU,oBAAAA,EAAKG,MAAQY,QAAAC,gCAEjCD,QAAAC,QACIf,KAASoB,KAAA,WAAA,4DAHoBQ,CAAA,EAI5BC,SAAAA,GAMP,MALA1C,EAAO2C,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUjC,EAAKG,QAGb2B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EACF,CAAA,GAACnB,QAAAC,SACJ,CAAC,MAAAkB,GAAAnB,OAAAA,QAAAoB,OAAAD,KACD,CAAE7B,WAAAA,IAGJ,MAAO,CACL+B,MAAOd,EAAOc,MAAMC,KAAKf,GACzB,EACJ,CAAC,MAAAY,GAAA,OAAAnB,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":"
|
|
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,eAmEF,CAAC"}
|
package/dist/index.module.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{
|
|
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 m=t(),a=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},u=new Set,l=function(t,l){if(u.has(t.name))throw new Error("Cron with name "+t.name+" already exists");var s=o(t.redisUrl),p=new c(t.name,{connection:s,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});return{start:function(){try{return a("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(t.name,function(){try{return e(r({type:"scheduled",contextId:n("cron_"),cron:t.cron,name:t.name}),function(){try{return a("Running cron job "+t.name),Promise.resolve(function(e,r){try{var n=Promise.resolve(l()).then(function(){})}catch(e){return r(e)}return n&&n.then?n.then(void 0,r):n}(0,function(e){throw m.captureException(e,{tags:{cronName:t.name}}),e}))}catch(e){return Promise.reject(e)}}),Promise.resolve()}catch(e){return Promise.reject(e)}},{connection:s});return{close:o.close.bind(o)}})}catch(e){return Promise.reject(e)}}}};export{l 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 { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { Queue, Worker } from 'bullmq';\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(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.name,\n async () => {\n log(`Running cron job ${opts.name}`);\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 let queue = new Queue(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.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 { connection }\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","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","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,MAAwBJ,kBAAAA,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAcN,EAAKO,UAChCC,EAAQ,IAAIC,EAAMT,EAAKG,KAAM,CAC/BE,WAAAA,EACAK,kBAAmB,CACjBC,kBAAkB,EAClBC,cAAc,KAIlB,MAAO,CACLC,MAAK,WAAa,IAC6D,OAA7ExB,EAAyBW,qBAAAA,EAAKG,KAAI,iBAAiBH,EAAKc,KAAI,iBAAiBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EACfvB,EAAKG,KACM,WAAA,IAsBP,OArBFqB,EACEC,EAAuB,CACrBC,KAAM,YACNC,UAAWC,EAAiB,SAC5Bd,KAAMd,EAAKc,KACXX,KAAMH,EAAKG,sBAG0B,OAArCd,EAAwBW,oBAAAA,EAAKG,MAAQY,QAAAC,gCAEjCD,QAAAC,QACIf,KAASoB,KAAA,WAAA,4DAHoBQ,CAAA,EAI5BC,SAAAA,GAMP,MALA3C,EAAO4C,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUjC,EAAKG,QAGb2B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EACF,CAAA,GAACnB,QAAAC,SACJ,CAAC,MAAAkB,GAAAnB,OAAAA,QAAAoB,OAAAD,KACD,CAAE7B,WAAAA,IAGJ,MAAO,CACL+B,MAAOd,EAAOc,MAAMC,KAAKf,GACzB,EACJ,CAAC,MAAAY,GAAA,OAAAnB,QAAAoB,OAAAD,KAEL"}
|
package/dist/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,
|
|
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),a=new c.Queue(e.name,{connection:s,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});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(e.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});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 { IQueueProcessor } from '@lowerdeck/queue';\nimport { parseRedisUrl } from '@lowerdeck/redis';\nimport { Queue, Worker } from 'bullmq';\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(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.name,\n async () => {\n log(`Running cron job ${opts.name}`);\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 let queue = new Queue(opts.name, {\n connection,\n defaultJobOptions: {\n removeOnComplete: true,\n removeOnFail: true\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 opts.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 { connection }\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","queue","Queue","defaultJobOptions","removeOnComplete","removeOnFail","start","cron","Promise","resolve","upsertJobScheduler","pattern","removeDependencyOnFailure","keepLogs","then","worker","Worker","provideExecutionContext","createExecutionContext","type","contextId","generateCustomId","_catch","err","captureException","tags","cronName","e","reject","close","bind"],"mappings":"qgBAOA,IAAIA,EAASC,EAAAA,YAETC,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,MAAwBJ,kBAAAA,EAAKG,KAAI,mBAG7C,IAAIE,EAAaC,EAAAA,cAAcN,EAAKO,UAChCC,EAAQ,IAAIC,EAAKA,MAACT,EAAKG,KAAM,CAC/BE,WAAAA,EACAK,kBAAmB,CACjBC,kBAAkB,EAClBC,cAAc,KAIlB,MAAO,CACLC,MAAK,WAAa,IAC6D,OAA7EvB,EAAyBU,qBAAAA,EAAKG,KAAI,iBAAiBH,EAAKc,KAAI,iBAAiBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAED,WAAA,IAAIC,EAAS,IAAIC,EAAMA,OACrBvB,EAAKG,KACM,WAAA,IAsBP,OArBFqB,EAAAA,wBACEC,EAAsBA,uBAAC,CACrBC,KAAM,YACNC,UAAWC,mBAAiB,SAC5Bd,KAAMd,EAAKc,KACXX,KAAMH,EAAKG,sBAG0B,OAArCb,EAAwBU,oBAAAA,EAAKG,MAAQY,QAAAC,gCAEjCD,QAAAC,QACIf,KAASoB,KAAA,WAAA,4DAHoBQ,CAAA,EAI5BC,SAAAA,GAMP,MALA1C,EAAO2C,iBAAiBD,EAAK,CAC3BE,KAAM,CACJC,SAAUjC,EAAKG,QAGb2B,CACR,GACF,CAAC,MAAAI,GAAAnB,OAAAA,QAAAoB,OAAAD,EACF,CAAA,GAACnB,QAAAC,SACJ,CAAC,MAAAkB,GAAAnB,OAAAA,QAAAoB,OAAAD,KACD,CAAE7B,WAAAA,IAGJ,MAAO,CACL+B,MAAOd,EAAOc,MAAMC,KAAKf,GACzB,EACJ,CAAC,MAAAY,GAAA,OAAAnB,QAAAoB,OAAAD,KAEL"}
|
package/package.json
CHANGED
|
@@ -1,9 +1,15 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lowerdeck/cron",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.4",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
7
|
+
"files": [
|
|
8
|
+
"src/**",
|
|
9
|
+
"dist/**",
|
|
10
|
+
"README.md",
|
|
11
|
+
"package.json"
|
|
12
|
+
],
|
|
7
13
|
"author": "Tobias Herber",
|
|
8
14
|
"license": "Apache 2",
|
|
9
15
|
"type": "module",
|
|
@@ -21,15 +27,18 @@
|
|
|
21
27
|
"scripts": {
|
|
22
28
|
"test": "vitest run --passWithNoTests",
|
|
23
29
|
"lint": "prettier src/**/*.ts --check",
|
|
24
|
-
"build": "microbundle"
|
|
30
|
+
"build": "rm -rf ./dist && microbundle"
|
|
25
31
|
},
|
|
26
32
|
"dependencies": {
|
|
27
|
-
"@lowerdeck/
|
|
28
|
-
"@lowerdeck/
|
|
33
|
+
"@lowerdeck/execution-context": "^1.0.2",
|
|
34
|
+
"@lowerdeck/id": "^1.0.5",
|
|
35
|
+
"@lowerdeck/queue": "^1.0.4",
|
|
36
|
+
"@lowerdeck/redis": "^1.0.3",
|
|
37
|
+
"@lowerdeck/sentry": "^1.0.2",
|
|
29
38
|
"bullmq": "^5.34.3"
|
|
30
39
|
},
|
|
31
40
|
"devDependencies": {
|
|
32
|
-
"@lowerdeck/tsconfig": "^1.0.
|
|
41
|
+
"@lowerdeck/tsconfig": "^1.0.1",
|
|
33
42
|
"typescript": "5.8.2",
|
|
34
43
|
"microbundle": "^0.15.1",
|
|
35
44
|
"vitest": "^3.1.2"
|
package/src/index.ts
CHANGED
|
@@ -1,7 +1,12 @@
|
|
|
1
|
+
import { createExecutionContext, provideExecutionContext } from '@lowerdeck/execution-context';
|
|
2
|
+
import { generateCustomId } from '@lowerdeck/id';
|
|
1
3
|
import { IQueueProcessor } from '@lowerdeck/queue';
|
|
2
4
|
import { parseRedisUrl } from '@lowerdeck/redis';
|
|
5
|
+
import { getSentry } from '@lowerdeck/sentry';
|
|
3
6
|
import { Queue, Worker } from 'bullmq';
|
|
4
7
|
|
|
8
|
+
let Sentry = getSentry();
|
|
9
|
+
|
|
5
10
|
let log = (...any: any[]) => console.log('[CRON MANAGER]:', ...any);
|
|
6
11
|
|
|
7
12
|
let seenNames = new Set<string>();
|
|
@@ -49,8 +54,28 @@ export let createCron = (
|
|
|
49
54
|
let worker = new Worker(
|
|
50
55
|
opts.name,
|
|
51
56
|
async () => {
|
|
52
|
-
|
|
53
|
-
|
|
57
|
+
provideExecutionContext(
|
|
58
|
+
createExecutionContext({
|
|
59
|
+
type: 'scheduled',
|
|
60
|
+
contextId: generateCustomId('cron_'),
|
|
61
|
+
cron: opts.cron,
|
|
62
|
+
name: opts.name
|
|
63
|
+
}),
|
|
64
|
+
async () => {
|
|
65
|
+
log(`Running cron job ${opts.name}`);
|
|
66
|
+
|
|
67
|
+
try {
|
|
68
|
+
await handler();
|
|
69
|
+
} catch (err) {
|
|
70
|
+
Sentry.captureException(err, {
|
|
71
|
+
tags: {
|
|
72
|
+
cronName: opts.name
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
throw err;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
);
|
|
54
79
|
},
|
|
55
80
|
{ connection }
|
|
56
81
|
);
|
package/.turbo/turbo-build.log
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
[0m[2m[35m$[0m [2m[1mmicrobundle[0m
|
|
3
|
-
No name was provided for external module '@lowerdeck/redis' in output.globals – guessing 'redis'
|
|
4
|
-
[34mBuild "@lowerdeck/cron" to dist:[39m
|
|
5
|
-
[32m496 B[39m: [37mindex.cjs[39m.gz
|
|
6
|
-
[32m427 B[39m: [37mindex.cjs[39m.br
|
|
7
|
-
[32m441 B[39m: [37mindex.module.js[39m.gz
|
|
8
|
-
[32m381 B[39m: [37mindex.module.js[39m.br
|
|
9
|
-
[32m510 B[39m: [37mindex.module.js[39m.gz
|
|
10
|
-
[32m429 B[39m: [37mindex.module.js[39m.br
|
|
11
|
-
[32m594 B[39m: [37mindex.umd.js[39m.gz
|
|
12
|
-
[32m497 B[39m: [37mindex.umd.js[39m.br
|
package/.turbo/turbo-test.log
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
[0m[2m[35m$[0m [2m[1mvitest run --passWithNoTests[0m
|
|
3
|
-
[?25l
|
|
4
|
-
[1m[46m RUN [49m[22m [36mv3.2.4 [39m[90m/Users/tobias/code/metorial/metorial-enterprise/oss/src/packages/backend/cron[39m
|
|
5
|
-
|
|
6
|
-
No test files found, exiting with code 0
|
|
7
|
-
|
|
8
|
-
[2minclude: [22m[33m**/*.{test,spec}.?(c|m)[jt]s?(x)[39m
|
|
9
|
-
[2mexclude: [22m[33m**/node_modules/**[2m, [22m**/dist/**[2m, [22m**/cypress/**[2m, [22m**/.{idea,git,cache,output,temp}/**[2m, [22m**/{karma,rollup,webpack,vite,vitest,jest,ava,babel,nyc,cypress,tsup,build,eslint,prettier}.config.*[39m
|
|
10
|
-
|
|
11
|
-
[?25h
|
package/CHANGELOG.md
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# @lowerdeck/cron
|
|
2
|
-
|
|
3
|
-
## 1.0.2
|
|
4
|
-
|
|
5
|
-
### Patch Changes
|
|
6
|
-
|
|
7
|
-
- Fix default entry point
|
|
8
|
-
- Updated dependencies
|
|
9
|
-
- @lowerdeck/queue@1.0.2
|
|
10
|
-
- @lowerdeck/redis@1.0.2
|
|
11
|
-
|
|
12
|
-
## 1.0.1
|
|
13
|
-
|
|
14
|
-
### Patch Changes
|
|
15
|
-
|
|
16
|
-
- update versions
|
|
17
|
-
- Updated dependencies
|
|
18
|
-
- @lowerdeck/queue@1.0.1
|
|
19
|
-
- @lowerdeck/redis@1.0.1
|
package/tsconfig.json
DELETED