|
@@ -3,13 +3,12 @@ package cn.iocoder.yudao.module.ai.job;
|
|
|
import cn.hutool.core.collection.CollUtil;
|
|
|
import cn.iocoder.yudao.framework.ai.core.enums.AiPlatformEnum;
|
|
|
import cn.iocoder.yudao.framework.ai.core.model.midjourney.api.MidjourneyApi;
|
|
|
+import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
|
|
|
import cn.iocoder.yudao.framework.quartz.core.handler.JobHandler;
|
|
|
-import cn.iocoder.yudao.module.ai.controller.admin.image.vo.MidjourneyNotifyReqVO;
|
|
|
import cn.iocoder.yudao.module.ai.dal.dataobject.image.AiImageDO;
|
|
|
import cn.iocoder.yudao.module.ai.dal.mysql.image.AiImageMapper;
|
|
|
import cn.iocoder.yudao.module.ai.enums.image.AiImageStatusEnum;
|
|
|
import cn.iocoder.yudao.module.ai.service.image.AiImageService;
|
|
|
-import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Component;
|
|
@@ -17,7 +16,6 @@ import org.springframework.stereotype.Component;
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
-import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* midjourney job 定时拉去 midjourney 绘制状态
|
|
@@ -42,25 +40,17 @@ public class MidjourneyJob implements JobHandler {
|
|
|
@Override
|
|
|
public String execute(String param) throws Exception {
|
|
|
// 1、获取 midjourney 平台,状态在 “进行中” 的 image
|
|
|
- // TODO @fan:43 和 51 其实有点重叠,日志,建议只打 51
|
|
|
- log.info("Midjourney 同步 - 开始...");
|
|
|
- // TODO @fan:Job、Service 等业务层,不要直接使用 LambdaUpdateWrapper,这样会导致 mapper 穿透到逻辑层。要收敛到 mapper 里。
|
|
|
- List<AiImageDO> imageList = imageMapper.selectList(
|
|
|
- new LambdaUpdateWrapper<AiImageDO>()
|
|
|
- .eq(AiImageDO::getStatus, AiImageStatusEnum.IN_PROGRESS.getStatus())
|
|
|
- .eq(AiImageDO::getPlatform, AiPlatformEnum.MIDJOURNEY.getPlatform())
|
|
|
- );
|
|
|
+ List<AiImageDO> imageList = imageMapper.selectByStatusAndPlatform(AiImageStatusEnum.IN_PROGRESS, AiPlatformEnum.MIDJOURNEY);
|
|
|
log.info("Midjourney 同步 - 任务数量 {}!", imageList.size());
|
|
|
if (CollUtil.isEmpty(imageList)) {
|
|
|
- // TODO @fan:51 和 54,其实有点重叠。建议 51 挪到 55 之后打。
|
|
|
return "Midjourney 同步 - 数量为空!";
|
|
|
}
|
|
|
+ log.info("Midjourney 同步 - 开始...");
|
|
|
// 2、批量拉去 task 信息
|
|
|
- // TODO @fan:imageList.stream().map(AiImageDO::getTaskId).collect(Collectors.toSet())),可以使用 CollectionUtils.convertSet 简化
|
|
|
List<MidjourneyApi.NotifyRequest> taskList = midjourneyApi
|
|
|
- .listByCondition(imageList.stream().map(AiImageDO::getTaskId).collect(Collectors.toSet()));
|
|
|
- // TODO @fan:taskList.stream().collect(Collectors.toMap(MidjourneyNotifyReqVO::getId, o -> o)),也可以使用 CollectionUtils.convertMap;本质上,重用 set、map 转换,要 convert 简化
|
|
|
- Map<String, MidjourneyApi.NotifyRequest> taskIdMap = taskList.stream().collect(Collectors.toMap(MidjourneyApi.NotifyRequest::id, o -> o));
|
|
|
+ .listByCondition(CollectionUtils.convertSet(imageList, AiImageDO::getTaskId));
|
|
|
+ Map<String, MidjourneyApi.NotifyRequest> taskIdMap
|
|
|
+ = CollectionUtils.convertMap(taskList, MidjourneyApi.NotifyRequest::id);
|
|
|
// 3、更新 image 状态
|
|
|
List<AiImageDO> updateImageList = new ArrayList<>();
|
|
|
for (AiImageDO aiImageDO : imageList) {
|