2024-08-08 04:41:35 +08:00
|
|
|
from datetime import datetime, timedelta
|
|
|
|
|
|
2024-09-14 19:17:40 +08:00
|
|
|
import nonebot
|
2024-08-08 04:41:35 +08:00
|
|
|
from nonebot_plugin_apscheduler import scheduler
|
2024-12-10 19:49:11 +08:00
|
|
|
import pytz
|
2024-08-08 04:41:35 +08:00
|
|
|
|
2024-09-14 19:17:40 +08:00
|
|
|
from zhenxun.configs.config import Config
|
|
|
|
|
from zhenxun.models.chat_history import ChatHistory
|
|
|
|
|
from zhenxun.models.group_console import GroupConsole
|
2024-12-10 19:49:11 +08:00
|
|
|
from zhenxun.models.task_info import TaskInfo
|
|
|
|
|
from zhenxun.services.log import logger
|
|
|
|
|
from zhenxun.utils.platform import PlatformUtils
|
2024-09-14 19:17:40 +08:00
|
|
|
|
|
|
|
|
Config.add_plugin_config(
|
|
|
|
|
"chat_check",
|
|
|
|
|
"STATUS",
|
|
|
|
|
True,
|
|
|
|
|
help="是否开启群组两日内未发送任何消息,关闭该群全部被动",
|
|
|
|
|
default_value=True,
|
|
|
|
|
type=bool,
|
|
|
|
|
)
|
2024-08-08 04:41:35 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@scheduler.scheduled_job(
|
|
|
|
|
"cron",
|
|
|
|
|
hour=4,
|
|
|
|
|
minute=40,
|
|
|
|
|
)
|
|
|
|
|
async def _():
|
2024-09-14 19:17:40 +08:00
|
|
|
if not Config.get_config("chat_history", "FLAG"):
|
|
|
|
|
logger.debug("未开启历史发言记录,过滤群组发言检测...")
|
|
|
|
|
return
|
|
|
|
|
if not Config.get_config("chat_check", "STATUS"):
|
|
|
|
|
logger.debug("未开启群组聊天时间检查,过滤群组发言检测...")
|
|
|
|
|
return
|
2024-08-08 04:41:35 +08:00
|
|
|
"""检测群组发言时间并禁用全部被动"""
|
|
|
|
|
update_list = []
|
2024-09-14 19:17:40 +08:00
|
|
|
if modules := await TaskInfo.annotate().values_list("module", flat=True):
|
2024-08-27 17:34:44 +08:00
|
|
|
for bot in nonebot.get_bots().values():
|
2024-12-25 12:03:49 +08:00
|
|
|
group_list, _ = await PlatformUtils.get_group_list(bot, True)
|
2024-08-27 17:34:44 +08:00
|
|
|
for group in group_list:
|
|
|
|
|
try:
|
|
|
|
|
last_message = (
|
|
|
|
|
await ChatHistory.filter(group_id=group.group_id)
|
|
|
|
|
.annotate()
|
|
|
|
|
.order_by("-create_time")
|
|
|
|
|
.first()
|
|
|
|
|
)
|
|
|
|
|
if last_message:
|
|
|
|
|
now = datetime.now(pytz.timezone("Asia/Shanghai"))
|
2024-08-08 04:41:35 +08:00
|
|
|
if now - timedelta(days=2) > last_message.create_time:
|
|
|
|
|
_group, _ = await GroupConsole.get_or_create(
|
|
|
|
|
group_id=group.group_id, channel_id__isnull=True
|
|
|
|
|
)
|
2024-10-09 17:45:53 +08:00
|
|
|
modules = [f"<{module}" for module in modules]
|
2024-08-08 04:41:35 +08:00
|
|
|
_group.block_task = ",".join(modules) + "," # type: ignore
|
|
|
|
|
update_list.append(_group)
|
|
|
|
|
logger.info(
|
|
|
|
|
"群组两日内未发送任何消息,关闭该群全部被动",
|
|
|
|
|
"Chat检测",
|
|
|
|
|
target=_group.group_id,
|
|
|
|
|
)
|
2024-09-14 19:17:40 +08:00
|
|
|
except Exception:
|
2024-08-27 17:34:44 +08:00
|
|
|
logger.error(
|
|
|
|
|
"检测群组发言时间失败...", "Chat检测", target=group.group_id
|
|
|
|
|
)
|
2024-08-08 04:41:35 +08:00
|
|
|
if update_list:
|
|
|
|
|
await GroupConsole.bulk_update(update_list, ["block_task"], 10)
|