From b0a706ed4d6a81c7da3777b967fa89b611d24751 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期一, 19 九月 2022 00:26:19 +0800
Subject: [PATCH] 优化 文档开发完成

---
 java110-doc/src/main/java/com/java110/doc/controller/DocController.java |  135 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 134 insertions(+), 1 deletions(-)

diff --git a/java110-doc/src/main/java/com/java110/doc/controller/DocController.java b/java110-doc/src/main/java/com/java110/doc/controller/DocController.java
index b59b262..add78eb 100644
--- a/java110-doc/src/main/java/com/java110/doc/controller/DocController.java
+++ b/java110-doc/src/main/java/com/java110/doc/controller/DocController.java
@@ -3,18 +3,21 @@
 
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.java110.doc.annotation.*;
 import com.java110.doc.entity.ApiDocDto;
 import com.java110.doc.entity.CmdDocDto;
 import com.java110.doc.entity.RequestMappingsDocDto;
 import com.java110.doc.registrar.ApiDocCmdPublishing;
 import com.java110.doc.registrar.ApiDocPublishing;
 import com.java110.utils.factory.ApplicationContextFactory;
+import org.springframework.core.annotation.AnnotationUtils;
 import org.springframework.http.*;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.client.HttpStatusCodeException;
 import org.springframework.web.client.RestTemplate;
 
 import javax.servlet.http.HttpServletRequest;
+import java.lang.annotation.Annotation;
 import java.util.List;
 
 @RestController
@@ -82,10 +85,140 @@
         return new ResponseEntity<>(JSONArray.toJSONString(cmdDocDtos), HttpStatus.OK);
     }
 
+
+    @RequestMapping(path = "/api/pageContent", method = RequestMethod.GET)
+    public ResponseEntity<String> pageContent(
+            @RequestParam("name") String name,
+            @RequestParam("serviceCode") String serviceCode,
+            @RequestParam("resource") String resource,
+            HttpServletRequest request) {
+
+        List<RequestMappingsDocDto> mappingsDocDtos = ApiDocPublishing.getMappingsDocDtos();
+
+        RequestMappingsDocDto newMappingsDocDto = null;
+        for (RequestMappingsDocDto mappingsDocDto : mappingsDocDtos) {
+            if (mappingsDocDto.getName().equals(name)) {
+                newMappingsDocDto = mappingsDocDto;
+            }
+        }
+
+        if (newMappingsDocDto == null) {
+            return new ResponseEntity<>("{}", HttpStatus.OK);
+        }
+
+        RestTemplate restTemplate = ApplicationContextFactory.getBean("restTemplate", RestTemplate.class);
+        if ("boot".equals(newMappingsDocDto.getStartWay())) {
+            restTemplate = ApplicationContextFactory.getBean("outRestTemplate", RestTemplate.class);
+        }
+        ResponseEntity<String> responseEntity = null;
+        HttpEntity<String> httpEntity = new HttpEntity<String>("", new HttpHeaders());
+        try {
+            responseEntity = restTemplate.exchange(newMappingsDocDto.getUrl()+"/doc/api/"+resource+"/"+serviceCode, HttpMethod.GET, httpEntity, String.class);
+        } catch (HttpStatusCodeException e) { //杩欓噷spring 妗嗘灦 鍦�4XX 鎴� 5XX 鏃舵姏鍑� HttpServerErrorException 寮傚父锛岄渶瑕侀噸鏂板皝瑁呬竴涓�
+            responseEntity = new ResponseEntity<String>(e.getResponseBodyAsString(), e.getStatusCode());
+        } catch (Exception e) {
+            responseEntity = new ResponseEntity<String>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
+        }
+        return responseEntity;
+    }
+
     @RequestMapping(path = "/api/{resource}/{serviceCode}", method = RequestMethod.GET)
     public ResponseEntity<String> api(@PathVariable String resource,
                                       @PathVariable String serviceCode,
                                       HttpServletRequest request) {
-        return null;
+        CmdDocDto cmdDocDto = ApiDocCmdPublishing.getCmdDocs(resource,serviceCode);
+
+        if(cmdDocDto == null){
+            return new ResponseEntity<>("{}", HttpStatus.OK);
+        }
+
+        JSONObject param = JSONObject.parseObject(JSONObject.toJSONString(cmdDocDto));
+
+        Class clazz = cmdDocDto.getCmdClass();
+
+
+        doJava110ParamsDoc(clazz,param);
+
+
+        doJava110ResponseDoc(param, clazz);
+
+        doJava110ExampleDoc(param, clazz);
+
+        return new ResponseEntity<>(param.toJSONString(), HttpStatus.OK);
+    }
+
+    private void doJava110ExampleDoc(JSONObject param, Class clazz) {
+        Java110ExampleDoc java110ExampleDoc = AnnotationUtils.findAnnotation(clazz,Java110ExampleDoc.class);
+
+        if(java110ExampleDoc == null){
+            return ;
+        }
+
+        param.put("reqBody",java110ExampleDoc.reqBody());
+        param.put("resBody",java110ExampleDoc.resBody());
+    }
+
+    private void doJava110ResponseDoc(JSONObject param, Class clazz) {
+        Java110ResponseDoc java110ResponseDoc = AnnotationUtils.findAnnotation(clazz,Java110ResponseDoc.class);
+
+        if(java110ResponseDoc == null){
+            return ;
+        }
+
+        Java110ParamDoc[] java110ParamDocs = java110ResponseDoc.params();
+
+        JSONArray params = new JSONArray();
+        JSONObject p = null;
+        for(Java110ParamDoc java110ParamDoc : java110ParamDocs){
+            p = new JSONObject();
+            p.put("name",java110ParamDoc.name());
+            p.put("defaultValue",java110ParamDoc.defaultValue());
+            p.put("remark",java110ParamDoc.remark());
+            p.put("type",java110ParamDoc.type());
+            p.put("length",java110ParamDoc.length());
+            p.put("parentNodeName",java110ParamDoc.parentNodeName());
+            params.add(p);
+        }
+        param.put("resParam",params);
+    }
+
+    private void doJava110ParamsDoc(Class clazz, JSONObject param) {
+
+        Java110ParamsDoc java110ParamsDoc = AnnotationUtils.findAnnotation(clazz,Java110ParamsDoc.class);
+
+        if(java110ParamsDoc == null){
+            return ;
+        }
+
+        Java110HeaderDoc[] java110HeaderDocs = java110ParamsDoc.headers();
+
+        JSONArray headers = new JSONArray();
+        JSONObject header = null;
+        for(Java110HeaderDoc java110HeaderDoc : java110HeaderDocs){
+            header = new JSONObject();
+            header.put("name",java110HeaderDoc.name());
+            header.put("defaultValue",java110HeaderDoc.defaultValue());
+            header.put("description",java110HeaderDoc.description());
+            headers.add(header);
+        }
+
+        param.put("header",headers);
+
+
+        Java110ParamDoc[] java110ParamDocs = java110ParamsDoc.params();
+
+        JSONArray params = new JSONArray();
+        JSONObject p = null;
+        for(Java110ParamDoc java110ParamDoc : java110ParamDocs){
+            p = new JSONObject();
+            header.put("name",java110ParamDoc.name());
+            header.put("defaultValue",java110ParamDoc.defaultValue());
+            header.put("remark",java110ParamDoc.remark());
+            header.put("type",java110ParamDoc.type());
+            header.put("length",java110ParamDoc.length());
+            header.put("parentNodeName",java110ParamDoc.parentNodeName());
+            params.add(p);
+        }
+        param.put("reqParam",params);
     }
 }

--
Gitblit v1.8.0