2021-08-04 13:42:21 +08:00

6.1 KiB

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 重连间隔