2022-10-10 20:50:21 +08:00
|
|
|
import { Hook, Manifest } from "../types.ts";
|
|
|
|
import { Cron } from "https://cdn.jsdelivr.net/gh/hexagon/croner@4/src/croner.js";
|
|
|
|
import { safeRun } from "../util.ts";
|
|
|
|
import { System } from "../system.ts";
|
2022-03-29 17:21:32 +08:00
|
|
|
export type CronHookT = {
|
2022-03-27 17:26:13 +08:00
|
|
|
cron?: string | string[];
|
2022-03-23 22:41:12 +08:00
|
|
|
};
|
|
|
|
|
2023-01-20 23:08:01 +08:00
|
|
|
export class CronHook implements Hook<CronHookT> {
|
2023-01-26 01:29:47 +08:00
|
|
|
tasks: Cron[] = [];
|
|
|
|
constructor(private system: System<CronHookT>) {
|
|
|
|
}
|
|
|
|
|
2022-03-29 17:21:32 +08:00
|
|
|
apply(system: System<CronHookT>): void {
|
2023-01-26 01:29:47 +08:00
|
|
|
this.system = system;
|
2022-03-23 22:41:12 +08:00
|
|
|
system.on({
|
2022-04-27 01:04:36 +08:00
|
|
|
plugLoaded: () => {
|
2023-01-26 01:29:47 +08:00
|
|
|
this.reloadCrons();
|
2022-03-23 22:41:12 +08:00
|
|
|
},
|
2023-01-26 01:29:47 +08:00
|
|
|
plugUnloaded: () => {
|
|
|
|
this.reloadCrons();
|
2022-03-23 22:41:12 +08:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2023-01-26 01:29:47 +08:00
|
|
|
this.reloadCrons();
|
|
|
|
}
|
2022-03-23 22:41:12 +08:00
|
|
|
|
2023-01-26 01:29:47 +08:00
|
|
|
stop() {
|
|
|
|
this.tasks.forEach((task) => task.stop());
|
|
|
|
this.tasks = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
reloadCrons() {
|
|
|
|
this.stop();
|
|
|
|
for (const plug of this.system.loadedPlugs.values()) {
|
|
|
|
if (!plug.manifest) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
for (
|
|
|
|
const [name, functionDef] of Object.entries(
|
|
|
|
plug.manifest.functions,
|
|
|
|
)
|
|
|
|
) {
|
|
|
|
if (!functionDef.cron) {
|
2022-03-27 17:26:13 +08:00
|
|
|
continue;
|
|
|
|
}
|
2023-01-26 01:29:47 +08:00
|
|
|
const crons = Array.isArray(functionDef.cron)
|
|
|
|
? functionDef.cron
|
|
|
|
: [functionDef.cron];
|
|
|
|
for (const cronDef of crons) {
|
|
|
|
this.tasks.push(
|
|
|
|
new Cron(cronDef, () => {
|
|
|
|
// console.log("Now acting on cron", cronDef);
|
|
|
|
safeRun(async () => {
|
|
|
|
try {
|
|
|
|
await plug.invoke(name, [cronDef]);
|
|
|
|
} catch (e: any) {
|
|
|
|
console.error("Execution of cron function failed", e);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}),
|
|
|
|
);
|
2022-03-23 22:41:12 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-29 17:21:32 +08:00
|
|
|
validateManifest(manifest: Manifest<CronHookT>): string[] {
|
2022-10-16 01:02:56 +08:00
|
|
|
const errors: string[] = [];
|
|
|
|
for (const functionDef of Object.values(manifest.functions)) {
|
2022-03-27 17:26:13 +08:00
|
|
|
if (!functionDef.cron) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
const crons = Array.isArray(functionDef.cron)
|
|
|
|
? functionDef.cron
|
|
|
|
: [functionDef.cron];
|
2022-10-16 01:02:56 +08:00
|
|
|
for (const _cronDef of crons) {
|
2022-10-10 20:50:21 +08:00
|
|
|
// if (!cron.validate(cronDef)) {
|
|
|
|
// errors.push(`Invalid cron expression ${cronDef}`);
|
|
|
|
// }
|
2022-03-23 22:41:12 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return errors;
|
|
|
|
}
|
|
|
|
}
|