-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #306 from cheng521521/main
feat:1.Add outline property 2. send mail when new share
- Loading branch information
Showing
4 changed files
with
98 additions
and
27 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,5 @@ | ||
package com.dl.officialsite.sharing; | ||
|
||
import cn.hutool.core.lang.Assert; | ||
import com.dl.officialsite.bot.constant.BotEnum; | ||
import com.dl.officialsite.bot.constant.ChannelEnum; | ||
import com.dl.officialsite.bot.event.EventNotify; | ||
|
@@ -21,7 +20,18 @@ | |
import com.dl.officialsite.sharing.model.req.UpdateSharingReq; | ||
import com.dl.officialsite.sharing.model.resp.ShareTagResp; | ||
import com.dl.officialsite.team.TeamService; | ||
import com.google.common.collect.Lists; | ||
import java.math.BigInteger; | ||
import java.text.SimpleDateFormat; | ||
import java.util.ArrayList; | ||
import java.util.Date; | ||
import java.util.LinkedList; | ||
import java.util.List; | ||
import java.util.Objects; | ||
import java.util.Optional; | ||
import java.util.stream.Collectors; | ||
import java.util.stream.Stream; | ||
import javax.persistence.criteria.Predicate; | ||
import javax.servlet.http.HttpServletRequest; | ||
import lombok.extern.slf4j.Slf4j; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.context.ApplicationContext; | ||
|
@@ -32,16 +42,6 @@ | |
import org.springframework.data.jpa.domain.Specification; | ||
import org.springframework.stereotype.Service; | ||
import org.springframework.transaction.annotation.Transactional; | ||
|
||
import javax.persistence.criteria.Predicate; | ||
import javax.servlet.http.HttpServletRequest; | ||
import java.math.BigInteger; | ||
import java.text.SimpleDateFormat; | ||
import java.util.ArrayList; | ||
import java.util.LinkedList; | ||
import java.util.List; | ||
import java.util.Objects; | ||
import java.util.Optional; | ||
import org.springframework.util.StringUtils; | ||
|
||
@Service | ||
|
@@ -75,27 +75,66 @@ public SharingService(EmailService emailService, ApplicationContext applicationC | |
|
||
@Transactional(rollbackFor = Exception.class) | ||
public Share createSharing(Share share, String address) { | ||
/** | ||
* 登陆用户转member | ||
*/ | ||
// SessionUserInfo userInfo = HttpSessionUtils.getMember(request.getSession()); | ||
// Preconditions.checkState(userInfo != null, "User info not null"); | ||
// Optional<Member> memberOpt = this.memberRepository.findByAddress(userInfo.getAddress()); | ||
// Member member = memberOpt.get(); | ||
// if(member.getId() != req.) | ||
// 保存分享记录 | ||
share = sharingRepository.save(share); | ||
Member creatorInfo = memberRepository.findByAddress(address).orElse(null); | ||
Assert.isNull(creatorInfo, "not found member by address"); | ||
|
||
// 查找分享创建者的信息 | ||
Member creatorInfo = memberRepository.findByAddress(address) | ||
.orElseThrow(() -> new IllegalArgumentException("Member not found by address: " + address)); | ||
|
||
// 格式化日期 | ||
String formattedDate = formatDate(share.getDate()); | ||
|
||
// 发布事件通知 | ||
publishShareCreationEvent(creatorInfo, share, formattedDate); | ||
|
||
// 准备邮件内容 | ||
String emailTitle = "New Sharing Created"; | ||
String emailContent = createEmailContent(share, creatorInfo); | ||
|
||
// 定义邮件收件人列表 | ||
List<String> toAddressList = Stream.of( | ||
"[email protected]", "[email protected]", "[email protected]" | ||
).collect(Collectors.toList()); | ||
|
||
// 发送邮件 | ||
emailService.sendMail(toAddressList, emailTitle, emailContent, null); | ||
|
||
return share; | ||
} | ||
|
||
private String formatDate(Date date) { | ||
// 格式化日期为字符串 | ||
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); | ||
String formatDate = format.format(share.getDate()); | ||
applicationContext.publishEvent(new EventNotify(Member.class, BotEnum.TELEGRAM, | ||
return format.format(date); | ||
} | ||
|
||
private void publishShareCreationEvent(Member creatorInfo, Share share, String formattedDate) { | ||
// 发布创建分享事件的通知 | ||
applicationContext.publishEvent(new EventNotify( | ||
Member.class, | ||
BotEnum.TELEGRAM, | ||
ChannelEnum.SHARING, | ||
NotifyMessageFactory.sharingMessage("👏Create New Share👏", creatorInfo.getNickName(), share.getTheme(), | ||
formatDate))); | ||
return share; | ||
NotifyMessageFactory.sharingMessage( | ||
"👏Create New Share👏", | ||
creatorInfo.getNickName(), | ||
share.getTheme(), | ||
formattedDate | ||
) | ||
)); | ||
} | ||
|
||
private String createEmailContent(Share share, Member creatorInfo) { | ||
// 构造邮件内容 | ||
return String.format( | ||
"Have a new sharing\n👉👉👉Theme: %s👈👈👈\nCreator: %s", | ||
share.getTheme(), | ||
creatorInfo.getNickName() | ||
); | ||
} | ||
|
||
|
||
|
||
public void updateSharing(UpdateSharingReq req, String address) { | ||
//Verify | ||
Optional<Share> existed = this.sharingRepository.findById(req.getId()); | ||
|