From 9c283e735476f1106262de58b4042f30acf61a45 Mon Sep 17 00:00:00 2001
From: jhjang <jhjang@maprex.co.kr>
Date: 월, 03 1월 2022 14:54:27 +0900
Subject: [PATCH] Merge branch 'master' of http://192.168.0.25:9001/r/owl-kisa

---
 src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java |  127 ++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 121 insertions(+), 6 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 d6f06f8..992923b 100644
--- a/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
+++ b/src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
@@ -7,19 +7,20 @@
 import com.google.common.collect.Lists;
 import com.sun.mail.smtp.SMTPAddressFailedException;
 import kr.wisestone.owl.config.CommonConfiguration;
+import kr.wisestone.owl.constant.ElasticSearchConstants;
 import kr.wisestone.owl.constant.MailConstants;
 import kr.wisestone.owl.constant.MsgConstants;
+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.CommonUtil;
-import kr.wisestone.owl.util.DateUtil;
-import kr.wisestone.owl.util.MapUtil;
-import kr.wisestone.owl.util.StringTemplateUtil;
+import kr.wisestone.owl.util.*;
 import org.apache.commons.io.FilenameUtils;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -63,6 +64,9 @@
     @Autowired
     private SpringTemplateEngine springTemplateEngine;
 
+    @Autowired
+    private UserDepartmentService userDepartmentService;
+
     @Override
     protected JpaRepository<SystemEmail, Long> getRepository() {
         return this.systemEmailRepository;
@@ -96,7 +100,6 @@
                         locale = CommonUtil.getUserLanguage(loginUser.getLanguage());
                     }
                 }
-
                 this.makeDirectContextEmail(emailType, params, locale, new String[]{CommonUtil.decryptAES128(sendUser)});
             }
         }
@@ -178,6 +181,24 @@
                 content = this.springTemplateEngine.process(mailConstants.getMailTemplate(), context);
                 break;
 
+            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;
+
             case USER_JOIN_STATISTICS:  //  �씪�씪 �궗�슜�옄 媛��엯 �젙蹂� 諛쒖넚
                 mailConstants = MailConstants.USER_JOIN_STATISTICS;
                 context = StringTemplateUtil.makeContext(params, locale);
@@ -206,6 +227,38 @@
         this.sendEmail(this.messageAccessor.message(mailConstants.getTitle(), locale), content, sendUsers, filePaths);
     }
 
+    //  �씠硫붿씪 �뀥�뵆由� 李얘린
+    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)
@@ -229,8 +282,8 @@
                     }
                 }
             }
-
             this.javaMailSender.send(message);
+
         } catch (MailSendException e) {
             log.error(e.getMessage());
             Exception[] exceptions = e.getMessageExceptions();
@@ -298,6 +351,37 @@
         return results;
     }
 
+    //  �봽濡쒖젥�듃�뿉�꽌 蹂�寃쎈맂 �떞�떦遺��꽌瑜� 李얘린 �쐞�빐 �궗�슜
+    @Override
+    @Transactional(readOnly = true)
+    public List<String> notificationDepartmentChange(List<Department> totalDepartments, List<Department> targetDepartments) {
+        List<String> results = Lists.newArrayList();
+
+        //  �젣�쇅 ���긽�옄 李얘린
+        for (Department department : totalDepartments) {
+            boolean excludeCheck = true;
+
+            for (Department newDepartment : targetDepartments) {
+                if (department.getId().equals(newDepartment.getId())) {
+                    excludeCheck = false;
+                    break;
+                }
+            }
+
+            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());
+            }
+        }
+        return results;
+    }
+
     //  �븘吏� 諛쒖넚�릺吏� �븡�� �씠硫붿씪�쓣 議고쉶�븳�떎.
     @Override
     @Transactional(readOnly = true)
@@ -336,6 +420,37 @@
         }
     }
 
+    //  �떎�떆媛� �씠硫붿씪 諛쒖넚
+    @Override
+    @Transactional
+    public void realTimeSendEmail() {
+
+        List<String> sendUsers = this.userService.findByRealTimeNotifyTime();
+
+        for (String sendUser : sendUsers) {
+            //  �궗�슜�옄 蹂꾨줈 �븘吏� 諛쒖넚�릺吏� �븡�� �씠硫붿씪�쓣 議고쉶�븳�떎.
+            List<SystemEmail> systemEmails = this.findBySendAddressAndSendYn(sendUser);
+            StringBuilder emailBuilder = new StringBuilder();
+            User user = this.userService.findByAccount(sendUser);
+
+            if (user != null) {
+                Locale locale = CommonUtil.getUserLanguage(user.getLanguage());    //  硫붿씪�쓣 諛쏅뒗 �궗�슜�옄媛� �궗�슜�븯怨� �엳�뒗 �뼵�뼱 �젙蹂대�� 媛��졇�삩�떎.
+
+                for (SystemEmail systemEmail : systemEmails) {
+                    //  諛쏅뒗 �궗�엺�쓽 �뼵�뼱濡� 蹂�寃쏀븯�뿬 �삁�빟�맂 �씠硫붿씪�쓣 諛쒖넚�븳�떎.
+                    this.makeReservationContextEmail(emailBuilder, systemEmail, locale);
+                    systemEmail.setSendYn(true);
+                }
+                //  �궡�슜�씠 �엳�쑝硫� 諛쒖넚
+                if (!StringUtils.isEmpty(emailBuilder.toString())) {
+                    //  �씠硫붿씪�쓣 諛쒖넚�븳�떎.
+                    this.sendEmail(this.messageAccessor.message(MsgConstants.REALTIME_EMAIL_TITLE, locale), emailBuilder.toString(), new String[]{CommonUtil.decryptAES128(sendUser)}, null);
+                    this.systemEmailRepository.saveAll(systemEmails);
+                }
+            }
+        }
+    }
+
     //  諛쏅뒗 �궗�엺�쓽 �뼵�뼱濡� 蹂�寃쏀븯�뿬 �삁�빟�맂 �씠硫붿씪�쓣 諛쒖넚�븳�떎.
     private void makeReservationContextEmail(StringBuilder emailBuilder, SystemEmail systemEmail, Locale locale) {
         MailConstants mailConstants;

--
Gitblit v1.8.0