package com.vincent.rsf.server.manager.schedules; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.vincent.rsf.framework.common.Cools; import com.vincent.rsf.framework.exception.CoolException; import com.vincent.rsf.server.manager.controller.params.LocToTaskParams; import com.vincent.rsf.server.manager.entity.BasContainer; import com.vincent.rsf.server.manager.entity.Loc; import com.vincent.rsf.server.manager.entity.WarehouseAreas; import com.vincent.rsf.server.manager.enums.LocStsType; import com.vincent.rsf.server.manager.service.*; import com.vincent.rsf.server.manager.service.impl.BasContainerServiceImpl; import com.vincent.rsf.server.manager.service.impl.WarehouseAreasServiceImpl; import com.vincent.rsf.server.system.constant.GlobalConfigCode; import com.vincent.rsf.server.system.entity.Config; import com.vincent.rsf.server.system.service.ConfigService; import lombok.extern.slf4j.Slf4j; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Objects; import java.util.concurrent.ConcurrentHashMap; /** * @author Munch D. Luffy * @date 2026/01/15 * 缓存区域任务自动触发 */ @Slf4j @Component public class TaskCacheLocSchedules { public static Logger logger = LoggerFactory.getLogger(TaskCacheLocSchedules.class); @Autowired private TaskService taskService; @Autowired private ConfigService configService; @Autowired private WarehouseAreasServiceImpl warehouseAreasService; @Autowired private LocService locService; @Autowired private LocItemService locItemService; @Autowired private BasContainerServiceImpl basContainerService; /** * @author Munch D. Luffy * @date 2026/01/15 * @description: 缓存区域自动生成移库任务 * @version 1.0 */ @Scheduled(cron = "0/15 * * * * ?") @Transactional(rollbackFor = Exception.class) public void startCacheInLocStock() throws Exception { Config config = configService.getOne(new LambdaQueryWrapper().eq(Config::getFlag, GlobalConfigCode.AUTO_RUN_CHECK_IN_YZ)); if (!Boolean.parseBoolean(config.getVal())) { return; } String autoRunAreaStartYz = configService.getVal("AUTO_RUN_IN_START_YZ", String.class); if (Cools.isEmpty(autoRunAreaStartYz)) { return; } String autoRunAreaEndYz = configService.getVal("AUTO_RUN_IN_END_YZ", String.class); if (Cools.isEmpty(autoRunAreaEndYz)) { return; } String curLoc = null; String deepLoc = null; try{ String[] split = autoRunAreaStartYz.split(";"); for (String c : split) { WarehouseAreas byId = warehouseAreasService.getById(Integer.parseInt(c)); if (!Cools.isEmpty(byId)) { Loc loc = locService.getOne(new LambdaQueryWrapper().eq(Loc::getAreaId, byId.getId()).eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type) .last("LIMIT 1")); if (!Objects.isNull(loc)) { curLoc = loc.getCode(); break; } } } } catch (Exception e){ log.error("配置参数AUTO_RUN_AREA_START_YZ解析失败,请检查!!!"); } try{ String[] split = autoRunAreaEndYz.split(";"); for (String c : split) { WarehouseAreas byId = warehouseAreasService.getById(Integer.parseInt(c)); if (!Cools.isEmpty(byId)) { Loc loc = locService.getOne(new LambdaQueryWrapper().eq(Loc::getAreaId, byId.getId()).eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type) .last("LIMIT 1")); if (!Objects.isNull(loc)) { deepLoc = loc.getCode(); break; } } } } catch (Exception e){ log.error("配置参数AUTO_RUN_AREA_START_YZ解析失败,请检查!!!"); } if (curLoc == null || deepLoc == null) { return; } LocToTaskParams params = new LocToTaskParams(); params.setOrgLoc(curLoc).setTarLoc(deepLoc); //生成移库位任务 locItemService.genMoveTask(params, 9999L); } /** * @author Munch D. Luffy * @date 2026/01/15 * @description: 缓存区域自动生成空货架出库任务 * @version 1.0 */ @Scheduled(cron = "0/5 * * * * ? ") @Transactional(rollbackFor = Exception.class) public void startCacheOutLocStock() throws Exception { Config config = configService.getOne(new LambdaQueryWrapper().eq(Config::getFlag, GlobalConfigCode.AUTO_RUN_CHECK_OUT_YZ)); if (!Boolean.parseBoolean(config.getVal())) { return; } String autoRunAreaStartYz = configService.getVal("AUTO_RUN_OUT_START_YZ", String.class); if (Cools.isEmpty(autoRunAreaStartYz)) { return; } String autoRunAreaEndYz = configService.getVal("AUTO_RUN_OUT_END_YZ", String.class); if (Cools.isEmpty(autoRunAreaEndYz)) { return; } String autoRunContainerEndYz = configService.getVal("AUTO_RUN_OUT_CONTAINER_YZ", String.class); if (Cools.isEmpty(autoRunContainerEndYz)) { return; } String autoRunContainerEndYzCount = configService.getVal("AUTO_RUN_CHECK_OUT_YZ_COUNT", String.class); if (Cools.isEmpty(autoRunContainerEndYzCount)) { return; } int autoOutCount = Integer.parseInt(autoRunContainerEndYzCount); if (autoOutCount <= 0) { return; } List souLocArea = new ArrayList<>(); List endLocArea = new ArrayList<>(); String curLoc = null; String deepLoc = null; try{ for (String c : autoRunAreaStartYz.split(";")) { WarehouseAreas byId = warehouseAreasService.getById(Integer.parseInt(c)); if (!Cools.isEmpty(byId)) { souLocArea.add(byId.getId()); } } if (souLocArea.isEmpty()) { return; } } catch (Exception e){ log.error("配置参数AUTO_RUN_AREA_START_YZ解析失败,请检查!!!"); return; } try{ for (String c : autoRunAreaEndYz.split(";")) { WarehouseAreas byId = warehouseAreasService.getById(Integer.parseInt(c)); if (!Cools.isEmpty(byId)) { endLocArea.add(byId.getId()); } } if (endLocArea.isEmpty()) { return; } } catch (Exception e){ log.error("配置参数AUTO_RUN_OUT_END_YZ解析失败,请检查!!!"); return; } ConcurrentHashMap CONTAINER_IDS = new ConcurrentHashMap<>();//需要补充的容器查询条件 // ArrayList CONTAINER_IDS = new ArrayList<>();//需要补充的容器查询条件 try{ String[] containerList = autoRunContainerEndYz.split(";"); for (String c : containerList) {//容器集合 long parseLong = Long.parseLong(c); BasContainer basContainer = basContainerService.getOne(new LambdaQueryWrapper() .eq(BasContainer::getContainerType, parseLong).last("LIMIT 1")); if (Cools.isEmpty(basContainer)){ throw new CoolException("未查询到相关容器规则,容器编码CONTAINER_ID:"+c); } //查询终点是否需要补充此容器 String barcodeType = "barcode REGEXP '"+basContainer.getCodeType()+"'"; int count = locService.count(new LambdaQueryWrapper() .apply(barcodeType) .in(Loc::getUseStatus, new ArrayList<>(Arrays.asList( LocStsType.LOC_STS_TYPE_D.type, LocStsType.LOC_STS_TYPE_S.type ))) .in(Loc::getAreaId, endLocArea) .eq(Loc::getDeleted, 0) .eq(Loc::getStatus, 1) .orderByDesc(Loc::getId)); if (!Cools.isEmpty(count) && count locMove = new ArrayList<>(); List locList = new ArrayList<>(); for (ConcurrentHashMap.Entry entry : CONTAINER_IDS.entrySet()) { String barcodeType = entry.getKey();// 获取String键 Integer entryValue = entry.getValue();// 获取数量 List souLocList = locService.list(new LambdaQueryWrapper() .apply(barcodeType) .eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_D.type) .in(Loc::getAreaId, souLocArea) .eq(Loc::getDeleted, 0) .eq(Loc::getStatus, 1) .orderByDesc(Loc::getId)); for (Loc souLoc : souLocList) { if (entryValue<=0){ break; } entryValue--; Loc endLoc = locService.getOne(new LambdaQueryWrapper() .eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type) .in(Loc::getAreaId, endLocArea) .notIn(!locList.isEmpty(), Loc::getCode, locList) .eq(Loc::getDeleted, 0) .eq(Loc::getStatus, 1) .orderByDesc(Loc::getId).last("LIMIT 1")); if (Cools.isEmpty(souLoc)){ continue; } locMove.add(new LocToTaskParams().setOrgLoc(souLoc.getCode()).setTarLoc(endLoc.getCode())); locList.add(endLoc.getCode()); } } if (locMove.isEmpty()) { return; } for (LocToTaskParams locToTaskParams : locMove) { //生成移库位任务 try{ locItemService.genMoveTask(locToTaskParams, 9999L); }catch (Exception e){ log.error("生成移库位任务失败,请检查!!!"+locToTaskParams.toString()); } } } }