/[sudobot]/branches/3.x/src/client/Client.ts
ViewVC logotype

Annotation of /branches/3.x/src/client/Client.ts

Parent Directory Parent Directory | Revision Log Revision Log


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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26