zhenxun_bot/basic_plugins/broadcast/__init__.py

74 lines
2.1 KiB
Python
Raw Normal View History

import asyncio
2023-03-19 21:05:34 +08:00
from typing import List
2021-11-23 21:44:59 +08:00
from nonebot import on_command
from nonebot.adapters.onebot.v11 import Bot, Message, MessageEvent
2022-02-19 18:20:19 +08:00
from nonebot.params import CommandArg
from nonebot.permission import SUPERUSER
from configs.config import Config
2021-11-23 21:44:59 +08:00
from services.log import logger
2023-03-19 21:05:34 +08:00
from utils.depends import ImageList
2021-11-23 21:44:59 +08:00
from utils.manager import group_manager
from utils.message_builder import image
2021-11-23 21:44:59 +08:00
__zx_plugin_name__ = "广播 [Superuser]"
__plugin_usage__ = """
usage
指令
广播- ?[消息] ?[图片]
示例广播- 你们好
""".strip()
__plugin_des__ = "昭告天下!"
__plugin_cmd__ = ["广播-"]
__plugin_version__ = 0.1
__plugin_author__ = "HibiKier"
__plugin_task__ = {"broadcast": "广播"}
2021-12-16 11:16:28 +08:00
Config.add_plugin_config(
"_task",
"DEFAULT_BROADCAST",
True,
help_="被动 广播 进群默认开关状态",
default_value=True,
type=bool,
2021-12-16 11:16:28 +08:00
)
2021-11-23 21:44:59 +08:00
broadcast = on_command("广播-", priority=1, permission=SUPERUSER, block=True)
@broadcast.handle()
2023-03-19 21:05:34 +08:00
async def _(
bot: Bot,
event: MessageEvent,
arg: Message = CommandArg(),
img_list: List[str] = ImageList(),
):
2022-02-19 18:20:19 +08:00
msg = arg.extract_plain_text().strip()
2021-11-23 21:44:59 +08:00
rst = ""
2022-02-19 18:20:19 +08:00
for img in img_list:
2021-11-23 21:44:59 +08:00
rst += image(img)
gl = [
g["group_id"]
for g in await bot.get_group_list()
2022-11-21 20:43:41 +08:00
if group_manager.check_group_task_status(g["group_id"], "broadcast")
2021-11-23 21:44:59 +08:00
]
g_cnt = len(gl)
cnt = 0
error = ""
x = 0.25
for g in gl:
cnt += 1
if cnt / g_cnt > x:
await broadcast.send(f"已播报至 {int(cnt / g_cnt * 100)}% 的群聊")
x += 0.25
try:
2022-02-19 18:20:19 +08:00
await bot.send_group_msg(group_id=g, message=msg + rst)
2023-03-19 21:05:34 +08:00
logger.info(f"投递广播成功", "广播", group_id=g)
2021-11-23 21:44:59 +08:00
except Exception as e:
2023-03-19 21:05:34 +08:00
logger.error(f"投递广播失败", "广播", group_id=g, e=e)
2021-11-23 21:44:59 +08:00
error += f"GROUP {g} 投递广播失败:{type(e)}\n"
await asyncio.sleep(0.5)
await broadcast.send(f"已播报至 100% 的群聊")
if error:
await broadcast.send(f"播报时错误:{error}")