import traceback from azure.ai.inference.aio import ChatCompletionsClient from azure.ai.inference.models import UserMessage, TextContentItem, ImageContentItem, ImageUrl, CompletionsFinishReason from melobot import Plugin, send_text from melobot.protocols.onebot.v11 import on_start_match, on_message, on_command, on_notice, on_event, Adapter from melobot.protocols.onebot.v11.handle import Args from melobot.protocols.onebot.v11.utils import MsgChecker, LevelRole, MsgCheckerFactory, StartMatcher, ParseArgs, Parser from melobot.protocols.onebot.v11.adapter.event import MessageEvent, PokeNotifyEvent, GroupMessageEvent, PrivateMessageEvent from melobot.protocols.onebot.v11.adapter.segment import PokeSegment from azure.core.credentials import AzureKeyCredential from typing import Union from .constants import * from .config import Config from .util import * from .models import MarshoContext from .checkers import superuser_checker, PokeMarshoChecker config = Config() model_name = config.marshoai_default_model context = MarshoContext() token = config.marshoai_token endpoint = config.marshoai_azure_endpoint client = ChatCompletionsClient( endpoint=endpoint, credential=AzureKeyCredential(token) ) @on_command(checker=superuser_checker, cmd_start="/", cmd_sep=" ", targets="changemodel") async def changemodel(args: ParseArgs = Args()): global model_name model_name = args.vals[0] await send_text("已切换") @on_start_match("reset") async def reset_group(event: GroupMessageEvent): context.reset(event.group_id, event.is_private) await send_text("上下文已重置") @on_start_match("reset") async def reset_private(event: PrivateMessageEvent): context.reset(event.user_id, event.is_private) await send_text("上下文已重置") @on_start_match("marsho") async def marsho_group(event: GroupMessageEvent): await marsho_main(event, True) @on_start_match("marsho") async def marsho_private(event: PrivateMessageEvent): await marsho_main(event, False) async def marsho_main(event: Union[GroupMessageEvent, PrivateMessageEvent], is_group: bool): if event.text.lstrip("marsho") == "": await send_text(USAGE) await send_text(INTRODUCTION) return # await UniMessage(str(text)).send() try: is_support_image_model = model_name.lower() in SUPPORT_IMAGE_MODELS usermsg = [] if is_support_image_model else "" user_id = event.sender.user_id target_id = event.group_id if is_group else event.user_id nickname_prompt = "" marsho_string_removed = False for i in event.get_segments("image"): if is_support_image_model: imgurl = str(i.data["url"]) picmsg = ImageContentItem( image_url=ImageUrl(url=str(await get_image_b64(imgurl))) ) usermsg.append(picmsg) else: await send_text("*此模型不支持图片处理。") for i in event.get_segments("text"): if not marsho_string_removed: # 去掉最前面的"marsho "字符串 clean_text = i.data["text"].lstrip("marsho ") marsho_string_removed = True # 标记文本已处理 else: clean_text = i.data["text"] if is_support_image_model: usermsg.append(TextContentItem(text=clean_text+nickname_prompt)) else: usermsg += str(clean_text+nickname_prompt) response = await make_chat( client=client, model_name=model_name, msg=context.build(target_id, event.is_private)+[UserMessage(content=usermsg)]) choice = response.choices[0] if choice["finish_reason"] == CompletionsFinishReason.STOPPED: # 当对话成功时,将dict的上下文添加到上下文类中 context.append(UserMessage(content=usermsg).as_dict(), target_id, event.is_private) context.append(choice.message.as_dict(), target_id, event.is_private) elif choice["finish_reason"] == CompletionsFinishReason.CONTENT_FILTERED: await send_text("*已被内容过滤器过滤。请调整聊天内容后重试。") return await send_text(str(choice.message.content)) except Exception as e: await send_text(str(e)+suggest_solution(str(e))) traceback.print_exc() return @on_event(checker=PokeMarshoChecker()) async def poke(event: PokeNotifyEvent, adapter: Adapter): # 尚未实现私聊戳一戳 QwQ #await adapter.send_custom(str(event.user_id),group_id=event.group_id) user_id = event.user_id # nicknames = await get_nicknames() # nickname = nicknames.get(user_id, "") nickname = "" try: if config.marshoai_poke_suffix != "": response = await make_chat( client=client, model_name=model_name, msg=[get_prompt(),UserMessage(content=f"*{nickname}{config.marshoai_poke_suffix}")] ) choice = response.choices[0] if choice["finish_reason"] == CompletionsFinishReason.STOPPED: await adapter.send_custom(" "+str(choice.message.content),group_id=event.group_id) except Exception as e: await adapter.send_custom(str(e)+suggest_solution(str(e)),group_id=event.group_id) traceback.print_exc() return class MarshoAI(Plugin): version = VERSION flows = [changemodel,marsho_group,marsho_private,reset_group,reset_private,poke]