From b7b3328fdfa45cf13d1943fa79d47f1b6bb43f01 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期三, 28 五月 2025 18:22:17 +0800 Subject: [PATCH] 添加定时任务用户 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java | 112 +++++++++++++++++++++++++++++++++++++------------------- 1 files changed, 74 insertions(+), 38 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java index 9c2cab2..71cce1a 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java @@ -13,7 +13,6 @@ import com.vincent.rsf.server.api.utils.LocUtils; import com.vincent.rsf.server.manager.controller.params.GenerateTaskParams; import com.vincent.rsf.server.manager.entity.*; -import com.vincent.rsf.server.manager.enums.LocType; import com.vincent.rsf.server.manager.mapper.TaskMapper; import com.vincent.rsf.server.manager.service.*; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; @@ -21,8 +20,11 @@ import com.vincent.rsf.server.system.constant.SerialRuleCode; import com.vincent.rsf.server.manager.enums.LocStsType; import com.vincent.rsf.server.system.utils.SerialRuleUtils; +import com.vincent.rsf.server.system.utils.SystemAuthUtils; import lombok.Synchronized; import org.apache.commons.lang3.StringUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -33,6 +35,8 @@ @Service("taskService") public class TaskServiceImpl extends ServiceImpl<TaskMapper, Task> implements TaskService { + + public static final Logger logger = LoggerFactory.getLogger(TaskServiceImpl.class); @Autowired private WaitPakinService waitPakinService; @@ -385,23 +389,24 @@ @Override @Transactional(rollbackFor = Exception.class) public void complateInTask(List<Task> tasks) throws Exception { + Long loginUserId = SystemAuthUtils.getLoginUserId(); for (Task task : tasks) { if (task.getTaskType().equals(TaskType.TASK_TYPE_IN.type)) { //1.鍏ュ簱 - complateInstock(task); + complateInstock(task, loginUserId); } else if (task.getTaskType().equals(TaskType.TASK_TYPE_PICK_IN.type) || task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)) { //53.鎷f枡鍐嶅叆搴� //57.鐩樼偣鍐嶅叆搴� - pickComplateInStock(task); + pickComplateInStock(task, loginUserId); } else if (task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) { //绉诲簱 - moveInStock(task); + moveInStock(task, loginUserId); } } } @Transactional(rollbackFor = Exception.class) - public void moveInStock(Task task) { + public void moveInStock(Task task, Long loginUserId) { if (Objects.isNull(task)) { return; } @@ -430,7 +435,7 @@ //绉诲簱鏈夊彲鑳芥槸绌烘澘 try { //鏇存柊搴撲綅鏄庣粏 - saveLocItem(taskItems, task.getId()); + saveLocItem(taskItems, task.getId(), loginUserId); } catch (Exception e) { throw new CoolException("搴撲綅鏄庣粏鏇存柊澶辫触锛侊紒"); } @@ -444,19 +449,26 @@ /**淇敼搴撲綅鐘舵�佷负F.鍦ㄥ簱*/ if (!locService.update(new LambdaUpdateWrapper<Loc>() .set(Loc::getBarcode, task.getBarcode()) - .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type) - .eq(Loc::getCode, task.getTargLoc()))) { + .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type) + .set(Loc::getUpdateBy, loginUserId) + .set(Loc::getUpdateTime, new Date()) + .eq(Loc::getCode, task.getTargLoc()))) { throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } if (!locService.update(new LambdaUpdateWrapper<Loc>() .set(Loc::getBarcode, null) - .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type).eq(Loc::getCode, task.getOrgLoc()))) { + .set(Loc::getUpdateBy, loginUserId) + .set(Loc::getUpdateTime, new Date()) + .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type) + .eq(Loc::getCode, task.getOrgLoc()))) { throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } - - if (!this.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()).set(Task::getTaskStatus, TaskStsType.UPDATED_IN.id))) { + if (!this.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()) + .set(Task::getUpdateBy, loginUserId) + .set(Task::getUpdateTime, new Date()) + .set(Task::getTaskStatus, TaskStsType.UPDATED_IN.id))) { throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } @@ -473,17 +485,18 @@ @Override @Transactional(rollbackFor = Exception.class) public void completeTask(List<Task> tasks) throws Exception { + Long loginUserId = SystemAuthUtils.getLoginUserId(); for (Task task : tasks) { //鍑哄簱浠诲姟 if (task.getTaskType().equals(TaskType.TASK_TYPE_OUT.type)) { //鍏ㄦ墭鍑哄簱 - complateOutStock(task); + complateOutStock(task, loginUserId); } else if (task.getTaskType().equals(TaskType.TASK_TYPE_PICK_AGAIN_OUT.type)) { //鎷f枡鍑哄簱 - complateOutStock(task); + complateOutStock(task, loginUserId); } else if (task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_OUT.type)) { //鐩樼偣鍑哄簱 - complateOutStock(task); + complateOutStock(task, loginUserId); } } } @@ -492,9 +505,10 @@ * 鎷f枡鍐嶅叆搴� * * @param task + * @param loginUserId */ @Transactional(rollbackFor = Exception.class) - public void pickComplateInStock(Task task) throws Exception { + public void pickComplateInStock(Task task, Long loginUserId) throws Exception { if (Objects.isNull(task)) { return; } @@ -506,7 +520,9 @@ throw new CoolException("褰撳墠搴撲綅鐘舵�佷笉澶勪簬S.鍏ュ簱棰勭害锛屼笉鍙墽琛屽叆搴撴搷浣滐紒"); } - loc.setUseStatus(LocStsType.LOC_STS_TYPE_F.type).setBarcode(task.getBarcode()); + loc.setUseStatus(LocStsType.LOC_STS_TYPE_F.type) + .setBarcode(task.getBarcode()) + .setUpdateBy(loginUserId).setUpdateTime(new Date()); if (!locService.updateById(loc)) { throw new CoolException("搴撲綅淇℃伅鏇存柊澶辫触锛侊紒"); @@ -531,7 +547,7 @@ locWorking.setAnfme(taskItem.getAnfme()); } BeanUtils.copyProperties(locWorking, locItem); - locItem.setWorkQty(0.0).setLocCode(loc.getCode()).setLocId(loc.getId()).setId(null); + locItem.setWorkQty(0.0).setLocCode(loc.getCode()).setLocId(loc.getId()).setId(null).setUpdateBy(loginUserId).setUpdateTime(new Date()); items.add(locItem); } @@ -541,13 +557,13 @@ TaskItem taskItem = taskItems.stream().findFirst().get(); //淇濆瓨鍏ュ嚭搴撴祦姘� - saveStockItems(taskItems, task, null, null, taskItem.getWkType(), taskItem.getOrderType()); + saveStockItems(taskItems, task, null, null, taskItem.getWkType(), taskItem.getOrderType(), loginUserId); if (!locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()))) { throw new CoolException("浣滀笟涓簱瀛樺垹闄ゅけ璐ワ紒锛�"); } - task.setTaskStatus(TaskStsType.UPDATED_IN.id).setUpdateTime(null); + task.setTaskStatus(TaskStsType.UPDATED_IN.id).setUpdateTime(new Date()).setUpdateBy(loginUserId); if (!taskService.updateById(task)) { throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } @@ -577,7 +593,7 @@ .eq(WaitPakin::getBarcode, task.getBarcode()) ); if (null != waitPakin) { - waitPakin.setIoStatus(Short.valueOf(PakinIOStatus.PAKIN_IO_STATUS_DONE.val)); + waitPakin.setIoStatus(PakinIOStatus.PAKIN_IO_STATUS_DONE.val); if (!waitPakinService.updateById(waitPakin)) { throw new CoolException("鏇存柊缁勬墭鐘舵�佸け璐ワ紒锛�"); } @@ -736,11 +752,10 @@ */ @Synchronized @Transactional(rollbackFor = Exception.class) - public void complateOutStock(Task task) throws Exception { + public void complateOutStock(Task task, Long loginUserId) throws Exception { if (Objects.isNull(task)) { throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); } - Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, task.getOrgLoc())); if (Objects.isNull(loc)) { throw new CoolException("搴撲綅涓嶅瓨鍦紒锛�"); @@ -763,7 +778,11 @@ for (LocItem item : locItems) { LocItemWorking working = new LocItemWorking(); BeanUtils.copyProperties(item, working); - working.setId(null).setTaskId(task.getId()).setLocItemId(item.getId()); + working.setId(null) + .setTaskId(task.getId()) + .setLocItemId(item.getId()) + .setUpdateBy(loginUserId) + .setUpdateTime(new Date()); workings.add(working); } @@ -775,7 +794,7 @@ //鏇存柊搴撲綅鏄庣粏 subtractLocItem(loc); } catch (Exception e) { - log.error("<UNK>", e); + logger.error("<UNK>", e); throw new CoolException(e.getMessage()); } @@ -794,14 +813,14 @@ throw new CoolException("娉㈡鏄庣粏涓嶅瓨鍦紒锛�"); } try { - saveOutStockItem(maps.get(key), waveItem); + saveOutStockItem(maps.get(key), waveItem, loginUserId); } catch (Exception e) { throw new CoolException(e.getMessage()); } }); } else { try { - saveOutStockItem(taskItems, null); + saveOutStockItem(taskItems, null, loginUserId); } catch (Exception e) { throw new CoolException(e.getMessage()); } @@ -811,6 +830,8 @@ if (!locService.update(new LambdaUpdateWrapper<Loc>() .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type) .set(Loc::getBarcode, null) + .set(Loc::getUpdateBy, loginUserId) + .set(Loc::getUpdateTime, new Date()) .eq(Loc::getId, loc.getId()))) { throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } @@ -818,21 +839,23 @@ if (task.getTaskType().equals(TaskType.TASK_TYPE_PICK_AGAIN_OUT.type) || task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_OUT.type)) { if (!this.update(new LambdaUpdateWrapper<Task>() .eq(Task::getId, task.getId()) + .set(Task::getUpdateBy, loginUserId) + .set(Task::getUpdateTime, new Date()) .set(Task::getTaskStatus, TaskStsType.WAVE_SEED.id))) { throw new CoolException("搴撳瓨鐘舵�佹洿鏂板け璐ワ紒锛�"); } } else { if (!this.update(new LambdaUpdateWrapper<Task>() .eq(Task::getId, task.getId()) + .set(Task::getUpdateBy, loginUserId) + .set(Task::getUpdateTime, new Date()) .set(Task::getTaskStatus, TaskStsType.UPDATED_OUT.id))) { throw new CoolException("搴撳瓨鐘舵�佹洿鏂板け璐ワ紒锛�"); } - //鍏ㄦ澘鍑哄簱锛屽垹闄や复鏃跺簱瀛� if (!locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()))) { throw new CoolException("涓存椂搴撳瓨娓呴櫎澶辫触锛侊紒"); } - } } @@ -844,7 +867,7 @@ * @version 1.0 */ @Transactional(rollbackFor = Exception.class) - public void saveOutStockItem(List<TaskItem> taskItems, WaveItem waveItem) throws Exception { + public void saveOutStockItem(List<TaskItem> taskItems, WaveItem waveItem, Long loginUserId) throws Exception { Stock stock = new Stock(); String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_STOCK_CODE, null); if (StringUtils.isBlank(ruleCode)) { @@ -852,6 +875,8 @@ } Double sum = taskItems.stream().mapToDouble(TaskItem::getAnfme).sum(); stock.setCode(ruleCode) + .setUpdateBy(loginUserId) + .setUpdateTime(new Date()) .setAnfme(sum); if (Objects.isNull(waveItem)) { stock.setWkType(Short.parseShort(OrderWorkType.ORDER_WORK_TYPE_STOCK_OUT.type)) @@ -870,6 +895,8 @@ StockItem stockItem = new StockItem(); BeanUtils.copyProperties(item, stockItem); stockItem.setSourceItemId(item.getOrderItemId()) + .setUpdateBy(loginUserId) + .setUpdateTime(new Date()) .setStockCode(stock.getCode()) .setId(null) .setStockId(stock.getId()); @@ -901,7 +928,7 @@ * @version 1.0 */ @Transactional(rollbackFor = Exception.class) - public void complateInstock(Task task) { + public void complateInstock(Task task, Long loginUserId) { if (Objects.isNull(task)) { return; } @@ -921,7 +948,7 @@ } try { //鏇存柊搴撲綅鏄庣粏 - saveLocItem(taskItems, task.getId()); + saveLocItem(taskItems, task.getId(), loginUserId); } catch (Exception e) { throw new CoolException("搴撲綅鏄庣粏鏇存柊澶辫触锛侊紒"); } @@ -936,10 +963,11 @@ List<TaskItem> items = orderMap.get(key); try { //淇濆瓨搴撳瓨鏄庣粏 - saveStockItems(items, task, pakinItem.getId(), pakinItem.getAsnCode(), pakinItem.getWkType(), pakinItem.getType()); + saveStockItems(items, task, pakinItem.getId(), pakinItem.getAsnCode(), pakinItem.getWkType(), pakinItem.getType(), loginUserId); //绉诲嚭鏀惰揣鍖哄簱瀛橈紝 淇敼缁勬墭鐘舵�� - removeReceiptStock(pakinItem); + removeReceiptStock(pakinItem, loginUserId); } catch (Exception e) { + logger.error("<UNK>", e); throw new CoolException(e.getMessage()); } }); @@ -954,24 +982,26 @@ /** * @param + * @param loginUserId * @return * @author Ryan * @description 绉婚櫎鏀惰揣鍖哄簱瀛� * @time 2025/4/30 16:32 */ @Transactional(rollbackFor = Exception.class) - public void removeReceiptStock(WaitPakinItem pakinItem) { + public void removeReceiptStock(WaitPakinItem pakinItem, Long loginUserId) { WarehouseAreasItem itemServiceOne = warehouseAreasItemService.getOne(new LambdaQueryWrapper<WarehouseAreasItem>() .eq(WarehouseAreasItem::getId, pakinItem.getSource())); if (Objects.isNull(itemServiceOne)) { throw new CoolException("鏁版嵁閿欒锛氳鏌ョ湅璇疯揣鍖哄簱瀛樻槸鍚﹀瓨鍦紒锛�"); } - Double workQty = itemServiceOne.getWorkQty() - pakinItem.getAnfme(); - Double qty = itemServiceOne.getQty() + pakinItem.getAnfme(); + Double workQty = Math.round((itemServiceOne.getWorkQty() - pakinItem.getAnfme()) * 10000) / 10000.0; + Double qty = Math.round((itemServiceOne.getQty() + pakinItem.getAnfme()) * 10000) / 10000.0; itemServiceOne.setWorkQty(workQty).setQty(qty); if (!waitPakinService.update(new LambdaUpdateWrapper<WaitPakin>() .set(WaitPakin::getIoStatus, PakinIOStatus.PAKIN_IO_STATUS_TASK_DONE.val) + .set(WaitPakin::getUpdateBy, loginUserId) .eq(WaitPakin::getId, pakinItem.getPakinId()))) { throw new CoolException("缁勬嫋鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } @@ -981,6 +1011,7 @@ throw new CoolException("鏀惰揣鍖虹墿鏂欏垹闄ゅけ璐ワ紒锛�"); } } else { + itemServiceOne.setUpdateBy(loginUserId).setUpdateTime(null); if (!warehouseAreasItemService.updateById(itemServiceOne)) { throw new CoolException("鏀惰揣鍖哄簱瀹屾垚鏁伴噺淇敼澶辫触锛侊紒"); } @@ -989,13 +1020,14 @@ /** * @param + * @param loginUserId * @return * @author Ryan * @description 鏇存柊搴撲綅鏄庣粏 * @time 2025/4/15 15:28 */ @Transactional(rollbackFor = Exception.class) - public void saveLocItem(List<TaskItem> items, Long taskId) throws Exception { + public void saveLocItem(List<TaskItem> items, Long taskId, Long loginUserId) throws Exception { Task task = this.getById(taskId); if (Objects.isNull(task)) { throw new CoolException("浠诲姟涓嶅瓨鍦�!!"); @@ -1008,6 +1040,7 @@ BeanUtils.copyProperties(taskItem, item); item.setLocCode(loc.getCode()).setId(null) .setLocId(loc.getId()) + .setUpdateBy(loginUserId) .setWkType(taskItem.getWkType()) .setType(taskItem.getOrderType()); locItems.add(item); @@ -1021,10 +1054,11 @@ * 鐢熸垚鍏ュ簱搴撳瓨鏄庣粏 * * @param items + * @param loginUserId * @return */ @Transactional(rollbackFor = Exception.class) - public void saveStockItems(List<TaskItem> items, Task task, Long id, String code, Short wkType, String type) throws + public void saveStockItems(List<TaskItem> items, Task task, Long id, String code, Short wkType, String type, Long loginUserId) throws Exception { Stock stock = new Stock(); String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_STOCK_CODE, null); @@ -1038,6 +1072,7 @@ .setAnfme(sum) .setWkType(wkType) .setBarcode(task.getBarcode()) + .setUpdateBy(loginUserId) .setType(type); if (task.getTaskType().equals(TaskType.TASK_TYPE_IN.type) || task.getTaskType().equals(TaskType.TASK_TYPE_MERGE_IN.type) || @@ -1061,6 +1096,7 @@ .setStockCode(stock.getCode()) .setBarcode(task.getBarcode()) .setSourceItemId(item.getOrderItemId()) + .setUpdateBy(loginUserId) .setId(null) .setStockId(stock.getId()); stockItems.add(stockItem); -- Gitblit v1.9.1