From fa41057432882ae94ea4edf816f4f76f1d6fd4ba Mon Sep 17 00:00:00 2001
From: 啊鑫 <t2856754968@163.com>
Date: 星期六, 19 四月 2025 10:41:03 +0800
Subject: [PATCH] SRM增加log日志

---
 src/main/java/com/gs/xky/service/XkyService.java |  104 ++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 80 insertions(+), 24 deletions(-)

diff --git a/src/main/java/com/gs/xky/service/XkyService.java b/src/main/java/com/gs/xky/service/XkyService.java
index 7a26aea..b907d43 100644
--- a/src/main/java/com/gs/xky/service/XkyService.java
+++ b/src/main/java/com/gs/xky/service/XkyService.java
@@ -1,6 +1,9 @@
 package com.gs.xky.service;
 
 
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.json.JSONUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.gs.xky.config.ApiResponse;
 import com.gs.xky.config.BodyParam;
@@ -9,8 +12,10 @@
 import com.gs.xky.dto.BarcodeDeliveryNo;
 import com.gs.xky.dto.XkyDetail;
 import com.gs.xky.dto.XkyEntity;
-import com.gs.xky.entity.DeliveryNotice;
+import com.gs.xky.entity.*;
 import lombok.RequiredArgsConstructor;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
@@ -22,58 +27,109 @@
 @RequiredArgsConstructor
 public class XkyService {
 
+    private static final Logger log = LoggerFactory.getLogger(XkyService.class);
     private final ApiService apiService;
-
-
     private final DeliveryNoticeService deliveryNoticeService;
 
     private final TblBarcodeInformationService barcodeInformationService;
+    private final DeliveryNoticeDetailService deliveryNoticeDetailService;
+
+    private final MesInvItemArnService mesInvItemArnService;
+    private final MesInvItemArnDetailService mesInvItemArnDetailService;
+    private final MesInvItemBarcodesService mesInvItemBarcodesService;
+
+    private final MesQaItemsDetect01Service mesQaItemsDetect01Service;
 
     public void GetSaveDetail() throws IOException {
         long currentTimeMillis = System.currentTimeMillis();
+        long startDate = currentTimeMillis - (20 * 60 * 1000); // 璁$畻 20 鍒嗛挓鍓嶇殑鏃堕棿鎴�
 
         XkyCommonParam param = XkyCommonParam.GetInit();
-
-        // 璁$畻浜斿垎閽熷墠鐨勬椂闂存埑
-        long startDate = currentTimeMillis - (65 * 60 * 1000); // 5 鍒嗛挓 = 5 * 60 * 1000 姣
-
-        // 鍒涘缓 BodyParam 瀵硅薄骞惰祴鍊�
         BodyParam bodyParam = new BodyParam();
         bodyParam.setStartDate(startDate);
         bodyParam.setEndDate(currentTimeMillis);
         bodyParam.setErpCode(DataAcquisitionConfiguration.TEST_ERP_CODE);
-        bodyParam.setStatus(new int[]{1});
-        bodyParam.setLogisticsStatus(2);
-
+        bodyParam.setStatus(new int[]{1, 6});
         param.setBody(bodyParam);
+
+        // 璁板綍璇锋眰鍙傛暟鏃ュ織
+        log.info("銆怗etSaveDetail 璇锋眰鍙傛暟銆戞椂闂�: {}, 鍙傛暟: {}", currentTimeMillis, JSONUtil.toJsonStr(param));
 
         ApiResponse<XkyEntity> noList = apiService.sendListRequest(param, XkyEntity.class, "https://openapi.xiekeyun.com/delivery/getNoList.json");
 
-//        List<String> deliveryNoList = noList.getDataList().stream().map(XkyEntity::getDeliveryNo).collect(Collectors.toList());
+        // 璁板綍杩斿洖鏁版嵁鏃ュ織
+        log.info("銆怗etSaveDetail 鍝嶅簲鏁版嵁銆戞椂闂�: {}, 杩斿洖: {}", currentTimeMillis, JSONUtil.toJsonStr(noList));
 
         List<XkyEntity> deliveryNoList = noList.getDataList();
-
-        LambdaUpdateWrapper<DeliveryNotice> deliveryNoticeWrapper = new LambdaUpdateWrapper<>();
+        if (CollUtil.isEmpty(deliveryNoList)) {
+            log.info("銆怗etSaveDetail銆戣繑鍥炲垪琛ㄤ负绌猴紝璺宠繃澶勭悊");
+            return;
+        }
 
         deliveryNoList.forEach(deliveryNo -> {
             try {
-
-                if ("4".equals(deliveryNo.getStatus()) || "8".equals(deliveryNo.getStatus())) {
-                    deliveryNoticeWrapper.clear();
-                    deliveryNoticeWrapper.eq(DeliveryNotice::getDeliveryNo, deliveryNo.getDeliveryNo());
-                    deliveryNoticeService.remove(deliveryNoticeWrapper);
+                if ("6".equals(deliveryNo.getStatus()) || "0".equals(deliveryNo.getLogisticsStatus())) {
+                    log.info("銆怗etSaveDetail銆戠Щ闄ら�佽揣鍗�: {}", deliveryNo.getDeliveryNo());
+                    remove(deliveryNo);
+                } else if ("1".equals(deliveryNo.getStatus()) && "2".equals(deliveryNo.getLogisticsStatus())) {
+                    log.info("銆怗etSaveDetail銆戝鐞嗛�佽揣鍗�: {}", deliveryNo.getDeliveryNo());
+                    XkyDetail detail = getDetail(deliveryNo.getDeliveryNo());
+                    deliveryNoticeService.saveDeliveryNotice(detail);
+                    List<BarcodeDeliveryNo> barcodeDeliveryNos = GetBarcodeInformation(deliveryNo.getDeliveryNo());
+                    barcodeInformationService.SaveBarcodeInformation(barcodeDeliveryNos, deliveryNo.getDeliveryNo());
+                    deliveryNoticeService.callPdaReceiptBtn("閫佽揣鍗曠鏀禰BTNOK[PL017[" + deliveryNo.getDeliveryNo(), "");
                 }
-
-                XkyDetail detail = getDetail(deliveryNo.getDeliveryNo());
-                deliveryNoticeService.saveDeliveryNotice(detail);
-                List<BarcodeDeliveryNo> barcodeDeliveryNos = GetBarcodeInformation(deliveryNo.getDeliveryNo());
-                barcodeInformationService.SaveBarcodeInformation(barcodeDeliveryNos, deliveryNo.getDeliveryNo());
             } catch (IOException e) {
+                log.error("銆怗etSaveDetail 澶勭悊寮傚父銆戦�佽揣鍗�: {}, 寮傚父: {}", deliveryNo.getDeliveryNo(), e.getMessage(), e);
                 throw new RuntimeException(e);
             }
         });
     }
 
+    private void remove(XkyEntity deliveryNo) {
+        LambdaUpdateWrapper<DeliveryNotice> deliveryNoticeWrapper = new LambdaUpdateWrapper<>();
+
+        deliveryNoticeWrapper.eq(DeliveryNotice::getDeliveryNo, deliveryNo.getDeliveryNo());
+
+        DeliveryNotice one = deliveryNoticeService.getOne(deliveryNoticeWrapper, false);
+
+        if (deliveryNoticeService.remove(deliveryNoticeWrapper)) {
+
+            LambdaUpdateWrapper<DeliveryNoticeDetail> updateWrapper = new LambdaUpdateWrapper<>();
+
+            updateWrapper.eq(DeliveryNoticeDetail::getPid, one.getId());
+
+            deliveryNoticeDetailService.remove(updateWrapper);
+
+            LambdaUpdateWrapper<TblBarcodeInformation> updateWrapper1 = new LambdaUpdateWrapper<>();
+
+            updateWrapper1.eq(TblBarcodeInformation::getDeliveryNo, deliveryNo.getDeliveryNo());
+
+            barcodeInformationService.remove(updateWrapper1);
+
+            LambdaQueryWrapper<MesInvItemArn> wrapper = new LambdaQueryWrapper<>();
+            wrapper.eq(MesInvItemArn::getPaperBillNo, deliveryNo.getDeliveryNo());
+
+            MesInvItemArn mesInvItemArn = mesInvItemArnService.getOne(wrapper, false);
+
+            mesInvItemArnService.remove(wrapper);
+
+            if (mesInvItemArn != null) {
+                LambdaUpdateWrapper<MesInvItemArnDetail> updateWrapper2 = new LambdaUpdateWrapper<>();
+
+                updateWrapper2.eq(MesInvItemArnDetail::getMid, mesInvItemArn.getId());
+                mesInvItemArnDetailService.remove(updateWrapper2);
+
+                LambdaUpdateWrapper<MesInvItemBarcodes> updateWrapper3 = new LambdaUpdateWrapper<>();
+
+                updateWrapper3.eq(MesInvItemBarcodes::getBillNo, mesInvItemArn.getBillNo());
+                mesInvItemBarcodesService.remove(updateWrapper3);
+
+                mesQaItemsDetect01Service.removeQa(mesInvItemArn.getBillNo());
+            }
+        }
+    }
+
     private XkyDetail getDetail(String deliveryNo) throws IOException {
         XkyCommonParam param = XkyCommonParam.GetInit();
 

--
Gitblit v1.9.3