nonebot2/website/docs/api/permission.md

139 lines
2.2 KiB
Markdown
Raw Normal View History

2020-09-14 20:48:03 +08:00
# NoneBot.permission 模块
## 权限
2021-11-21 16:13:56 +08:00
每个 `Matcher` 拥有一个 `Permission` ,其中是 `PermissionChecker` 的集合,只要有一个 `PermissionChecker` 检查结果为 `True` 时就会继续运行。
2020-09-14 20:48:03 +08:00
:::tip 提示
`PermissionChecker` 既可以是 async function 也可以是 sync function
:::
2021-05-30 11:07:27 +08:00
## _class_ `Permission`
基类:`object`
* **说明**
`Matcher` 规则类,当事件传递时,在 `Matcher` 运行前进行检查。
* **示例**
```python
Permission(async_function) | sync_function
# 等价于
from nonebot.utils import run_sync
Permission(async_function, run_sync(sync_function))
```
2021-11-21 16:13:56 +08:00
### `__init__(*checkers)`
2021-05-30 11:07:27 +08:00
* **参数**
2021-11-21 15:48:02 +08:00
* `*checkers: Union[T_PermissionChecker, Handler]`: PermissionChecker
2021-05-30 11:07:27 +08:00
### `checkers`
* **说明**
存储 `PermissionChecker`
* **类型**
2021-11-21 12:37:46 +08:00
* `Set[Handler]`
2021-05-30 11:07:27 +08:00
2021-11-21 12:37:46 +08:00
### _async_ `__call__(bot, event, stack=None, dependency_cache=None)`
2021-05-30 11:07:27 +08:00
* **说明**
检查是否满足某个权限
* **参数**
* `bot: Bot`: Bot 对象
* `event: Event`: Event 对象
2021-11-21 12:37:46 +08:00
* `stack: Optional[AsyncExitStack]`: 异步上下文栈
* `dependency_cache: Optional[Dict[Callable[..., Any], Any]]`: 依赖缓存
2021-05-30 11:07:27 +08:00
* **返回**
* `bool`
2020-09-14 20:48:03 +08:00
## `MESSAGE`
* **说明**: 匹配任意 `message` 类型事件,仅在需要同时捕获不同类型事件时使用。优先使用 message type 的 Matcher。
## `NOTICE`
* **说明**: 匹配任意 `notice` 类型事件,仅在需要同时捕获不同类型事件时使用。优先使用 notice type 的 Matcher。
## `REQUEST`
* **说明**: 匹配任意 `request` 类型事件,仅在需要同时捕获不同类型事件时使用。优先使用 request type 的 Matcher。
## `METAEVENT`
* **说明**: 匹配任意 `meta_event` 类型事件,仅在需要同时捕获不同类型事件时使用。优先使用 meta_event type 的 Matcher。
## `USER(*user, perm=None)`
2020-09-14 20:48:03 +08:00
* **说明**
`event``session_id` 在白名单内且满足 perm
2020-09-14 20:48:03 +08:00
* **参数**
2020-12-13 12:53:33 +08:00
* `*user: str`: 白名单
2020-09-14 20:48:03 +08:00
* `perm: Optional[Permission]`: 需要同时满足的权限
2020-09-14 20:48:03 +08:00
## `SUPERUSER`
* **说明**: 匹配任意超级用户消息类型事件