dylanmay před 1 rokem
rodič
revize
29a3ad42b6

+ 1 - 22
yudao-module-im/yudao-module-im-biz/src/main/java/cn/iocoder/yudao/module/im/controller/admin/conversation/ImConversationController.java

@@ -6,6 +6,7 @@ import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversatio
 import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationRespVO;
 import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationUpdatePinnedReqVO;
 import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageListByNoReqVO;
+import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageListReqVO;
 import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
 import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
 import cn.iocoder.yudao.module.im.enums.message.ImMessageContentTypeEnum;
@@ -56,28 +57,6 @@ public class ImConversationController {
                 item.setNickname(receiverUser.getNickname());
             }
 
-            // 处理未读消息条数【TODO:】
-
-
-            // 处理最后一条消息描述
-            ImMessageListByNoReqVO imMessageListByNoReqVO = new ImMessageListByNoReqVO();
-            imMessageListByNoReqVO.setConversationNo(item.getNo());
-            List<ImMessageDO> listMessage = imMessageService.getMessageListByConversationNo(imMessageListByNoReqVO);
-
-            if (!listMessage.isEmpty()) {
-                ImMessageDO lastMessage = listMessage.get(listMessage.size() - 1);
-                if (lastMessage != null) {
-                    if (Objects.equals(lastMessage.getContentType(), ImMessageContentTypeEnum.TEXT.getType())) {
-                        item.setLastMessageDescription(lastMessage.getContent());
-                    } else if (Objects.equals(lastMessage.getContentType(), ImMessageContentTypeEnum.PICTURE.getType())) {
-                        item.setLastMessageDescription("[图片]");
-                    } else {
-                        item.setLastMessageDescription("[未知类型]");
-                    }
-                }
-            }
-
-
         });
         return success(imConversationRespVOList);
     }

+ 0 - 7
yudao-module-im/yudao-module-im-biz/src/main/java/cn/iocoder/yudao/module/im/controller/admin/message/ImMessageController.java

@@ -51,11 +51,4 @@ public class ImMessageController {
         return success(BeanUtils.toBean(messagePage, ImMessageRespVO.class));
     }
 
-    @GetMapping("/listByNo")
-    @Operation(summary = "消息列表-根据接收人和发送时间进行分页查询")
-    public CommonResult<List<ImMessageRespVO>> getMessageListByNo(@Valid ImMessageListByNoReqVO listReqVO) {
-        List<ImMessageDO> messagePage = imMessageService.getMessageListByConversationNo(listReqVO);
-        return success(BeanUtils.toBean(messagePage, ImMessageRespVO.class));
-    }
-
 }

+ 3 - 9
yudao-module-im/yudao-module-im-biz/src/main/java/cn/iocoder/yudao/module/im/controller/admin/message/vo/ImMessageListReqVO.java

@@ -15,14 +15,13 @@ import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_
 @Data
 public class ImMessageListReqVO {
 
-    // TODO @dylan:是不是 receiverId 和 senderId 保留一个 receiverId 就行。这样,A + 自己(调用接口,从 getLoginUserId 拿),然后 conversationType,最终可以拼接出 conversationNo
     @Schema(description = "接收人编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "32494")
     @NotNull(message = "接收人编号不能为空")
     private Long receiverId;
 
-    @Schema(description = "发送人编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "32494")
-    @NotNull(message = "发送人编号不能为空")
-    private Long senderId;
+    @Schema(description = "会话所属人编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "32494")
+    @NotNull(message = "会话所属人编号不能为空")
+    private Long userId;
 
     @Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
     @InEnum(value = ImConversationTypeEnum.class,message = "会话类型必须是 {value}")
@@ -33,9 +32,4 @@ public class ImMessageListReqVO {
     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY)
     private LocalDateTime sendTime;
 
-    // TODO @dylan:这个,可以根据 receiverId、senderId、conversationType 推导的,建议可以去掉。
-    @Schema(description = "会话编号编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "32494")
-    @NotNull(message = "会话编号不能为空")
-    private String conversationNo;
-
 }

+ 3 - 4
yudao-module-im/yudao-module-im-biz/src/main/java/cn/iocoder/yudao/module/im/controller/admin/message/vo/ImMessageSendReqVO.java

@@ -24,10 +24,9 @@ public class ImMessageSendReqVO {
     @NotNull(message = "会话类型不能为空")
     private Integer conversationType;
 
-    // TODO @dylan:这个 conversationNo,直接计算哈。不用传递
-    @Schema(description = "会话编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
-    @NotNull(message = "会话编号不能为空")
-    private String conversationNo;
+    @Schema(description = "会话所属用户id", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
+    @NotNull(message = "会话所属用户id")
+    private Long conversationUserId;
 
     @Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
     @InEnum(ImMessageContentTypeEnum.class)

+ 23 - 3
yudao-module-im/yudao-module-im-biz/src/main/java/cn/iocoder/yudao/module/im/service/message/ImMessageServiceImpl.java

@@ -23,9 +23,12 @@ import org.springframework.validation.annotation.Validated;
 import java.time.LocalDateTime;
 import java.util.Collections;
 import java.util.List;
+import java.util.Objects;
 
 import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
+import static cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils.getLoginUserId;
 import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.MESSAGE_RECEIVER_NOT_EXISTS;
+import static cn.iocoder.yudao.module.im.enums.conversation.ImConversationTypeEnum.generateConversationNo;
 
 /**
  * 消息 Service 实现类
@@ -48,8 +51,16 @@ public class ImMessageServiceImpl implements ImMessageService {
 
     @Override
     public List<ImMessageDO> getMessageList(ImMessageListReqVO listReqVO) {
+
         // 1. 获得会话编号
-        String no = ImConversationTypeEnum.generateConversationNo(listReqVO.getSenderId(), listReqVO.getReceiverId(), listReqVO.getConversationType());
+        String no = "";
+        Long loginUserId = getLoginUserId();
+        if (Objects.equals(loginUserId, listReqVO.getUserId())) {
+            no = generateConversationNo(loginUserId, listReqVO.getReceiverId(), listReqVO.getConversationType());
+        } else {
+            no = generateConversationNo(listReqVO.getReceiverId(),loginUserId , listReqVO.getConversationType());
+        }
+
         // 2. 查询历史消息
         ImMessageDO message = new ImMessageDO()
                 .setSendTime(listReqVO.getSendTime())
@@ -92,11 +103,20 @@ public class ImMessageServiceImpl implements ImMessageService {
         validateReceiverIdExists(message);
         // 2. 查询发送人信息
         AdminUserRespDTO fromUser = adminUserApi.getUser(fromUserId);
-        // 3. 保存消息
+
+        // 3. 生成conversationNo
+        String conversationNo = "";
+        if (fromUserId == message.getConversationUserId()) {
+            conversationNo = generateConversationNo(fromUserId, message.getReceiverId(), message.getConversationType());
+        } else {
+            conversationNo = generateConversationNo(message.getReceiverId(), fromUserId, message.getConversationType());
+        }
+
+        // 4. 保存消息
         ImMessageDO imMessageDO = BeanUtil.copyProperties(message, ImMessageDO.class)
                 .setSenderNickname(fromUser.getNickname()).setSenderAvatar(fromUser.getAvatar())
                 .setSenderId(fromUserId)
-                .setConversationNo(message.getConversationNo())
+                .setConversationNo(conversationNo)
                 .setSendFrom(ImMessageSourceEnum.USER_SEND.getSource())
                 .setMessageStatus(ImMessageStatusEnum.SENDING.getStatus())
                 .setSendTime(LocalDateTime.now());