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<Config>().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<Loc>().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<Loc>().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<Config>().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<Long> souLocArea = new ArrayList<>();
|
List<Long> 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<String,Integer> CONTAINER_IDS = new ConcurrentHashMap<>();//需要补充的容器查询条件
|
// ArrayList<String> CONTAINER_IDS = new ArrayList<>();//需要补充的容器查询条件
|
try{
|
String[] containerList = autoRunContainerEndYz.split(";");
|
for (String c : containerList) {//容器集合
|
long parseLong = Long.parseLong(c);
|
BasContainer basContainer = basContainerService.getOne(new LambdaQueryWrapper<BasContainer>()
|
.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<Loc>()
|
.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<autoOutCount){
|
CONTAINER_IDS.put(barcodeType, autoOutCount-count);
|
}
|
}
|
} catch (Exception e){
|
log.error("配置参数AUTO_RUN_AREA_START_YZ解析失败,请检查!!!");
|
return;
|
}
|
List<LocToTaskParams> locMove = new ArrayList<>();
|
List<String> locList = new ArrayList<>();
|
for (ConcurrentHashMap.Entry<String,Integer> entry : CONTAINER_IDS.entrySet()) {
|
String barcodeType = entry.getKey();// 获取String键
|
Integer entryValue = entry.getValue();// 获取数量
|
List<Loc> souLocList = locService.list(new LambdaQueryWrapper<Loc>()
|
.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<Loc>()
|
.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());
|
}
|
}
|
}
|
}
|