-
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.
Revert "feat:1.Add outline property 2. send mail when new share"
- Loading branch information
1 parent
7c565b4
commit 3df0ac2
Showing
4 changed files
with
27 additions
and
98 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,5 +1,6 @@ | ||
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; | ||
|
@@ -20,18 +21,7 @@ | |
import com.dl.officialsite.sharing.model.req.UpdateSharingReq; | ||
import com.dl.officialsite.sharing.model.resp.ShareTagResp; | ||
import com.dl.officialsite.team.TeamService; | ||
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 com.google.common.collect.Lists; | ||
import lombok.extern.slf4j.Slf4j; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.context.ApplicationContext; | ||
|
@@ -42,6 +32,16 @@ | |
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,66 +75,27 @@ 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) | ||
.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) { | ||
// 格式化日期为字符串 | ||
Member creatorInfo = memberRepository.findByAddress(address).orElse(null); | ||
Assert.isNull(creatorInfo, "not found member by address"); | ||
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); | ||
return format.format(date); | ||
} | ||
|
||
private void publishShareCreationEvent(Member creatorInfo, Share share, String formattedDate) { | ||
// 发布创建分享事件的通知 | ||
applicationContext.publishEvent(new EventNotify( | ||
Member.class, | ||
BotEnum.TELEGRAM, | ||
String formatDate = format.format(share.getDate()); | ||
applicationContext.publishEvent(new EventNotify(Member.class, BotEnum.TELEGRAM, | ||
ChannelEnum.SHARING, | ||
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() | ||
); | ||
NotifyMessageFactory.sharingMessage("👏Create New Share👏", creatorInfo.getNickName(), share.getTheme(), | ||
formatDate))); | ||
return share; | ||
} | ||
|
||
|
||
|
||
public void updateSharing(UpdateSharingReq req, String address) { | ||
//Verify | ||
Optional<Share> existed = this.sharingRepository.findById(req.getId()); | ||
|