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", {