From 8e0decd25b9ec86b02d58de53dee1451f83d1566 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期四, 10 七月 2025 23:48:35 +0800
Subject: [PATCH] 新增

---
 src/main/java/com/linghu/controller/CollectController.java |   36 +++++++++++++++++++++++++++++++-----
 1 files changed, 31 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/linghu/controller/CollectController.java b/src/main/java/com/linghu/controller/CollectController.java
index e0fdeeb..fb6d23f 100644
--- a/src/main/java/com/linghu/controller/CollectController.java
+++ b/src/main/java/com/linghu/controller/CollectController.java
@@ -223,13 +223,14 @@
                        log.warn(errorMsg);
                        return Mono.just(ResponseResult.error(503, errorMsg));
                    }
+                   Integer keywordId = searchTaskRequest.getKeyword_id();
 
                    int maxConcurrentUsers = searchTaskRequest.getConfig() != null ?
                            searchTaskRequest.getConfig().getMax_concurrent_users() : 3;
-                   List<List<UserDto>> userBatches = splitUsersIntoBatches(searchTaskRequest.getUsers(), maxConcurrentUsers);
+                   List<List<UserDto>> userBatches = splitUsersIntoBatches(searchTaskRequest.getUsers(), maxConcurrentUsers,keywordId);
 
                    // 获取 keywordId
-                   Integer keywordId = searchTaskRequest.getKeyword_id();
+
                    //分割
 
      
@@ -381,14 +382,39 @@
                 .onStatus(HttpStatus::isError, response -> response.bodyToMono(TaskCancelResponse.class)
                         .flatMap(errorBody -> Mono.error(new RuntimeException(errorBody.getDetail()))))
                 .bodyToMono(TaskCancelResponse.class)
+                .flatMap(cancelResponse -> {
+                    // 更新关键词状态
+                    Mono<Void> updateKeyword = Mono.fromRunnable(() -> {
+                                LambdaUpdateWrapper<Keyword> updateWrapper = new LambdaUpdateWrapper<>();
+                                updateWrapper.eq(Keyword::getTask_id, taskId);
+                                updateWrapper.set(Keyword::getStatus, "canceled"); // 统一使用"canceled"
+                                keywordService.update(updateWrapper);
+                            })
+                            .subscribeOn(Schedulers.boundedElastic())
+                            .then();
+
+                    // 更新关键词任务状态
+                    Mono<Void> updateKeywordTask = Mono.fromRunnable(() -> {
+                                LambdaUpdateWrapper<KeywordTask> updateWrapper = new LambdaUpdateWrapper<>();
+                                updateWrapper.eq(KeywordTask::getTask_id, taskId);
+                                updateWrapper.set(KeywordTask::getStatus, "canceled"); // 统一使用"canceled"
+                                keywordTaskService.update(updateWrapper);
+                            })
+                            .subscribeOn(Schedulers.boundedElastic())
+                            .then();
+
+                    // 并行执行两个更新操作,并在完成后返回cancelResponse
+                    return Mono.when(updateKeyword, updateKeywordTask)
+                            .thenReturn(cancelResponse);
+                })
                 .map(data -> ResponseResult.success(data))
                 .onErrorResume(e -> {
                     if (e.getMessage().contains("任务不存在")) {
-                        return Mono.just(ResponseResult.error(200, "任务不存在"));
+                        return Mono.just(ResponseResult.error(200, e.getMessage()));
                     } else if (e.getMessage().contains("无法取消")) {
-                        return Mono.just(ResponseResult.error(200, "任务已完成,无法取消"));
+                        return Mono.just(ResponseResult.error(200, e.getMessage()));
                     }
-                    return Mono.just(ResponseResult.error(500, "取消任务失败: " + e.getMessage()));
+                    return Mono.just(ResponseResult.error(500,  e.getMessage()));
                 });
     }
 

--
Gitblit v1.7.1