1
0
mirror of https://gitlab.com/Deukhoofd/DeukBot4.git synced 2026-04-04 03:30:05 +00:00

Work on permission system, along with initial work on database(postgres) system

This commit is contained in:
2018-03-29 15:35:00 +02:00
parent 3a85a9f18f
commit 25d691c4e9
13 changed files with 337 additions and 15 deletions

View File

@@ -39,7 +39,7 @@ namespace DeukBot4.MessageHandlers.CommandHandler
public static async Task HandleMessage(SocketMessage message)
{
if (message.Content[0] != CommandTrigger) return;
var req = CommandRequest.Create(message);
var req = await CommandRequest.Create(message);
var resultCode = req.Item2;
if (resultCode == CommandRequest.RequestCode.Invalid)
{

View File

@@ -1,6 +1,7 @@
using System;
using System.Collections.Generic;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using DeukBot4.MessageHandlers.Permissions;
using Discord.WebSocket;
@@ -30,7 +31,7 @@ namespace DeukBot4.MessageHandlers.CommandHandler.RequestStructure
OK, Invalid, Forbidden
}
public static (CommandRequest, RequestCode) Create(SocketMessage message)
public static async Task<(CommandRequest, RequestCode)> Create(SocketMessage message)
{
var originalMessage = message;
var content = message.Content;
@@ -45,7 +46,16 @@ namespace DeukBot4.MessageHandlers.CommandHandler.RequestStructure
return (null, RequestCode.Invalid);
}
var permission = PermissionValidator.GetUserPermissionLevel(message);
PermissionLevel permission;
try
{
permission = await PermissionValidator.GetUserPermissionLevel(message);
}
catch (Exception e)
{
await Logger.LogError(e.Message);
return (null, RequestCode.Forbidden);
}
if (permission < command.Permission)
{
return (null, RequestCode.Forbidden);

View File

@@ -0,0 +1,100 @@
using System;
using System.Text;
using System.Threading.Tasks;
using DeukBot4.Database;
using DeukBot4.MessageHandlers.CommandHandler.RequestStructure;
using DeukBot4.MessageHandlers.Permissions;
using Discord;
namespace DeukBot4.MessageHandlers.CommandHandler
{
public class RolePermissionCommands : CommandContainerBase
{
public override string Name => "Role Related";
[Command("roles", PermissionLevel.Admin)]
[CommandHelp("Lists all roles on the server along with their IDs", "Lists all roles on the server along with their IDs")]
public async Task ListServerRoles(CommandRequest request)
{
var channel = request.OriginalMessage.Channel;
if (!(channel is IGuildChannel serverChannel))
return;
var roles = serverChannel.Guild.Roles;
var sb = new StringBuilder();
foreach (var role in roles)
{
sb.Append($"``{role.Name}`` --> {role.Id}\n");
}
await channel.SendMessageAsync(sb.ToString());
}
[Command("adminrole", PermissionLevel.ServerOwner)]
[CommandParameters(new []{ParameterMatcher.ParameterType.Number})]
public async Task SetAdminRole(CommandRequest request)
{
await SetRolePermission(request, PermissionLevel.Admin);
}
[Command("moderatorrole", PermissionLevel.ServerOwner)]
[CommandParameters(new []{ParameterMatcher.ParameterType.Number})]
public async Task SetModRole(CommandRequest request)
{
await SetRolePermission(request, PermissionLevel.Moderator);
}
[Command("helperrole", PermissionLevel.ServerOwner)]
[CommandParameters(new []{ParameterMatcher.ParameterType.Number})]
public async Task SetHelperRole(CommandRequest request)
{
await SetRolePermission(request, PermissionLevel.Helper);
}
[Command("bannedrole", PermissionLevel.ServerOwner)]
[CommandParameters(new []{ParameterMatcher.ParameterType.Number})]
public async Task SetBannedRole(CommandRequest request)
{
await SetRolePermission(request, PermissionLevel.Banned);
}
private static async Task SetRolePermission(CommandRequest request, PermissionLevel permissionLevel)
{
var channel = request.OriginalMessage.Channel;
if (!(channel is IGuildChannel serverChannel))
return;
if (request.Parameters.Length == 0)
{
await request.OriginalMessage.Channel.SendMessageAsync(
$"You did not give a valid role ID. Use ``!roles`` to list all current server roles, along with their ids");
return;
}
if (!ulong.TryParse(request.Parameters[0].AsString(), out var roleId))
{
await request.OriginalMessage.Channel.SendMessageAsync(
$"You did not give a valid role ID. Use ``!roles`` to list all current server roles, along with their ids");
return;
}
var role = serverChannel.Guild.GetRole(roleId);
if (role == null)
{
await request.OriginalMessage.Channel.SendMessageAsync("No role with that id exists on this server");
return;
}
try
{
await DatabaseRolePermissions.SetRolePermission(serverChannel.GuildId, roleId, permissionLevel);
PermissionValidator.UpdateCache(serverChannel.GuildId, roleId, permissionLevel);
}
catch(Exception e)
{
await Logger.LogError(e.Message);
}
}
}
}