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