From b839bdc85e784e545cb5d371ed3f638747fb6a06 Mon Sep 17 00:00:00 2001
From: tjx <t2856754968@163.com>
Date: 星期一, 22 十二月 2025 09:05:22 +0800
Subject: [PATCH] 新增企业微信的接口

---
 src/test/java/com/gs/xky/XkyApplicationTests.java |  302 ++++++++++++++++++++++---------------------------
 1 files changed, 136 insertions(+), 166 deletions(-)

diff --git a/src/test/java/com/gs/xky/XkyApplicationTests.java b/src/test/java/com/gs/xky/XkyApplicationTests.java
index 4e485e0..782b4ed 100644
--- a/src/test/java/com/gs/xky/XkyApplicationTests.java
+++ b/src/test/java/com/gs/xky/XkyApplicationTests.java
@@ -1,217 +1,187 @@
 package com.gs.xky;
 
-import com.gs.xky.service.VwCjScSjTsBbService;
-import com.gs.xky.service.WorkWXService;
+import com.alibaba.fastjson.JSONObject;
+import com.gs.xky.config.ApiResponse;
+import com.gs.xky.config.BodyParam;
+import com.gs.xky.config.DataAcquisitionConfiguration;
+import com.gs.xky.config.XkyCommonParam;
+import com.gs.xky.dto.BarcodeDeliveryNo;
+import com.gs.xky.dto.XkyDetail;
+import com.gs.xky.dto.XkyEntity;
+import com.gs.xky.service.*;
 import org.junit.jupiter.api.Test;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.test.context.SpringBootTest;
 
 import java.io.IOException;
-import java.util.ArrayList;
 import java.util.List;
 
 @SpringBootTest
 class XkyApplicationTests {
 
 
+    public static final String URL = "http://192.168.1.64/eHR/eHRExternalService/Service.ashx";
     @Autowired
-    private VwCjScSjTsBbService vwCjScSjTsBbService;
+    private XkyService xkyService;
 
     @Autowired
-    private WorkWXService workWXService;
+    private ApiService apiService;
 
-    /**
-     * 娴嬭瘯瀵煎嚭鐢熶骇鏁版嵁骞跺彂閫侀拤閽夋秷鎭�
-     * 鍔熻兘锛氭煡璇W_CJ_SC_SJ_TS_BB琛ㄦ暟鎹� -> 瀵煎嚭Excel -> 鍙戦�侀拤閽夋枃浠舵秷鎭�
-     */
+    @Autowired
+    private MesStaffService staffService;
+
+    @Autowired
+    private DeliveryNoticeService deliveryNoticeService;
+
+    @Autowired
+    private TblBarcodeInformationService barcodeInformationService;
+
+    @Autowired
+    private MesInvItemArnService invItemArnService;
+    @Autowired
+    private PurchaseService service;
+    @Autowired
+    private DingtalkInfoService dingtalkInfoService;
+
     @Test
-    void testExportAndSendProductionData() throws Exception {
-        System.out.println("=== 寮�濮嬫祴璇曞鍑虹敓浜ф暟鎹苟鍙戦�侀拤閽� ===");
+    void contextLoads() throws IOException {
 
-//        try {
-//            boolean result = vwCjScSjTsBbService.exportAndSendToDingtalk();
+//        List<MesInvItemArn> itemArnMinus = invItemArnService.getItemArnMinus();
 //
-//            if (result) {
-//                System.out.println("鉁� 鐢熶骇鏁版嵁瀵煎嚭骞跺彂閫佹垚鍔�");
-//                System.out.println("  - 鏁版嵁宸蹭粠 VW_CJ_SC_SJ_TS_BB 琛ㄦ煡璇�");
-//                System.out.println("  - Excel 鏂囦欢宸茬敓鎴愬苟淇濆瓨鍒� D:\\BIFile\\");
-//                System.out.println("  - 閽夐拤鏂囦欢娑堟伅宸插彂閫�");
-//            } else {
-//                System.out.println("鉁� 鐢熶骇鏁版嵁瀵煎嚭鎴栧彂閫佸け璐�");
-//            }
-//        } catch (Exception e) {
-//            System.out.println("鉁� 瀵煎嚭骞跺彂閫佹椂鍙戠敓寮傚父: " + e.getMessage());
-//            e.printStackTrace();
-//        }
+//        deliveryNoticeService.processMesInvItemArnStatusAsync(itemArnMinus);
 
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
     }
 
-    /**
-     * 娴嬭瘯鑾峰彇浼佷笟寰俊access_token
-     * 鍔熻兘锛氳皟鐢ㄤ紒涓氬井淇PI鑾峰彇access_token
-     */
     @Test
-    void testGetWorkWXAccessToken() {
-        System.out.println("=== 寮�濮嬫祴璇曡幏鍙栦紒涓氬井淇ccess_token ===");
-
-        try {
-            String accessToken = workWXService.getAccessToken();
-
-            if (accessToken != null && !accessToken.isEmpty()) {
-                System.out.println("鉁� 鎴愬姛鑾峰彇浼佷笟寰俊access_token");
-                System.out.println("  - access_token: " + accessToken);
-                System.out.println("  - token闀垮害: " + accessToken.length());
-            } else {
-                System.out.println("鉁� 鑾峰彇鐨刟ccess_token涓虹┖");
-            }
-        } catch (IOException e) {
-            System.out.println("鉁� 鑾峰彇access_token澶辫触: " + e.getMessage());
-            e.printStackTrace();
-        }
-
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
+    public void getDeviceRealTimeData() throws IOException {
+//        xkyService.GetSaveDetail();
     }
 
-    /**
-     * 娴嬭瘯閫氳繃鎵嬫満鍙疯幏鍙杣serid
-     * 鍔熻兘锛氳皟鐢ㄤ紒涓氬井淇PI閫氳繃鎵嬫満鍙锋煡璇serid
-     */
     @Test
-    void testGetUserIdByMobile() {
-        System.out.println("=== 寮�濮嬫祴璇曢�氳繃鎵嬫満鍙疯幏鍙杣serid ===");
+    void cs() throws IOException {
 
-        try {
-            String mobile = "13335712023";
-            String userid = workWXService.getUserIdByMobile(mobile);
+        String str = "22251123LM3X";
 
-            if (userid != null && !userid.isEmpty()) {
-                System.out.println("鉁� 鎴愬姛閫氳繃鎵嬫満鍙疯幏鍙杣serid");
-                System.out.println("  - 鎵嬫満鍙�: " + mobile);
-                System.out.println("  - userid: " + userid);
-            } else {
-                System.out.println("鉁� 鑾峰彇鐨剈serid涓虹┖");
-            }
-        } catch (IOException e) {
-            System.out.println("鉁� 鑾峰彇userid澶辫触: " + e.getMessage());
-            e.printStackTrace();
-        }
 
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
-    }
+        String[] split = str.split(";");
 
-    /**
-     * 娴嬭瘯鑾峰彇浼佷笟寰俊鐢ㄦ埛鍒楄〃
-     * 鍔熻兘锛氳皟鐢ㄤ紒涓氬井淇PI鑾峰彇鎵�鏈夌敤鎴风殑userid鍜岄儴闂ㄤ俊鎭�
-     */
-    @Test
-    void testGetWorkWXUserList() {
-        System.out.println("=== 寮�濮嬫祴璇曡幏鍙栦紒涓氬井淇$敤鎴峰垪琛� ===");
+        for (String s : split) {
+            XkyCommonParam param = XkyCommonParam.GetInit();
 
-        try {
-            List<WorkWXService.WorkWXUser> userList = workWXService.getUserList();
+            // 鍒涘缓 BodyParam 瀵硅薄骞惰祴鍊�
+            BodyParam bodyParam = new BodyParam();
 
-            if (userList != null && !userList.isEmpty()) {
-                System.out.println("鉁� 鎴愬姛鑾峰彇浼佷笟寰俊鐢ㄦ埛鍒楄〃");
-                System.out.println("  - 鐢ㄦ埛鎬绘暟: " + userList.size());
-                System.out.println("  - 鍓�5鏉℃暟鎹�:");
-                userList.stream().limit(5).forEach(user -> {
-                    System.out.println("    * userid: " + user.getUserid() +
-                            ", name: " + user.getName() +
-                            ", department: " + user.getDepartment());
-                });
-            } else {
-                System.out.println("鉁� 鑾峰彇鐨勭敤鎴峰垪琛ㄤ负绌�");
-            }
-        } catch (IOException e) {
-            System.out.println("鉁� 鑾峰彇鐢ㄦ埛鍒楄〃澶辫触: " + e.getMessage());
-            e.printStackTrace();
-        }
+            bodyParam.setErpCode(DataAcquisitionConfiguration.TEST_ERP_CODE);
+            bodyParam.setDeliveryNo(s);
 
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
-    }
+            param.setBody(bodyParam);
 
-    /**
-     * 娴嬭瘯鑾峰彇浼佷笟寰俊鎵撳崱鏁版嵁
-     * 鍔熻兘锛氳幏鍙栨寚瀹氭椂闂磋寖鍥村唴鐨勫憳宸ユ墦鍗¤褰�
-     */
-    @Test
-    void testGetCheckinData() {
-        System.out.println("=== 寮�濮嬫祴璇曡幏鍙栦紒涓氬井淇℃墦鍗℃暟鎹� ===");
+            ApiResponse<XkyDetail> detail = apiService.sendListRequest(param, XkyDetail.class, "https://openapi.xiekeyun.com/delivery/getDetail.json");
 
-        try {
-            List<WorkWXService.WorkWXUser> userList = workWXService.getUserList();
-
-            if (userList == null || userList.isEmpty()) {
-                System.out.println("鉁� 鏈幏鍙栧埌鐢ㄦ埛鍒楄〃锛屾棤娉曠户缁祴璇�");
+            XkyDetail deliveryNo = detail.getData();
+            System.out.println((JSONObject) JSONObject.toJSON(deliveryNo));
+            if (deliveryNo == null) {
+                System.out.println("涓虹┖鐨勯�佽揣鍗曞彿" + s);
                 return;
             }
-
-            List<String> useridList = new ArrayList<>();
-            userList.forEach(user -> useridList.add(user.getUserid()));
-
-            long endTime = System.currentTimeMillis() / 1000;
-            long startTime = endTime - 86400;
-
-            System.out.println("  - 鐢ㄦ埛鎬绘暟: " + useridList.size());
-            System.out.println("  - 寮�濮嬫椂闂�: " + new java.util.Date(startTime * 1000));
-            System.out.println("  - 缁撴潫鏃堕棿: " + new java.util.Date(endTime * 1000));
-
-            List<WorkWXService.CheckinData> checkinDataList = workWXService.getCheckinData(startTime, endTime, useridList);
-
-            if (checkinDataList != null && !checkinDataList.isEmpty()) {
-                System.out.println("鉁� 鎴愬姛鑾峰彇鎵撳崱鏁版嵁");
-                System.out.println("  - 鎵撳崱璁板綍鎬绘暟: " + checkinDataList.size());
-                System.out.println("  - 鍓�3鏉℃暟鎹�:");
-                checkinDataList.stream().limit(3).forEach(data -> {
-                    System.out.println("    * userid: " + data.getUserid() +
-                            ", 鎵撳崱鏃堕棿: " + new java.util.Date(data.getCheckinTime() * 1000) +
-                            ", 鎵撳崱绫诲瀷: " + data.getCheckinType() +
-                            ", 鍦扮偣: " + data.getLocationDetail());
-                });
-            } else {
-                System.out.println("鉁� 鑾峰彇鐨勬墦鍗℃暟鎹负绌�");
+            System.out.println("閫佽揣鍗曠姸鎬�" + deliveryNo.getStatus());
+            if ("6".equals(deliveryNo.getStatus()) || "8".equals(deliveryNo.getStatus()) || "0".equals(deliveryNo.getLogisticsStatus())) {
+                XkyEntity xkyEntity = new XkyEntity();
+                xkyEntity.setDeliveryNo(deliveryNo.getDeliveryNo());
+                xkyService.remove1(xkyEntity);
+            } else if ("1".equals(deliveryNo.getStatus()) && ("2".equals(deliveryNo.getLogisticsStatus()) || "1".equals(deliveryNo.getLogisticsStatus()))) {
+                XkyDetail detail1 = deliveryNo;
+                deliveryNoticeService.saveDeliveryNotice(detail1);
+                List<BarcodeDeliveryNo> barcodeDeliveryNos = GetBarcodeInformation(deliveryNo.getDeliveryNo());
+                barcodeInformationService.SaveBarcodeInformation(barcodeDeliveryNos, deliveryNo.getDeliveryNo());
+                if ("2".equals(deliveryNo.getLogisticsStatus())) {
+                    deliveryNoticeService.callPdaReceiptBtn("閫佽揣鍗曠鏀禰BTNOK[PL017[" + deliveryNo.getDeliveryNo(), "");
+                }
             }
-        } catch (IOException e) {
-            System.out.println("鉁� 鑾峰彇鎵撳崱鏁版嵁澶辫触: " + e.getMessage());
-            e.printStackTrace();
         }
+    }
 
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
+    private List<BarcodeDeliveryNo> GetBarcodeInformation(String deliveryNo) throws IOException {
+        XkyCommonParam param = XkyCommonParam.GetInit();
+
+        // 鍒涘缓 BodyParam 瀵硅薄骞惰祴鍊�
+        BodyParam bodyParam = new BodyParam();
+
+        bodyParam.setErpCode(DataAcquisitionConfiguration.TEST_ERP_CODE);
+        bodyParam.setDeliveryNo(deliveryNo);
+
+        param.setBody(bodyParam);
+
+
+        ApiResponse<BarcodeDeliveryNo> noList = apiService.sendListRequest(param, BarcodeDeliveryNo.class, "https://openapi.xiekeyun.com/barcode/byDeliveryNo.json");
+
+        return noList.getDataList();
     }
 
     @Test
-    void testGetCheckinDataByQwStaff() {
-        System.out.println("=== 寮�濮嬫祴璇曢�氳繃QW_STAFF琛ㄨ幏鍙栨墦鍗℃暟鎹� ===");
+    void cs1() throws IOException {
+//        DingTalkParam dingTalkParam = new DingTalkParam(0);
+//
+//        DingTalkResponse<EmployeeInfo> employeeInfoDingTalkResponse = apiService.sendListRequest(dingTalkParam, EmployeeInfo.class, "http://192.168.1.64/eHR/eHRExternalService/Service.ashx");
+//
+//        //閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃 cUnitName
+//        //http://192.168.1.64/eHR
+//        List<EmployeeInfo> collect = employeeInfoDingTalkResponse.getData().stream().filter(s -> "閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃".equals(s.getCUnitName())).collect(Collectors.toList());
+//        //System.out.println(collect.size());
+//
+//        collect.stream().filter(s->s.getEmployeeId().equals("2025130028")).forEach(System.out::println);
+//
+//        List<List<EmployeeInfo>> partition = ListUtil.partition(collect, 500);
 
-        try {
-            long endTime = System.currentTimeMillis() / 1000;
-            long startTime = endTime - 86400;
+//        partition.forEach(list -> {
+//            staffService.SaveStaff(list);
+//        });
+//        XkyCommonParam param = XkyCommonParam.GetInit();
+//        String jsonString = JSON.toJSONString(param);
+//        System.out.println(jsonString);
+    }
 
-            System.out.println("  - 寮�濮嬫椂闂�: " + new java.util.Date(startTime * 1000));
-            System.out.println("  - 缁撴潫鏃堕棿: " + new java.util.Date(endTime * 1000));
+    @Test
+    void cs2() throws IOException {
+//        DingTalkParam dingTalkParam = new DingTalkParam(1);
+//
+//        DingTalkResponse<EmployeeInfo> employeeInfoDingTalkResponse = apiService.sendListRequest(dingTalkParam, EmployeeInfo.class, "http://192.168.1.64/eHR/eHRExternalService/Service.ashx");
+//
+//        //閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃 cUnitName
+//        //http://192.168.1.64/eHR
+//        List<EmployeeInfo> collect = employeeInfoDingTalkResponse.getData().stream().filter(s -> "閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃".equals(s.getCUnitName())).collect(Collectors.toList());
+//        System.out.println(collect.size());
+//
+//        List<List<EmployeeInfo>> partition = ListUtil.partition(collect, 100);
+//
+//        partition.forEach(list -> {
+//            staffService.UpdateStaff(list);
+//
+//
+//        });
 
-            List<WorkWXService.CheckinData> checkinDataList = workWXService.getCheckinDataByQwStaff(startTime, endTime);
+    }
 
-            if (checkinDataList != null && !checkinDataList.isEmpty()) {
-                System.out.println("鉁� 鎴愬姛鑾峰彇鎵撳崱鏁版嵁");
-                System.out.println("  - 鎵撳崱璁板綍鎬绘暟: " + checkinDataList.size());
-                System.out.println("  - 鍓�5鏉℃暟鎹�:");
-                checkinDataList.stream().limit(5).forEach(data -> {
-                    System.out.println("    * userid: " + data.getUserid() +
-                            ", 鎵撳崱鏃堕棿: " + new java.util.Date(data.getCheckinTime() * 1000) +
-                            ", 鎵撳崱绫诲瀷: " + data.getCheckinType() +
-                            ", 寮傚父绫诲瀷: " + data.getExceptionType() +
-                            ", 鍦扮偣: " + data.getLocationDetail());
-                });
-            } else {
-                System.out.println("鉁� 鑾峰彇鐨勬墦鍗℃暟鎹负绌猴紙鍙兘QW_STAFF琛ㄦ棤鏁版嵁鎴栨椂闂磋寖鍥村唴鏃犳墦鍗¤褰曪級");
-            }
-        } catch (IOException e) {
-            System.out.println("鉁� 鑾峰彇鎵撳崱鏁版嵁澶辫触: " + e.getMessage());
-            e.printStackTrace();
-        }
+    @Test
+    void cs113() throws Exception {
+//        DingTalkParam dingTalkParam = new DingTalkParam(1);
+//        DingTalkResponse<EmployeeInfo> employeeInfoDingTalkResponse =
+//                apiService.sendListRequest(dingTalkParam, EmployeeInfo.class,
+//                        "http://192.168.1.64/eHR/eHRExternalService/Service.ashx");
+//
+//        List<EmployeeInfo> collect = employeeInfoDingTalkResponse.getData().stream()
+//                .filter(s -> "閫犳ⅵ鑰咃紙娴欐睙锛夌鎶�鏈夐檺鍏徃".equals(s.getCUnitName()))
+//                .collect(Collectors.toList());
 
-        System.out.println("=== 娴嬭瘯缁撴潫 ===");
+    }
+
+    @Test
+    void cs3() throws Exception {
+//        dingtalkInfoService.sendMessage("CGJY20250412166");
+
+//        XkyEntity xkyEntity = new XkyEntity();
+//        xkyEntity.setDeliveryNo("222505057541");
+//        xkyService.remove1(xkyEntity);
+
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3