/[sudobot]/branches/4.x/src/utils/structures/Queue.ts
ViewVC logotype

Contents of /branches/4.x/src/utils/structures/Queue.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 2701 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 /**
2 * This file is part of SudoBot.
3 *
4 * Copyright (C) 2021-2022 OSN Inc.
5 *
6 * SudoBot is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * SudoBot is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20 import DiscordClient from "../../client/Client";
21 import { generate as randomstring } from 'randomstring';
22 import { IQueuedJob } from "../../models/QueuedJob";
23
24 export interface QueueOptions {
25 runAfter?: number;
26 id?: string;
27 runAt?: Date;
28 model: IQueuedJob;
29 }
30
31 export default abstract class Queue {
32 protected completed = false;
33 public readonly runOn: number = 0;
34 public readonly id: string;
35 public readonly model: IQueuedJob;
36 protected readonly timeout: NodeJS.Timeout;
37 public readonly guild: string | undefined;
38
39 constructor(protected client: DiscordClient, { runAfter, id, runAt, model }: QueueOptions) {
40 if (runAfter !== 0 && runAfter !== 0 && !runAfter && !runAt) {
41 throw new Error("One of runAfter or runAt must be specified for creating a queue");
42 }
43
44 this.runOn = runAfter ? Date.now() + runAfter : runAt!.getTime();
45 this.id = id ?? randomstring(7);
46 this.model = model;
47 this.guild = model.guild;
48
49 const ms = this.runOn - Date.now();
50
51 this.timeout = setTimeout(async () => {
52 await this.run();
53 await this.finish();
54 }, ms < 0 ? 0 : ms);
55
56 console.log('Queue created: ', this.constructor.name, this.id);
57 }
58
59 get data() {
60 return this.model.data;
61 }
62
63 async finish() {
64 this.client.queueManager.removeQueue(this);
65 console.log("Job complete: ", this.constructor.name);
66 }
67
68 async cancel() {
69 clearTimeout(this.timeout);
70 await this.model.delete();
71 this.client.queueManager.removeQueue(this);
72 }
73
74 abstract execute(data?: { [key: string | number]: any }): Promise<any>;
75
76 async run() {
77 this.completed = true;
78 this.model.delete();
79
80 try {
81 return await this.execute(this.model.data);
82 }
83 catch (e) {
84 console.error(`An error occurred in queue job\nJob ID: ${this.id}`, e);
85 }
86 }
87 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26