From 4d45de01e35f8b271e5ba25439b574a8b67bc5eb Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期五, 26 十二月 2025 14:00:55 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/StaReserveServiceImpl.java |   65 +++++++++++++++++++++++++++++++-
 1 files changed, 62 insertions(+), 3 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/StaReserveServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/StaReserveServiceImpl.java
index 9c37886..95329c7 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/StaReserveServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/StaReserveServiceImpl.java
@@ -1,12 +1,71 @@
 package com.zy.acs.manager.manager.service.impl;
 
-import com.zy.acs.manager.manager.mapper.StaReserveMapper;
-import com.zy.acs.manager.manager.entity.StaReserve;
-import com.zy.acs.manager.manager.service.StaReserveService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.zy.acs.manager.common.exception.BusinessException;
+import com.zy.acs.manager.manager.entity.Sta;
+import com.zy.acs.manager.manager.entity.StaReserve;
+import com.zy.acs.manager.manager.entity.Task;
+import com.zy.acs.manager.manager.enums.StaReserveStateType;
+import com.zy.acs.manager.manager.enums.StaReserveType;
+import com.zy.acs.manager.manager.enums.StatusType;
+import com.zy.acs.manager.manager.mapper.StaMapper;
+import com.zy.acs.manager.manager.mapper.StaReserveMapper;
+import com.zy.acs.manager.manager.service.StaReserveService;
+import com.zy.acs.manager.manager.service.StaService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.Date;
+import java.util.Optional;
 
 @Service("staReserveService")
 public class StaReserveServiceImpl extends ServiceImpl<StaReserveMapper, StaReserve> implements StaReserveService {
 
+    public static final Long RESERVE_EXPIRE_TIME = 30 * 60 * 1000L;
+
+    @Autowired
+    private StaService staService;
+    @Autowired
+    private StaMapper staMapper;
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public StaReserve reserveStaIn(Sta sta, Task task, Integer qty) {
+        qty = Optional.ofNullable(qty).orElse(1);
+
+        // reserve sta in
+        if (qty < staMapper.tryReserveIn(sta.getId(), qty)) {
+            throw new BusinessException("Sta[" + sta.getStaNo() + "] can't reserve IN");
+        }
+        Date now = new Date();
+
+        // save staReserve
+        StaReserve reserve = new StaReserve();
+        reserve.setStaId(sta.getId());
+        reserve.setTaskId(task.getId());
+        reserve.setType(StaReserveType.IN.toString());
+        reserve.setQty(qty);
+        reserve.setState(StaReserveStateType.RESERVED.toString());
+
+        reserve.setUniqKey(this.generateReserveUniqKey(sta.getId(), task.getId()));
+        reserve.setExpireTime(new Date(now.getTime() + RESERVE_EXPIRE_TIME));
+
+        reserve.setStatus(StatusType.ENABLE.val);
+        reserve.setCreateTime(now);
+        reserve.setUpdateTime(now);
+
+        if (!this.save(reserve)) {
+            staMapper.releaseReserveIn(sta.getId(), qty);
+            throw new BusinessException("reserve record insert failed");
+        }
+
+        return reserve;
+    }
+
+
+    private String generateReserveUniqKey(Long staId, Long taskId) {
+        return "STA:" + staId + "-TASK:" + taskId + "-T";
+    }
+
 }

--
Gitblit v1.9.1