contentSidebar | sidebarDepth |
---|---|
true | 0 |
NoneBot.drivers 模块
后端驱动适配基类
各驱动请继承以下基类
class Driver
基类:abc.ABC
Driver 基类。
_adapters
-
类型
Dict[str, Type[Bot]]
-
说明
已注册的适配器列表
_bot_connection_hook
-
类型
Set[T_BotConnectionHook]
-
说明
Bot 连接建立时执行的函数
_bot_disconnection_hook
-
类型
Set[T_BotDisconnectionHook]
-
说明
Bot 连接断开时执行的函数
__init__(env, config)
-
参数
-
env: Env
: 包含环境信息的 Env 对象 -
config: Config
: 包含配置信息的 Config 对象
-
env
-
类型
str
-
说明
环境名称
config
-
类型
Config
-
说明
配置对象
_clients
-
类型
Dict[str, Bot]
-
说明
已连接的 Bot
property bots
-
类型
Dict[str, Bot]
-
说明
获取当前所有已连接的 Bot
register_adapter(name, adapter, **kwargs)
-
说明
注册一个协议适配器
-
参数
-
name: str
: 适配器名称,用于在连接时进行识别 -
adapter: Type[Bot]
: 适配器 Class -
**kwargs
: 其他传递给适配器的参数
-
abstract property type
驱动类型名称
abstract property logger
驱动专属 logger 日志记录器
abstract run(*args, **kwargs)
-
说明
启动驱动框架
-
参数
-
*args
-
**kwargs
-
abstract on_startup(func)
注册一个在驱动启动时运行的函数
abstract on_shutdown(func)
注册一个在驱动停止时运行的函数
on_bot_connect(func)
-
说明
装饰一个函数使他在 bot 通过 WebSocket 连接成功时执行。
-
函数参数
bot: Bot
: 当前连接上的 Bot 对象
on_bot_disconnect(func)
-
说明
装饰一个函数使他在 bot 通过 WebSocket 连接断开时执行。
-
函数参数
bot: Bot
: 当前连接上的 Bot 对象
_bot_connect(bot)
在 WebSocket 连接成功后,调用该函数来注册 bot 对象
_bot_disconnect(bot)
在 WebSocket 连接断开后,调用该函数来注销 bot 对象
class ForwardDriver
基类:nonebot.drivers.Driver
Forward Driver 基类。将客户端框架封装,以满足适配器使用。
abstract setup_http_polling(setup)
-
说明
注册一个 HTTP 轮询连接,如果传入一个函数,则该函数会在每次连接时被调用
-
参数
setup: Union[HTTPPollingSetup, Callable[[], Awaitable[HTTPPollingSetup]]]
abstract setup_websocket(setup)
-
说明
注册一个 WebSocket 连接,如果传入一个函数,则该函数会在每次重连时被调用
-
参数
setup: Union[WebSocketSetup, Callable[[], Awaitable[WebSocketSetup]]]
class ReverseDriver
基类:nonebot.drivers.Driver
Reverse Driver 基类。将后端框架封装,以满足适配器使用。
abstract property server_app
驱动 APP 对象
abstract property asgi
驱动 ASGI 对象
class HTTPConnection
基类:abc.ABC
http_version
One of "1.0"
, "1.1"
or "2"
.
scheme
URL scheme portion (likely "http"
or "https"
).
path
HTTP request target excluding any query string, with percent-encoded sequences and UTF-8 byte sequences decoded into characters.
query_string
URL portion after the ?
, percent-encoded.
headers
A dict of name-value pairs, where name is the header name, and value is the header value.
Order of header values must be preserved from the original HTTP request; order of header names is not important.
Header names must be lowercased.
abstract property type
Connection type.
class HTTPRequest
基类:nonebot.drivers.HTTPConnection
HTTP 请求封装。参考 asgi http scope。
method
The HTTP method name, uppercased.
body
Body of the request.
Optional; if missing defaults to b""
.
property type
Always http
class HTTPResponse
基类:object
HTTP 响应封装。参考 asgi http scope。
status
HTTP status code.
body
HTTP body content.
Optional; if missing defaults to None
.
headers
A dict of name-value pairs, where name is the header name, and value is the header value.
Order must be preserved in the HTTP response.
Header names must be lowercased.
Optional; if missing defaults to an empty dict.
property type
Always http
class WebSocket
基类:nonebot.drivers.HTTPConnection
, abc.ABC
WebSocket 连接封装。参考 asgi websocket scope。
property type
Always websocket
abstract property closed
-
类型
bool
-
说明
连接是否已经关闭
abstract async accept()
接受 WebSocket 连接请求
abstract async close(code)
关闭 WebSocket 连接请求
abstract async receive()
接收一条 WebSocket text 信息
abstract async receive_bytes()
接收一条 WebSocket binary 信息
abstract async send(data)
发送一条 WebSocket text 信息
abstract async send_bytes(data)
发送一条 WebSocket binary 信息
class HTTPPollingSetup
基类:object
adapter
协议适配器名称
self_id
机器人 ID
url
URL
method
HTTP method
body
HTTP body
headers
HTTP headers
http_version
HTTP version
poll_interval
HTTP 轮询间隔
class WebSocketSetup
基类:object
adapter
协议适配器名称
self_id
机器人 ID
url
URL
headers
HTTP headers
reconnect_interval
WebSocket 重连间隔