From 43753b38a5c8aa2f21bbea0c3a4e7f854eb6a858 Mon Sep 17 00:00:00 2001 From: Lex Lim Date: Sat, 4 Mar 2023 05:40:26 +0000 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=85=A8=E7=BE=A4=E5=85=B1?= =?UTF-8?q?=E4=BA=AB=E5=AF=B9=E8=AF=9D=E5=8A=9F=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/controller/ChatGPTController.ts | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/controller/ChatGPTController.ts b/src/controller/ChatGPTController.ts index da346da..1b9072c 100644 --- a/src/controller/ChatGPTController.ts +++ b/src/controller/ChatGPTController.ts @@ -58,6 +58,15 @@ export default class ChatGPTController implements PluginController { this.handleChatGPTChat(args, message).catch(console.error); }); + this.event.registerCommand({ + command: 'aig', + name: '开始全群共享的对话', + }, (args, message, resolve) => { + resolve(); + + this.handleChatGPTChat(args, message, true).catch(console.error); + }); + this.event.registerCommand({ command: '重置对话', name: '重置对话', @@ -111,7 +120,7 @@ export default class ChatGPTController implements PluginController { this.DEFAULT_PROMPT = config.browser_api.prefix_prompt; } - private async handleChatGPTChat(content: string, message: CommonReceivedMessage) { + private async handleChatGPTChat(content: string, message: CommonReceivedMessage, shareWithGroup: boolean = false) { if (this.chatGenerating) { message.sendReply('正在生成另一段对话,请稍后', true); return; @@ -121,10 +130,11 @@ export default class ChatGPTController implements PluginController { return; } + const sessionStore = shareWithGroup ? message.session.group : message.session.chat; let response: any; let isFirstMessage = false; - let chatSession = await message.session.chat.get(this.SESSION_KEY_CHAT_SESSION); + let chatSession = await sessionStore.get(this.SESSION_KEY_CHAT_SESSION); if (!chatSession) { isFirstMessage = true; chatSession = {}; @@ -149,7 +159,7 @@ export default class ChatGPTController implements PluginController { if (err?.json?.detail) { if (err.json.detail === 'Conversation not found') { message.sendReply('对话已失效,请重新开始', true); - await message.session.chat.del(this.SESSION_KEY_CHAT_SESSION); + await sessionStore.del(this.SESSION_KEY_CHAT_SESSION); return; } } @@ -178,7 +188,7 @@ export default class ChatGPTController implements PluginController { chatSession.conversationId = response.conversationId; chatSession.parentMessageId = response.messageId; - await message.session.chat.set(this.SESSION_KEY_CHAT_SESSION, chatSession, 600); + await sessionStore.set(this.SESSION_KEY_CHAT_SESSION, chatSession, 600); message.sendReply(reply, true); }