mirror of
https://gitlab.com/Kwoth/nadekobot.git
synced 2025-09-10 17:28:27 -04:00
132 lines
5.0 KiB
C#
132 lines
5.0 KiB
C#
using Discord;
|
|
using Discord.Commands;
|
|
using NadekoBot.Common;
|
|
using NadekoBot.Common.Attributes;
|
|
using NadekoBot.Common.TypeReaders.Models;
|
|
using NadekoBot.Services.Database.Models;
|
|
using NadekoBot.Extensions;
|
|
using NadekoBot.Modules.Administration.Services;
|
|
using System;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace NadekoBot.Modules.Administration
|
|
{
|
|
public partial class Administration
|
|
{
|
|
[Group]
|
|
[NoPublicBot]
|
|
public class LogCommands : NadekoSubmodule<ILogCommandService>
|
|
{
|
|
public enum EnableDisable
|
|
{
|
|
Enable,
|
|
Disable
|
|
}
|
|
|
|
[NadekoCommand, Aliases]
|
|
[RequireContext(ContextType.Guild)]
|
|
[UserPerm(GuildPerm.Administrator)]
|
|
[OwnerOnly]
|
|
public async Task LogServer(PermissionAction action)
|
|
{
|
|
await _service.LogServer(ctx.Guild.Id, ctx.Channel.Id, action.Value).ConfigureAwait(false);
|
|
if (action.Value)
|
|
await ReplyConfirmLocalizedAsync(strs.log_all).ConfigureAwait(false);
|
|
else
|
|
await ReplyConfirmLocalizedAsync(strs.log_disabled).ConfigureAwait(false);
|
|
}
|
|
|
|
[NadekoCommand, Aliases]
|
|
[RequireContext(ContextType.Guild)]
|
|
[UserPerm(GuildPerm.Administrator)]
|
|
[OwnerOnly]
|
|
public async Task LogIgnore()
|
|
{
|
|
var channel = (ITextChannel)ctx.Channel;
|
|
|
|
var removed = _service.LogIgnore(ctx.Guild.Id, ctx.Channel.Id);
|
|
|
|
if (!removed)
|
|
await ReplyConfirmLocalizedAsync(strs.log_ignore(Format.Bold(channel.Mention + "(" + channel.Id + ")"))).ConfigureAwait(false);
|
|
else
|
|
await ReplyConfirmLocalizedAsync(strs.log_not_ignore(Format.Bold(channel.Mention + "(" + channel.Id + ")"))).ConfigureAwait(false);
|
|
}
|
|
|
|
[NadekoCommand, Aliases]
|
|
[RequireContext(ContextType.Guild)]
|
|
[UserPerm(GuildPerm.Administrator)]
|
|
[OwnerOnly]
|
|
public async Task LogEvents()
|
|
{
|
|
var logSetting = _service.GetGuildLogSettings(ctx.Guild.Id);
|
|
var str = string.Join("\n", Enum.GetNames(typeof(LogType))
|
|
.Select(x =>
|
|
{
|
|
var val = logSetting is null ? null : GetLogProperty(logSetting, Enum.Parse<LogType>(x));
|
|
if (val != null)
|
|
return $"{Format.Bold(x)} <#{val}>";
|
|
return Format.Bold(x);
|
|
}));
|
|
|
|
await SendConfirmAsync(Format.Bold(GetText(strs.log_events)) + "\n" +
|
|
str)
|
|
.ConfigureAwait(false);
|
|
}
|
|
|
|
private static ulong? GetLogProperty(LogSetting l, LogType type)
|
|
{
|
|
switch (type)
|
|
{
|
|
case LogType.Other:
|
|
return l.LogOtherId;
|
|
case LogType.MessageUpdated:
|
|
return l.MessageUpdatedId;
|
|
case LogType.MessageDeleted:
|
|
return l.MessageDeletedId;
|
|
case LogType.UserJoined:
|
|
return l.UserJoinedId;
|
|
case LogType.UserLeft:
|
|
return l.UserLeftId;
|
|
case LogType.UserBanned:
|
|
return l.UserBannedId;
|
|
case LogType.UserUnbanned:
|
|
return l.UserUnbannedId;
|
|
case LogType.UserUpdated:
|
|
return l.UserUpdatedId;
|
|
case LogType.ChannelCreated:
|
|
return l.ChannelCreatedId;
|
|
case LogType.ChannelDestroyed:
|
|
return l.ChannelDestroyedId;
|
|
case LogType.ChannelUpdated:
|
|
return l.ChannelUpdatedId;
|
|
case LogType.UserPresence:
|
|
return l.LogUserPresenceId;
|
|
case LogType.VoicePresence:
|
|
return l.LogVoicePresenceId;
|
|
case LogType.VoicePresenceTTS:
|
|
return l.LogVoicePresenceTTSId;
|
|
case LogType.UserMuted:
|
|
return l.UserMutedId;
|
|
default:
|
|
return null;
|
|
}
|
|
}
|
|
|
|
[NadekoCommand, Aliases]
|
|
[RequireContext(ContextType.Guild)]
|
|
[UserPerm(GuildPerm.Administrator)]
|
|
[OwnerOnly]
|
|
public async Task Log(LogType type)
|
|
{
|
|
var val = _service.Log(ctx.Guild.Id, ctx.Channel.Id, type);
|
|
|
|
if (val)
|
|
await ReplyConfirmLocalizedAsync(strs.log(Format.Bold(type.ToString()))).ConfigureAwait(false);
|
|
else
|
|
await ReplyConfirmLocalizedAsync(strs.log_stop(Format.Bold(type.ToString()))).ConfigureAwait(false);
|
|
}
|
|
}
|
|
}
|
|
}
|