forked from RPCS3/discord-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUsernameValidationMonitor.cs
97 lines (85 loc) · 3.88 KB
/
UsernameValidationMonitor.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
using System;
using System.Linq;
using System.Threading.Tasks;
using CompatBot.Commands;
using CompatBot.Database;
using CompatBot.Utils;
using DSharpPlus;
using DSharpPlus.Entities;
using DSharpPlus.EventArgs;
using Microsoft.EntityFrameworkCore;
namespace CompatBot.EventHandlers;
public static class UsernameValidationMonitor
{
public static Task OnMemberUpdated(DiscordClient _, GuildMemberUpdateEventArgs args) => UpdateDisplayName(args.Guild, args.Member);
public static Task OnMemberAdded(DiscordClient _, GuildMemberAddEventArgs args) => UpdateDisplayName(args.Guild, args.Member);
private static async Task UpdateDisplayName(DiscordGuild guild, DiscordMember guildMember)
{
try
{
if (guildMember.IsWhitelisted())
return;
if (guild.Permissions?.HasFlag(Permissions.ChangeNickname) is false)
return;
await using var db = new BotDb();
var forcedNickname = await db.ForcedNicknames.AsNoTracking().FirstOrDefaultAsync(x => x.UserId == guildMember.Id && x.GuildId == guildMember.Guild.Id).ConfigureAwait(false);
if (forcedNickname is null)
return;
if (guildMember.DisplayName == forcedNickname.Nickname)
return;
Config.Log.Debug($"Expected nickname {forcedNickname.Nickname}, but was {guildMember.Nickname}. Renaming...");
await guildMember.ModifyAsync(mem => mem.Nickname = forcedNickname.Nickname).ConfigureAwait(false);
Config.Log.Info($"Enforced nickname {forcedNickname.Nickname} for user {guildMember.Id} ({guildMember.Username}#{guildMember.Discriminator})");
}
catch (Exception e)
{
Config.Log.Error(e);
}
}
public static async Task MonitorAsync(DiscordClient client, bool once = false)
{
do
{
if (!once)
await Task.Delay(Config.ForcedNicknamesRecheckTimeInHours, Config.Cts.Token).ConfigureAwait(false);
if (!await Moderation.Audit.CheckLock.WaitAsync(0).ConfigureAwait(false))
continue;
try
{
foreach (var guild in client.Guilds.Values)
try
{
if (guild.Permissions?.HasFlag(Permissions.ChangeNickname) is false)
continue;
await using var db = new BotDb();
var forcedNicknames = await db.ForcedNicknames
.Where(mem => mem.GuildId == guild.Id)
.ToListAsync()
.ConfigureAwait(false);
if (forcedNicknames.Count == 0)
continue;
foreach (var forced in forcedNicknames)
{
var member = await client.GetMemberAsync(guild, forced.UserId).ConfigureAwait(false);
if (member is null || member.DisplayName == forced.Nickname)
continue;
try
{
await member.ModifyAsync(mem => mem.Nickname = forced.Nickname).ConfigureAwait(false);
Config.Log.Info($"Enforced nickname {forced.Nickname} for user {member.Id} ({member.Username}#{member.Discriminator})");
}
catch { }
}
}
catch (Exception e)
{
Config.Log.Error(e);
}
}
finally
{
Moderation.Audit.CheckLock.Release();
}
} while (!Config.Cts.IsCancellationRequested && !once);
}
}