/[sudobot]/trunk/src/client/Client.ts
ViewVC logotype

Contents of /trunk/src/client/Client.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 421 - (show annotations)
Mon Jul 29 17:30:09 2024 UTC (8 months ago) by rakin
File MIME type: application/typescript
File size: 7278 byte(s)
refactor: queue jobs
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 { Client, ClientOptions, Collection, Interaction, Message } from 'discord.js';
21 import BaseEvent from '../utils/structures/BaseEvent';
22 import BaseCommand from '../utils/structures/BaseCommand';
23 import { Config } from './Config';
24 import Database from './Database';
25 import path from 'path';
26 import { appendFile } from "fs/promises";
27 import Logger from '../automod/Logger';
28 import SnippetManager from '../services/SnippetManager';
29 import AFKEngine from '../services/AFKEngine';
30 import Auth from '../services/Auth';
31 import MessageFilter from '../automod/MessageFilter';
32 import AntiRaid from '../automod/AntiRaid';
33 import Starboard from '../services/Starboard';
34 import Server from '../api/Server';
35 import StartupManager from '../services/StartupManager';
36 import AutoClear from '../automod/AutoClear';
37 import RandomStatus from '../services/RandomStatus';
38 import DebugLogger from '../services/DebugLogger';
39 import BaseCLICommand from '../utils/structures/BaseCLICommand';
40 import discordModals from 'discord-modals';
41 import SpamFilter from '../automod/SpamFilter';
42 import Verification from '../services/Verification';
43 import Welcomer from '../services/Welcomer';
44 import Antijoin from '../automod/Antijoin';
45 import Automute from '../automod/Automute';
46 import ServiceManager from './ServiceManager';
47 import ChannelLockManager from '../services/ChannelLockManager';
48 import Cooldown from '../services/Cooldown';
49 import ProfileFilter from '../automod/ProfileFilter';
50 import QueueManager from '../services/QueueManager';
51
52 export default class DiscordClient extends Client {
53 private _commands = new Collection<string, BaseCommand>();
54 private _cliCommands = new Collection<string, BaseCLICommand>();
55 private _events = new Collection<string, BaseEvent>();
56
57 rootdir: string;
58 msg: Message | Interaction | null = null;
59
60 config: Config;
61 db: Database;
62 server: Server;
63 serviceManager: ServiceManager;
64
65 logger: Logger = {} as Logger;
66 snippetManager: SnippetManager = {} as SnippetManager;
67 afkEngine: AFKEngine = {} as AFKEngine;
68 auth: Auth = {} as Auth;
69 spamFilter: SpamFilter = {} as SpamFilter;
70 messageFilter: MessageFilter = {} as MessageFilter;
71 antiraid: AntiRaid = {} as AntiRaid;
72 starboard: Starboard = {} as Starboard;
73 startupManager: StartupManager = {} as StartupManager;
74 autoClear: AutoClear = {} as AutoClear;
75 randomStatus: RandomStatus = {} as RandomStatus;
76 debugLogger: DebugLogger = {} as DebugLogger;
77 verification: Verification = {} as Verification;
78 welcomer: Welcomer = {} as Welcomer;
79 antijoin: Antijoin = {} as Antijoin;
80 automute: Automute = {} as Automute;
81 channelLock: ChannelLockManager = {} as ChannelLockManager;
82 cooldown: Cooldown = {} as Cooldown;
83 profileFilter: ProfileFilter = {} as ProfileFilter;
84 queueManager: QueueManager = {} as QueueManager;
85
86 aliases = {
87 automod: path.resolve(__dirname, '..', 'automod'),
88 services: path.resolve(__dirname, '..', 'services'),
89 };
90
91 services = {
92 "@services/DebugLogger": "debugLogger",
93 "@automod/Logger": "logger",
94 "@services/SnippetManager": "snippetManager",
95 "@services/AFKEngine": "afkEngine",
96 "@services/Auth": "auth",
97 "@automod/SpamFilter": "spamFilter",
98 "@automod/MessageFilter": "messageFilter",
99 "@automod/AntiRaid": "antiraid",
100 "@services/Starboard": "starboard",
101 "@services/StartupManager": "startupManager",
102 "@automod/AutoClear": "autoClear",
103 "@services/RandomStatus": "randomStatus",
104 "@services/Verification": "verification",
105 "@services/Welcomer": "welcomer",
106 "@services/ChannelLockManager": "channelLock",
107 "@automod/Antijoin": "antijoin",
108 "@automod/Automute": "automute",
109 "@services/Cooldown": "cooldown",
110 "@automod/ProfileFilter": "profileFilter",
111 "@services/QueueManager": "queueManager",
112 };
113
114 static client: DiscordClient;
115
116 constructor(options: ClientOptions, rootdir: string = __dirname) {
117 super({
118 ws: {
119 properties: {
120 browser: "Discord iOS"
121 }
122 },
123 ...options
124 });
125
126 process.on('uncaughtException', (error, origin) => {
127 console.log('Uncaught', error);
128 this.handleCrash(error, origin).then(() => process.exit(-1)).catch(err => {
129 console.log(err);
130 process.exit(-1);
131 });
132 });
133
134 console.log('init');
135
136 this.rootdir = rootdir;
137
138 DiscordClient.client = this;
139
140 this.config = new Config(this);
141 this.db = new Database(this);
142 this.serviceManager = new ServiceManager(this, this.aliases);
143 this.serviceManager.load(this.services);
144
145 // this.logger = new Logger(this);
146 // this.snippetManager = new SnippetManager(this);
147 // this.afkEngine = new AFKEngine(this);
148 // this.auth = new Auth(this);
149 // this.spamFilter = new SpamFilter(this);
150 // this.messageFilter = new MessageFilter(this);
151 // this.antiraid = new AntiRaid(this);
152 // this.starboard = new Starboard(this);
153 // this.cooldown = new Cooldown(this);
154 // this.startupManager = new StartupManager(this);
155 // this.autoClear = new AutoClear(this);
156 // this.randomStatus = new RandomStatus(this);
157 // this.debugLogger = new DebugLogger(this);
158 // this.verification = new Verification(this);
159 // this.welcomer = new Welcomer(this);
160 // this.antijoin = new Antijoin(this);
161 // this.automute = new Automute(this);
162
163 this.server = new Server(this);
164
165 discordModals(this);
166 }
167
168 get commands(): Collection<string, BaseCommand> {
169 return this._commands;
170 }
171
172 get cliCommands(): Collection<string, BaseCLICommand> {
173 return this._cliCommands;
174 }
175
176 get events(): Collection<string, BaseEvent> {
177 return this._events;
178 }
179
180 setMessage(msg: Message | Interaction) {
181 this.msg = msg;
182 }
183
184 async handleCrash(error: Error, origin: NodeJS.UncaughtExceptionOrigin) {
185 console.log('here');
186 await appendFile(path.join(process.env.SUDO_PREFIX ?? (__dirname + "/../../"), "logs", "error.log"), `Uncaught ${error.name}: ${error.message}\n+ ${error.stack}`);
187 await this.debugLogger.logToHomeServer(`Uncaught ${error.name}: ${error.message}\n${error.stack}`);
188 }
189 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26