/[sudobot]/trunk/src/automod/Logger.ts
ViewVC logotype

Diff of /trunk/src/automod/Logger.ts

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

revision 338 by rakin, Mon Jul 29 17:29:37 2024 UTC revision 559 by rakin, Mon Jul 29 17:30:49 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 { roleMention } from '@discordjs/builders';  import { roleMention } from '@discordjs/builders';
21  import { formatDuration, intervalToDuration } from 'date-fns';  import { formatDuration, intervalToDuration } from 'date-fns';
22  import { BanOptions, CommandInteraction, FileOptions, Guild, GuildBan, GuildMember, Message, MessageEmbed, MessageOptions, MessagePayload, TextChannel, User } from 'discord.js';  import { BanOptions, CommandInteraction, FileOptions, Guild, GuildBan, GuildMember, Message, MessageEmbed, MessageOptions, MessagePayload, TextChannel, User } from 'discord.js';
23  import ms from 'ms';  import ms from 'ms';
24  import DiscordClient from '../client/Client';  import DiscordClient from '../client/Client';
25  import Punishment, { IPunishment } from '../models/Punishment';  import { IPunishment } from '../models/Punishment';
26  import { timeProcess, timeSince } from '../utils/util';  import { timeSince } from '../utils/util';
27    
28  class Logger {  class Logger {
29      client: DiscordClient;      client: DiscordClient;
30        pause = false;
31        pauseBan = false;
32    
33        pauseAll(p = true) {
34            this.pause = p;
35        }
36    
37      constructor(client: DiscordClient) {      constructor(client: DiscordClient) {
38          this.client = client;          this.client = client;
39      }      }
40    
41      channel(callback: (channel: TextChannel) => any, msg: any) {      channel(callback: (channel: TextChannel) => any, msg: any) {
42            if (this.pause) {
43                return;
44            }
45    
46          let channelID = this.client.config.props[msg.guild!.id].logging_channel;          let channelID = this.client.config.props[msg.guild!.id].logging_channel;
47          let channel = msg.guild!.channels.cache.find((c: any) => c.id === channelID) as TextChannel;          let channel = msg.guild!.channels.cache.find((c: any) => c.id === channelID) as TextChannel;
48    
# Line 116  class Logger { Line 145  class Logger {
145                  type: 'MEMBER_BAN_ADD',                  type: 'MEMBER_BAN_ADD',
146              })).entries.first();                        })).entries.first();          
147                
   
148              if (ban.reason) {              if (ban.reason) {
149                  r = ban.reason;                  r = ban.reason;
150              }              }
# Line 125  class Logger { Line 153  class Logger {
153                  const { target, reason } = await auditLog;                  const { target, reason } = await auditLog;
154    
155                  if (target!.id === ban.user.id && reason) {                  if (target!.id === ban.user.id && reason) {
156                      r = await reason;                      r = reason.replace(/^\[BAN\]/, '');
157                    }
158    
159                    if (auditLog.executor?.id === this.client.user!.id || (r.startsWith("[TEMPBAN]") || r.startsWith("[SOFTBAN]"))) {
160                        return;
161                  }                  }
162              }              }
163    
# Line 140  class Logger { Line 172  class Logger {
172                      })                      })
173                      .addField('Reason', r)                      .addField('Reason', r)
174                      .addField('User ID', ban.user.id)                      .addField('User ID', ban.user.id)
175                        .addFields({
176                            name: 'Banned by',
177                            value: auditLog?.executor ? `${auditLog.executor.tag} (${auditLog.executor.id})` : 'Unknown'
178                        })
179                      .setFooter({                      .setFooter({
180                          text: "Banned",                          text: "Banned",
181                      })                      })
# Line 166  class Logger { Line 202  class Logger {
202                  const { target, reason } = await auditLog;                  const { target, reason } = await auditLog;
203    
204                  if (target!.id === user.id && reason) {                  if (target!.id === user.id && reason) {
205                      r = await reason;                      r = reason.replace(/^\[SOFTBAN\]/, '');
206                  }                  }
207              }              }
208    
# Line 210  class Logger { Line 246  class Logger {
246                  const { target, reason } = await auditLog;                  const { target, reason } = await auditLog;
247    
248                  if (target!.id === user.id && reason) {                  if (target!.id === user.id && reason) {
249                      r = await reason;                      r = reason.replace(/^\[TEMPBAN\]/, '');
250                  }                  }
251              }              }
252    

Legend:
Removed from v.338  
changed lines
  Added in v.559

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26