From 7d55f35e2aaa689ef4a02ec811f3ac7dbeeb59d2 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期一, 13 七月 2020 19:39:10 +0800
Subject: [PATCH] 优化采购

---
 service-front/src/main/java/com/java110/front/smo/api/impl/ApiSMOImpl.java |   41 ++++++++++++++++++++++++++++++++++++++---
 1 files changed, 38 insertions(+), 3 deletions(-)

diff --git a/service-front/src/main/java/com/java110/front/smo/api/impl/ApiSMOImpl.java b/service-front/src/main/java/com/java110/front/smo/api/impl/ApiSMOImpl.java
index 895bf20..9da2711 100644
--- a/service-front/src/main/java/com/java110/front/smo/api/impl/ApiSMOImpl.java
+++ b/service-front/src/main/java/com/java110/front/smo/api/impl/ApiSMOImpl.java
@@ -1,10 +1,14 @@
 package com.java110.front.smo.api.impl;
 
 import com.alibaba.fastjson.JSONObject;
-import com.java110.front.smo.api.IApiSMO;
 import com.java110.core.component.BaseComponentSMO;
+import com.java110.core.context.IPageData;
+import com.java110.entity.component.ComponentValidateResult;
+import com.java110.front.smo.api.IApiSMO;
 import com.java110.utils.constant.CommonConstant;
 import com.java110.utils.constant.ServiceConstant;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.StringUtil;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -13,6 +17,7 @@
 import org.springframework.web.client.HttpStatusCodeException;
 import org.springframework.web.client.RestTemplate;
 
+import javax.servlet.http.HttpServletRequest;
 import java.util.Map;
 
 @Service("apiSMOImpl")
@@ -25,8 +30,38 @@
     private RestTemplate restTemplate;
 
     @Override
-    public ResponseEntity<String> doApi(String body, Map<String, String> headers) {
+    protected ComponentValidateResult validateStoreStaffCommunityRelationship(IPageData pd, RestTemplate restTemplate) {
+        // 鏍¢獙 鍛樺伐鍜屽晢鎴锋槸鍚︽湁鍏崇郴
+        ResponseEntity responseEntity = getStoreInfo(pd, restTemplate);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return new ComponentValidateResult("", "", "", pd.getUserId(), pd.getUserName());
+        }
 
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "鏍规嵁鐢ㄦ埛ID鏌ヨ鍟嗘埛ID澶辫触锛屾湭鍖呭惈storeId鑺傜偣");
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeTypeCd", "鏍规嵁鐢ㄦ埛ID鏌ヨ鍟嗘埛绫诲瀷澶辫触锛屾湭鍖呭惈storeTypeCd鑺傜偣");
+
+        String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
+        String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
+
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+
+        String communityId = "";
+        if (paramIn != null && paramIn.containsKey("communityId") && !StringUtil.isEmpty(paramIn.getString("communityId"))) {
+            communityId = paramIn.getString("communityId");
+            checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
+        }
+        return new ComponentValidateResult(storeId, storeTypeCd, communityId, pd.getUserId(), pd.getUserName());
+    }
+
+    @Override
+    public ResponseEntity<String> doApi(String body, Map<String, String> headers, HttpServletRequest request) {
+        HttpHeaders header = new HttpHeaders();
+        IPageData pd = (IPageData) request.getAttribute(CommonConstant.CONTEXT_PAGE_DATA);
+
+        ComponentValidateResult result = this.validateStoreStaffCommunityRelationship(pd, restTemplate);
+        header.add("user-id", result.getUserId());
+        header.add("user-name", result.getUserName());
+        header.add("store-id", result.getStoreId());
         logger.debug("api璇锋眰澶�" + headers + ";璇锋眰鍐呭锛�" + body);
         HttpMethod method = null;
         String url = ServiceConstant.SERVICE_API_URL + "/api/" + headers.get(CommonConstant.HTTP_SERVICE);
@@ -44,7 +79,7 @@
             throw new IllegalArgumentException("涓嶆敮鎸佺殑璇锋眰鏂瑰紡" + headers.get(CommonConstant.HTTP_METHOD));
         }
 
-        HttpHeaders header = new HttpHeaders();
+
         for (String key : headers.keySet()
         ) {
             header.add(key, headers.get(key));

--
Gitblit v1.8.0