From 0642c06251d5c9d1a942a4290479e79fe4d44441 Mon Sep 17 00:00:00 2001
From: Dominika Zemanovicova <xzemanov@fi.muni.cz>
Date: Sun, 16 Apr 2023 15:38:00 +0200
Subject: [PATCH] Change AnswerMapper to map to entities inside dto

---
 .../moduleexercise/answer/AnswerFacade.java   |  9 -------
 .../moduleexercise/answer/AnswerMapper.java   | 25 +++++++++++++++----
 2 files changed, 20 insertions(+), 14 deletions(-)

diff --git a/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerFacade.java b/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerFacade.java
index 57ad9053..d0f88ecb 100644
--- a/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerFacade.java
+++ b/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerFacade.java
@@ -89,15 +89,6 @@ public class AnswerFacade {
      * @param id of answer to delete
      */
     public void delete(long id) {
-        var answer = answerService.find(id);
-
-        Question question;
-        question = questionService.find(answer.getQuestion().getId());
-
-        var questionAnswers = question.getAnswers();
-        questionAnswers.removeIf(a -> a.getId() == answer.getId());
-        question.setAnswers(questionAnswers);
-
         answerService.delete(id);
     }
 }
diff --git a/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerMapper.java b/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerMapper.java
index f1cb4626..e365d778 100644
--- a/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerMapper.java
+++ b/application/module-exercise/src/main/java/org/fuseri/moduleexercise/answer/AnswerMapper.java
@@ -4,7 +4,12 @@ import org.fuseri.model.dto.exercise.AnswerCreateDto;
 import org.fuseri.model.dto.exercise.AnswerDto;
 import org.fuseri.model.dto.exercise.AnswerInQuestionCreateDto;
 import org.fuseri.moduleexercise.common.DomainMapper;
+import org.fuseri.moduleexercise.question.Question;
+import org.fuseri.moduleexercise.question.QuestionService;
 import org.mapstruct.Mapper;
+import org.mapstruct.Mapping;
+import org.mapstruct.Named;
+import org.springframework.beans.factory.annotation.Autowired;
 
 import java.util.List;
 import java.util.Set;
@@ -12,8 +17,16 @@ import java.util.Set;
 /**
  * Mapper between Answers and their corresponding DTOs
  */
-@Mapper
-public interface AnswerMapper extends DomainMapper<Answer, AnswerDto> {
+@Mapper(componentModel = "spring", uses = {QuestionService.class})
+public abstract class AnswerMapper implements DomainMapper<Answer, AnswerDto> {
+
+    @Autowired
+    private QuestionService questionService;
+
+    @Named("mapIdToQuestion")
+    public Question mapIdToQuestion(Long id) {
+        return questionService.find(id);
+    }
 
     /**
      * Convert DTO of type AnswerCreateDto to Answer
@@ -21,7 +34,8 @@ public interface AnswerMapper extends DomainMapper<Answer, AnswerDto> {
      * @param dto DTO to be converted
      * @return corresponding Answer entity created from DTO
      */
-    Answer fromCreateDto(AnswerCreateDto dto);
+    @Mapping(target = "question", source = "dto.questionId", qualifiedByName = "mapIdToQuestion")
+    public abstract Answer fromCreateDto(AnswerCreateDto dto);
 
     /**
      * Convert List of AnswerInQuestionCreateDto to List of corresponding Answers
@@ -29,12 +43,13 @@ public interface AnswerMapper extends DomainMapper<Answer, AnswerDto> {
      * @param dtos to be converted
      * @return corresponding list of Answers
      */
-    Set<Answer> fromCreateDtoList(List<AnswerInQuestionCreateDto> dtos);
+    public abstract Set<Answer> fromCreateDtoList(List<AnswerInQuestionCreateDto> dtos);
 
     /**
      * Convert DTO of type AnswerInQuestionCreateDto to Answer
+     *
      * @param dto DTO to be converted
      * @return corresponding Answer entity created from DTO
      */
-    Answer fromCreateDto(AnswerInQuestionCreateDto dto);
+    public abstract Answer fromCreateDto(AnswerInQuestionCreateDto dto);
 }
-- 
GitLab