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 |
|
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 |
} |