LittlePaimon/Paimon_Chat/__init__.py

106 lines
4.3 KiB
Python
Raw Normal View History

2022-05-20 18:44:18 +08:00
import random
2022-06-21 16:26:13 +08:00
from pathlib import Path
from typing import Union
2022-05-20 18:44:18 +08:00
2022-08-07 00:17:07 +08:00
from littlepaimon_utils.files import load_json_from_url
from nonebot import get_driver
2022-05-20 20:47:32 +08:00
from nonebot import on_regex, on_command, logger
2022-08-07 00:17:07 +08:00
from nonebot.adapters.onebot.v11 import MessageEvent, GroupMessageEvent, PrivateMessageEvent
from nonebot.exception import FinishedException
2022-05-20 20:47:32 +08:00
from nonebot.matcher import matchers
2022-06-21 16:26:13 +08:00
from nonebot.plugin import PluginMetadata
2022-05-20 20:47:32 +08:00
from nonebot.rule import Rule
2022-06-16 19:13:11 +08:00
2022-08-07 00:17:07 +08:00
from ..utils.auth_util import FreqLimiter2
from ..utils.config import config
from ..utils.message_util import MessageBuild
2022-06-21 16:26:13 +08:00
__plugin_meta__ = PluginMetadata(
name="派蒙聊天",
description="派蒙会发语音、会学群友们说骚话哦(",
usage=(
"被动技能"
),
extra={
'type': '派蒙聊天',
'range': ['group'],
"author": "惜月 SCUOP",
"version": "1.0.1",
},
)
2022-06-16 20:46:38 +08:00
2022-05-28 23:30:59 +08:00
if config.paimon_mongodb_url:
try:
from .Learning_repeate import main
except ImportError:
2022-06-21 16:26:13 +08:00
logger.warning('派蒙机器学习聊天启用失败可能是mongodb连接失败或缺少相关库jieba_fast、pymongo、pypinyin')
2022-05-28 23:30:59 +08:00
else:
2022-08-07 00:17:07 +08:00
logger.warning('派蒙机器学习启用失败未配置mongodb连接url如无需该功能可忽略')
driver = get_driver()
2022-05-20 20:47:32 +08:00
voice_url = 'https://static.cherishmoon.fun/LittlePaimon/voice/'
chat_lmt = FreqLimiter2(60)
2022-05-20 20:47:32 +08:00
update_voice = on_command('更新派蒙语音', priority=2)
2022-06-21 16:26:13 +08:00
def check_group(event: Union[GroupMessageEvent, PrivateMessageEvent]) -> bool:
return True if isinstance(event, PrivateMessageEvent) else event.group_id in config.paimon_chat_group
2022-05-20 20:47:32 +08:00
@update_voice.handle()
async def update_paimon_voice(event: MessageEvent):
try:
old_len = len([m for m in matchers[10] if m.plugin_name == 'Paimon_Chat'])
2022-06-21 16:26:13 +08:00
path = Path() / 'data' / 'LittlePaimon' / 'voice' / 'voice_list.json'
voice_list = await load_json_from_url('https://static.cherishmoon.fun/LittlePaimon/voice/voice_list.json', path, True)
2022-05-20 20:47:32 +08:00
matchers[10] = [m for m in matchers[10] if m.plugin_name != 'Paimon_Chat']
for key, value in voice_list.items():
create_matcher(key, value['pattern'], value['cooldown'], value['pro'], value['files'])
new_len = len(voice_list) - old_len
await update_voice.send(f'派蒙语音更新成功,本次获取到{len(voice_list)}种语音, 新增{new_len}种语音')
except FinishedException:
raise
except Exception as e:
await update_voice.send(f'派蒙语音更新失败:{e}')
def create_matcher(chat_word: str, pattern: str, cooldown: int, pro: float, responses):
def check_pro() -> bool:
return random.random() < pro
2022-06-21 16:26:13 +08:00
def check_cooldown(event: Union[GroupMessageEvent, PrivateMessageEvent]) -> bool:
2022-06-21 18:37:10 +08:00
return isinstance(event, PrivateMessageEvent) or chat_lmt.check(event.group_id, chat_word)
hammer = on_regex(pattern, priority=10, rule=Rule(check_group, check_pro, check_cooldown))
2022-05-20 20:47:32 +08:00
hammer.plugin_name = 'Paimon_Chat'
@hammer.handle()
2022-06-21 16:26:13 +08:00
async def handler(event: Union[GroupMessageEvent, PrivateMessageEvent]):
try:
2022-06-21 18:37:10 +08:00
if isinstance(event, GroupMessageEvent):
chat_lmt.start_cd(event.group_id, chat_word, cooldown)
2022-06-21 16:26:13 +08:00
response: str = random.choice(responses)
if response.endswith('.mp3'):
await hammer.finish(await MessageBuild.StaticRecord(url=f'LittlePaimon/voice/{response}'))
2022-06-21 16:26:13 +08:00
if response.endswith(('.png', '.jpg', '.jpeg', '.image', '.gif')):
await hammer.finish(await MessageBuild.StaticImage(url=f'LittlePaimon/voice/{response}'))
if response.endswith(('.mp4', '.avi')):
await hammer.finish(await MessageBuild.StaticVideo(url=f'LittlePaimon/voice/{response}'))
else:
await hammer.finish(MessageBuild.Text(response))
except FinishedException:
raise
except Exception as e:
logger.error('派蒙发送语音失败', e)
@driver.on_startup
async def load_voice():
2022-06-21 16:26:13 +08:00
path = Path() / 'data' / 'LittlePaimon' / 'voice' / 'voice_list.json'
voice_list = await load_json_from_url('https://static.cherishmoon.fun/LittlePaimon/voice/voice_list.json', path)
for k, v in voice_list.items():
create_matcher(k, v['pattern'], v['cooldown'], v['pro'], v['files'])