From f9a89f158a9624d27fec314315a8b7f7dcb28af1 Mon Sep 17 00:00:00 2001 From: wl <173@qq.com> Date: 星期二, 27 十二月 2022 15:34:30 +0800 Subject: [PATCH] fix: 查询取消脱敏 --- src/main/java/com/example/jz/service/impl/GroupServiceImpl.java | 62 ++++++++++++++++++++++++++----- 1 files changed, 52 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/example/jz/service/impl/GroupServiceImpl.java b/src/main/java/com/example/jz/service/impl/GroupServiceImpl.java index a4cfab5..9379d66 100644 --- a/src/main/java/com/example/jz/service/impl/GroupServiceImpl.java +++ b/src/main/java/com/example/jz/service/impl/GroupServiceImpl.java @@ -1,22 +1,22 @@ package com.example.jz.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.example.jz.dao.AnnouncementDao; -import com.example.jz.dao.GroupDao; -import com.example.jz.dao.MessageDao; -import com.example.jz.modle.entity.Announcement; -import com.example.jz.modle.entity.Group; -import com.example.jz.modle.entity.Message; +import com.example.jz.dao.*; +import com.example.jz.modle.entity.*; import com.example.jz.modle.vo.GroupMessageVo; import com.example.jz.modle.vo.GroupUserVo; import com.example.jz.service.GroupService; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.stereotype.Service; import javax.annotation.Resource; import java.util.Date; import java.util.List; +import java.util.stream.Collectors; /** * 缇よ〃 @@ -27,9 +27,16 @@ */ @Service("groupService") public class GroupServiceImpl extends ServiceImpl<GroupDao, Group> implements GroupService { + @Resource private MessageDao messageDao; + @Resource private AnnouncementDao announcementDao; + @Resource private GroupDao groupDao; + @Resource + private UserDao userDao; + @Resource + private ReportDao reportDao; @Autowired public void setMessageDao(MessageDao messageDao) { @@ -48,18 +55,38 @@ @Override public List<GroupMessageVo> getAllMessage(Integer id) { - return messageDao.getAllMessageByGroup(id); + List<GroupMessageVo> list = messageDao.selectList(new QueryWrapper<Message>().eq("group_id", id).orderByAsc("ctime")).stream().map(item -> { + String username; + String pic = null; + if (item.getUserId() == null) { + username = userDao.selectOne(new QueryWrapper<User>().eq("id", item.getCopId())).getRealName(); + } else { + Report report = reportDao.selectOne(new QueryWrapper<Report>().eq("id", item.getUserId())); + username = userDao.selectOne(new QueryWrapper<User>().eq("id", report.getUserId())).getRealName(); + pic = report.getPic(); + Message message = new Message(); + message.setReportName(username); + messageDao.update(message, new QueryWrapper<Message>().eq("user_id", item.getUserId())); + } + GroupMessageVo groupMessageVo = new GroupMessageVo(); + groupMessageVo.setUserName(username); + groupMessageVo.setText(item.getText()); + groupMessageVo.setCtime(item.getCtime()); + groupMessageVo.setPic(pic); + return groupMessageVo; + }).collect(Collectors.toList()); + return list; } @Override public List<Announcement> getAllNotice(Integer id) { - return announcementDao.selectList(new LambdaQueryWrapper<>(Announcement.class).eq(Announcement::getGroupId, id)); + return announcementDao.selectList(new LambdaQueryWrapper<>(Announcement.class).eq(Announcement::getGroupId, id).eq(Announcement::getStatus, 1)); } @Override public Boolean sendMessage(Integer id, String text) { - // todo 鍔ㄦ�佽幏鍙栧綋鍓嶇櫥褰曠敤鎴风殑id - Message message = new Message().setUserId(1).setText(text).setGroupId(id).setCtime(new Date()); + Message message = new Message().setCopId(userDao.selectOne(new QueryWrapper<User>().eq("login_username", SecurityContextHolder.getContext().getAuthentication().getPrincipal())).getId()) + .setText(text).setGroupId(id).setCtime(new Date()); return messageDao.insert(message) > 0; } @@ -67,4 +94,19 @@ public List<GroupUserVo> getAllUser(Integer id) { return groupDao.getAllUser(id); } + + @Override + public List<GroupMessageVo> getByCondition(String name, String text, Integer groupId) { + return messageDao.selectList(new QueryWrapper<Message>().like(StringUtils.isNotBlank(text), "text", text).eq(StringUtils.isNotBlank(name),"report_name",name).eq("group_id", groupId).orderByAsc("ctime")).stream() + .filter(item -> item.getUserId() != null) + .map(item -> { + Report report = reportDao.selectOne(new QueryWrapper<Report>().eq("id", item.getUserId())); + GroupMessageVo groupMessageVo = new GroupMessageVo(); + groupMessageVo.setUserName(item.getReportName()); + groupMessageVo.setText(item.getText()); + groupMessageVo.setCtime(item.getCtime()); + groupMessageVo.setPic(report.getPic()); + return groupMessageVo; + }).collect(Collectors.toList()); + } } -- Gitblit v1.8.0