mirror of
https://gitlab.com/Kwoth/nadekobot.git
synced 2025-09-10 17:28:27 -04:00
1252 lines
48 KiB
C#
1252 lines
48 KiB
C#
using Microsoft.EntityFrameworkCore;
|
||
using Microsoft.Extensions.Caching.Memory;
|
||
using NadekoBot.Common.Collections;
|
||
using NadekoBot.Services.Database.Models;
|
||
using NadekoBot.Db;
|
||
using NadekoBot.Modules.Administration.Common;
|
||
|
||
namespace NadekoBot.Modules.Administration.Services;
|
||
|
||
public interface ILogCommandService
|
||
{
|
||
void AddDeleteIgnore(ulong xId);
|
||
Task LogServer(ulong guildId, ulong channelId, bool actionValue);
|
||
bool LogIgnore(ulong guildId, ulong itemId, IgnoredItemType itemType);
|
||
LogSetting GetGuildLogSettings(ulong guildId);
|
||
bool Log(ulong guildId, ulong? channelId, LogType type);
|
||
}
|
||
|
||
public sealed class DummyLogCommandService : ILogCommandService
|
||
{
|
||
public void AddDeleteIgnore(ulong xId)
|
||
{
|
||
}
|
||
|
||
public Task LogServer(ulong guildId, ulong channelId, bool actionValue)
|
||
{
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
public bool LogIgnore(ulong guildId, ulong itemId, IgnoredItemType itemType)
|
||
{
|
||
return false;
|
||
}
|
||
|
||
public LogSetting GetGuildLogSettings(ulong guildId)
|
||
{
|
||
return default;
|
||
}
|
||
|
||
public bool Log(ulong guildId, ulong? channelId, LogType type)
|
||
{
|
||
return false;
|
||
}
|
||
}
|
||
|
||
public sealed class LogCommandService : ILogCommandService
|
||
{
|
||
private readonly DiscordSocketClient _client;
|
||
|
||
public ConcurrentDictionary<ulong, LogSetting> GuildLogSettings { get; }
|
||
|
||
private ConcurrentDictionary<ITextChannel, List<string>> PresenceUpdates { get; } = new();
|
||
|
||
private readonly Timer _timerReference;
|
||
private readonly IBotStrings _strings;
|
||
private readonly DbService _db;
|
||
private readonly MuteService _mute;
|
||
private readonly ProtectionService _prot;
|
||
private readonly GuildTimezoneService _tz;
|
||
private readonly IEmbedBuilderService _eb;
|
||
private readonly IMemoryCache _memoryCache;
|
||
|
||
private readonly Timer _clearTimer;
|
||
private readonly ConcurrentHashSet<ulong> _ignoreMessageIds = new();
|
||
|
||
public LogCommandService(DiscordSocketClient client, IBotStrings strings,
|
||
DbService db, MuteService mute, ProtectionService prot, GuildTimezoneService tz,
|
||
IMemoryCache memoryCache, IEmbedBuilderService eb)
|
||
{
|
||
_client = client;
|
||
_memoryCache = memoryCache;
|
||
_eb = eb;
|
||
_strings = strings;
|
||
_db = db;
|
||
_mute = mute;
|
||
_prot = prot;
|
||
_tz = tz;
|
||
|
||
#if !GLOBAL_NADEKO
|
||
|
||
using (var uow = db.GetDbContext())
|
||
{
|
||
var guildIds = client.Guilds.Select(x => x.Id).ToList();
|
||
var configs = uow
|
||
.LogSettings
|
||
.AsQueryable()
|
||
.AsNoTracking()
|
||
.Where(x => guildIds.Contains(x.GuildId))
|
||
.Include(ls => ls.LogIgnores)
|
||
.ToList();
|
||
|
||
GuildLogSettings = configs
|
||
.ToDictionary(ls => ls.GuildId)
|
||
.ToConcurrent();
|
||
}
|
||
|
||
_timerReference = new(async state =>
|
||
{
|
||
var keys = PresenceUpdates.Keys.ToList();
|
||
|
||
await Task.WhenAll(keys.Select(key =>
|
||
{
|
||
if (!((SocketGuild) key.Guild).CurrentUser.GetPermissions(key).SendMessages)
|
||
return Task.CompletedTask;
|
||
if (PresenceUpdates.TryRemove(key, out var msgs))
|
||
{
|
||
var title = GetText(key.Guild, strs.presence_updates);
|
||
var desc = string.Join(Environment.NewLine, msgs);
|
||
return key.SendConfirmAsync(_eb, title, desc.TrimTo(2048));
|
||
}
|
||
|
||
return Task.CompletedTask;
|
||
})).ConfigureAwait(false);
|
||
}, null, TimeSpan.FromSeconds(15), TimeSpan.FromSeconds(15));
|
||
|
||
//_client.MessageReceived += _client_MessageReceived;
|
||
_client.MessageUpdated += _client_MessageUpdated;
|
||
_client.MessageDeleted += _client_MessageDeleted;
|
||
_client.UserBanned += _client_UserBanned;
|
||
_client.UserUnbanned += _client_UserUnbanned;
|
||
_client.UserJoined += _client_UserJoined;
|
||
_client.UserLeft += _client_UserLeft;
|
||
//_client.UserPresenceUpdated += _client_UserPresenceUpdated;
|
||
_client.UserVoiceStateUpdated += _client_UserVoiceStateUpdated;
|
||
_client.UserVoiceStateUpdated += _client_UserVoiceStateUpdated_TTS;
|
||
_client.GuildMemberUpdated += _client_GuildUserUpdated;
|
||
_client.UserUpdated += _client_UserUpdated;
|
||
_client.ChannelCreated += _client_ChannelCreated;
|
||
_client.ChannelDestroyed += _client_ChannelDestroyed;
|
||
_client.ChannelUpdated += _client_ChannelUpdated;
|
||
_client.RoleDeleted += _client_RoleDeleted;
|
||
|
||
_mute.UserMuted += MuteCommands_UserMuted;
|
||
_mute.UserUnmuted += MuteCommands_UserUnmuted;
|
||
|
||
_prot.OnAntiProtectionTriggered += TriggeredAntiProtection;
|
||
|
||
_clearTimer = new(_ =>
|
||
{
|
||
_ignoreMessageIds.Clear();
|
||
}, null, TimeSpan.FromHours(1), TimeSpan.FromHours(1));
|
||
|
||
#endif
|
||
}
|
||
|
||
public LogSetting GetGuildLogSettings(ulong guildId)
|
||
{
|
||
GuildLogSettings.TryGetValue(guildId, out var logSetting);
|
||
return logSetting;
|
||
}
|
||
|
||
public void AddDeleteIgnore(ulong messageId)
|
||
{
|
||
_ignoreMessageIds.Add(messageId);
|
||
}
|
||
|
||
public bool LogIgnore(ulong gid, ulong itemId, IgnoredItemType itemType)
|
||
{
|
||
var removed = 0;
|
||
using (var uow = _db.GetDbContext())
|
||
{
|
||
var logSetting = uow.LogSettingsFor(gid);
|
||
removed = logSetting.LogIgnores
|
||
.RemoveAll(x => x.ItemType == itemType && itemId == x.LogItemId);
|
||
|
||
if (removed == 0)
|
||
{
|
||
var toAdd = new IgnoredLogItem { LogItemId = itemId, ItemType = itemType};
|
||
logSetting.LogIgnores.Add(toAdd);
|
||
}
|
||
|
||
uow.SaveChanges();
|
||
GuildLogSettings.AddOrUpdate(gid, logSetting, (_, _) => logSetting);
|
||
}
|
||
|
||
return removed > 0;
|
||
}
|
||
|
||
private string GetText(IGuild guild, LocStr str) =>
|
||
_strings.GetText(str, guild.Id);
|
||
|
||
private string PrettyCurrentTime(IGuild g)
|
||
{
|
||
var time = DateTime.UtcNow;
|
||
if (g != null)
|
||
time = TimeZoneInfo.ConvertTime(time, _tz.GetTimeZoneOrUtc(g.Id));
|
||
return $"【{time:HH:mm:ss}】";
|
||
}
|
||
|
||
private string CurrentTime(IGuild g)
|
||
{
|
||
var time = DateTime.UtcNow;
|
||
if (g != null)
|
||
time = TimeZoneInfo.ConvertTime(time, _tz.GetTimeZoneOrUtc(g.Id));
|
||
|
||
return $"{time:HH:mm:ss}";
|
||
}
|
||
|
||
public async Task LogServer(ulong guildId, ulong channelId, bool value)
|
||
{
|
||
await using (var uow = _db.GetDbContext())
|
||
{
|
||
var logSetting = uow.LogSettingsFor(guildId);
|
||
|
||
logSetting.LogOtherId =
|
||
logSetting.MessageUpdatedId =
|
||
logSetting.MessageDeletedId =
|
||
logSetting.UserJoinedId =
|
||
logSetting.UserLeftId =
|
||
logSetting.UserBannedId =
|
||
logSetting.UserUnbannedId =
|
||
logSetting.UserUpdatedId =
|
||
logSetting.ChannelCreatedId =
|
||
logSetting.ChannelDestroyedId =
|
||
logSetting.ChannelUpdatedId =
|
||
logSetting.LogUserPresenceId =
|
||
logSetting.LogVoicePresenceId =
|
||
logSetting.UserMutedId =
|
||
logSetting.LogVoicePresenceTTSId =
|
||
value ? channelId : null;
|
||
;
|
||
await uow.SaveChangesAsync();
|
||
GuildLogSettings.AddOrUpdate(guildId, id => logSetting, (id, old) => logSetting);
|
||
}
|
||
}
|
||
|
||
private Task _client_UserUpdated(SocketUser before, SocketUser uAfter)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (uAfter is not SocketGuildUser after)
|
||
return;
|
||
|
||
var g = after.Guild;
|
||
|
||
if (!GuildLogSettings.TryGetValue(g.Id, out var logSetting)
|
||
|| logSetting.UserUpdatedId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel =
|
||
await TryGetLogChannel(g, logSetting, LogType.UserUpdated).ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var embed = _eb.Create();
|
||
|
||
if (before.Username != after.Username)
|
||
{
|
||
embed.WithTitle("👥 " + GetText(g, strs.username_changed))
|
||
.WithDescription($"{before.Username}#{before.Discriminator} | {before.Id}")
|
||
.AddField("Old Name", $"{before.Username}", true)
|
||
.AddField("New Name", $"{after.Username}", true)
|
||
.WithFooter(CurrentTime(g))
|
||
.WithOkColor();
|
||
}
|
||
else if (before.AvatarId != after.AvatarId)
|
||
{
|
||
embed.WithTitle("👥" + GetText(g, strs.avatar_changed))
|
||
.WithDescription($"{before.Username}#{before.Discriminator} | {before.Id}")
|
||
.WithFooter(CurrentTime(g))
|
||
.WithOkColor();
|
||
|
||
var bav = before.RealAvatarUrl();
|
||
if (bav != null && bav.IsAbsoluteUri)
|
||
embed.WithThumbnailUrl(bav.ToString());
|
||
|
||
var aav = after.RealAvatarUrl();
|
||
if (aav != null && aav.IsAbsoluteUri)
|
||
embed.WithImageUrl(aav.ToString());
|
||
}
|
||
else
|
||
{
|
||
return;
|
||
}
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
public bool Log(ulong gid, ulong? cid, LogType type/*, string options*/)
|
||
{
|
||
ulong? channelId = null;
|
||
using (var uow = _db.GetDbContext())
|
||
{
|
||
var logSetting = uow.LogSettingsFor(gid);
|
||
GuildLogSettings.AddOrUpdate(gid, id => logSetting, (id, old) => logSetting);
|
||
switch (type)
|
||
{
|
||
case LogType.Other:
|
||
channelId = logSetting.LogOtherId = logSetting.LogOtherId is null ? cid : default;
|
||
break;
|
||
case LogType.MessageUpdated:
|
||
channelId = logSetting.MessageUpdatedId = logSetting.MessageUpdatedId is null ? cid : default;
|
||
break;
|
||
case LogType.MessageDeleted:
|
||
channelId = logSetting.MessageDeletedId = logSetting.MessageDeletedId is null ? cid : default;
|
||
//logSetting.DontLogBotMessageDeleted = (options == "nobot");
|
||
break;
|
||
case LogType.UserJoined:
|
||
channelId = logSetting.UserJoinedId = logSetting.UserJoinedId is null ? cid : default;
|
||
break;
|
||
case LogType.UserLeft:
|
||
channelId = logSetting.UserLeftId = logSetting.UserLeftId is null ? cid : default;
|
||
break;
|
||
case LogType.UserBanned:
|
||
channelId = logSetting.UserBannedId = logSetting.UserBannedId is null ? cid : default;
|
||
break;
|
||
case LogType.UserUnbanned:
|
||
channelId = logSetting.UserUnbannedId = logSetting.UserUnbannedId is null ? cid : default;
|
||
break;
|
||
case LogType.UserUpdated:
|
||
channelId = logSetting.UserUpdatedId = logSetting.UserUpdatedId is null ? cid : default;
|
||
break;
|
||
case LogType.UserMuted:
|
||
channelId = logSetting.UserMutedId = logSetting.UserMutedId is null ? cid : default;
|
||
break;
|
||
case LogType.ChannelCreated:
|
||
channelId = logSetting.ChannelCreatedId = logSetting.ChannelCreatedId is null ? cid : default;
|
||
break;
|
||
case LogType.ChannelDestroyed:
|
||
channelId = logSetting.ChannelDestroyedId =
|
||
logSetting.ChannelDestroyedId is null ? cid : default;
|
||
break;
|
||
case LogType.ChannelUpdated:
|
||
channelId = logSetting.ChannelUpdatedId = logSetting.ChannelUpdatedId is null ? cid : default;
|
||
break;
|
||
case LogType.UserPresence:
|
||
channelId = logSetting.LogUserPresenceId =
|
||
logSetting.LogUserPresenceId is null ? cid : default;
|
||
break;
|
||
case LogType.VoicePresence:
|
||
channelId = logSetting.LogVoicePresenceId =
|
||
logSetting.LogVoicePresenceId is null ? cid : default;
|
||
break;
|
||
case LogType.VoicePresenceTTS:
|
||
channelId = logSetting.LogVoicePresenceTTSId =
|
||
logSetting.LogVoicePresenceTTSId is null ? cid : default;
|
||
break;
|
||
}
|
||
|
||
uow.SaveChanges();
|
||
}
|
||
|
||
return channelId != null;
|
||
}
|
||
|
||
private Task _client_UserVoiceStateUpdated_TTS(SocketUser iusr, SocketVoiceState before, SocketVoiceState after)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (iusr is not IGuildUser usr)
|
||
return;
|
||
|
||
var beforeVch = before.VoiceChannel;
|
||
var afterVch = after.VoiceChannel;
|
||
|
||
if (beforeVch == afterVch)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(usr.Guild.Id, out var logSetting)
|
||
|| logSetting.LogVoicePresenceTTSId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(usr.Guild, logSetting, LogType.VoicePresenceTTS)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var str = string.Empty;
|
||
if (beforeVch?.Guild == afterVch?.Guild)
|
||
{
|
||
str = GetText(logChannel.Guild, strs.log_vc_moved(usr.Username, beforeVch?.Name, afterVch?.Name));
|
||
}
|
||
else if (beforeVch is null)
|
||
{
|
||
str = GetText(logChannel.Guild, strs.log_vc_joined(usr.Username, afterVch.Name));
|
||
}
|
||
else if (afterVch is null)
|
||
{
|
||
str = GetText(logChannel.Guild, strs.log_vc_left(usr.Username, beforeVch.Name));
|
||
}
|
||
|
||
var toDelete = await logChannel.SendMessageAsync(str, true).ConfigureAwait(false);
|
||
toDelete.DeleteAfter(5);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private void MuteCommands_UserMuted(IGuildUser usr, IUser mod, MuteType muteType, string reason)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(usr.Guild.Id, out var logSetting)
|
||
|| logSetting.UserMutedId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(usr.Guild, logSetting, LogType.UserMuted)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
var mutes = string.Empty;
|
||
var mutedLocalized = GetText(logChannel.Guild, strs.muted_sn);
|
||
switch (muteType)
|
||
{
|
||
case MuteType.Voice:
|
||
mutes = "🔇 " + GetText(logChannel.Guild, strs.xmuted_voice(mutedLocalized, mod.ToString()));
|
||
break;
|
||
case MuteType.Chat:
|
||
mutes = "🔇 " + GetText(logChannel.Guild, strs.xmuted_text(mutedLocalized, mod.ToString()));
|
||
break;
|
||
case MuteType.All:
|
||
mutes = "🔇 " + GetText(logChannel.Guild, strs.xmuted_text_and_voice(mutedLocalized,
|
||
mod.ToString()));
|
||
break;
|
||
}
|
||
|
||
var embed = _eb.Create().WithAuthor(mutes)
|
||
.WithTitle($"{usr.Username}#{usr.Discriminator} | {usr.Id}")
|
||
.WithFooter(CurrentTime(usr.Guild))
|
||
.WithOkColor();
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
}
|
||
|
||
private void MuteCommands_UserUnmuted(IGuildUser usr, IUser mod, MuteType muteType, string reason)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(usr.Guild.Id, out var logSetting)
|
||
|| logSetting.UserMutedId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(usr.Guild, logSetting, LogType.UserMuted)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var mutes = string.Empty;
|
||
var unmutedLocalized = GetText(logChannel.Guild, strs.unmuted_sn);
|
||
switch (muteType)
|
||
{
|
||
case MuteType.Voice:
|
||
mutes = "🔊 " + GetText(logChannel.Guild, strs.xmuted_voice(unmutedLocalized, mod.ToString()));
|
||
break;
|
||
case MuteType.Chat:
|
||
mutes = "🔊 " + GetText(logChannel.Guild, strs.xmuted_text(unmutedLocalized, mod.ToString()));
|
||
break;
|
||
case MuteType.All:
|
||
mutes = "🔊 " + GetText(logChannel.Guild, strs.xmuted_text_and_voice(unmutedLocalized,
|
||
mod.ToString()));
|
||
break;
|
||
}
|
||
|
||
var embed = _eb.Create().WithAuthor(mutes)
|
||
.WithTitle($"{usr.Username}#{usr.Discriminator} | {usr.Id}")
|
||
.WithFooter($"{CurrentTime(usr.Guild)}")
|
||
.WithOkColor();
|
||
|
||
if (!string.IsNullOrWhiteSpace(reason))
|
||
embed.WithDescription(reason);
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
}
|
||
|
||
public Task TriggeredAntiProtection(PunishmentAction action, ProtectionType protection,
|
||
params IGuildUser[] users)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (users.Length == 0)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(users.First().Guild.Id, out var logSetting)
|
||
|| logSetting.LogOtherId is null)
|
||
return;
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(users.First().Guild, logSetting, LogType.Other)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var punishment = string.Empty;
|
||
switch (action)
|
||
{
|
||
case PunishmentAction.Mute:
|
||
punishment = "🔇 " + GetText(logChannel.Guild, strs.muted_pl).ToUpperInvariant();
|
||
break;
|
||
case PunishmentAction.Kick:
|
||
punishment = "👢 " + GetText(logChannel.Guild, strs.kicked_pl).ToUpperInvariant();
|
||
break;
|
||
case PunishmentAction.Softban:
|
||
punishment = "☣ " + GetText(logChannel.Guild, strs.soft_banned_pl).ToUpperInvariant();
|
||
break;
|
||
case PunishmentAction.Ban:
|
||
punishment = "⛔️ " + GetText(logChannel.Guild, strs.banned_pl).ToUpperInvariant();
|
||
break;
|
||
case PunishmentAction.RemoveRoles:
|
||
punishment = "⛔️ " + GetText(logChannel.Guild, strs.remove_roles_pl).ToUpperInvariant();
|
||
break;
|
||
}
|
||
|
||
var embed = _eb.Create().WithAuthor($"🛡 Anti-{protection}")
|
||
.WithTitle(GetText(logChannel.Guild, strs.users) + " " + punishment)
|
||
.WithDescription(string.Join("\n", users.Select(u => u.ToString())))
|
||
.WithFooter(CurrentTime(logChannel.Guild))
|
||
.WithOkColor();
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private string GetRoleDeletedKey(ulong roleId)
|
||
=> $"role_deleted_{roleId}";
|
||
|
||
private Task _client_RoleDeleted(SocketRole socketRole)
|
||
{
|
||
Serilog.Log.Information("Role deleted {RoleId}", socketRole.Id);
|
||
_memoryCache.Set(GetRoleDeletedKey(socketRole.Id),
|
||
true,
|
||
TimeSpan.FromMinutes(5));
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private bool IsRoleDeleted(ulong roleId)
|
||
{
|
||
var isDeleted = _memoryCache.TryGetValue(GetRoleDeletedKey(roleId), out var _);
|
||
return isDeleted;
|
||
}
|
||
|
||
private Task _client_GuildUserUpdated(Cacheable<SocketGuildUser, ulong> optBefore, SocketGuildUser after)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
var before = await optBefore.GetOrDownloadAsync();
|
||
|
||
if (before is null)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(before.Guild.Id, out var logSetting)
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == after.Id && ilc.ItemType == IgnoredItemType.User))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if (logSetting.UserUpdatedId != null &&
|
||
(logChannel = await TryGetLogChannel(before.Guild, logSetting, LogType.UserUpdated)
|
||
.ConfigureAwait(false)) != null)
|
||
{
|
||
var embed = _eb.Create().WithOkColor()
|
||
.WithFooter(CurrentTime(before.Guild))
|
||
.WithTitle($"{before.Username}#{before.Discriminator} | {before.Id}");
|
||
if (before.Nickname != after.Nickname)
|
||
{
|
||
embed.WithAuthor("👥 " + GetText(logChannel.Guild, strs.nick_change))
|
||
.AddField(GetText(logChannel.Guild, strs.old_nick)
|
||
, $"{before.Nickname}#{before.Discriminator}")
|
||
.AddField(GetText(logChannel.Guild, strs.new_nick)
|
||
, $"{after.Nickname}#{after.Discriminator}");
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
else if (!before.Roles.SequenceEqual(after.Roles))
|
||
{
|
||
if (before.Roles.Count < after.Roles.Count)
|
||
{
|
||
var diffRoles = after.Roles.Where(r => !before.Roles.Contains(r)).Select(r => r.Name);
|
||
embed.WithAuthor("⚔ " + GetText(logChannel.Guild, strs.user_role_add))
|
||
.WithDescription(string.Join(", ", diffRoles).SanitizeMentions());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
else if (before.Roles.Count > after.Roles.Count)
|
||
{
|
||
await Task.Delay(1000);
|
||
var diffRoles = before.Roles
|
||
.Where(r => !after.Roles.Contains(r) && !IsRoleDeleted(r.Id))
|
||
.Select(r => r.Name)
|
||
.ToList();
|
||
|
||
if (diffRoles.Any())
|
||
{
|
||
embed.WithAuthor("⚔ " + GetText(logChannel.Guild, strs.user_role_rem))
|
||
.WithDescription(string.Join(", ", diffRoles).SanitizeMentions());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
logChannel = null;
|
||
if (!before.IsBot && logSetting.LogUserPresenceId != null && (logChannel =
|
||
await TryGetLogChannel(before.Guild, logSetting, LogType.UserPresence)
|
||
.ConfigureAwait(false)) != null)
|
||
{
|
||
if (before.Status != after.Status)
|
||
{
|
||
var str = "🎭" + Format.Code(PrettyCurrentTime(after.Guild)) +
|
||
GetText(logChannel.Guild, strs.user_status_change(
|
||
"👤" + Format.Bold(after.Username),
|
||
Format.Bold(after.Status.ToString())));
|
||
PresenceUpdates.AddOrUpdate(logChannel,
|
||
new List<string>() {str}, (id, list) =>
|
||
{
|
||
list.Add(str);
|
||
return list;
|
||
});
|
||
}
|
||
else if (before.Activities.FirstOrDefault()?.Name != after.Activities.FirstOrDefault()?.Name)
|
||
{
|
||
var str =
|
||
$"👾`{PrettyCurrentTime(after.Guild)}`👤__**{after.Username}**__ is now playing **{after.Activities.FirstOrDefault()?.Name ?? "-"}**.";
|
||
PresenceUpdates.AddOrUpdate(logChannel,
|
||
new List<string>() {str}, (id, list) =>
|
||
{
|
||
list.Add(str);
|
||
return list;
|
||
});
|
||
}
|
||
}
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_ChannelUpdated(IChannel cbefore, IChannel cafter)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (cbefore is not IGuildChannel before)
|
||
return;
|
||
|
||
var after = (IGuildChannel) cafter;
|
||
|
||
if (!GuildLogSettings.TryGetValue(before.Guild.Id, out var logSetting)
|
||
|| logSetting.ChannelUpdatedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == after.Id && ilc.ItemType == IgnoredItemType.Channel))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(before.Guild, logSetting, LogType.ChannelUpdated)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var embed = _eb.Create().WithOkColor()
|
||
.WithFooter(CurrentTime(before.Guild));
|
||
|
||
var beforeTextChannel = cbefore as ITextChannel;
|
||
var afterTextChannel = cafter as ITextChannel;
|
||
|
||
if (before.Name != after.Name)
|
||
{
|
||
embed.WithTitle("ℹ️ " + GetText(logChannel.Guild, strs.ch_name_change))
|
||
.WithDescription($"{after} | {after.Id}")
|
||
.AddField(GetText(logChannel.Guild, strs.ch_old_name), before.Name);
|
||
}
|
||
else if (beforeTextChannel?.Topic != afterTextChannel?.Topic)
|
||
{
|
||
embed.WithTitle("ℹ️ " + GetText(logChannel.Guild, strs.ch_topic_change))
|
||
.WithDescription($"{after} | {after.Id}")
|
||
.AddField(GetText(logChannel.Guild, strs.old_topic) , beforeTextChannel?.Topic ?? "-")
|
||
.AddField(GetText(logChannel.Guild, strs.new_topic), afterTextChannel?.Topic ?? "-");
|
||
}
|
||
else
|
||
return;
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_ChannelDestroyed(IChannel ich)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (ich is not IGuildChannel ch)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(ch.Guild.Id, out var logSetting)
|
||
|| logSetting.ChannelDestroyedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == ch.Id && ilc.ItemType == IgnoredItemType.Channel))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(ch.Guild, logSetting, LogType.ChannelDestroyed)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
string title;
|
||
if (ch is IVoiceChannel)
|
||
{
|
||
title = GetText(logChannel.Guild, strs.voice_chan_destroyed);
|
||
}
|
||
else
|
||
title = GetText(logChannel.Guild, strs.text_chan_destroyed);
|
||
|
||
await logChannel.EmbedAsync(_eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("🆕 " + title)
|
||
.WithDescription($"{ch.Name} | {ch.Id}")
|
||
.WithFooter(CurrentTime(ch.Guild))).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_ChannelCreated(IChannel ich)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (ich is not IGuildChannel ch)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(ch.Guild.Id, out var logSetting)
|
||
|| logSetting.ChannelCreatedId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(ch.Guild, logSetting, LogType.ChannelCreated)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
string title;
|
||
if (ch is IVoiceChannel)
|
||
{
|
||
title = GetText(logChannel.Guild, strs.voice_chan_created);
|
||
}
|
||
else
|
||
title = GetText(logChannel.Guild, strs.text_chan_created);
|
||
|
||
await logChannel.EmbedAsync(_eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("🆕 " + title)
|
||
.WithDescription($"{ch.Name} | {ch.Id}")
|
||
.WithFooter(CurrentTime(ch.Guild))).ConfigureAwait(false);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_UserVoiceStateUpdated(SocketUser iusr, SocketVoiceState before, SocketVoiceState after)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (iusr is not IGuildUser usr || usr.IsBot)
|
||
return;
|
||
|
||
var beforeVch = before.VoiceChannel;
|
||
var afterVch = after.VoiceChannel;
|
||
|
||
if (beforeVch == afterVch)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(usr.Guild.Id, out var logSetting)
|
||
|| logSetting.LogVoicePresenceId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == iusr.Id && ilc.ItemType == IgnoredItemType.User))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(usr.Guild, logSetting, LogType.VoicePresence)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
string str = null;
|
||
if (beforeVch?.Guild == afterVch?.Guild)
|
||
{
|
||
str = "🎙" + Format.Code(PrettyCurrentTime(usr.Guild)) + GetText(logChannel.Guild,
|
||
strs.user_vmoved(
|
||
"👤" + Format.Bold(usr.Username + "#" + usr.Discriminator),
|
||
Format.Bold(beforeVch?.Name ?? ""), Format.Bold(afterVch?.Name ?? "")));
|
||
}
|
||
else if (beforeVch is null)
|
||
{
|
||
str = "🎙" + Format.Code(PrettyCurrentTime(usr.Guild)) + GetText(logChannel.Guild,
|
||
strs.user_vjoined(
|
||
"👤" + Format.Bold(usr.Username + "#" + usr.Discriminator),
|
||
Format.Bold(afterVch.Name ?? "")));
|
||
}
|
||
else if (afterVch is null)
|
||
{
|
||
str = "🎙" + Format.Code(PrettyCurrentTime(usr.Guild)) + GetText(logChannel.Guild,
|
||
strs.user_vleft("👤" + Format.Bold(usr.Username + "#" + usr.Discriminator),
|
||
Format.Bold(beforeVch.Name ?? "")));
|
||
}
|
||
|
||
if (!string.IsNullOrWhiteSpace(str))
|
||
PresenceUpdates.AddOrUpdate(logChannel, new List<string>() {str}, (id, list) =>
|
||
{
|
||
list.Add(str);
|
||
return list;
|
||
});
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_UserLeft(SocketGuild guild, SocketUser usr)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(guild.Id, out var logSetting)
|
||
|| logSetting.UserLeftId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == usr.Id && ilc.ItemType == IgnoredItemType.User))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(guild, logSetting, LogType.UserLeft)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("❌ " + GetText(logChannel.Guild, strs.user_left))
|
||
.WithDescription(usr.ToString())
|
||
.AddField("Id", usr.Id.ToString())
|
||
.WithFooter(CurrentTime(guild));
|
||
|
||
if (Uri.IsWellFormedUriString(usr.GetAvatarUrl(), UriKind.Absolute))
|
||
embed.WithThumbnailUrl(usr.GetAvatarUrl());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_UserJoined(IGuildUser usr)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(usr.Guild.Id, out var logSetting)
|
||
|| logSetting.UserJoinedId is null)
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(usr.Guild, logSetting, LogType.UserJoined)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("✅ " + GetText(logChannel.Guild, strs.user_joined))
|
||
.WithDescription($"{usr.Mention} `{usr}`")
|
||
.AddField("Id", usr.Id.ToString())
|
||
.AddField(GetText(logChannel.Guild, strs.joined_server),
|
||
$"{usr.JoinedAt?.ToString("dd.MM.yyyy HH:mm" ?? "?")}",
|
||
true)
|
||
.AddField(GetText(logChannel.Guild, strs.joined_discord),
|
||
$"{usr.CreatedAt:dd.MM.yyyy HH:mm}",
|
||
true)
|
||
.WithFooter(CurrentTime(usr.Guild));
|
||
|
||
if (Uri.IsWellFormedUriString(usr.GetAvatarUrl(), UriKind.Absolute))
|
||
embed.WithThumbnailUrl(usr.GetAvatarUrl());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_UserUnbanned(IUser usr, IGuild guild)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(guild.Id, out var logSetting)
|
||
|| logSetting.UserUnbannedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == usr.Id && ilc.ItemType == IgnoredItemType.User))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(guild, logSetting, LogType.UserUnbanned)
|
||
.ConfigureAwait(false)) is null)
|
||
return;
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("♻️ " + GetText(logChannel.Guild, strs.user_unbanned))
|
||
.WithDescription(usr.ToString())
|
||
.AddField("Id", usr.Id.ToString())
|
||
.WithFooter(CurrentTime(guild));
|
||
|
||
if (Uri.IsWellFormedUriString(usr.GetAvatarUrl(), UriKind.Absolute))
|
||
embed.WithThumbnailUrl(usr.GetAvatarUrl());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_UserBanned(IUser usr, IGuild guild)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (!GuildLogSettings.TryGetValue(guild.Id, out var logSetting)
|
||
|| logSetting.UserBannedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == usr.Id && ilc.ItemType == IgnoredItemType.User))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel =
|
||
await TryGetLogChannel(guild, logSetting, LogType.UserBanned).ConfigureAwait(false)) ==
|
||
null)
|
||
return;
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("🚫 " + GetText(logChannel.Guild, strs.user_banned))
|
||
.WithDescription(usr.ToString())
|
||
.AddField("Id", usr.Id.ToString())
|
||
.WithFooter(CurrentTime(guild));
|
||
|
||
var avatarUrl = usr.GetAvatarUrl();
|
||
|
||
if (Uri.IsWellFormedUriString(avatarUrl, UriKind.Absolute))
|
||
embed.WithThumbnailUrl(usr.GetAvatarUrl());
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_MessageDeleted(Cacheable<IMessage, ulong> optMsg, Cacheable<IMessageChannel, ulong> optCh)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
var msg = optMsg.Value as IUserMessage;
|
||
if (msg is null || msg.IsAuthor(_client))
|
||
return;
|
||
|
||
if (_ignoreMessageIds.Contains(msg.Id))
|
||
return;
|
||
|
||
var ch = optCh.Value;
|
||
if (ch is not ITextChannel channel)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(channel.Guild.Id, out var logSetting)
|
||
|| logSetting.MessageDeletedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == channel.Id && ilc.ItemType == IgnoredItemType.Channel))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(channel.Guild, logSetting, LogType.MessageDeleted)
|
||
.ConfigureAwait(false)) is null || logChannel.Id == msg.Id)
|
||
return;
|
||
|
||
var resolvedMessage = msg.Resolve(userHandling: TagHandling.FullName);
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("🗑 " + GetText(logChannel.Guild, strs.msg_del(((ITextChannel) msg.Channel).Name)))
|
||
.WithDescription(msg.Author.ToString())
|
||
.AddField(GetText(logChannel.Guild, strs.content),
|
||
string.IsNullOrWhiteSpace(resolvedMessage) ? "-" : resolvedMessage,
|
||
false)
|
||
.AddField("Id", msg.Id.ToString(), false)
|
||
.WithFooter(CurrentTime(channel.Guild));
|
||
if (msg.Attachments.Any())
|
||
embed.AddField(GetText(logChannel.Guild, strs.attachments),
|
||
string.Join(", ", msg.Attachments.Select(a => a.Url)),
|
||
false);
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private Task _client_MessageUpdated(Cacheable<IMessage, ulong> optmsg, SocketMessage imsg2,
|
||
ISocketMessageChannel ch)
|
||
{
|
||
var _ = Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
if (imsg2 is not IUserMessage after || after.IsAuthor(_client))
|
||
return;
|
||
|
||
var before = (optmsg.HasValue ? optmsg.Value : null) as IUserMessage;
|
||
if (before is null)
|
||
return;
|
||
|
||
if (ch is not ITextChannel channel)
|
||
return;
|
||
|
||
if (before.Content == after.Content)
|
||
return;
|
||
|
||
if (before.Author.IsBot)
|
||
return;
|
||
|
||
if (!GuildLogSettings.TryGetValue(channel.Guild.Id, out var logSetting)
|
||
|| logSetting.MessageUpdatedId is null
|
||
|| logSetting.LogIgnores.Any(ilc => ilc.LogItemId == channel.Id && ilc.ItemType == IgnoredItemType.Channel))
|
||
return;
|
||
|
||
ITextChannel logChannel;
|
||
if ((logChannel = await TryGetLogChannel(channel.Guild, logSetting, LogType.MessageUpdated)
|
||
.ConfigureAwait(false)) is null || logChannel.Id == after.Channel.Id)
|
||
return;
|
||
|
||
var embed = _eb.Create()
|
||
.WithOkColor()
|
||
.WithTitle("📝 " + GetText(logChannel.Guild, strs.msg_update(((ITextChannel)after.Channel).Name)))
|
||
.WithDescription(after.Author.ToString())
|
||
.AddField(GetText(logChannel.Guild, strs.old_msg),
|
||
string.IsNullOrWhiteSpace(before.Content)
|
||
? "-"
|
||
: before.Resolve(userHandling: TagHandling.FullName),
|
||
false)
|
||
.AddField(
|
||
GetText(logChannel.Guild, strs.new_msg),
|
||
string.IsNullOrWhiteSpace(after.Content)
|
||
? "-"
|
||
: after.Resolve(userHandling: TagHandling.FullName),
|
||
false)
|
||
.AddField("Id", after.Id.ToString(), false)
|
||
.WithFooter(CurrentTime(channel.Guild));
|
||
|
||
await logChannel.EmbedAsync(embed).ConfigureAwait(false);
|
||
}
|
||
catch
|
||
{
|
||
// ignored
|
||
}
|
||
});
|
||
return Task.CompletedTask;
|
||
}
|
||
|
||
private async Task<ITextChannel> TryGetLogChannel(IGuild guild, LogSetting logSetting, LogType logChannelType)
|
||
{
|
||
ulong? id = null;
|
||
switch (logChannelType)
|
||
{
|
||
case LogType.Other:
|
||
id = logSetting.LogOtherId;
|
||
break;
|
||
case LogType.MessageUpdated:
|
||
id = logSetting.MessageUpdatedId;
|
||
break;
|
||
case LogType.MessageDeleted:
|
||
id = logSetting.MessageDeletedId;
|
||
break;
|
||
case LogType.UserJoined:
|
||
id = logSetting.UserJoinedId;
|
||
break;
|
||
case LogType.UserLeft:
|
||
id = logSetting.UserLeftId;
|
||
break;
|
||
case LogType.UserBanned:
|
||
id = logSetting.UserBannedId;
|
||
break;
|
||
case LogType.UserUnbanned:
|
||
id = logSetting.UserUnbannedId;
|
||
break;
|
||
case LogType.UserUpdated:
|
||
id = logSetting.UserUpdatedId;
|
||
break;
|
||
case LogType.ChannelCreated:
|
||
id = logSetting.ChannelCreatedId;
|
||
break;
|
||
case LogType.ChannelDestroyed:
|
||
id = logSetting.ChannelDestroyedId;
|
||
break;
|
||
case LogType.ChannelUpdated:
|
||
id = logSetting.ChannelUpdatedId;
|
||
break;
|
||
case LogType.UserPresence:
|
||
id = logSetting.LogUserPresenceId;
|
||
break;
|
||
case LogType.VoicePresence:
|
||
id = logSetting.LogVoicePresenceId;
|
||
break;
|
||
case LogType.VoicePresenceTTS:
|
||
id = logSetting.LogVoicePresenceTTSId;
|
||
break;
|
||
case LogType.UserMuted:
|
||
id = logSetting.UserMutedId;
|
||
break;
|
||
}
|
||
|
||
if (!id.HasValue || id == 0)
|
||
{
|
||
UnsetLogSetting(guild.Id, logChannelType);
|
||
return null;
|
||
}
|
||
|
||
var channel = await guild.GetTextChannelAsync(id.Value).ConfigureAwait(false);
|
||
|
||
if (channel is null)
|
||
{
|
||
UnsetLogSetting(guild.Id, logChannelType);
|
||
return null;
|
||
}
|
||
else
|
||
return channel;
|
||
}
|
||
|
||
private void UnsetLogSetting(ulong guildId, LogType logChannelType)
|
||
{
|
||
using (var uow = _db.GetDbContext())
|
||
{
|
||
var newLogSetting = uow.LogSettingsFor(guildId);
|
||
switch (logChannelType)
|
||
{
|
||
case LogType.Other:
|
||
newLogSetting.LogOtherId = null;
|
||
break;
|
||
case LogType.MessageUpdated:
|
||
newLogSetting.MessageUpdatedId = null;
|
||
break;
|
||
case LogType.MessageDeleted:
|
||
newLogSetting.MessageDeletedId = null;
|
||
break;
|
||
case LogType.UserJoined:
|
||
newLogSetting.UserJoinedId = null;
|
||
break;
|
||
case LogType.UserLeft:
|
||
newLogSetting.UserLeftId = null;
|
||
break;
|
||
case LogType.UserBanned:
|
||
newLogSetting.UserBannedId = null;
|
||
break;
|
||
case LogType.UserUnbanned:
|
||
newLogSetting.UserUnbannedId = null;
|
||
break;
|
||
case LogType.UserUpdated:
|
||
newLogSetting.UserUpdatedId = null;
|
||
break;
|
||
case LogType.UserMuted:
|
||
newLogSetting.UserMutedId = null;
|
||
break;
|
||
case LogType.ChannelCreated:
|
||
newLogSetting.ChannelCreatedId = null;
|
||
break;
|
||
case LogType.ChannelDestroyed:
|
||
newLogSetting.ChannelDestroyedId = null;
|
||
break;
|
||
case LogType.ChannelUpdated:
|
||
newLogSetting.ChannelUpdatedId = null;
|
||
break;
|
||
case LogType.UserPresence:
|
||
newLogSetting.LogUserPresenceId = null;
|
||
break;
|
||
case LogType.VoicePresence:
|
||
newLogSetting.LogVoicePresenceId = null;
|
||
break;
|
||
case LogType.VoicePresenceTTS:
|
||
newLogSetting.LogVoicePresenceTTSId = null;
|
||
break;
|
||
}
|
||
|
||
GuildLogSettings.AddOrUpdate(guildId, newLogSetting, (gid, old) => newLogSetting);
|
||
uow.SaveChanges();
|
||
}
|
||
}
|
||
} |