990 lines
25 KiB
Python
Raw Normal View History

2020-09-26 16:33:57 +08:00
import asyncio
2020-09-29 22:32:15 +08:00
from nonebot.config import Config
2020-08-26 17:47:36 +08:00
from nonebot.adapters import BaseBot
2020-09-29 22:32:15 +08:00
from nonebot.typing import Any, Dict, List, Union, Driver, Optional, NoReturn, WebSocket, Iterable
2020-09-26 14:40:08 +08:00
def log(level: str, message: str):
...
2020-09-28 12:45:55 +08:00
def escape(s: str, *, escape_comma: bool = ...) -> str:
2020-09-26 14:40:08 +08:00
...
def unescape(s: str) -> str:
...
def _b2s(b: Optional[bool]) -> Optional[str]:
...
async def _check_reply(bot: "Bot", event: "Event"):
...
def _check_at_me(bot: "Bot", event: "Event"):
...
def _check_nickname(bot: "Bot", event: "Event"):
...
2020-09-29 22:32:15 +08:00
def _handle_api_result(
result: Optional[Dict[str, Any]]) -> Union[Any, NoReturn]:
2020-09-26 14:40:08 +08:00
...
class ResultStore:
2020-09-26 16:33:57 +08:00
_seq: int = ...
_futures: Dict[int, asyncio.Future] = ...
@classmethod
def get_seq(cls) -> int:
...
@classmethod
def add_result(cls, result: Dict[str, Any]):
...
@classmethod
async def fetch(cls, seq: int, timeout: Optional[float]) -> Dict[str, Any]:
...
2020-08-26 17:47:36 +08:00
class Bot(BaseBot):
2020-09-29 22:32:15 +08:00
def __init__(self,
driver: Driver,
connection_type: str,
config: Config,
self_id: str,
*,
websocket: WebSocket = None):
...
def type(self) -> str:
...
async def handle_message(self, message: dict):
...
async def call_api(self, api: str, **data) -> Union[Any, NoReturn]:
...
async def send(self, event: "Event", message: Union[str, "Message",
"MessageSegment"],
**kwargs) -> Union[Any, NoReturn]:
...
2020-08-26 17:47:36 +08:00
async def send_private_msg(self,
*,
user_id: int,
message: Union[str, Message],
2020-09-28 12:45:55 +08:00
auto_escape: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
发送私聊消息
:参数:
* ``user_id``: 对方 QQ
* ``message``: 要发送的内容
* ``auto_escape``: 消息内容是否作为纯文本发送即不解析 CQ 只在 ``message`` 字段是字符串时有效
* ``self_id``: 机器人 QQ
"""
...
async def send_group_msg(self,
*,
group_id: int,
message: Union[str, Message],
2020-09-28 12:45:55 +08:00
auto_escape: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
发送群消息
:参数:
* ``group_id``: 群号
* ``message``: 要发送的内容
* ``auto_escape``: 消息内容是否作为纯文本发送即不解析 CQ 只在 ``message`` 字段是字符串时有效
* ``self_id``: 机器人 QQ
"""
...
async def send_msg(self,
*,
2020-09-28 12:45:55 +08:00
message_type: Optional[str] = ...,
user_id: Optional[int] = ...,
group_id: Optional[int] = ...,
2020-08-26 17:47:36 +08:00
message: Union[str, Message],
2020-09-28 12:45:55 +08:00
auto_escape: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
发送消息
:参数:
* ``message_type``: 消息类型支持 ``private````group``分别对应私聊群组讨论组如不传入则根据传入的 ``*_id`` 参数判断
* ``user_id``: 对方 QQ 消息类型为 ``private`` 时需要
* ``group_id``: 群号消息类型为 ``group`` 时需要
* ``message``: 要发送的内容
* ``auto_escape``: 消息内容是否作为纯文本发送即不解析 CQ 只在 ``message`` 字段是字符串时有效
* ``self_id``: 机器人 QQ
"""
...
async def delete_msg(self,
*,
message_id: int,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
撤回消息
:参数:
* ``message_id``: 消息 ID
* ``self_id``: 机器人 QQ
"""
...
async def get_msg(self,
*,
message_id: int,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取消息
:参数:
* ``message_id``: 消息 ID
* ``self_id``: 机器人 QQ
"""
...
async def get_forward_msg(self,
*,
id: int,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取合并转发消息
:参数:
* ``id``: 合并转发 ID
* ``self_id``: 机器人 QQ
"""
...
async def send_like(self,
*,
user_id: int,
2020-09-28 12:45:55 +08:00
times: int = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
发送好友赞
:参数:
* ``user_id``: 对方 QQ
* ``times``: 赞的次数每个好友每天最多 10
* ``self_id``: 机器人 QQ
"""
...
async def set_group_kick(self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
reject_add_request: bool = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组踢人
:参数:
* ``group_id``: 群号
* ``user_id``: 要踢的 QQ
* ``reject_add_request``: 拒绝此人的加群请求
* ``self_id``: 机器人 QQ
"""
...
async def set_group_ban(self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
duration: int = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组单人禁言
:参数:
* ``group_id``: 群号
* ``user_id``: 要禁言的 QQ
* ``duration``: 禁言时长单位秒``0`` 表示取消禁言
* ``self_id``: 机器人 QQ
"""
...
async def set_group_anonymous_ban(self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
anonymous: Optional[Dict[str, Any]] = ...,
anonymous_flag: Optional[str] = ...,
duration: int = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组匿名用户禁言
:参数:
* ``group_id``: 群号
* ``anonymous``: 可选要禁言的匿名用户对象群消息上报的 ``anonymous`` 字段
* ``anonymous_flag``: 可选要禁言的匿名用户的 flag需从群消息上报的数据中获得
* ``duration``: 禁言时长单位秒无法取消匿名用户禁言
* ``self_id``: 机器人 QQ
"""
...
async def set_group_whole_ban(self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
enable: bool = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组全员禁言
:参数:
* ``group_id``: 群号
* ``enable``: 是否禁言
* ``self_id``: 机器人 QQ
"""
...
async def set_group_admin(self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
enable: bool = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组设置管理员
:参数:
* ``group_id``: 群号
* ``user_id``: 要设置管理员的 QQ
* ``enable``: ``True`` 为设置``False`` 为取消
* ``self_id``: 机器人 QQ
"""
...
async def set_group_anonymous(self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
enable: bool = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
群组匿名
:参数:
* ``group_id``: 群号
* ``enable``: 是否允许匿名聊天
* ``self_id``: 机器人 QQ
"""
...
async def set_group_card(self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
card: str = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
设置群名片群备注
:参数:
* ``group_id``: 群号
* ``user_id``: 要设置的 QQ
* ``card``: 群名片内容不填或空字符串表示删除群名片
* ``self_id``: 机器人 QQ
"""
...
async def set_group_name(self,
*,
group_id: int,
group_name: str,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
设置群名
:参数:
* ``group_id``: 群号
* ``group_name``: 新群名
* ``self_id``: 机器人 QQ
"""
...
async def set_group_leave(self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
is_dismiss: bool = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
退出群组
:参数:
* ``group_id``: 群号
* ``is_dismiss``: 是否解散如果登录号是群主则仅在此项为 True 时能够解散
* ``self_id``: 机器人 QQ
"""
...
async def set_group_special_title(self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
special_title: str = ...,
duration: int = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
设置群组专属头衔
:参数:
* ``group_id``: 群号
* ``user_id``: 要设置的 QQ
* ``special_title``: 专属头衔不填或空字符串表示删除专属头衔
* ``duration``: 专属头衔有效期单位秒-1 表示永久不过此项似乎没有效果可能是只有某些特殊的时间长度有效有待测试
* ``self_id``: 机器人 QQ
"""
...
async def set_friend_add_request(self,
*,
flag: str,
2020-09-28 12:45:55 +08:00
approve: bool = ...,
remark: str = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
处理加好友请求
:参数:
* ``flag``: 加好友请求的 flag需从上报的数据中获得
* ``approve``: 是否同意请求
* ``remark``: 添加后的好友备注仅在同意时有效
* ``self_id``: 机器人 QQ
"""
...
async def set_group_add_request(self,
*,
flag: str,
sub_type: str,
2020-09-28 12:45:55 +08:00
approve: bool = ...,
reason: str = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
处理加群请求邀请
:参数:
* ``flag``: 加群请求的 flag需从上报的数据中获得
* ``sub_type``: ``add`` ``invite``请求类型需要和上报消息中的 ``sub_type`` 字段相符
* ``approve``: 是否同意请求邀请
* ``reason``: 拒绝理由仅在拒绝时有效
* ``self_id``: 机器人 QQ
"""
...
async def get_login_info(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取登录号信息
:参数:
* ``self_id``: 机器人 QQ
"""
...
2020-09-28 12:45:55 +08:00
async def get_stranger_info(self,
*,
user_id: int,
no_cache: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取陌生人信息
:参数:
* ``user_id``: QQ
* ``no_cache``: 是否不使用缓存使用缓存可能更新不及时但响应更快
* ``self_id``: 机器人 QQ
"""
...
async def get_friend_list(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...
2020-08-26 17:47:36 +08:00
) -> List[Dict[str, Any]]:
"""
:说明:
获取好友列表
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def get_group_info(self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
no_cache: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取群信息
:参数:
* ``group_id``: 群号
* ``no_cache``: 是否不使用缓存使用缓存可能更新不及时但响应更快
* ``self_id``: 机器人 QQ
"""
...
async def get_group_list(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...
2020-08-26 17:47:36 +08:00
) -> List[Dict[str, Any]]:
"""
:说明:
获取群列表
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def get_group_member_info(
self,
*,
group_id: int,
user_id: int,
2020-09-28 12:45:55 +08:00
no_cache: bool = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取群成员信息
:参数:
* ``group_id``: 群号
* ``user_id``: QQ
* ``no_cache``: 是否不使用缓存使用缓存可能更新不及时但响应更快
* ``self_id``: 机器人 QQ
"""
...
async def get_group_member_list(
self,
*,
group_id: int,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> List[Dict[str, Any]]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取群成员列表
:参数:
* ``group_id``: 群号
* ``self_id``: 机器人 QQ
"""
...
2020-09-28 12:45:55 +08:00
async def get_group_honor_info(self,
*,
group_id: int,
type: str = ...,
self_id: Optional[int] = ...
) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取群荣誉信息
:参数:
* ``group_id``: 群号
* ``type``: 要获取的群荣誉类型可传入 ``talkative`` ``performer`` ``legend`` ``strong_newbie`` ``emotion`` 以分别获取单个类型的群荣誉数据或传入 ``all`` 获取所有数据
* ``self_id``: 机器人 QQ
"""
...
async def get_cookies(self,
*,
2020-09-28 12:45:55 +08:00
domain: str = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取 Cookies
:参数:
* ``domain``: 需要获取 cookies 的域名
* ``self_id``: 机器人 QQ
"""
...
async def get_csrf_token(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取 CSRF Token
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def get_credentials(self,
*,
2020-09-28 12:45:55 +08:00
domain: str = ...,
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取 QQ 相关接口凭证
:参数:
* ``domain``: 需要获取 cookies 的域名
* ``self_id``: 机器人 QQ
"""
...
async def get_record(self,
*,
file: str,
out_format: str,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取语音
:参数:
* ``file``: 收到的语音文件名CQ 码的 ``file`` 参数 ``0B38145AA44505000B38145AA4450500.silk``
* ``out_format``: 要转换到的格式目前支持 ``mp3````amr````wma````m4a````spx````ogg````wav````flac``
* ``self_id``: 机器人 QQ
"""
...
async def get_image(self,
*,
file: str,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取图片
:参数:
* ``file``: 收到的图片文件名CQ 码的 ``file`` 参数 ``6B4DE3DFD1BD271E3297859D41C530F5.jpg``
* ``self_id``: 机器人 QQ
"""
...
async def can_send_image(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
检查是否可以发送图片
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def can_send_record(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
检查是否可以发送语音
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def get_status(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取插件运行状态
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def get_version_info(self,
*,
2020-09-28 12:45:55 +08:00
self_id: Optional[int] = ...) -> Dict[str, Any]:
2020-08-26 17:47:36 +08:00
"""
:说明:
获取版本信息
:参数:
* ``self_id``: 机器人 QQ
"""
...
async def set_restart(self,
*,
2020-09-28 12:45:55 +08:00
delay: int = ...,
self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
重启 OneBot 实现
:参数:
* ``delay``: 要延迟的毫秒数如果默认情况下无法重启可以尝试设置延迟为 2000 左右
* ``self_id``: 机器人 QQ
"""
...
2020-09-28 12:45:55 +08:00
async def clean_cache(self, *, self_id: Optional[int] = ...) -> None:
2020-08-26 17:47:36 +08:00
"""
:说明:
清理数据目录
:参数:
* ``self_id``: 机器人 QQ
"""
...
2020-09-26 14:40:08 +08:00
class Event:
2020-09-26 16:33:57 +08:00
def __init__(self, raw_event: dict):
...
@property
def id(self) -> Optional[int]:
...
@property
def name(self) -> str:
...
@property
def self_id(self) -> str:
...
@property
def time(self) -> int:
...
@property
def type(self) -> str:
...
@type.setter
def type(self, value) -> None:
...
@property
def detail_type(self) -> str:
...
@detail_type.setter
def detail_type(self, value) -> None:
...
@property
def sub_type(self) -> Optional[str]:
...
2020-10-04 16:24:26 +08:00
@sub_type.setter
2020-09-26 16:33:57 +08:00
def sub_type(self, value) -> None:
...
@property
def user_id(self) -> Optional[int]:
...
@user_id.setter
def user_id(self, value) -> None:
...
@property
def group_id(self) -> Optional[int]:
...
@group_id.setter
def group_id(self, value) -> None:
...
@property
def to_me(self) -> Optional[bool]:
...
@to_me.setter
def to_me(self, value) -> None:
...
@property
def message(self) -> Optional["Message"]:
...
@message.setter
def message(self, value) -> None:
...
@property
def reply(self) -> Optional[dict]:
...
@reply.setter
def reply(self, value) -> None:
...
@property
def raw_message(self) -> Optional[str]:
...
@raw_message.setter
def raw_message(self, value) -> None:
...
@property
def plain_text(self) -> Optional[str]:
...
@property
def sender(self) -> Optional[dict]:
...
@sender.setter
def sender(self, value) -> None:
...
2020-09-26 14:40:08 +08:00
class MessageSegment:
2020-09-26 16:33:57 +08:00
def __init__(self, type: str, data: Dict[str, Any]) -> None:
2020-09-26 16:33:57 +08:00
...
def __str__(self):
...
def __add__(self, other) -> "Message":
...
@staticmethod
2020-09-28 12:45:55 +08:00
def anonymous(ignore_failure: Optional[bool] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def at(user_id: Union[int, str]) -> "MessageSegment":
...
@staticmethod
def contact_group(group_id: int) -> "MessageSegment":
...
@staticmethod
def contact_user(user_id: int) -> "MessageSegment":
...
@staticmethod
def dice() -> "MessageSegment":
...
@staticmethod
def face(id_: int) -> "MessageSegment":
...
@staticmethod
def forward(id_: str) -> "MessageSegment":
...
@staticmethod
def image(file: str,
2020-09-28 12:45:55 +08:00
type_: Optional[str] = ...,
cache: bool = ...,
proxy: bool = ...,
timeout: Optional[int] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def json(data: str) -> "MessageSegment":
...
@staticmethod
def location(latitude: float,
longitude: float,
2020-09-28 12:45:55 +08:00
title: Optional[str] = ...,
content: Optional[str] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def music(type_: str, id_: int) -> "MessageSegment":
...
@staticmethod
def music_custom(url: str,
audio: str,
title: str,
2020-09-28 12:45:55 +08:00
content: Optional[str] = ...,
img_url: Optional[str] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def node(id_: int) -> "MessageSegment":
...
@staticmethod
def node_custom(user_id: int, nickname: str,
content: Union[str, "Message"]) -> "MessageSegment":
...
@staticmethod
def poke(type_: str, id_: str) -> "MessageSegment":
...
@staticmethod
def record(file: str,
2020-09-28 12:45:55 +08:00
magic: Optional[bool] = ...,
cache: Optional[bool] = ...,
proxy: Optional[bool] = ...,
timeout: Optional[int] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def reply(id_: int) -> "MessageSegment":
...
@staticmethod
def rps() -> "MessageSegment":
...
@staticmethod
def shake() -> "MessageSegment":
...
@staticmethod
2020-09-28 12:45:55 +08:00
def share(url: str = ...,
title: str = ...,
content: Optional[str] = ...,
img_url: Optional[str] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def text(text: str) -> "MessageSegment":
...
@staticmethod
def video(file: str,
2020-09-28 12:45:55 +08:00
cache: Optional[bool] = ...,
proxy: Optional[bool] = ...,
timeout: Optional[int] = ...) -> "MessageSegment":
2020-09-26 16:33:57 +08:00
...
@staticmethod
def xml(data: str) -> "MessageSegment":
...
2020-09-26 14:40:08 +08:00
class Message:
2020-09-26 16:33:57 +08:00
@staticmethod
def _construct(msg: Union[str, dict, list]) -> Iterable[MessageSegment]:
...