From d438f9c81cffd2e2cbec48150b43a5a89c9ab749 Mon Sep 17 00:00:00 2001
From: 이민희 <mhlee@maprex.co.kr>
Date: 수, 16 2월 2022 15:56:56 +0900
Subject: [PATCH] - 하위이슈 직접 생성 시 프로젝트 변경 못하도록 수정 - 연관이슈 직접 생성 시 프로젝트 변경 할 경우 이슈타입도 변경 되도록 수정

---
 src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java |   70 +++++++++++++++++++++++++++++++----
 1 files changed, 62 insertions(+), 8 deletions(-)

diff --git a/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
index 7e6ecaa..92d20d5 100644
--- a/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
+++ b/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
@@ -13,13 +13,16 @@
 import kr.wisestone.owl.domain.Department;
 import kr.wisestone.owl.domain.SystemEmail;
 import kr.wisestone.owl.domain.User;
+import kr.wisestone.owl.domain.UserDepartment;
 import kr.wisestone.owl.domain.enumType.EmailType;
 import kr.wisestone.owl.exception.OwlRuntimeException;
 import kr.wisestone.owl.repository.SystemEmailRepository;
 import kr.wisestone.owl.service.SystemEmailService;
+import kr.wisestone.owl.service.UserDepartmentService;
 import kr.wisestone.owl.service.UserService;
 import kr.wisestone.owl.util.*;
 import org.apache.commons.io.FilenameUtils;
+import org.flywaydb.core.internal.util.scanner.filesystem.FileSystemResource;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -36,12 +39,11 @@
 import javax.activation.DataSource;
 import javax.activation.FileDataSource;
 import javax.mail.SendFailedException;
-import javax.mail.internet.InternetAddress;
-import javax.mail.internet.MimeMessage;
-import javax.mail.internet.MimeUtility;
+import javax.mail.internet.*;
 import java.io.IOException;
 import java.util.*;
 
+import org.springframework.web.multipart.MultipartFile;
 import org.thymeleaf.context.Context;
 import org.thymeleaf.spring5.SpringTemplateEngine;
 
@@ -62,6 +64,9 @@
     @Autowired
     private SpringTemplateEngine springTemplateEngine;
 
+    @Autowired
+    private UserDepartmentService userDepartmentService;
+
     @Override
     protected JpaRepository<SystemEmail, Long> getRepository() {
         return this.systemEmailRepository;
@@ -72,6 +77,9 @@
 
     @Value("${email.userName}")
     private String emailUserName;
+
+    @Value("${email.sender}")
+    private String emailSender;
 
     //  �씠硫붿씪 利됱떆 �쟾�넚
     @Async
@@ -219,22 +227,61 @@
                 break;
         }
 
-        this.sendEmail(this.messageAccessor.message(mailConstants.getTitle(), locale), content, sendUsers, filePaths);
+        this.sendEmail(this.messageAccessor.message(mailConstants.getTitle(), locale), content, sendUsers, filePaths, null);
     }
+
+    //  �씠硫붿씪 �뀥�뵆由� 李얘린
+    public String makeEmailContent(EmailType emailType, Map<String, Object> params) {
+        MailConstants mailConstants = null;
+        Context context;
+        String content = null;
+        //params.put("url", this.commonConfiguration.getEmailSendUrl());
+
+        Locale locale = Locale.getDefault();
+
+        switch (emailType) {
+            case ISSUE_SEND_1:    //  �씠�뒋 �씠硫붿씪 �뀥�뵆由�1濡� ���긽�옄�뿉寃� 諛쒖넚
+                mailConstants = MailConstants.ISSUE_SEND_1;
+                context = StringTemplateUtil.makeContext(params, locale);
+                content = this.springTemplateEngine.process(mailConstants.getMailTemplate(), context);
+                break;
+
+            case ISSUE_SEND_2:    //  �씠�뒋 �씠硫붿씪 �뀥�뵆由�2濡� ���긽�옄�뿉寃� 諛쒖넚
+                mailConstants = MailConstants.ISSUE_SEND_2;
+                context = StringTemplateUtil.makeContext(params, locale);
+                content = this.springTemplateEngine.process(mailConstants.getMailTemplate(), context);
+                break;
+
+            case ISSUE_SEND_3:    //  �씠�뒋 �씠硫붿씪 �뀥�뵆由�3濡� ���긽�옄�뿉寃� 諛쒖넚
+                mailConstants = MailConstants.ISSUE_SEND_3;
+                context = StringTemplateUtil.makeContext(params, locale);
+                content = this.springTemplateEngine.process(mailConstants.getMailTemplate(), context);
+                break;
+        }
+        return content;
+    }
+
 
     //  �씠硫붿씪�쓣 諛쒖넚�븳�떎.
     @Override
     @Transactional(readOnly = true)
-    public void sendEmail(String subject, String content, String[] to, String[] filePaths) {
+    public void sendEmail(String subject, String content, String[] to, String[] filePaths, List<MultipartFile> multipartFiles) {
         MimeMessage message = this.javaMailSender.createMimeMessage();
 
         try {
-            InternetAddress from = new InternetAddress(this.emailUserName, "OWL-ITS");
+            InternetAddress from = new InternetAddress(this.emailUserName, this.emailSender);
             MimeMessageHelper messageHelper = new MimeMessageHelper(message, true, "utf-8");
             messageHelper.setSubject(subject);
             messageHelper.setText(content, true);
             messageHelper.setFrom(from);
             messageHelper.setTo(to);
+
+            if (multipartFiles != null && multipartFiles.size() > 0) {
+                for (MultipartFile file : multipartFiles) {
+                    // �뙆�씪 泥⑤�
+                    messageHelper.addAttachment(MimeUtility.encodeText(file.getOriginalFilename(), "utf-8", "B"), file);
+                }
+            }
 
             if (filePaths != null && filePaths.length > 0) {
                 for (String filePath : filePaths) {
@@ -332,6 +379,13 @@
             }
 
             if (excludeCheck) {
+                /*List<UserDepartment> userDepartments = this.userDepartmentService.getUserDepartments(department.getId());
+                if(userDepartments != null){
+                    for (UserDepartment userDepartment : userDepartments){
+                        User user = this.userService.getUser(userDepartment.getUserId());
+                        results.add(user.getAccount());
+                    }
+                }*/
                 results.add(department.getDepartmentName());
             }
         }
@@ -369,7 +423,7 @@
                 //  �궡�슜�씠 �엳�쑝硫� 諛쒖넚
                 if (!StringUtils.isEmpty(emailBuilder.toString())) {
                     //  �씠硫붿씪�쓣 諛쒖넚�븳�떎.
-                    this.sendEmail(this.messageAccessor.message(MsgConstants.RESERVATION_EMAIL_TITLE, locale), emailBuilder.toString(), new String[]{CommonUtil.decryptAES128(sendUser)}, null);
+                    this.sendEmail(this.messageAccessor.message(MsgConstants.RESERVATION_EMAIL_TITLE, locale), emailBuilder.toString(), new String[]{CommonUtil.decryptAES128(sendUser)}, null, null);
                     this.systemEmailRepository.saveAll(systemEmails);
                 }
             }
@@ -400,7 +454,7 @@
                 //  �궡�슜�씠 �엳�쑝硫� 諛쒖넚
                 if (!StringUtils.isEmpty(emailBuilder.toString())) {
                     //  �씠硫붿씪�쓣 諛쒖넚�븳�떎.
-                    this.sendEmail(this.messageAccessor.message(MsgConstants.REALTIME_EMAIL_TITLE, locale), emailBuilder.toString(), new String[]{CommonUtil.decryptAES128(sendUser)}, null);
+                    this.sendEmail(this.messageAccessor.message(MsgConstants.REALTIME_EMAIL_TITLE, locale), emailBuilder.toString(), new String[]{CommonUtil.decryptAES128(sendUser)}, null, null);
                     this.systemEmailRepository.saveAll(systemEmails);
                 }
             }

--
Gitblit v1.8.0