如何只允许管理员执行命令

问题描述

我正在编写以下命令

@bot.command(pass_context=True)
async def admins_only_command(ctx, *, args):
    '''do stuff

我怎样才能将此命令限制为仅限管理员?我尝试查看 ctx.author.roles.role 并显示 @everyone.如何检查给定用户是否为 admin?

how can i restrict this command to admins only? I tried looking at ctx.author.roles.role and it says @everyone. How can i check if the given user is an admin or not?


解决方案

有两种方法:通过角色白名单使用 has_any_role

There are two ways: by a whitelist of roles using has_any_role

@bot.command(pass_context=True)
@commands.has_any_role("Big Cheese", "Medium Cheese")
async def admins_only_command(ctx, *, args):
    '''do stuff'''

或通过使用 <代码>has_permissions

@bot.command(pass_context=True)
@commands.has_permissions(administrator=True)
async def admins_only_command(ctx, *, args):
    '''do stuff'''

这两个装饰器都是 Checks,并且会引发 CommandError 的一些子类,如果它们失败,您可以选择处理.

Both of these decorators are Checks, and will raise some subclass of CommandError for you to optionally handle if they fail.

相关文章