/[sudobot]/trunk/src/events/debug/DebugEvent.ts
ViewVC logotype

Diff of /trunk/src/events/debug/DebugEvent.ts

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

revision 293 by rakin, Mon Jul 29 17:29:24 2024 UTC revision 393 by rakin, Mon Jul 29 17:29:59 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 { exec } from "child_process";  import { exec } from "child_process";
21  import { format } from "date-fns";  import { format } from "date-fns";
22  import { appendFile } from "fs/promises";  import { appendFile } from "fs/promises";
23  import path from "path";  import path from "path";
 import { exit } from "process";  
24  import DiscordClient from "../../client/Client";  import DiscordClient from "../../client/Client";
25    import { LogLevel } from "../../services/DebugLogger";
26  import BaseEvent from "../../utils/structures/BaseEvent";  import BaseEvent from "../../utils/structures/BaseEvent";
27    
28  export default class DebugEvent extends BaseEvent {  export default class DebugEvent extends BaseEvent {
29      logFile: string = path.resolve(__dirname, "..", "..", "..", "logs", 'debug.log');      logFile: string = path.join(process.env.SUDO_PREFIX ?? (__dirname + "/../../../"), "logs", 'debug.log');
30    
31      constructor() {      constructor() {
32          super("debug");          super("debug");
# Line 23  export default class DebugEvent extends Line 42  export default class DebugEvent extends
42          console.log("DEBUG: ", e);          console.log("DEBUG: ", e);
43          await appendFile(this.logFile, `[${format(new Date(), "yyyy-MM-dd'T'HH:mm:ss.SSSxxx")}] [LOG] ${e}\n`);          await appendFile(this.logFile, `[${format(new Date(), "yyyy-MM-dd'T'HH:mm:ss.SSSxxx")}] [LOG] ${e}\n`);
44    
45          if (process.env.PLATFORM === 'replit' && e.includes("Hit a 429 while executing a request") && !client.isReady()) {          if (process.env.PLATFORM === 'replit' && e.includes("Hit a 429") && !client.isReady()) {
46                console.log("DEBUG: ", "Restart Required");
47                await appendFile(this.logFile, `[${format(new Date(), "yyyy-MM-dd'T'HH:mm:ss.SSSxxx")}] [LOG] ${e}\n`);
48                await appendFile(this.logFile, `[${format(new Date(), "yyyy-MM-dd'T'HH:mm:ss.SSSxxx")}] [FATAL] Restart Required\n`);
49                await client.debugLogger.logToHomeServer("Discord Ratelimit [429]: System restart required.\nAutomated restart is in progress.", LogLevel.WARN);
50    
51              exec("kill 1");              exec("kill 1");
52              return;              return;
53          }          }

Legend:
Removed from v.293  
changed lines
  Added in v.393

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26