From e1749547c76a5d8bae94e47d38d4d75b481610c1 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期四, 09 九月 2021 10:51:15 +0800
Subject: [PATCH] #

---
 src/main/java/zy/cloud/wms/common/service/erp/ErpService.java |   56 +++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 49 insertions(+), 7 deletions(-)

diff --git a/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java b/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
index a33e517..eefc7a0 100644
--- a/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
+++ b/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
@@ -9,10 +9,14 @@
 import zy.cloud.wms.common.model.BillDto;
 import zy.cloud.wms.common.service.erp.entity.UploadBill;
 import zy.cloud.wms.common.service.erp.entity.UploadBillDetail;
+import zy.cloud.wms.manager.entity.DocLog;
 import zy.cloud.wms.manager.entity.DocType;
 import zy.cloud.wms.manager.entity.Mat;
+import zy.cloud.wms.manager.entity.RequestLog;
+import zy.cloud.wms.manager.service.DocLogService;
 import zy.cloud.wms.manager.service.DocTypeService;
 import zy.cloud.wms.manager.service.MatService;
+import zy.cloud.wms.manager.service.RequestLogService;
 import zy.cloud.wms.manager.utils.HttpHandler;
 
 import java.util.ArrayList;
@@ -30,18 +34,27 @@
     private DocTypeService docTypeService;
     @Autowired
     private MatService matService;
+    @Autowired
+    private RequestLogService requestLogService;
+    @Autowired
+    private DocLogService docLogService;
+
     /**
      * 鍗曟嵁涓婃姤
      */
-    public Boolean uploadBill(List<BillDto> dtos, Integer docId, String docNumber){
+    public ErpR uploadBill(List<BillDto> dtos, Integer docId, String docNumber){
         try {
+            Date now = new Date();
             if (Cools.isEmpty(dtos)) {
-                return false;
+                return new ErpR(false, null);
             }
             DocType docType = docTypeService.selectById(docId);
             if (Cools.isEmpty(docType)) {
-                return false;
+                return new ErpR(false, null);
             }
+
+            // 鏃ュ織
+            List<DocLog> docLogs = new ArrayList<>();
 
             UploadBill uploadBill = new UploadBill();
             uploadBill.setNumber(docNumber);
@@ -65,8 +78,20 @@
                 detl.setPrice(0);
                 detl.setUnit(mat==null?"鏆傛棤":mat.getUnit());
                 detail.add(detl);
+
+                // 鏃ュ織
+                docLogs.add(new DocLog(
+                        docNumber,    // 鍗曟嵁缂栧彿
+                        docId.longValue(),    // 鍗曟嵁绫诲瀷
+                        null,    // 鍗曟嵁鍚嶇О
+                        dto.getMatnr(),    // 鍟嗗搧缂栧彿
+                        dto.getQty(),    // 涓婃姤鏁伴噺
+                        1,    // 缁撴灉
+                        now,    // 涓婃姤鏃堕棿
+                        null    // 澶囨敞
+                ));
             }
-            System.out.println(JSON.toJSONString(uploadBill));
+            log.warn(JSON.toJSONString(uploadBill));
             String response = new HttpHandler.Builder()
                     .setUri(ErpScheduler.URI)
                     .setPath(ErpScheduler.UPLOAD_BILL)
@@ -74,18 +99,35 @@
                     .build()
                     .doPost();
 
+            try {
+                for (DocLog docLog : docLogs) {
+                    docLogService.insert(docLog);
+                }
+
+                // 鏃ュ織璁板綍
+                RequestLog logInfo = new RequestLog();
+                logInfo.setName("鍗曟嵁涓婁紶锛屽崟鎹被鍨�" + docId);
+                logInfo.setRequest(JSON.toJSONString(uploadBill)); // 鍏ュ弬
+                logInfo.setResponse(response); // 鍑哄弬
+                logInfo.setCreateTime(new Date());
+                requestLogService.insert(logInfo);
+            } catch (Exception e) {
+                log.error(e.getMessage());
+            }
+
+
             if (!Cools.isEmpty(response)) {
                 log.warn(response);
                 Result result = JSON.parseObject(response, Result.class);
                 if (result.getCode() != 1) {
-                    return false;
+                    return new ErpR(false, result.getMsg());
                 }
             }
         } catch (Exception e) {
             e.printStackTrace();
-            return false;
+            return new ErpR(false, e.getMessage());
         }
-        return Boolean.TRUE;
+        return new ErpR(true, null);
     }
 
 

--
Gitblit v1.9.1