问题描述
我正在编写以下命令
@bot.command(pass_context=True) async def *****s_only_command(ctx, *, args): '''do stuff
我怎样才能将此命令限制为仅限管理员?我尝试查看 ctx.author.roles.role 并显示 @everyone.如何检查给定用户是否为 *****?
how can i restrict this command to *****s only? I tried looking at ctx.author.roles.role and it says @everyone. How can i check if the given user is an ***** 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 *****s_only_command(ctx, *, args): '''do stuff'''
或通过使用 <代码>has_permissions
@bot.command(pass_context=True) @commands.has_permissions(*****istrator=True) async def *****s_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.