/[sudobot]/branches/4.x/src/services/DebugLogger.ts
ViewVC logotype

Contents of /branches/4.x/src/services/DebugLogger.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 3510 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
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 { format } from "date-fns";
21 import { MessageEmbed, WebhookClient } from "discord.js";
22 import { appendFile } from "fs/promises";
23 import path from "path";
24 import Service from "../utils/structures/Service";
25 import { splitMessage } from "../utils/util";
26
27 export enum LogLevel {
28 LOG = 'LOG',
29 INFO = 'INFO',
30 WARN = 'WARN',
31 CRITICAL = 'CRITICAL',
32 ERROR = 'ERROR'
33 }
34
35 export default class DebugLogger extends Service {
36 private joinLeaveLogFile = path.join(process.env.SUDO_PREFIX ?? (__dirname + '/../../'), 'logs/join-leave.log');
37 private appLogFile = path.join(process.env.SUDO_PREFIX ?? (__dirname + '/../../'), 'logs/app.log');
38 private debugLogFile = path.join(process.env.SUDO_PREFIX ?? (__dirname + '/../../'), 'logs/debug.log');
39
40 async logApp(level: LogLevel, message: string) {
41 await this.log(this.appLogFile, level, message);
42 }
43
44 async logLeaveJoin(level: LogLevel, message: string) {
45 await this.log(this.joinLeaveLogFile, level, message);
46 }
47
48 async log(stream: string, level: LogLevel, message: string) {
49 await appendFile(stream, `[${new Date().toISOString()}] [${level}] ${message}\n`);
50 }
51
52 async logDebug(message: string, newLine = false) {
53 await appendFile(this.debugLogFile, `${newLine ? '\n' : ''}[${format(new Date(), "yyyy-MM-dd'T'HH:mm:ss.SSSxxx")}] ${message}\n`);
54 }
55
56 async logToHomeServer(message: string, logLevel: LogLevel = LogLevel.ERROR) {
57 if (!process.env.DEBUG_WEKHOOK_URL)
58 return;
59
60 const webhookClient = new WebhookClient({ url: process.env.DEBUG_WEKHOOK_URL! });
61 const splitted = splitMessage(message);
62 const embed = new MessageEmbed({
63 color: logLevel === LogLevel.WARN ? 'GOLD' : 0xf14a60,
64 title: logLevel === LogLevel.WARN ? 'Core Warning' : 'Fatal Error',
65 description: splitted.shift(),
66 });
67
68 if (splitted.length === 0) {
69 embed.setTimestamp();
70 }
71
72 try {
73 await webhookClient.send({
74 embeds: [
75 embed
76 ]
77 });
78
79 for (const index in splitted) {
80 const embed = new MessageEmbed({
81 color: logLevel === LogLevel.WARN ? 'GOLD' : 0xf14a60,
82 description: splitted[index],
83 });
84
85 if (parseInt(index) === (splitted.length - 1)) {
86 embed.setTimestamp();
87 }
88
89 await webhookClient.send({
90 embeds: [
91 embed
92 ]
93 });
94 }
95
96 await webhookClient.destroy();
97 }
98 catch (e) {
99 console.log(e);
100 }
101 }
102 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26