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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

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

Legend:
Removed from v.77  
changed lines
  Added in v.397

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26