如何只允许管理员执行命令 [英] How to allow only admins to execute a command

查看:23
本文介绍了如何只允许管理员执行命令的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在编写以下命令

@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.

这篇关于如何只允许管理员执行命令的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆