From bab30d6a2aad0810fea7d5238c10c7635e94e604 Mon Sep 17 00:00:00 2001
From: wyu <kknd09321@nate.com>
Date: 목, 09 12월 2021 14:33:30 +0900
Subject: [PATCH] 이슈리스트, 이슈상세 API로 추가된 이슈 표시

---
 src/main/java/kr/wisestone/owl/web/controller/ApiController.java |   26 +++++++++++++++++---------
 1 files changed, 17 insertions(+), 9 deletions(-)

diff --git a/src/main/java/kr/wisestone/owl/web/controller/ApiController.java b/src/main/java/kr/wisestone/owl/web/controller/ApiController.java
index 5d4c383..7033cf2 100644
--- a/src/main/java/kr/wisestone/owl/web/controller/ApiController.java
+++ b/src/main/java/kr/wisestone/owl/web/controller/ApiController.java
@@ -1,15 +1,12 @@
 package kr.wisestone.owl.web.controller;
 
 import kr.wisestone.owl.constant.Constants;
+import kr.wisestone.owl.constant.MsgConstants;
 import kr.wisestone.owl.domain.Issue;
-import kr.wisestone.owl.service.GuideService;
+import kr.wisestone.owl.exception.OwlRuntimeException;
 import kr.wisestone.owl.service.IssueService;
 import kr.wisestone.owl.util.ConvertUtil;
-import kr.wisestone.owl.util.MapUtil;
-import kr.wisestone.owl.web.condition.GuideCondition;
-import kr.wisestone.owl.web.form.GuideForm;
 import kr.wisestone.owl.web.form.IssueApiForm;
-import kr.wisestone.owl.web.form.IssueForm;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.domain.Pageable;
 import org.springframework.http.MediaType;
@@ -21,6 +18,7 @@
 import org.springframework.web.multipart.MultipartHttpServletRequest;
 
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 @Controller
@@ -45,13 +43,23 @@
     @RequestMapping(value = "api/issue", method = RequestMethod.POST)
     public
     @ResponseBody
-    Map<String, Object> addIssue(MultipartHttpServletRequest request) throws Exception {
+    Map<String, Object> addIssue(MultipartHttpServletRequest request) throws OwlRuntimeException, CloneNotSupportedException {
         Map<String, Object> resJsonData = new HashMap<>();
 
         IssueApiForm issueForm = IssueApiForm.make(ConvertUtil.convertJsonToMap(request.getParameter(Constants.REQ_KEY_CONTENT)), request.getFiles("file"));
-        Issue issue = this.issueService.addApiIssue(issueForm);
-        //  踰꾩쟾 �깮�꽦
-        this.issueService.addIssueVersion(issue.getId());
+        if (issueForm == null) {
+            throw new OwlRuntimeException(this.messageAccessor.getMessage(MsgConstants.API_PARAMETER_ERROR));
+        }
+        if (issueForm.getApiType() == IssueApiForm.ApiType.add) {
+            List<Issue> issues = this.issueService.addApiIssue(issueForm);
+            //  踰꾩쟾 �깮�꽦
+            for (Issue issue : issues) {
+                this.issueService.addIssueVersion(issue.getId());
+            }
+        } else {
+            this.issueService.modifyIssue(issueForm, request.getFiles("file"));
+        }
+
         return this.setSuccessMessage(resJsonData);
     }
 

--
Gitblit v1.8.0