From 2a2bc2abf283784151fe1c15047ff65d41ce5583 Mon Sep 17 00:00:00 2001
From: 吴学文 <wuxuewen@wuxuewendeMacBook-Pro.local>
Date: 星期四, 25 四月 2019 23:52:07 +0800
Subject: [PATCH] 增加小区楼信息开发中

---
 WebService/src/main/java/com/java110/web/core/BaseComponentSMO.java |   88 ++++++++++++++++++++++++++++++++++---------
 1 files changed, 69 insertions(+), 19 deletions(-)

diff --git a/WebService/src/main/java/com/java110/web/core/BaseComponentSMO.java b/WebService/src/main/java/com/java110/web/core/BaseComponentSMO.java
index 0bedf62..6977c2d 100644
--- a/WebService/src/main/java/com/java110/web/core/BaseComponentSMO.java
+++ b/WebService/src/main/java/com/java110/web/core/BaseComponentSMO.java
@@ -1,7 +1,10 @@
 package com.java110.web.core;
 
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.java110.common.cache.MappingCache;
 import com.java110.common.constant.CommonConstant;
+import com.java110.common.constant.MappingConstant;
 import com.java110.common.constant.ServiceConstant;
 import com.java110.common.exception.SMOException;
 import com.java110.common.factory.ApplicationContextFactory;
@@ -23,24 +26,25 @@
  */
 public class BaseComponentSMO extends BaseServiceSMO {
 
-    private final static Logger logger = LoggerFactory.getLogger(BaseComponentSMO.class);
+    private static Logger logger = LoggerFactory.getLogger(BaseComponentSMO.class);
 
     /**
      * 璋冪敤缁勪欢
-     * @param componentCode 缁勪欢缂栫爜
+     *
+     * @param componentCode   缁勪欢缂栫爜
      * @param componentMethod 缁勪欢鏂规硶
      * @param pd
      * @return
      */
-    protected ResponseEntity<String> invokeComponent(String componentCode,String componentMethod,IPageData pd){
+    protected ResponseEntity<String> invokeComponent(String componentCode, String componentMethod, IPageData pd) {
 
-        logger.debug("寮�濮嬭皟鐢ㄧ粍浠讹細{}",pd.toString());
+        logger.debug("寮�濮嬭皟鐢ㄧ粍浠讹細{}", pd.toString());
 
         ResponseEntity<String> responseEntity = null;
 
         Object componentInstance = ApplicationContextFactory.getBean(componentCode);
 
-        Assert.notNull(componentInstance,"鏈壘鍒扮粍浠跺搴旂殑澶勭悊绫伙紝璇风‘璁� "+componentCode);
+        Assert.notNull(componentInstance, "鏈壘鍒扮粍浠跺搴旂殑澶勭悊绫伙紝璇风‘璁� " + componentCode);
         try {
 
             Method cMethod = componentInstance.getClass().getDeclaredMethod(componentMethod, IPageData.class);
@@ -50,11 +54,11 @@
             logger.debug("缁勪欢缂栫爜{}锛岀粍浠舵柟娉晎}锛宲d 涓簕}", componentCode, componentMethod, pd.toString());
 
             responseEntity = (ResponseEntity<String>) cMethod.invoke(componentInstance, pd);
-        }catch (Exception e){
-            logger.error("璋冪敤缁勪欢澶辫触锛�",e);
-            responseEntity = new ResponseEntity<String>("璋冪敤缁勪欢"+componentCode+",缁勪欢鏂规硶"+componentMethod+"澶辫触锛�"+e.getMessage(),
+        } catch (Exception e) {
+            logger.error("璋冪敤缁勪欢澶辫触锛�", e);
+            responseEntity = new ResponseEntity<String>("璋冪敤缁勪欢" + componentCode + ",缁勪欢鏂规硶" + componentMethod + "澶辫触锛�" + e.getMessage(),
                     HttpStatus.INTERNAL_SERVER_ERROR);
-        }finally {
+        } finally {
             return responseEntity;
         }
     }
@@ -62,14 +66,15 @@
 
     /**
      * 鑾峰彇鐢ㄦ埛淇℃伅
+     *
      * @param pd
      * @param restTemplate
      * @return
      */
-    protected ResponseEntity<String> getUserInfo(IPageData pd, RestTemplate restTemplate){
-        Assert.hasLength(pd.getUserId(),"鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
+    protected ResponseEntity<String> getUserInfo(IPageData pd, RestTemplate restTemplate) {
+        Assert.hasLength(pd.getUserId(), "鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
         ResponseEntity<String> responseEntity = null;
-        responseEntity = this.callCenterService(restTemplate,pd,"", ServiceConstant.SERVICE_API_URL+"/api/query.user.userInfo?userId="+pd.getUserId(), HttpMethod.GET);
+        responseEntity = this.callCenterService(restTemplate, pd, "", ServiceConstant.SERVICE_API_URL + "/api/query.user.userInfo?userId=" + pd.getUserId(), HttpMethod.GET);
         // 杩囨护杩斿洖鎶ユ枃涓殑瀛楁锛屽彧杩斿洖name瀛楁
         //{"address":"","orderTypeCd":"Q","serviceCode":"","responseTime":"20190401194712","sex":"","localtionCd":"","userId":"302019033054910001","levelCd":"00","transactionId":"-1","dataFlowId":"-1","response":{"code":"0000","message":"鎴愬姛"},"name":"996icu","tel":"18909780341","bId":"-1","businessType":"","email":""}
 
@@ -79,27 +84,72 @@
 
     /**
      * 鏌ヨ鍟嗘埛淇℃伅
+     *
      * @return
      */
-    protected ResponseEntity<String> getStoreInfo(IPageData pd, RestTemplate restTemplate){
-        Assert.hasLength(pd.getUserId(),"鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
+    protected ResponseEntity<String> getStoreInfo(IPageData pd, RestTemplate restTemplate) {
+        Assert.hasLength(pd.getUserId(), "鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
         ResponseEntity<String> responseEntity = null;
-        responseEntity = this.callCenterService(restTemplate,pd,"", ServiceConstant.SERVICE_API_URL+"/api/query.store.byuser?userId="+pd.getUserId(), HttpMethod.GET);
+        responseEntity = this.callCenterService(restTemplate, pd, "", ServiceConstant.SERVICE_API_URL + "/api/query.store.byuser?userId=" + pd.getUserId(), HttpMethod.GET);
 
         return responseEntity;
     }
 
     /**
+     * 鏌ヨ鍟嗘埛淇℃伅
+     *
+     * @return
+     */
+    protected void checkStoreEnterCommunity(IPageData pd, String storeId, String storeTypeCd, String communityId, RestTemplate restTemplate) {
+        Assert.hasLength(pd.getUserId(), "鐢ㄦ埛鏈櫥褰曡鍏堢櫥褰�");
+        ResponseEntity<String> responseEntity = null;
+        responseEntity = this.callCenterService(restTemplate, pd, "",
+                ServiceConstant.SERVICE_API_URL + "/api/query.myCommunity.byMember?memberId=" + storeId + "&memberTypeCd="
+                        + MappingCache.getValue(MappingConstant.DOMAIN_STORE_TYPE_2_COMMUNITY_MEMBER_TYPE,storeTypeCd), HttpMethod.GET);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            throw new SMOException(1999, "杩樻湭鍏ラ┗灏忓尯锛岃鍏堝叆椹诲皬鍖�");
+        }
+
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "communitys", "杩樻湭鍏ラ┗灏忓尯锛岃鍏堝叆椹诲皬鍖�");
+
+        JSONObject community = JSONObject.parseObject(responseEntity.getBody().toString());
+
+        JSONArray communitys = community.getJSONArray("communitys");
+
+        if (communitys == null || communitys.size() == 0) {
+            throw new SMOException(1999, "杩樻湭鍏ラ┗灏忓尯锛岃鍏堝叆椹诲皬鍖�");
+        }
+
+        JSONObject currentCommunity = getCurrentCommunity(communitys,communityId);
+
+        if(currentCommunity == null){
+            throw new SMOException(1999, "浼犲叆灏忓尯ID闈炴硶锛岃姝e父鎿嶄綔");
+        }
+
+    }
+
+    private JSONObject getCurrentCommunity(JSONArray communitys,String communityId){
+        for (int communityIndex = 0; communityIndex < communitys.size(); communityIndex++) {
+            if(communityId.equals(communitys.getJSONObject(communityIndex).getString("communityId"))){
+                return communitys.getJSONObject(communityIndex);
+            }
+        }
+
+        return null;
+    }
+
+    /**
      * 妫�鏌ョ敤鎴锋槸鍚︽湁鏉冮檺
+     *
      * @param pd
      * @param restTemplate
      * @param privilegeCode
      */
-    protected void checkUserHasPrivilege(IPageData pd,RestTemplate restTemplate,String privilegeCode){
+    protected void checkUserHasPrivilege(IPageData pd, RestTemplate restTemplate, String privilegeCode) {
         ResponseEntity<String> responseEntity = null;
-        responseEntity = this.callCenterService(restTemplate,pd,"", ServiceConstant.SERVICE_API_URL+"/api/check.user.hasPrivilege?userId="+pd.getUserId()+"&pId="+privilegeCode, HttpMethod.GET);
-        if(responseEntity.getStatusCode() != HttpStatus.OK){
-            throw new SMOException(1999,"鐢ㄦ埛娌℃湁鏉冮檺鎿嶄綔鏉冮檺"+privilegeCode);
+        responseEntity = this.callCenterService(restTemplate, pd, "", ServiceConstant.SERVICE_API_URL + "/api/check.user.hasPrivilege?userId=" + pd.getUserId() + "&pId=" + privilegeCode, HttpMethod.GET);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            throw new SMOException(1999, "鐢ㄦ埛娌℃湁鏉冮檺鎿嶄綔鏉冮檺" + privilegeCode);
         }
     }
 }

--
Gitblit v1.8.0