from nonebot import on_message from nonebot.adapters.cqhttp.permission import GROUP from nonebot.typing import T_State from nonebot.adapters.cqhttp import Bot, GroupMessageEvent import time from .data_source import cancel_all_notice, save_data, get_data, set_data_value from services.log import logger __plugin_name__ = '查看群最后聊天时间 [Hidden]' last_chat = on_message(priority=1, block=False, permission=GROUP) @last_chat.handle() async def _(bot: Bot, event: GroupMessageEvent, state: T_State): time_data = await get_data() set_data_value(event.group_id, time.time()) if event.group_id in time_data['_group']: time_data['_group'].remove(event.group_id) set_data_value('_group', time_data['_group']) for key in time_data.keys(): if key not in ['check_time', '_group']: if key not in time_data['_group']: if time.time() - time_data[key] > 60 * 60 * 36: await cancel_all_notice(key) time_data["_group"].append(key) set_data_value('_group', time_data['_group']) logger.info(f'GROUP {event.group_id} 因群内发言时间大于36小时被取消全部通知') if time.time() - time_data['check_time'] > 60 * 60 * 1: set_data_value('check_time', time.time()) save_data()