From e328acd399dae70ccdf413a6dce94272563477b5 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期一, 18 十二月 2023 15:03:06 +0800
Subject: [PATCH] 格式调整

---
 ycl-platform/src/main/java/com/ycl/common/dingding/DingCommon.java |  100 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 89 insertions(+), 11 deletions(-)

diff --git a/ycl-platform/src/main/java/com/ycl/common/dingding/DingCommon.java b/ycl-platform/src/main/java/com/ycl/common/dingding/DingCommon.java
index f3f58e4..9898fd2 100644
--- a/ycl-platform/src/main/java/com/ycl/common/dingding/DingCommon.java
+++ b/ycl-platform/src/main/java/com/ycl/common/dingding/DingCommon.java
@@ -62,6 +62,7 @@
 //        鍒ゆ柇ding 淇℃伅鏄惁瀛樺湪
         boolean hasDing = redisTemplate.hasKey("ding");
         if (hasDing) {
+            log.info("redis姝e父鏈夋秷鎭�");
             String dingStr = redisTemplate.opsForValue().get("ding");
             JSONObject dingObj = JSONObject.parseObject(dingStr);
             String getToken = dingObj.getString("token");
@@ -74,6 +75,7 @@
             postClient.addParameter("auth_code", code);//涓存椂鎺堟潈鐮�
             String apiResult = postClient.post();
             JSONObject resObj = parsingJson(apiResult);
+            log.info("resObj--------------->{}",resObj);
             if (null != resObj) {
                 resObj = resObj.getJSONObject("data");
                 redisTemplate.opsForValue().set("realmId", resObj.getString("realmId"));
@@ -84,7 +86,6 @@
                 DingUserInfo dingUserInfo = BeanUtil.toBean(resObj, DingUserInfo.class);
                 String accId = DingEncodeUtil.getMD5(resObj.getString("employeeCode").getBytes());
                 dingUserInfo.setUserId(Long.parseLong(accId));
-                dingUserInfo.setAccountId(resObj.getLong("accountId"));
                 return dingUserInfo;
             }
         }
@@ -95,7 +96,7 @@
      * 鏍规嵁鍛樺伐Code鏌ヨ璇︽儏
      *
      * @param employeeCode 鍛樺伐code鍒楄〃
-     * @param TENANT_ID    绉熸埛id
+     * @param tenantId    绉熸埛id
      * @return
      */
     public JSONObject getEmpByCode(String employeeCode, String tenantId) {
@@ -127,13 +128,34 @@
         postClient.addParameter("tenantId", dingConfig.getTenantId());
         postClient.addParameter("msg", getJsonStringText(content));
         String apiResult = postClient.post();
+        log.info("apiResult------>{}",apiResult);
         JSONObject resObj = parsingJson(apiResult);
         if (null != resObj) {
             resObj = resObj.getJSONObject("data");
         }
         return resObj;
     }
-
+    /**
+     * 鍙戦�乵arkdown娑堟伅
+     *
+     * @param receiverIds 鎺ユ敹浜虹敤鎴稩D(accountId)锛� 澶氫釜浜烘椂浣跨敤鍗婅閫楀彿鍒嗛殧锛�
+     * @param text     娑堟伅锛屾渶濂�500瀛椾互鍐�
+     * @return
+     */
+    public JSONObject sendDingMsgMarkDown(String receiverIds, String title,String text) {
+        //鑾峰彇鐢ㄦ埛淇℃伅
+        PostClient postClient = executableClient.newPostClient(POST_SEND_NOTIFY);
+        postClient.addParameter("receiverIds", receiverIds);
+        postClient.addParameter("tenantId", dingConfig.getTenantId());
+        postClient.addParameter("msg", getJsonMarkDown(title,text));
+        String apiResult = postClient.post();
+        log.info("apiResult------>{}",apiResult);
+        JSONObject resObj = parsingJson(apiResult);
+        if (null != resObj) {
+            resObj = resObj.getJSONObject("data");
+        }
+        return resObj;
+    }
     /**
      * 鍙戦�侀摼鎺ユ秷鎭�
      *
@@ -240,6 +262,7 @@
         orgLambdaQueryWrapper.likeRight(UmsDepart::getCode, "GO_");
         List<UmsDepart> orgList = umsDepartService.list(orgLambdaQueryWrapper);
         Set<DingUserInfo> dingUserInfoList = new HashSet<>();
+        List<String> employeeCodes = new ArrayList();
         for (UmsDepart org : orgList) {
             if (ObjectUtil.isNotEmpty(org.getCode())) {
                 IntelligentGetClient intelligentGetClient = executableClient.newIntelligentGetClient(POST_PERSON_INFO_BY_ORG_CODE);
@@ -276,6 +299,7 @@
                                 JSONObject data = dataArr.getJSONObject(i);
 //                                String empName = data.getString("employeeName");
                                 String employeeCode = data.getString("employeeCode");
+                                employeeCodes.add(employeeCode);
                                 //鏍规嵁鍛樺伐code 鑾峰彇鍛樺伐璇︽儏
                                 DingUserInfo dingUserInfo = getEmpInfoByCode(employeeCode);
                                 if (ObjectUtil.isNotEmpty(dingUserInfo)) {
@@ -289,9 +313,48 @@
                 } while (isHasPage);
             }
         }
+        //琛ュ厖accountId
+        if(CollectionUtils.isNotEmpty(employeeCodes)) {
+            log.info("寮�濮嬭ˉ鍏卆ccountId");
+            JSONArray users = getAccountId(employeeCodes);
+            if(CollectionUtils.isNotEmpty(users)) {
+                for (int i = 0; i < users.size(); i++) {
+                    JSONObject jsonObject = users.getJSONObject(i);
+                    String employeeCode = jsonObject.getString("employeeCode");
+                    String accountId = jsonObject.getString("accountId");
+                    Optional<DingUserInfo> first = dingUserInfoList.stream().filter(dingUserInfo -> dingUserInfo.getEmployeeCode().equals(employeeCode))
+                            .findFirst();
+                    if(first.isPresent()){
+                        DingUserInfo dingUserInfo = first.get();
+                        dingUserInfo.setAccountId(Long.parseLong(accountId));
+                    }
+                }
+            }
+        }
+
         JSONArray arr = new JSONArray(Collections.singletonList(dingUserInfoList));
         redisTemplate.opsForValue().set("userJsonList", arr.toJSONString());
         return dingUserInfoList;
+    }
+    /**
+     * 鏍规嵁鍛樺伐code 鑾峰彇鍛樺伐accountId
+     *
+     * @param employeeCodes 鍛樺伐code
+     * @return 閽夐拤鐢ㄦ埛浣撶郴瀹炰綋瀵硅薄
+     */
+    private JSONArray getAccountId(List<String> employeeCodes) {
+        log.info("Code鍙傛暟闆嗗悎------>{}",employeeCodes);
+        PostClient postClient = executableClient.newPostClient(POST_ACCOUNTID_BY_EMPLOYEECODE);
+        for (String code : employeeCodes) {
+            postClient.addParameter("employeeCodes",code);
+        }
+        postClient.addParameter("tenantId", dingConfig.getTenantId());
+        String apiResult = postClient.post();
+        JSONObject resObj = parsingJson(apiResult);
+        if (null != resObj) {
+            return resObj.getJSONArray("data");
+        }
+        return null;
     }
 
     @Resource
@@ -324,14 +387,14 @@
                         JSONObject holdapost = jobArr.getJSONObject(0);
                         String orgCode = holdapost.getString("organizationCode");
                         if (StrUtil.isNotBlank(orgCode)) {
-                            JSONObject orgDetail = getOrgDetailByCode(orgCode);
-                            if (null != orgDetail) {
-                                String orgId = orgDetail.getString("organizationCode");
-                                String orgName = orgDetail.getString("organizationName");
-                                orgId = DingEncodeUtil.getMD5(orgId.getBytes());
+//                            JSONObject orgDetail = getOrgDetailByCode(orgCode);
+//                            if (null != orgDetail) {
+//                                String orgId = orgDetail.getString("organizationCode");
+//                                String orgName = orgDetail.getString("organizationName");
+                                Long orgId = Long.parseLong(DingEncodeUtil.getMD5(orgCode.getBytes()));
                                 empCodeObj.put("orgId", orgId);
-                                empCodeObj.put("orgName", orgName);
-                            }
+//                                empCodeObj.put("orgName", orgName);
+//                            }
                         }
                     }
                     //鑱屼綅淇℃伅
@@ -547,7 +610,22 @@
         String jsonStr = JSONObject.toJSONString(jsonObject);
         return jsonStr;
     }
-
+    /**
+     * 鎷兼帴瑕佸彂閫佺殑娑堟伅  markdown娑堟伅
+     * json瀵硅薄 蹇呴』 {"msgtype":"markdown","markdown":{"title":"棣栧睆浼氳瘽閫忓嚭鐨勫睍绀哄唴瀹�","text":"娑堟伅鍐呭"}}
+     *
+     * @param title 棣栧睆浼氳瘽閫忓嚭鐨勫睍绀哄唴瀹�
+     */
+    private String getJsonMarkDown(String title,String text) {
+        JSONObject jsonObject = new JSONObject();
+        jsonObject.put("msgtype", "markdown");//娑堟伅绫诲瀷锛屾鏃跺浐瀹氫负锛歮arkdown
+        JSONObject markdown = new JSONObject();
+        markdown.put("title", title);//棣栧睆浼氳瘽閫忓嚭鐨勫睍绀哄唴瀹�
+        markdown.put("text",text);//娑堟伅鍐呭锛屽缓璁�500瀛楃浠ュ唴
+        jsonObject.put("markdown", markdown);
+        String jsonStr = JSONObject.toJSONString(jsonObject);
+        return jsonStr;
+    }
     /**
      * 鎷兼帴瑕佸彂閫佺殑娑堟伅   閾炬帴娑堟伅
      *

--
Gitblit v1.8.0