nonebot2/docs/api/config.md

312 lines
3.9 KiB
Markdown
Raw Normal View History

2020-08-23 09:03:59 +00:00
---
contentSidebar: true
sidebarDepth: 0
---
2020-08-19 12:29:37 +00:00
# NoneBot.config 模块
2020-08-20 08:34:07 +00:00
## 配置
NoneBot 使用 [pydantic](https://pydantic-docs.helpmanual.io/) 以及 [python-dotenv](https://saurabh-kumar.com/python-dotenv/) 来读取配置。
2020-08-22 06:11:04 +00:00
配置项需符合特殊格式或 json 序列化格式。详情见 [pydantic Field Type](https://pydantic-docs.helpmanual.io/usage/types/) 文档。
2020-08-20 08:34:07 +00:00
2020-08-19 12:29:37 +00:00
2020-08-20 07:07:05 +00:00
## _class_ `Env`
2020-08-19 12:29:37 +00:00
2021-01-27 03:46:47 +00:00
基类:`nonebot.config.BaseConfig`
2020-08-19 12:29:37 +00:00
2020-08-20 07:07:05 +00:00
运行环境配置。大小写不敏感。
2020-08-19 12:29:37 +00:00
2020-08-20 07:07:05 +00:00
将会从 `nonebot.init 参数` > `环境变量` > `.env 环境配置文件` 的优先级读取配置。
2020-08-19 15:00:31 +00:00
2020-08-20 07:07:05 +00:00
### `environment`
2020-11-30 04:43:44 +00:00
* **类型**: `str`
2020-08-20 07:07:05 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `"prod"`
2020-08-20 07:07:05 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
当前环境名。 NoneBot 将从 `.env.{environment}` 文件中加载配置。
2020-08-20 07:07:05 +00:00
## _class_ `Config`
基类:`nonebot.config.BaseConfig`
NoneBot 主要配置。大小写不敏感。
2020-08-20 08:34:07 +00:00
除了 NoneBot 的配置项外,还可以自行添加配置项到 `.env.{environment}` 文件中。
这些配置将会在 json 反序列化后一起带入 `Config` 类中。
2020-08-20 07:07:05 +00:00
### `driver`
2020-11-30 04:43:44 +00:00
* **类型**: `str`
2020-08-20 07:07:05 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `"nonebot.drivers.fastapi"`
2020-08-20 07:07:05 +00:00
2020-08-19 15:00:31 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
NoneBot 运行所使用的 `Driver` 。继承自 `nonebot.driver.BaseDriver`
2020-08-19 15:00:31 +00:00
配置格式为 `<module>[:<class>]`,默认类名为 `Driver`
2020-08-20 07:07:05 +00:00
### `host`
2020-11-30 04:43:44 +00:00
* **类型**: `IPvAnyAddress`
2020-08-20 07:07:05 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `127.0.0.1`
2020-08-20 07:07:05 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
NoneBot 的 HTTP 和 WebSocket 服务端监听的 IP/主机名。
2020-08-20 07:07:05 +00:00
2020-08-19 12:29:37 +00:00
2020-08-20 07:07:05 +00:00
### `port`
2020-08-19 12:29:37 +00:00
2020-11-30 04:43:44 +00:00
* **类型**: `int`
2020-08-19 12:29:37 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `8080`
2020-08-19 12:29:37 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
NoneBot 的 HTTP 和 WebSocket 服务端监听的端口。
2020-08-19 12:29:37 +00:00
2020-08-20 07:07:05 +00:00
2020-08-20 08:34:07 +00:00
### `debug`
2020-11-30 04:43:44 +00:00
* **类型**: `bool`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `False`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
是否以调试模式运行 NoneBot。
2020-08-20 08:34:07 +00:00
### `log_level`
* **类型**: `Union[int, str]`
* **默认值**: `None`
* **说明**
配置 NoneBot 日志输出等级,可以为 `int` 类型等级或等级名称,参考 [loguru 日志等级](https://loguru.readthedocs.io/en/stable/api/logger.html#levels)。
* **示例**
```default
LOG_LEVEL=25
LOG_LEVEL=INFO
```
2020-08-20 08:34:07 +00:00
### `api_root`
2020-11-30 04:43:44 +00:00
* **类型**: `Dict[str, str]`
* **默认值**: `{}`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
以机器人 ID 为键,上报地址为值的字典,环境变量或文件中应使用 json 序列化。
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **示例**
2020-08-20 08:34:07 +00:00
2020-09-17 10:21:13 +00:00
```default
2020-08-20 08:34:07 +00:00
API_ROOT={"123456": "http://127.0.0.1:5700"}
```
### `api_timeout`
2020-11-30 04:43:44 +00:00
* **类型**: `Optional[float]`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `30.`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
API 请求超时时间,单位: 秒。
2020-08-20 08:34:07 +00:00
### `access_token`
2020-11-30 04:43:44 +00:00
* **类型**: `Optional[str]`
* **默认值**: `None`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
API 请求以及上报所需密钥,在请求头中携带。
2020-08-20 08:34:07 +00:00
2020-09-17 10:21:13 +00:00
2020-11-30 04:43:44 +00:00
* **示例**
2020-09-17 10:21:13 +00:00
```http
POST /cqhttp/ HTTP/1.1
Authorization: Bearer kSLuTF2GC2Q4q4ugm3
```
### `secret`
2020-11-30 04:43:44 +00:00
* **类型**: `Optional[str]`
* **默认值**: `None`
2020-09-17 10:21:13 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-09-17 10:21:13 +00:00
2020-11-30 04:43:44 +00:00
HTTP POST 形式上报所需签名,在请求头中携带。
2020-09-17 10:21:13 +00:00
2020-11-30 04:43:44 +00:00
* **示例**
2020-09-17 10:21:13 +00:00
```http
POST /cqhttp/ HTTP/1.1
X-Signature: sha1=f9ddd4863ace61e64f462d41ca311e3d2c1176e2
```
2020-08-20 08:34:07 +00:00
### `superusers`
2020-12-19 07:31:14 +00:00
* **类型**: `Set[str]`
2020-11-30 04:43:44 +00:00
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `set()`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
机器人超级用户。
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **示例**
2020-08-20 08:34:07 +00:00
2020-09-17 10:21:13 +00:00
```default
2021-01-05 15:08:58 +00:00
SUPERUSERS=["12345789"]
2020-08-20 08:34:07 +00:00
```
### `nickname`
2020-11-30 04:43:44 +00:00
* **类型**: `Set[str]`
* **默认值**: `set()`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
机器人昵称。
2020-08-20 08:34:07 +00:00
### `command_start`
2020-11-30 04:43:44 +00:00
* **类型**: `Set[str]`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `{"/"}`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
命令的起始标记,用于判断一条消息是不是命令。
2020-08-20 08:34:07 +00:00
### `command_sep`
2020-11-30 04:43:44 +00:00
* **类型**: `Set[str]`
* **默认值**: `{"."}`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
命令的分隔标记,用于将文本形式的命令切分为元组(实际的命令名)。
2020-08-20 08:34:07 +00:00
### `session_expire_timeout`
2020-11-30 04:43:44 +00:00
* **类型**: `timedelta`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **默认值**: `timedelta(minutes=2)`
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
* **说明**
2020-08-20 08:34:07 +00:00
2020-11-30 04:43:44 +00:00
等待用户回复的超时时间。
* **示例**
2020-08-20 08:34:07 +00:00
2020-09-17 10:21:13 +00:00
```default
2020-08-20 08:34:07 +00:00
SESSION_EXPIRE_TIMEOUT=120 # 单位: 秒
SESSION_EXPIRE_TIMEOUT=[DD ][HH:MM]SS[.ffffff]
SESSION_EXPIRE_TIMEOUT=P[DD]DT[HH]H[MM]M[SS]S # ISO 8601
```