@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 CHANGED
@@ -1,2 +1,2 @@
1
- var e=require("@lowerdeck/redis"),r=require("bullmq"),n=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},o=new Set;exports.createCron=function(t,c){if(o.has(t.name))throw new Error("Cron with name "+t.name+" already exists");var i=e.parseRedisUrl(t.redisUrl),a=new r.Queue(t.name,{connection:i,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});return{start:function(){try{return n("Starting cron job "+t.name+" to run every "+t.cron+" using bullmq"),Promise.resolve(a.upsertJobScheduler("cron",{pattern:t.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var e=new r.Worker(t.name,function(){try{return n("Running cron job "+t.name),Promise.resolve(c()).then(function(){})}catch(e){return Promise.reject(e)}},{connection:i});return{close:e.close.bind(e)}})}catch(e){return Promise.reject(e)}}}};
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
@@ -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 await handler();\n },\n { connection }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["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","e","reject","close","bind"],"mappings":"sDAIIA,EAAM,WAAH,IAAAC,EAAA,OAAsBA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAA,GAAAC,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,uBAEI,SACtBC,EAKAC,GAEA,GAAIH,EAAUI,IAAIF,EAAKG,MACrB,UAAUC,MAAwBJ,kBAAAA,EAAKG,KAAqB,mBAG9D,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,IAC0E,OAA7EvB,EAAyBU,qBAAAA,EAAKG,KAAqBH,iBAAAA,EAAKc,sBAAqBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAAA,WAED,IAAIC,EAAS,IAAIC,EAAAA,OACfvB,EAAKG,KACM,WAAA,IAC4B,OAArCb,EAAG,oBAAqBU,EAAKG,MAAQY,QAAAC,QAC/Bf,KAASoB,KACjB,WAAA,EAAA,CAAC,MAAAG,GAAAT,OAAAA,QAAAU,OAAAD,EAAA,CAAA,EACD,CAAEnB,WAAAA,IAGJ,MAAO,CACLqB,MAAOJ,EAAOI,MAAMC,KAAKL,GACzB,EACJ,CAAC,MAAAE,GAAA,OAAAT,QAAAU,OAAAD,EAAA,CAAA,EAEL"}
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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAQnD,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,eA+CF,CAAC"}
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"}
@@ -1,2 +1,2 @@
1
- import{parseRedisUrl as e}from"@lowerdeck/redis";import{Queue as n,Worker as r}from"bullmq";var o=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},t=new Set,c=function(c,i){if(t.has(c.name))throw new Error("Cron with name "+c.name+" already exists");var a=e(c.redisUrl),l=new n(c.name,{connection:a,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});return{start:function(){try{return o("Starting cron job "+c.name+" to run every "+c.cron+" using bullmq"),Promise.resolve(l.upsertJobScheduler("cron",{pattern:c.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var e=new r(c.name,function(){try{return o("Running cron job "+c.name),Promise.resolve(i()).then(function(){})}catch(e){return Promise.reject(e)}},{connection:a});return{close:e.close.bind(e)}})}catch(e){return Promise.reject(e)}}}};export{c as createCron};
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
@@ -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 await handler();\n },\n { connection }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["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","e","reject","close","bind"],"mappings":"4FAIA,IAAIA,EAAM,WAAH,IAAAC,EAAA,OAAsBA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAA,GAAAC,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,IAETC,EAAa,SACtBC,EAKAC,GAEA,GAAIJ,EAAUK,IAAIF,EAAKG,MACrB,UAAUC,MAAwBJ,kBAAAA,EAAKG,KAAqB,mBAG9D,IAAIE,EAAaC,EAAcN,EAAKO,UAChCC,EAAQ,IAAIC,EAAMT,EAAKG,KAAM,CAC/BE,WAAAA,EACAK,kBAAmB,CACjBC,kBAAkB,EAClBC,cAAc,KAIlB,MAAO,CACLC,MAAK,WAAA,IAC0E,OAA7ExB,EAAyBW,qBAAAA,EAAKG,KAAqBH,iBAAAA,EAAKc,sBAAqBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAAA,WAED,IAAIC,EAAS,IAAIC,EACfvB,EAAKG,KACM,WAAA,IAC4B,OAArCd,EAAG,oBAAqBW,EAAKG,MAAQY,QAAAC,QAC/Bf,KAASoB,KACjB,WAAA,EAAA,CAAC,MAAAG,GAAAT,OAAAA,QAAAU,OAAAD,EAAA,CAAA,EACD,CAAEnB,WAAAA,IAGJ,MAAO,CACLqB,MAAOJ,EAAOI,MAAMC,KAAKL,GACzB,EACJ,CAAC,MAAAE,GAAA,OAAAT,QAAAU,OAAAD,EAAA,CAAA,EAEL"}
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,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@lowerdeck/redis"),require("bullmq")):"function"==typeof define&&define.amd?define(["exports","@lowerdeck/redis","bullmq"],n):n((e||self).cron={},e.redis,e.bullmq)}(this,function(e,n,r){var o=function(){var e;return(e=console).log.apply(e,["[CRON MANAGER]:"].concat([].slice.call(arguments)))},t=new Set;e.createCron=function(e,i){if(t.has(e.name))throw new Error("Cron with name "+e.name+" already exists");var c=n.parseRedisUrl(e.redisUrl),l=new r.Queue(e.name,{connection:c,defaultJobOptions:{removeOnComplete:!0,removeOnFail:!0}});return{start:function(){try{return o("Starting cron job "+e.name+" to run every "+e.cron+" using bullmq"),Promise.resolve(l.upsertJobScheduler("cron",{pattern:e.cron},{opts:{removeDependencyOnFailure:!0,removeOnComplete:!0,removeOnFail:!0,keepLogs:0}})).then(function(){var n=new r.Worker(e.name,function(){try{return o("Running cron job "+e.name),Promise.resolve(i()).then(function(){})}catch(e){return Promise.reject(e)}},{connection:c});return{close:n.close.bind(n)}})}catch(e){return Promise.reject(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
@@ -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 await handler();\n },\n { connection }\n );\n\n return {\n close: worker.close.bind(worker)\n };\n }\n };\n};\n"],"names":["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","e","reject","close","bind"],"mappings":"6TAIA,IAAIA,EAAM,WAAH,IAAAC,EAAA,OAAsBA,EAAAC,SAAQF,IAAGG,MAAAF,EAAA,CAAC,mBAAiBG,OAAA,GAAAC,MAAAC,KAAAC,YAAS,EAE/DC,EAAY,IAAIC,iBAEI,SACtBC,EAKAC,GAEA,GAAIH,EAAUI,IAAIF,EAAKG,MACrB,UAAUC,MAAwBJ,kBAAAA,EAAKG,KAAqB,mBAG9D,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,IAC0E,OAA7EvB,EAAyBU,qBAAAA,EAAKG,KAAqBH,iBAAAA,EAAKc,sBAAqBC,QAAAC,QAEvER,EAAMS,mBACV,OACA,CACEC,QAASlB,EAAKc,MAEhB,CACEd,KAAM,CACJmB,2BAA2B,EAC3BR,kBAAkB,EAClBC,cAAc,EACdQ,SAAU,MAGfC,KAAA,WAED,IAAIC,EAAS,IAAIC,EAAAA,OACfvB,EAAKG,KACM,WAAA,IAC4B,OAArCb,EAAG,oBAAqBU,EAAKG,MAAQY,QAAAC,QAC/Bf,KAASoB,KACjB,WAAA,EAAA,CAAC,MAAAG,GAAAT,OAAAA,QAAAU,OAAAD,EAAA,CAAA,EACD,CAAEnB,WAAAA,IAGJ,MAAO,CACLqB,MAAOJ,EAAOI,MAAMC,KAAKL,GACzB,EACJ,CAAC,MAAAE,GAAA,OAAAT,QAAAU,OAAAD,EAAA,CAAA,EAEL"}
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.2",
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/queue": "^1.0.2",
28
- "@lowerdeck/redis": "^1.0.2",
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.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
- log(`Running cron job ${opts.name}`);
53
- await handler();
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
  );
@@ -1,12 +0,0 @@
1
-
2
- $ microbundle
3
- No name was provided for external module '@lowerdeck/redis' in output.globals – guessing 'redis'
4
- Build "@lowerdeck/cron" to dist:
5
- 496 B: index.cjs.gz
6
- 427 B: index.cjs.br
7
- 441 B: index.module.js.gz
8
- 381 B: index.module.js.br
9
- 510 B: index.module.js.gz
10
- 429 B: index.module.js.br
11
- 594 B: index.umd.js.gz
12
- 497 B: index.umd.js.br
@@ -1,11 +0,0 @@
1
-
2
- $ vitest run --passWithNoTests
3
- [?25l
4
-  RUN  v3.2.4 /Users/tobias/code/metorial/metorial-enterprise/oss/src/packages/backend/cron
5
-
6
- No test files found, exiting with code 0
7
-
8
- include: **/*.{test,spec}.?(c|m)[jt]s?(x)
9
- exclude: **/node_modules/**, **/dist/**, **/cypress/**, **/.{idea,git,cache,output,temp}/**, **/{karma,rollup,webpack,vite,vitest,jest,ava,babel,nyc,cypress,tsup,build,eslint,prettier}.config.*
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
@@ -1,11 +0,0 @@
1
- {
2
- "$schema": "https://json.schemastore.org/tsconfig",
3
- "extends": "@lowerdeck/tsconfig/base.json",
4
- "exclude": ["dist"],
5
- "include": ["src"],
6
- "compilerOptions": {
7
- "outDir": "dist",
8
- "lib": ["es2021"],
9
- "target": "ES2019"
10
- }
11
- }