diff --git a/app/Http/Controllers/Api/DialogController.php b/app/Http/Controllers/Api/DialogController.php index a653f34b6..16f704c47 100755 --- a/app/Http/Controllers/Api/DialogController.php +++ b/app/Http/Controllers/Api/DialogController.php @@ -1280,6 +1280,9 @@ class DialogController extends AbstractController if ($model_name) { $msgData['model_name'] = $model_name; } + if (User::isBot($user->userid)) { + $msgData['force_webhook'] = true; // 强制使用webhook发送 + } $result = WebSocketDialogMsg::sendMsg($action, $dialog_id, 'text', $msgData, $user->userid, false, false, $silence, $key); } } diff --git a/app/Tasks/BotReceiveMsgTask.php b/app/Tasks/BotReceiveMsgTask.php index 68dc7917a..b6193d4b6 100644 --- a/app/Tasks/BotReceiveMsgTask.php +++ b/app/Tasks/BotReceiveMsgTask.php @@ -66,7 +66,7 @@ class BotReceiveMsgTask extends AbstractTask } // 判断消息是否存在 - $msg = WebSocketDialogMsg::with(['user'])->find($this->msgId); + $msg = WebSocketDialogMsg::with(['user', 'webSocketDialog'])->find($this->msgId); if (empty($msg)) { return; } @@ -75,7 +75,11 @@ class BotReceiveMsgTask extends AbstractTask $msg->readSuccess($botUser->userid); // 判断消息是否是机器人发送的则不处理,避免循环 - if (!$msg->user || $msg->user->bot) { + if ((!$msg->user || $msg->user->bot)) { + $msgData = Base::json2array($msg->msg); + if (Base::val($msgData, 'force_webhook') && $msg->webSocketDialog) { + $this->handleWebhookRequest($msgData['text'], null, $msg, $msg->webSocketDialog, $botUser); + } return; } diff --git a/app/Tasks/WebSocketDialogMsgTask.php b/app/Tasks/WebSocketDialogMsgTask.php index 4dcf271b6..fd3507aa3 100644 --- a/app/Tasks/WebSocketDialogMsgTask.php +++ b/app/Tasks/WebSocketDialogMsgTask.php @@ -138,11 +138,11 @@ class WebSocketDialogMsgTask extends AbstractTask 'dot' => $dot, 'updated' => $updated, ]; - // 机器人收到消处理 - $botUser = User::whereUserid($userid)->whereBot(1)->first(); - if ($botUser) { - $this->endArray[] = new BotReceiveMsgTask($botUser->userid, $msg->id, $mentions, $this->client); - } + } + // 机器人收到消处理 + $botUser = User::whereUserid($userid)->whereBot(1)->first(); + if ($botUser) { // 避免机器人处理自己发送的消息 + $this->endArray[] = new BotReceiveMsgTask($botUser->userid, $msg->id, $mentions, $this->client); } } // 更新已发送数量 diff --git a/resources/assets/js/pages/manage/components/DialogWrapper.vue b/resources/assets/js/pages/manage/components/DialogWrapper.vue index 719af23b1..bea6d7913 100644 --- a/resources/assets/js/pages/manage/components/DialogWrapper.vue +++ b/resources/assets/js/pages/manage/components/DialogWrapper.vue @@ -463,7 +463,7 @@ - + {{$L(option.label)}} @@ -781,6 +781,7 @@ export default { {value: 'member_join', label: '成员加入'}, {value: 'member_leave', label: '成员退出'}, ], + webhookEvents: [], openId: 0, errorId: 0, @@ -2762,8 +2763,9 @@ export default { clear_day: 0, webhook_url: '', system_name: '', - webhook_events: this.prepareWebhookEvents([], true), + webhook_events: [], }) + this.webhookEvents = this.prepareWebhookEvents([], true) this.modifyLoad++; this.$store.dispatch("call", { url: 'users/bot/info', @@ -2774,7 +2776,7 @@ export default { this.modifyData.clear_day = data.clear_day this.modifyData.webhook_url = data.webhook_url this.modifyData.system_name = data.system_name - this.modifyData.webhook_events = this.prepareWebhookEvents(data.webhook_events, true) + this.webhookEvents = this.prepareWebhookEvents(data.webhook_events, true) }).finally(() => { this.modifyLoad--; }) @@ -2929,7 +2931,7 @@ export default { name: this.modifyData.name, clear_day: this.modifyData.clear_day, webhook_url: this.modifyData.webhook_url, - webhook_events: this.normalizeWebhookEvents(this.modifyData.webhook_events, false), + webhook_events: this.normalizeWebhookEvents(this.webhookEvents), dialog_id: this.modifyData.dialog_id }).then(({msg}) => { $A.messageSuccess(msg); diff --git a/resources/assets/js/store/actions.js b/resources/assets/js/store/actions.js index 5d64def7d..67e3f2073 100644 --- a/resources/assets/js/store/actions.js +++ b/resources/assets/js/store/actions.js @@ -3399,7 +3399,7 @@ export default { } return item.dialog_user.userid === userid }); - if (dialog) { + if (dialog && dialog.bot !== 1) { return dispatch("openDialog", dialog.id).then(resolve).catch(reject) } dispatch("call", {