From 1c64cab900cbda2d0ba6cb35ec150330273daaed Mon Sep 17 00:00:00 2001 From: Kang Duoh Date: Sat, 2 Nov 2024 17:20:20 +0900 Subject: [PATCH] =?UTF-8?q?Feat:=20=EB=A9=94=EC=9D=BC=20=EC=A0=84=EC=86=A1?= =?UTF-8?q?=20=EA=B5=AC=ED=98=84=20(#17)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../notification/domain/Notification.java | 44 ------------------- .../team/application/EmailService.java | 43 ++++++++++++++++++ .../momento/team/application/TeamService.java | 38 ++++++++++++++++ src/main/resources/application.yml | 2 +- 4 files changed, 82 insertions(+), 45 deletions(-) delete mode 100644 src/main/java/com/hackathon/momento/notification/domain/Notification.java create mode 100644 src/main/java/com/hackathon/momento/team/application/EmailService.java diff --git a/src/main/java/com/hackathon/momento/notification/domain/Notification.java b/src/main/java/com/hackathon/momento/notification/domain/Notification.java deleted file mode 100644 index 738162d..0000000 --- a/src/main/java/com/hackathon/momento/notification/domain/Notification.java +++ /dev/null @@ -1,44 +0,0 @@ -package com.hackathon.momento.notification.domain; - -import com.hackathon.momento.global.entity.BaseEntity; -import com.hackathon.momento.member.domain.Member; -import jakarta.persistence.Column; -import jakarta.persistence.Entity; -import jakarta.persistence.FetchType; -import jakarta.persistence.GeneratedValue; -import jakarta.persistence.GenerationType; -import jakarta.persistence.Id; -import jakarta.persistence.JoinColumn; -import jakarta.persistence.ManyToOne; -import lombok.AccessLevel; -import lombok.Builder; -import lombok.Getter; -import lombok.NoArgsConstructor; - -@Entity -@Getter -@NoArgsConstructor(access = AccessLevel.PROTECTED) -public class Notification extends BaseEntity { - - @Id - @GeneratedValue(strategy = GenerationType.IDENTITY) - @Column(name = "notification_id") - private Long id; - - @Column(nullable = false) - private String title; - - @Column(columnDefinition = "TEXT") - private String message; - - @ManyToOne(fetch = FetchType.LAZY) - @JoinColumn(name = "member_id") - private Member member; - - @Builder - private Notification(String title, String message, Member member) { - this.title = title; - this.message = message; - this.member = member; - } -} diff --git a/src/main/java/com/hackathon/momento/team/application/EmailService.java b/src/main/java/com/hackathon/momento/team/application/EmailService.java new file mode 100644 index 0000000..0866dcf --- /dev/null +++ b/src/main/java/com/hackathon/momento/team/application/EmailService.java @@ -0,0 +1,43 @@ +package com.hackathon.momento.team.application; + +import jakarta.mail.MessagingException; +import jakarta.mail.internet.MimeMessage; +import java.io.UnsupportedEncodingException; +import lombok.RequiredArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springframework.mail.javamail.JavaMailSender; +import org.springframework.mail.javamail.MimeMessageHelper; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +@Slf4j +@Service +@Transactional(readOnly = true) +@RequiredArgsConstructor +public class EmailService { + + private static final String FROM_EMAIL = "kduoh99@gmail.com"; + private static final String TEAM_NAME = "TeamUp"; + + private final JavaMailSender mailSender; + + public void sendMessage(String to, String body) { + try { + MimeMessage message = mailSender.createMimeMessage(); + + String subject = "[TeamUp] 요청하신 팀 빌딩이 완료되었습니다, 팀 정보를 확인해주세요."; + MimeMessageHelper mimeMessageHelper = new MimeMessageHelper(message, true); + + mimeMessageHelper.setTo(to); + mimeMessageHelper.setFrom(FROM_EMAIL, TEAM_NAME); + mimeMessageHelper.setSubject(subject); + mimeMessageHelper.setText(body, true); + + mailSender.send(message); + log.info("Email sent to: {}", to); + + } catch (MessagingException | UnsupportedEncodingException e) { + log.error("Email send failed to {}", to, e); + } + } +} diff --git a/src/main/java/com/hackathon/momento/team/application/TeamService.java b/src/main/java/com/hackathon/momento/team/application/TeamService.java index 9f261fe..4c00253 100644 --- a/src/main/java/com/hackathon/momento/team/application/TeamService.java +++ b/src/main/java/com/hackathon/momento/team/application/TeamService.java @@ -35,6 +35,7 @@ public class TeamService { private final TeamInfoRepository teamInfoRepository; private final MemberRepository memberRepository; private final RestTemplate restTemplate; + private final EmailService emailService; @Value("${openai.api.url}") private String apiURL; @@ -77,6 +78,43 @@ public void executeTeamBuilding() { List teamInfos = parseResToTeamInfo(resContent, requests); teamInfoRepository.saveAll(teamInfos); + + sendTeamCompletionEmails(teamInfos); + } + } + + private void sendTeamCompletionEmails(List teamInfos) { + for (TeamInfo teamInfo : teamInfos) { + String teamName = teamInfo.getTeamName(); + String description = teamInfo.getDescription(); + List teamMembers = teamInfo.getTeamBuildings(); + + StringBuilder emailBody = new StringBuilder(); + emailBody.append("
") + .append("

") + .append(teamName).append("

") + .append("

").append(description).append("

") + .append("

Team Members

") + .append("
    "); + + for (TeamBuilding memberBuilding : teamMembers) { + Member member = memberBuilding.getMember(); + emailBody.append( + "
  • ") + .append("Name: ").append(member.getName()).append("
    ") + .append("Email: ").append(member.getEmail()).append("
    ") + .append("Position: ").append(memberBuilding.getMyPosition()) + .append("
  • "); + } + emailBody.append("
") + .append("

") + .append("Thank you for using TeamUp") + .append("

") + .append("
"); + + for (TeamBuilding memberBuilding : teamMembers) { + emailService.sendMessage(memberBuilding.getMember().getEmail(), emailBody.toString()); + } } } diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index 0c91ecf..5525fb5 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -27,7 +27,7 @@ spring: host: ${MAIL_SERVER} username: ${MAIL_USERNAME} password: ${MAIL_PASSWORD} - + logging: level: org.hibernate.sql: debug