From f73988664a12e3185288ce19359d501a1c478a64 Mon Sep 17 00:00:00 2001 From: soomanbaek Date: Mon, 14 Aug 2023 03:06:13 +0900 Subject: [PATCH] =?UTF-8?q?feat:=20=EC=A7=88=EB=AC=B8=20=EA=B0=80=EC=A0=B8?= =?UTF-8?q?=EC=98=A4=EA=B8=B0=20(#36)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../domain/question/api/QuestionApi.java | 23 ++++++++++++++++--- .../question/application/QuestionService.java | 15 +++++++++--- .../question/dao/QuestionRepository.java | 5 ++++ 3 files changed, 37 insertions(+), 6 deletions(-) diff --git a/src/main/java/blacktokkies/toquiz/domain/question/api/QuestionApi.java b/src/main/java/blacktokkies/toquiz/domain/question/api/QuestionApi.java index 4cb1d76..85a9b27 100644 --- a/src/main/java/blacktokkies/toquiz/domain/question/api/QuestionApi.java +++ b/src/main/java/blacktokkies/toquiz/domain/question/api/QuestionApi.java @@ -2,24 +2,41 @@ import blacktokkies.toquiz.domain.question.application.QuestionService; import blacktokkies.toquiz.domain.question.dto.request.CreateQuestionRequest; -import blacktokkies.toquiz.domain.question.dto.response.CreateQuestionResponse; +import blacktokkies.toquiz.domain.question.dto.response.GetQuestionsResponse; +import blacktokkies.toquiz.domain.question.dto.response.QuestionResponse; import blacktokkies.toquiz.global.common.response.SuccessResponse; import jakarta.validation.Valid; import lombok.RequiredArgsConstructor; +import org.springframework.data.domain.Pageable; +import org.springframework.data.domain.Sort; +import org.springframework.data.web.PageableDefault; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; +import java.util.List; + @RestController @RequiredArgsConstructor public class QuestionApi { private final QuestionService questionService; @PostMapping("api/panels/{panelId}/question") - public ResponseEntity> createQuestion( + public ResponseEntity> createQuestion( @RequestBody @Valid CreateQuestionRequest request, @CookieValue("active_info_id") String activeInfoId, @PathVariable Long panelId ){ - CreateQuestionResponse response = questionService.createQuestion(request, activeInfoId, panelId); + QuestionResponse response = questionService.createQuestion(request, activeInfoId, panelId); + + return ResponseEntity.ok(new SuccessResponse<>(response)); + } + + @GetMapping("api/panels/{panelId}/questions") + public ResponseEntity> getQuestions( + @PageableDefault(size = 30, sort = {"likeNum", "createdDate"}, direction = Sort.Direction.DESC) Pageable pageable, + @PathVariable Long panelId + ){ + List questionResponses = questionService.getQuestions(panelId, pageable); + GetQuestionsResponse response = GetQuestionsResponse.toDto(questionResponses, pageable); return ResponseEntity.ok(new SuccessResponse<>(response)); } diff --git a/src/main/java/blacktokkies/toquiz/domain/question/application/QuestionService.java b/src/main/java/blacktokkies/toquiz/domain/question/application/QuestionService.java index e0100a5..e8ac379 100644 --- a/src/main/java/blacktokkies/toquiz/domain/question/application/QuestionService.java +++ b/src/main/java/blacktokkies/toquiz/domain/question/application/QuestionService.java @@ -5,12 +5,15 @@ import blacktokkies.toquiz.domain.question.dao.QuestionRepository; import blacktokkies.toquiz.domain.question.domain.Question; import blacktokkies.toquiz.domain.question.dto.request.CreateQuestionRequest; -import blacktokkies.toquiz.domain.question.dto.response.CreateQuestionResponse; +import blacktokkies.toquiz.domain.question.dto.response.QuestionResponse; import blacktokkies.toquiz.global.common.error.RestApiException; import lombok.RequiredArgsConstructor; +import org.springframework.data.domain.Pageable; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import java.util.List; + import static blacktokkies.toquiz.domain.panel.exception.PanelErrorCode.NOT_EXIST_PANEL; @Service @@ -21,18 +24,24 @@ public class QuestionService { private final PanelRepository panelRepository; @Transactional - public CreateQuestionResponse createQuestion( + public QuestionResponse createQuestion( CreateQuestionRequest createQuestionRequest, String activeInfoId, Long panelId) { Question question = questionRepository.save(new Question(createQuestionRequest.getContent(), getPanel(panelId), activeInfoId)); - return CreateQuestionResponse.toDto(question); + return QuestionResponse.toDto(question); } private Panel getPanel(Long panelId){ return panelRepository.findById(panelId).orElseThrow( () -> new RestApiException(NOT_EXIST_PANEL)); } + + public List getQuestions(Long panelId, Pageable pageable) { + List questions = questionRepository.findAllByPanel(getPanel(panelId), pageable); + + return questions.stream().map(QuestionResponse::toDto).toList(); + } } diff --git a/src/main/java/blacktokkies/toquiz/domain/question/dao/QuestionRepository.java b/src/main/java/blacktokkies/toquiz/domain/question/dao/QuestionRepository.java index bd90c16..937ea85 100644 --- a/src/main/java/blacktokkies/toquiz/domain/question/dao/QuestionRepository.java +++ b/src/main/java/blacktokkies/toquiz/domain/question/dao/QuestionRepository.java @@ -1,9 +1,14 @@ package blacktokkies.toquiz.domain.question.dao; +import blacktokkies.toquiz.domain.panel.domain.Panel; import blacktokkies.toquiz.domain.question.domain.Question; +import org.springframework.data.domain.Pageable; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; +import java.util.List; + @Repository public interface QuestionRepository extends JpaRepository { + List findAllByPanel(Panel panel, Pageable pageable); }