using Autofac; using Myriad.Extensions; using Myriad.Types; using PluralKit.Core; namespace PluralKit.Bot; public static class ContextChecksExt { public static Context CheckGuildContext(this Context ctx) { if (ctx.Channel.GuildId != null) return ctx; throw new PKError("This command can not be run in a DM."); } public static Context CheckDMContext(this Context ctx) { if (ctx.Channel.GuildId == null) return ctx; throw new PKError("This command must be run in a DM."); } public static Context CheckSystemPrivacy(this Context ctx, SystemId target, PrivacyLevel level) { if (level.CanAccess(ctx.DirectLookupContextFor(target))) return ctx; throw Errors.LookupNotAllowed; } public static Context CheckOwnSystem(this Context ctx, PKSystem system) { if (system.Id != ctx.System?.Id) throw Errors.NotOwnSystemError; return ctx; } public static Context CheckOwnMember(this Context ctx, PKMember member) { if (member.System != ctx.System?.Id) throw Errors.NotOwnMemberError; return ctx; } public static Context CheckOwnGroup(this Context ctx, PKGroup group) { if (group.System != ctx.System?.Id) throw Errors.NotOwnGroupError; return ctx; } public static Context CheckSystem(this Context ctx) { if (ctx.System == null) throw Errors.NoSystemError; return ctx; } public static Context CheckSystem(this Context ctx, PKSystem system) { if (system == null) throw Errors.NoSystemError; return ctx; } public static Context CheckNoSystem(this Context ctx) { if (ctx.System != null) throw Errors.ExistingSystemError; return ctx; } public static async Task CheckAuthorPermission(this Context ctx, PermissionSet neededPerms, string permissionName) { if ((await ctx.UserPermissions & neededPerms) != neededPerms) throw new PKError( $"You must have the \"{permissionName}\" permission in this server to use this command."); return ctx; } public static async Task CheckPermissionsInGuildChannel(this Context ctx, Channel channel, PermissionSet neededPerms) { // this is a quick hack, should probably do it properly eventually var guild = await ctx.Cache.TryGetGuild(channel.GuildId.Value); if (guild == null) await ctx.Rest.GetGuild(channel.GuildId.Value); if (guild == null) return false; var guildMember = ctx.Member; if (ctx.Guild?.Id != channel.GuildId) { guildMember = await ctx.Rest.GetGuildMember(channel.GuildId.Value, ctx.Author.Id); if (guildMember == null) return false; } var userPermissions = PermissionExtensions.PermissionsFor(guild, channel, ctx.Author.Id, guildMember); if ((userPermissions & neededPerms) == 0) return false; return true; } public static bool CheckBotAdmin(this Context ctx) { var botConfig = ctx.Services.Resolve(); return botConfig.AdminRole != null && ctx.Member != null && ctx.Member.Roles.Contains(botConfig.AdminRole.Value); } public static Context AssertBotAdmin(this Context ctx) { if (!ctx.CheckBotAdmin()) throw new PKError("This command is only usable by bot admins."); return ctx; } }