From 26f0d66017a6374a2dd44b24e3dd9c5ba7079fb0 Mon Sep 17 00:00:00 2001 From: Mix Date: Thu, 12 Aug 2021 23:14:45 +0800 Subject: [PATCH] :sparkles: add multiple account support for mirai adapter --- docs/guide/mirai-guide.md | 6 +++++- .../nonebot/adapters/mirai/bot.py | 12 ++++++++---- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/docs/guide/mirai-guide.md b/docs/guide/mirai-guide.md index c2f2f538..aa598dfa 100644 --- a/docs/guide/mirai-guide.md +++ b/docs/guide/mirai-guide.md @@ -133,7 +133,11 @@ pip install nonebot-adapter-mirai from nonebot.adapters.mirai import Bot nonebot.init() - nonebot.get_driver().register_adapter('mirai', Bot, qq=12345678) # qq参数需要填在mah中登录的qq + nonebot.get_driver().register_adapter('mirai', + Bot, + qq=12345678) + # qq参数需要填在mah中登录的qq, 如果需要多个帐号, 可以填写类似于 [123456,789100] 的数组形式 + nonebot.load_builtin_plugins() # 加载 nonebot 内置插件 nonebot.run() ``` diff --git a/packages/nonebot-adapter-mirai/nonebot/adapters/mirai/bot.py b/packages/nonebot-adapter-mirai/nonebot/adapters/mirai/bot.py index 5831c5fd..aa1e1c5c 100644 --- a/packages/nonebot-adapter-mirai/nonebot/adapters/mirai/bot.py +++ b/packages/nonebot-adapter-mirai/nonebot/adapters/mirai/bot.py @@ -1,5 +1,6 @@ import asyncio import json +from functools import partial from io import BytesIO from ipaddress import IPv4Address from typing import Any, Dict, List, NoReturn, Optional, Tuple, Union @@ -192,7 +193,7 @@ class Bot(BaseBot): def register(cls, driver: Driver, config: "Config", - qq: Optional[int] = None): + qq: Optional[Union[int, List[int]]] = None): cls.mirai_config = MiraiConfig(**config.dict()) if (cls.mirai_config.auth_key and cls.mirai_config.host and cls.mirai_config.port) is None: @@ -205,11 +206,12 @@ class Bot(BaseBot): f"Current driver {cls.config.driver} don't support forward connections" ) elif isinstance(driver, ForwardDriver) and qq: + self_ids = [qq] if isinstance(qq, int) else qq - async def url_factory(): + async def url_factory(qq: int): assert cls.mirai_config.host and cls.mirai_config.port and cls.mirai_config.auth_key session = await SessionManager.new( - qq, # type: ignore + qq, host=cls.mirai_config.host, port=cls.mirai_config.port, auth_key=cls.mirai_config.auth_key) @@ -219,7 +221,9 @@ class Bot(BaseBot): url=(f'ws://{cls.mirai_config.host}:{cls.mirai_config.port}' f'/all?sessionKey={session.session_key}')) - driver.setup_websocket(url_factory) + for self_id in self_ids: + driver.setup_websocket(partial(url_factory, qq=self_id)) + elif isinstance(driver, ReverseDriver): logger.debug( 'Param "qq" does not set for mirai adapter, use http post instead'