修改:im 模块简单实现

This commit is contained in:
安浩浩 2024-03-13 21:43:05 +08:00
parent bb0b7056cf
commit 3696b666f4
34 changed files with 385 additions and 348 deletions

View File

@ -15,8 +15,6 @@
<!-- 各种 module 拓展 --> <!-- 各种 module 拓展 -->
<module>yudao-module-system</module> <module>yudao-module-system</module>
<module>yudao-module-infra</module> <module>yudao-module-infra</module>
<module>yudao-module-im</module>
<module>yudao-module-im/yudao-module-im-api</module>
<!-- <module>yudao-module-member</module>--> <!-- <module>yudao-module-member</module>-->
<!-- <module>yudao-module-bpm</module>--> <!-- <module>yudao-module-bpm</module>-->
<!-- <module>yudao-module-report</module>--> <!-- <module>yudao-module-report</module>-->

View File

@ -6,11 +6,11 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils; import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationRespVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationRespVO;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ConversationDO; import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
import cn.iocoder.yudao.module.im.service.conversation.ConversationService; import cn.iocoder.yudao.module.im.service.conversation.ImConversationService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
@ -31,23 +31,23 @@ import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.E
@RestController @RestController
@RequestMapping("/im/conversation") @RequestMapping("/im/conversation")
@Validated @Validated
public class ConversationController { public class ImConversationController {
@Resource @Resource
private ConversationService conversationService; private ImConversationService imConversationService;
@PostMapping("/create") @PostMapping("/create")
@Operation(summary = "创建会话") @Operation(summary = "创建会话")
@PreAuthorize("@ss.hasPermission('im:conversation:create')") @PreAuthorize("@ss.hasPermission('im:conversation:create')")
public CommonResult<Long> createConversation(@Valid @RequestBody ConversationSaveReqVO createReqVO) { public CommonResult<Long> createConversation(@Valid @RequestBody ImConversationSaveReqVO createReqVO) {
return success(conversationService.createConversation(createReqVO)); return success(imConversationService.createConversation(createReqVO));
} }
@PutMapping("/update") @PutMapping("/update")
@Operation(summary = "更新会话") @Operation(summary = "更新会话")
@PreAuthorize("@ss.hasPermission('im:conversation:update')") @PreAuthorize("@ss.hasPermission('im:conversation:update')")
public CommonResult<Boolean> updateConversation(@Valid @RequestBody ConversationSaveReqVO updateReqVO) { public CommonResult<Boolean> updateConversation(@Valid @RequestBody ImConversationSaveReqVO updateReqVO) {
conversationService.updateConversation(updateReqVO); imConversationService.updateConversation(updateReqVO);
return success(true); return success(true);
} }
@ -56,7 +56,7 @@ public class ConversationController {
@Parameter(name = "id", description = "编号", required = true) @Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('im:conversation:delete')") @PreAuthorize("@ss.hasPermission('im:conversation:delete')")
public CommonResult<Boolean> deleteConversation(@RequestParam("id") Long id) { public CommonResult<Boolean> deleteConversation(@RequestParam("id") Long id) {
conversationService.deleteConversation(id); imConversationService.deleteConversation(id);
return success(true); return success(true);
} }
@ -64,30 +64,30 @@ public class ConversationController {
@Operation(summary = "获得会话") @Operation(summary = "获得会话")
@Parameter(name = "id", description = "编号", required = true, example = "1024") @Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('im:conversation:query')") @PreAuthorize("@ss.hasPermission('im:conversation:query')")
public CommonResult<ConversationRespVO> getConversation(@RequestParam("id") Long id) { public CommonResult<ImConversationRespVO> getConversation(@RequestParam("id") Long id) {
ConversationDO conversation = conversationService.getConversation(id); ImConversationDO conversation = imConversationService.getConversation(id);
return success(BeanUtils.toBean(conversation, ConversationRespVO.class)); return success(BeanUtils.toBean(conversation, ImConversationRespVO.class));
} }
@GetMapping("/page") @GetMapping("/page")
@Operation(summary = "获得会话分页") @Operation(summary = "获得会话分页")
@PreAuthorize("@ss.hasPermission('im:conversation:query')") @PreAuthorize("@ss.hasPermission('im:conversation:query')")
public CommonResult<PageResult<ConversationRespVO>> getConversationPage(@Valid ConversationPageReqVO pageReqVO) { public CommonResult<PageResult<ImConversationRespVO>> getConversationPage(@Valid ImConversationPageReqVO pageReqVO) {
PageResult<ConversationDO> pageResult = conversationService.getConversationPage(pageReqVO); PageResult<ImConversationDO> pageResult = imConversationService.getConversationPage(pageReqVO);
return success(BeanUtils.toBean(pageResult, ConversationRespVO.class)); return success(BeanUtils.toBean(pageResult, ImConversationRespVO.class));
} }
@GetMapping("/export-excel") @GetMapping("/export-excel")
@Operation(summary = "导出会话 Excel") @Operation(summary = "导出会话 Excel")
@PreAuthorize("@ss.hasPermission('im:conversation:export')") @PreAuthorize("@ss.hasPermission('im:conversation:export')")
@OperateLog(type = EXPORT) @OperateLog(type = EXPORT)
public void exportConversationExcel(@Valid ConversationPageReqVO pageReqVO, public void exportConversationExcel(@Valid ImConversationPageReqVO pageReqVO,
HttpServletResponse response) throws IOException { HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
List<ConversationDO> list = conversationService.getConversationPage(pageReqVO).getList(); List<ImConversationDO> list = imConversationService.getConversationPage(pageReqVO).getList();
// 导出 Excel // 导出 Excel
ExcelUtils.write(response, "会话.xls", "数据", ConversationRespVO.class, ExcelUtils.write(response, "会话.xls", "数据", ImConversationRespVO.class,
BeanUtils.toBean(list, ConversationRespVO.class)); BeanUtils.toBean(list, ImConversationRespVO.class));
} }
} }

View File

@ -15,13 +15,13 @@ import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true) @ToString(callSuper = true)
public class ConversationPageReqVO extends PageParam { public class ImConversationPageReqVO extends PageParam {
@Schema(description = "所属用户", example = "11545") @Schema(description = "所属用户", example = "11545")
private Long userId; private Long userId;
@Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", example = "1") @Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", example = "1")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "单聊时,用户编号;群聊时,群编号", example = "21454") @Schema(description = "单聊时,用户编号;群聊时,群编号", example = "21454")
private String targetId; private String targetId;

View File

@ -10,7 +10,7 @@ import java.time.LocalDateTime;
@Schema(description = "管理后台 - 会话 Response VO") @Schema(description = "管理后台 - 会话 Response VO")
@Data @Data
@ExcelIgnoreUnannotated @ExcelIgnoreUnannotated
public class ConversationRespVO { public class ImConversationRespVO {
@Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "13905") @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "13905")
@ExcelProperty("编号") @ExcelProperty("编号")
@ -22,7 +22,7 @@ public class ConversationRespVO {
@Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("类型1 单聊2 群聊4 通知会话(预留)") @ExcelProperty("类型1 单聊2 群聊4 通知会话(预留)")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "单聊时,用户编号;群聊时,群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "21454") @Schema(description = "单聊时,用户编号;群聊时,群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "21454")
@ExcelProperty("单聊时,用户编号;群聊时,群编号") @ExcelProperty("单聊时,用户编号;群聊时,群编号")

View File

@ -9,7 +9,7 @@ import java.time.LocalDateTime;
@Schema(description = "管理后台 - 会话新增/修改 Request VO") @Schema(description = "管理后台 - 会话新增/修改 Request VO")
@Data @Data
public class ConversationSaveReqVO { public class ImConversationSaveReqVO {
@Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "13905") @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "13905")
private Long id; private Long id;
@ -20,7 +20,7 @@ public class ConversationSaveReqVO {
@Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "类型1 单聊2 群聊4 通知会话(预留)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotNull(message = "类型1 单聊2 群聊4 通知会话(预留)不能为空") @NotNull(message = "类型1 单聊2 群聊4 通知会话(预留)不能为空")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "单聊时,用户编号;群聊时,群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "21454") @Schema(description = "单聊时,用户编号;群聊时,群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "21454")
@NotEmpty(message = "单聊时,用户编号;群聊时,群编号不能为空") @NotEmpty(message = "单聊时,用户编号;群聊时,群编号不能为空")

View File

@ -9,7 +9,7 @@ import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxRespVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxRespVO;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.inbox.InboxDO; import cn.iocoder.yudao.module.im.dal.dataobject.inbox.ImInboxDO;
import cn.iocoder.yudao.module.im.service.inbox.InboxService; import cn.iocoder.yudao.module.im.service.inbox.InboxService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Parameter;
@ -65,7 +65,7 @@ public class InboxController {
@Parameter(name = "id", description = "编号", required = true, example = "1024") @Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('im:inbox:query')") @PreAuthorize("@ss.hasPermission('im:inbox:query')")
public CommonResult<InboxRespVO> getInbox(@RequestParam("id") Long id) { public CommonResult<InboxRespVO> getInbox(@RequestParam("id") Long id) {
InboxDO inbox = inboxService.getInbox(id); ImInboxDO inbox = inboxService.getInbox(id);
return success(BeanUtils.toBean(inbox, InboxRespVO.class)); return success(BeanUtils.toBean(inbox, InboxRespVO.class));
} }
@ -73,7 +73,7 @@ public class InboxController {
@Operation(summary = "获得收件箱分页") @Operation(summary = "获得收件箱分页")
@PreAuthorize("@ss.hasPermission('im:inbox:query')") @PreAuthorize("@ss.hasPermission('im:inbox:query')")
public CommonResult<PageResult<InboxRespVO>> getInboxPage(@Valid InboxPageReqVO pageReqVO) { public CommonResult<PageResult<InboxRespVO>> getInboxPage(@Valid InboxPageReqVO pageReqVO) {
PageResult<InboxDO> pageResult = inboxService.getInboxPage(pageReqVO); PageResult<ImInboxDO> pageResult = inboxService.getInboxPage(pageReqVO);
return success(BeanUtils.toBean(pageResult, InboxRespVO.class)); return success(BeanUtils.toBean(pageResult, InboxRespVO.class));
} }
@ -84,7 +84,7 @@ public class InboxController {
public void exportInboxExcel(@Valid InboxPageReqVO pageReqVO, public void exportInboxExcel(@Valid InboxPageReqVO pageReqVO,
HttpServletResponse response) throws IOException { HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
List<InboxDO> list = inboxService.getInboxPage(pageReqVO).getList(); List<ImInboxDO> list = inboxService.getInboxPage(pageReqVO).getList();
// 导出 Excel // 导出 Excel
ExcelUtils.write(response, "收件箱.xls", "数据", InboxRespVO.class, ExcelUtils.write(response, "收件箱.xls", "数据", InboxRespVO.class,
BeanUtils.toBean(list, InboxRespVO.class)); BeanUtils.toBean(list, InboxRespVO.class));

View File

@ -6,11 +6,11 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils; import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessagePageReqVO; import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessagePageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessageRespVO; import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageRespVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessageSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.MessageDO; import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
import cn.iocoder.yudao.module.im.service.message.MessageService; import cn.iocoder.yudao.module.im.service.message.ImMessageService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
@ -31,23 +31,23 @@ import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.E
@RestController @RestController
@RequestMapping("/im/message") @RequestMapping("/im/message")
@Validated @Validated
public class MessageController { public class ImMessageController {
@Resource @Resource
private MessageService messageService; private ImMessageService imMessageService;
@PostMapping("/create") @PostMapping("/create")
@Operation(summary = "创建消息") @Operation(summary = "创建消息")
@PreAuthorize("@ss.hasPermission('im:message:create')") @PreAuthorize("@ss.hasPermission('im:message:create')")
public CommonResult<Long> createMessage(@Valid @RequestBody MessageSaveReqVO createReqVO) { public CommonResult<Long> createMessage(@Valid @RequestBody ImMessageSaveReqVO createReqVO) {
return success(messageService.createMessage(createReqVO)); return success(imMessageService.createMessage(createReqVO));
} }
@PutMapping("/update") @PutMapping("/update")
@Operation(summary = "更新消息") @Operation(summary = "更新消息")
@PreAuthorize("@ss.hasPermission('im:message:update')") @PreAuthorize("@ss.hasPermission('im:message:update')")
public CommonResult<Boolean> updateMessage(@Valid @RequestBody MessageSaveReqVO updateReqVO) { public CommonResult<Boolean> updateMessage(@Valid @RequestBody ImMessageSaveReqVO updateReqVO) {
messageService.updateMessage(updateReqVO); imMessageService.updateMessage(updateReqVO);
return success(true); return success(true);
} }
@ -56,7 +56,7 @@ public class MessageController {
@Parameter(name = "id", description = "编号", required = true) @Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('im:message:delete')") @PreAuthorize("@ss.hasPermission('im:message:delete')")
public CommonResult<Boolean> deleteMessage(@RequestParam("id") Long id) { public CommonResult<Boolean> deleteMessage(@RequestParam("id") Long id) {
messageService.deleteMessage(id); imMessageService.deleteMessage(id);
return success(true); return success(true);
} }
@ -64,36 +64,36 @@ public class MessageController {
@Operation(summary = "获得消息") @Operation(summary = "获得消息")
@Parameter(name = "id", description = "编号", required = true, example = "1024") @Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('im:message:query')") @PreAuthorize("@ss.hasPermission('im:message:query')")
public CommonResult<MessageRespVO> getMessage(@RequestParam("id") Long id) { public CommonResult<ImMessageRespVO> getMessage(@RequestParam("id") Long id) {
MessageDO message = messageService.getMessage(id); ImMessageDO message = imMessageService.getMessage(id);
return success(BeanUtils.toBean(message, MessageRespVO.class)); return success(BeanUtils.toBean(message, ImMessageRespVO.class));
} }
@GetMapping("/page") @GetMapping("/page")
@Operation(summary = "获得消息分页") @Operation(summary = "获得消息分页")
@PreAuthorize("@ss.hasPermission('im:message:query')") @PreAuthorize("@ss.hasPermission('im:message:query')")
public CommonResult<PageResult<MessageRespVO>> getMessagePage(@Valid MessagePageReqVO pageReqVO) { public CommonResult<PageResult<ImMessageRespVO>> getMessagePage(@Valid ImMessagePageReqVO pageReqVO) {
PageResult<MessageDO> pageResult = messageService.getMessagePage(pageReqVO); PageResult<ImMessageDO> pageResult = imMessageService.getMessagePage(pageReqVO);
return success(BeanUtils.toBean(pageResult, MessageRespVO.class)); return success(BeanUtils.toBean(pageResult, ImMessageRespVO.class));
} }
@GetMapping("/export-excel") @GetMapping("/export-excel")
@Operation(summary = "导出消息 Excel") @Operation(summary = "导出消息 Excel")
@PreAuthorize("@ss.hasPermission('im:message:export')") @PreAuthorize("@ss.hasPermission('im:message:export')")
@OperateLog(type = EXPORT) @OperateLog(type = EXPORT)
public void exportMessageExcel(@Valid MessagePageReqVO pageReqVO, public void exportMessageExcel(@Valid ImMessagePageReqVO pageReqVO,
HttpServletResponse response) throws IOException { HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
List<MessageDO> list = messageService.getMessagePage(pageReqVO).getList(); List<ImMessageDO> list = imMessageService.getMessagePage(pageReqVO).getList();
// 导出 Excel // 导出 Excel
ExcelUtils.write(response, "消息.xls", "数据", MessageRespVO.class, ExcelUtils.write(response, "消息.xls", "数据", ImMessageRespVO.class,
BeanUtils.toBean(list, MessageRespVO.class)); BeanUtils.toBean(list, ImMessageRespVO.class));
} }
@PostMapping("/send") @PostMapping("/send")
@Operation(summary = "发送私聊消息") @Operation(summary = "发送私聊消息")
public CommonResult<Long> sendMessage(@Valid @RequestBody MessageSaveReqVO messageSaveReqVO) { public CommonResult<Long> sendMessage(@Valid @RequestBody ImMessageSaveReqVO imMessageSaveReqVO) {
return success(messageService.sendPrivateMessage(messageSaveReqVO)); return success(imMessageService.sendPrivateMessage(imMessageSaveReqVO));
} }
} }

View File

@ -15,7 +15,7 @@ import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true) @ToString(callSuper = true)
public class MessagePageReqVO extends PageParam { public class ImMessagePageReqVO extends PageParam {
@Schema(description = "客户端消息编号 uuid用于排重", example = "3331") @Schema(description = "客户端消息编号 uuid用于排重", example = "3331")
private String clientMessageId; private String clientMessageId;
@ -33,13 +33,13 @@ public class MessagePageReqVO extends PageParam {
private String senderAvatar; private String senderAvatar;
@Schema(description = "会话类型", example = "2") @Schema(description = "会话类型", example = "2")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "会话标志") @Schema(description = "会话标志")
private String conversationNo; private String conversationNo;
@Schema(description = "消息类型", example = "1") @Schema(description = "消息类型", example = "1")
private Boolean contentType; private Integer contentType;
@Schema(description = "消息内容") @Schema(description = "消息内容")
private String content; private String content;
@ -49,7 +49,7 @@ public class MessagePageReqVO extends PageParam {
private LocalDateTime[] sendTime; private LocalDateTime[] sendTime;
@Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);") @Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);")
private Boolean sendFrom; private Integer sendFrom;
@Schema(description = "创建时间") @Schema(description = "创建时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)

View File

@ -10,7 +10,7 @@ import java.time.LocalDateTime;
@Schema(description = "管理后台 - 消息 Response VO") @Schema(description = "管理后台 - 消息 Response VO")
@Data @Data
@ExcelIgnoreUnannotated @ExcelIgnoreUnannotated
public class MessageRespVO { public class ImMessageRespVO {
@Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "30713") @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "30713")
@ExcelProperty("编号") @ExcelProperty("编号")
@ -38,7 +38,7 @@ public class MessageRespVO {
@Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2") @Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty("会话类型") @ExcelProperty("会话类型")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "会话标志", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "会话标志", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("会话标志") @ExcelProperty("会话标志")
@ -46,7 +46,7 @@ public class MessageRespVO {
@Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("消息类型") @ExcelProperty("消息类型")
private Boolean contentType; private Integer contentType;
@Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("消息内容") @ExcelProperty("消息内容")
@ -58,7 +58,7 @@ public class MessageRespVO {
@Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("消息来源 100-用户发送200-系统发送(一般是通知);") @ExcelProperty("消息来源 100-用户发送200-系统发送(一般是通知);")
private Boolean sendFrom; private Integer sendFrom;
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("创建时间") @ExcelProperty("创建时间")

View File

@ -9,7 +9,7 @@ import java.time.LocalDateTime;
@Schema(description = "管理后台 - 消息新增/修改 Request VO") @Schema(description = "管理后台 - 消息新增/修改 Request VO")
@Data @Data
public class MessageSaveReqVO { public class ImMessageSaveReqVO {
@Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "30713") @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "30713")
private Long id; private Long id;
@ -36,7 +36,7 @@ public class MessageSaveReqVO {
@Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2") @Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotNull(message = "会话类型不能为空") @NotNull(message = "会话类型不能为空")
private Boolean conversationType; private Integer conversationType;
@Schema(description = "会话标志", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "会话标志", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "会话标志不能为空") @NotEmpty(message = "会话标志不能为空")
@ -44,18 +44,17 @@ public class MessageSaveReqVO {
@Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotNull(message = "消息类型不能为空") @NotNull(message = "消息类型不能为空")
private Boolean contentType; private Integer contentType;
@Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "消息内容不能为空") @NotEmpty(message = "消息内容不能为空")
private String content; private String content;
@Schema(description = "发送时间", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "发送时间", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "发送时间不能为空")
private LocalDateTime sendTime; private LocalDateTime sendTime;
@Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息来源 100-用户发送200-系统发送(一般是通知);", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "消息来源 100-用户发送200-系统发送(一般是通知);不能为空") @NotNull(message = "消息来源 100-用户发送200-系统发送(一般是通知);不能为空")
private Boolean sendFrom; private Integer sendFrom;
} }

View File

@ -21,7 +21,7 @@ import java.time.LocalDateTime;
@Builder @Builder
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class ConversationDO extends BaseDO { public class ImConversationDO extends BaseDO {
/** /**
* 编号 * 编号
@ -35,7 +35,7 @@ public class ConversationDO extends BaseDO {
/** /**
* 类型1 单聊2 群聊4 通知会话预留 * 类型1 单聊2 群聊4 通知会话预留
*/ */
private Boolean conversationType; private Integer conversationType;
/** /**
* 单聊时用户编号群聊时群编号 * 单聊时用户编号群聊时群编号
*/ */

View File

@ -19,7 +19,7 @@ import lombok.*;
@Builder @Builder
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class InboxDO extends BaseDO { public class ImInboxDO extends BaseDO {
/** /**
* 编号 * 编号

View File

@ -21,7 +21,7 @@ import java.time.LocalDateTime;
@Builder @Builder
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class MessageDO extends BaseDO { public class ImMessageDO extends BaseDO {
/** /**
* 编号 * 编号
@ -51,7 +51,7 @@ public class MessageDO extends BaseDO {
/** /**
* 会话类型 * 会话类型
*/ */
private Boolean conversationType; private Integer conversationType;
/** /**
* 会话标志 * 会话标志
*/ */
@ -59,7 +59,7 @@ public class MessageDO extends BaseDO {
/** /**
* 消息类型 * 消息类型
*/ */
private Boolean contentType; private Integer contentType;
/** /**
* 消息内容 * 消息内容
*/ */
@ -71,6 +71,6 @@ public class MessageDO extends BaseDO {
/** /**
* 消息来源 100-用户发送200-系统发送一般是通知 * 消息来源 100-用户发送200-系统发送一般是通知
*/ */
private Boolean sendFrom; private Integer sendFrom;
} }

View File

@ -3,8 +3,8 @@ package cn.iocoder.yudao.module.im.dal.mysql.conversation;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationPageReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ConversationDO; import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
/** /**
@ -13,18 +13,18 @@ import org.apache.ibatis.annotations.Mapper;
* @author 芋道源码 * @author 芋道源码
*/ */
@Mapper @Mapper
public interface ConversationMapper extends BaseMapperX<ConversationDO> { public interface ConversationMapper extends BaseMapperX<ImConversationDO> {
default PageResult<ConversationDO> selectPage(ConversationPageReqVO reqVO) { default PageResult<ImConversationDO> selectPage(ImConversationPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<ConversationDO>() return selectPage(reqVO, new LambdaQueryWrapperX<ImConversationDO>()
.eqIfPresent(ConversationDO::getUserId, reqVO.getUserId()) .eqIfPresent(ImConversationDO::getUserId, reqVO.getUserId())
.eqIfPresent(ConversationDO::getConversationType, reqVO.getConversationType()) .eqIfPresent(ImConversationDO::getConversationType, reqVO.getConversationType())
.eqIfPresent(ConversationDO::getTargetId, reqVO.getTargetId()) .eqIfPresent(ImConversationDO::getTargetId, reqVO.getTargetId())
.eqIfPresent(ConversationDO::getNo, reqVO.getNo()) .eqIfPresent(ImConversationDO::getNo, reqVO.getNo())
.eqIfPresent(ConversationDO::getPinned, reqVO.getPinned()) .eqIfPresent(ImConversationDO::getPinned, reqVO.getPinned())
.betweenIfPresent(ConversationDO::getLastReadTime, reqVO.getLastReadTime()) .betweenIfPresent(ImConversationDO::getLastReadTime, reqVO.getLastReadTime())
.betweenIfPresent(ConversationDO::getCreateTime, reqVO.getCreateTime()) .betweenIfPresent(ImConversationDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(ConversationDO::getId)); .orderByDesc(ImConversationDO::getId));
} }
} }

View File

@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.inbox.InboxDO; import cn.iocoder.yudao.module.im.dal.dataobject.inbox.ImInboxDO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
/** /**
@ -13,15 +13,15 @@ import org.apache.ibatis.annotations.Mapper;
* @author 芋道源码 * @author 芋道源码
*/ */
@Mapper @Mapper
public interface InboxMapper extends BaseMapperX<InboxDO> { public interface InboxMapper extends BaseMapperX<ImInboxDO> {
default PageResult<InboxDO> selectPage(InboxPageReqVO reqVO) { default PageResult<ImInboxDO> selectPage(InboxPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<InboxDO>() return selectPage(reqVO, new LambdaQueryWrapperX<ImInboxDO>()
.eqIfPresent(InboxDO::getUserId, reqVO.getUserId()) .eqIfPresent(ImInboxDO::getUserId, reqVO.getUserId())
.eqIfPresent(InboxDO::getMessageId, reqVO.getMessageId()) .eqIfPresent(ImInboxDO::getMessageId, reqVO.getMessageId())
.eqIfPresent(InboxDO::getSequence, reqVO.getSequence()) .eqIfPresent(ImInboxDO::getSequence, reqVO.getSequence())
.betweenIfPresent(InboxDO::getCreateTime, reqVO.getCreateTime()) .betweenIfPresent(ImInboxDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(InboxDO::getId)); .orderByDesc(ImInboxDO::getId));
} }
} }

View File

@ -0,0 +1,35 @@
package cn.iocoder.yudao.module.im.dal.mysql.message;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessagePageReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
import org.apache.ibatis.annotations.Mapper;
/**
* 消息 Mapper
*
* @author 芋道源码
*/
@Mapper
public interface ImMessageMapper extends BaseMapperX<ImMessageDO> {
default PageResult<ImMessageDO> selectPage(ImMessagePageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<ImMessageDO>()
.eqIfPresent(ImMessageDO::getClientMessageId, reqVO.getClientMessageId())
.eqIfPresent(ImMessageDO::getSenderId, reqVO.getSenderId())
.eqIfPresent(ImMessageDO::getReceiverId, reqVO.getReceiverId())
.likeIfPresent(ImMessageDO::getSenderNickname, reqVO.getSenderNickname())
.eqIfPresent(ImMessageDO::getSenderAvatar, reqVO.getSenderAvatar())
.eqIfPresent(ImMessageDO::getConversationType, reqVO.getConversationType())
.eqIfPresent(ImMessageDO::getConversationNo, reqVO.getConversationNo())
.eqIfPresent(ImMessageDO::getContentType, reqVO.getContentType())
.eqIfPresent(ImMessageDO::getContent, reqVO.getContent())
.betweenIfPresent(ImMessageDO::getSendTime, reqVO.getSendTime())
.eqIfPresent(ImMessageDO::getSendFrom, reqVO.getSendFrom())
.betweenIfPresent(ImMessageDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(ImMessageDO::getId));
}
}

View File

@ -1,35 +0,0 @@
package cn.iocoder.yudao.module.im.dal.mysql.message;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessagePageReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.MessageDO;
import org.apache.ibatis.annotations.Mapper;
/**
* 消息 Mapper
*
* @author 芋道源码
*/
@Mapper
public interface MessageMapper extends BaseMapperX<MessageDO> {
default PageResult<MessageDO> selectPage(MessagePageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<MessageDO>()
.eqIfPresent(MessageDO::getClientMessageId, reqVO.getClientMessageId())
.eqIfPresent(MessageDO::getSenderId, reqVO.getSenderId())
.eqIfPresent(MessageDO::getReceiverId, reqVO.getReceiverId())
.likeIfPresent(MessageDO::getSenderNickname, reqVO.getSenderNickname())
.eqIfPresent(MessageDO::getSenderAvatar, reqVO.getSenderAvatar())
.eqIfPresent(MessageDO::getConversationType, reqVO.getConversationType())
.eqIfPresent(MessageDO::getConversationNo, reqVO.getConversationNo())
.eqIfPresent(MessageDO::getContentType, reqVO.getContentType())
.eqIfPresent(MessageDO::getContent, reqVO.getContent())
.betweenIfPresent(MessageDO::getSendTime, reqVO.getSendTime())
.eqIfPresent(MessageDO::getSendFrom, reqVO.getSendFrom())
.betweenIfPresent(MessageDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(MessageDO::getId));
}
}

View File

@ -1,9 +1,9 @@
package cn.iocoder.yudao.module.im.service.conversation; package cn.iocoder.yudao.module.im.service.conversation;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ConversationDO; import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
import jakarta.validation.Valid; import jakarta.validation.Valid;
/** /**
@ -11,7 +11,7 @@ import jakarta.validation.Valid;
* *
* @author 芋道源码 * @author 芋道源码
*/ */
public interface ConversationService { public interface ImConversationService {
/** /**
* 创建会话 * 创建会话
@ -19,14 +19,14 @@ public interface ConversationService {
* @param createReqVO 创建信息 * @param createReqVO 创建信息
* @return 编号 * @return 编号
*/ */
Long createConversation(@Valid ConversationSaveReqVO createReqVO); Long createConversation(@Valid ImConversationSaveReqVO createReqVO);
/** /**
* 更新会话 * 更新会话
* *
* @param updateReqVO 更新信息 * @param updateReqVO 更新信息
*/ */
void updateConversation(@Valid ConversationSaveReqVO updateReqVO); void updateConversation(@Valid ImConversationSaveReqVO updateReqVO);
/** /**
* 删除会话 * 删除会话
@ -41,7 +41,7 @@ public interface ConversationService {
* @param id 编号 * @param id 编号
* @return 会话 * @return 会话
*/ */
ConversationDO getConversation(Long id); ImConversationDO getConversation(Long id);
/** /**
* 获得会话分页 * 获得会话分页
@ -49,6 +49,6 @@ public interface ConversationService {
* @param pageReqVO 分页查询 * @param pageReqVO 分页查询
* @return 会话分页 * @return 会话分页
*/ */
PageResult<ConversationDO> getConversationPage(ConversationPageReqVO pageReqVO); PageResult<ImConversationDO> getConversationPage(ImConversationPageReqVO pageReqVO);
} }

View File

@ -2,9 +2,9 @@ package cn.iocoder.yudao.module.im.service.conversation;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils; import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ConversationSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ConversationDO; import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
import cn.iocoder.yudao.module.im.dal.mysql.conversation.ConversationMapper; import cn.iocoder.yudao.module.im.dal.mysql.conversation.ConversationMapper;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -20,26 +20,26 @@ import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.CONVERSATION_N
*/ */
@Service @Service
@Validated @Validated
public class ConversationServiceImpl implements ConversationService { public class ImConversationServiceImpl implements ImConversationService {
@Resource @Resource
private ConversationMapper conversationMapper; private ConversationMapper conversationMapper;
@Override @Override
public Long createConversation(ConversationSaveReqVO createReqVO) { public Long createConversation(ImConversationSaveReqVO createReqVO) {
// 插入 // 插入
ConversationDO conversation = BeanUtils.toBean(createReqVO, ConversationDO.class); ImConversationDO conversation = BeanUtils.toBean(createReqVO, ImConversationDO.class);
conversationMapper.insert(conversation); conversationMapper.insert(conversation);
// 返回 // 返回
return conversation.getId(); return conversation.getId();
} }
@Override @Override
public void updateConversation(ConversationSaveReqVO updateReqVO) { public void updateConversation(ImConversationSaveReqVO updateReqVO) {
// 校验存在 // 校验存在
validateConversationExists(updateReqVO.getId()); validateConversationExists(updateReqVO.getId());
// 更新 // 更新
ConversationDO updateObj = BeanUtils.toBean(updateReqVO, ConversationDO.class); ImConversationDO updateObj = BeanUtils.toBean(updateReqVO, ImConversationDO.class);
conversationMapper.updateById(updateObj); conversationMapper.updateById(updateObj);
} }
@ -58,12 +58,12 @@ public class ConversationServiceImpl implements ConversationService {
} }
@Override @Override
public ConversationDO getConversation(Long id) { public ImConversationDO getConversation(Long id) {
return conversationMapper.selectById(id); return conversationMapper.selectById(id);
} }
@Override @Override
public PageResult<ConversationDO> getConversationPage(ConversationPageReqVO pageReqVO) { public PageResult<ImConversationDO> getConversationPage(ImConversationPageReqVO pageReqVO) {
return conversationMapper.selectPage(pageReqVO); return conversationMapper.selectPage(pageReqVO);
} }

View File

@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.im.service.inbox;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.inbox.InboxDO; import cn.iocoder.yudao.module.im.dal.dataobject.inbox.ImInboxDO;
import jakarta.validation.Valid; import jakarta.validation.Valid;
/** /**
@ -41,7 +41,7 @@ public interface InboxService {
* @param id 编号 * @param id 编号
* @return 收件箱 * @return 收件箱
*/ */
InboxDO getInbox(Long id); ImInboxDO getInbox(Long id);
/** /**
* 获得收件箱分页 * 获得收件箱分页
@ -49,6 +49,6 @@ public interface InboxService {
* @param pageReqVO 分页查询 * @param pageReqVO 分页查询
* @return 收件箱分页 * @return 收件箱分页
*/ */
PageResult<InboxDO> getInboxPage(InboxPageReqVO pageReqVO); PageResult<ImInboxDO> getInboxPage(InboxPageReqVO pageReqVO);
} }

View File

@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils; import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxPageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.InboxSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.inbox.InboxDO; import cn.iocoder.yudao.module.im.dal.dataobject.inbox.ImInboxDO;
import cn.iocoder.yudao.module.im.dal.mysql.inbox.InboxMapper; import cn.iocoder.yudao.module.im.dal.mysql.inbox.InboxMapper;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -28,7 +28,7 @@ public class InboxServiceImpl implements InboxService {
@Override @Override
public Long createInbox(InboxSaveReqVO createReqVO) { public Long createInbox(InboxSaveReqVO createReqVO) {
// 插入 // 插入
InboxDO inbox = BeanUtils.toBean(createReqVO, InboxDO.class); ImInboxDO inbox = BeanUtils.toBean(createReqVO, ImInboxDO.class);
inboxMapper.insert(inbox); inboxMapper.insert(inbox);
// 返回 // 返回
return inbox.getId(); return inbox.getId();
@ -39,7 +39,7 @@ public class InboxServiceImpl implements InboxService {
// 校验存在 // 校验存在
validateInboxExists(updateReqVO.getId()); validateInboxExists(updateReqVO.getId());
// 更新 // 更新
InboxDO updateObj = BeanUtils.toBean(updateReqVO, InboxDO.class); ImInboxDO updateObj = BeanUtils.toBean(updateReqVO, ImInboxDO.class);
inboxMapper.updateById(updateObj); inboxMapper.updateById(updateObj);
} }
@ -58,12 +58,12 @@ public class InboxServiceImpl implements InboxService {
} }
@Override @Override
public InboxDO getInbox(Long id) { public ImInboxDO getInbox(Long id) {
return inboxMapper.selectById(id); return inboxMapper.selectById(id);
} }
@Override @Override
public PageResult<InboxDO> getInboxPage(InboxPageReqVO pageReqVO) { public PageResult<ImInboxDO> getInboxPage(InboxPageReqVO pageReqVO) {
return inboxMapper.selectPage(pageReqVO); return inboxMapper.selectPage(pageReqVO);
} }

View File

@ -1,9 +1,9 @@
package cn.iocoder.yudao.module.im.service.message; package cn.iocoder.yudao.module.im.service.message;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessagePageReqVO; import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessagePageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessageSaveReqVO; import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.MessageDO; import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
import jakarta.validation.Valid; import jakarta.validation.Valid;
/** /**
@ -11,7 +11,7 @@ import jakarta.validation.Valid;
* *
* @author 芋道源码 * @author 芋道源码
*/ */
public interface MessageService { public interface ImMessageService {
/** /**
* 创建消息 * 创建消息
@ -19,14 +19,14 @@ public interface MessageService {
* @param createReqVO 创建信息 * @param createReqVO 创建信息
* @return 编号 * @return 编号
*/ */
Long createMessage(@Valid MessageSaveReqVO createReqVO); Long createMessage(@Valid ImMessageSaveReqVO createReqVO);
/** /**
* 更新消息 * 更新消息
* *
* @param updateReqVO 更新信息 * @param updateReqVO 更新信息
*/ */
void updateMessage(@Valid MessageSaveReqVO updateReqVO); void updateMessage(@Valid ImMessageSaveReqVO updateReqVO);
/** /**
* 删除消息 * 删除消息
@ -41,7 +41,7 @@ public interface MessageService {
* @param id 编号 * @param id 编号
* @return 消息 * @return 消息
*/ */
MessageDO getMessage(Long id); ImMessageDO getMessage(Long id);
/** /**
* 获得消息分页 * 获得消息分页
@ -49,12 +49,12 @@ public interface MessageService {
* @param pageReqVO 分页查询 * @param pageReqVO 分页查询
* @return 消息分页 * @return 消息分页
*/ */
PageResult<MessageDO> getMessagePage(MessagePageReqVO pageReqVO); PageResult<ImMessageDO> getMessagePage(ImMessagePageReqVO pageReqVO);
/** /**
* 发送私聊消息 * 发送私聊消息
* @param messageSaveReqVO 消息信息 * @param imMessageSaveReqVO 消息信息
* @return 消息编号 * @return 消息编号
*/ */
Long sendPrivateMessage(MessageSaveReqVO messageSaveReqVO); Long sendPrivateMessage(ImMessageSaveReqVO imMessageSaveReqVO);
} }

View File

@ -0,0 +1,75 @@
package cn.iocoder.yudao.module.im.service.message;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessagePageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
import cn.iocoder.yudao.module.im.dal.mysql.message.ImMessageMapper;
import jakarta.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.MESSAGE_NOT_EXISTS;
/**
* 消息 Service 实现类
*
* @author 芋道源码
*/
@Service
@Validated
public class ImMessageServiceImpl implements ImMessageService {
@Resource
private ImMessageMapper imMessageMapper;
@Override
public Long createMessage(ImMessageSaveReqVO createReqVO) {
// 插入
ImMessageDO message = BeanUtils.toBean(createReqVO, ImMessageDO.class);
imMessageMapper.insert(message);
// 返回
return message.getId();
}
@Override
public void updateMessage(ImMessageSaveReqVO updateReqVO) {
// 校验存在
validateMessageExists(updateReqVO.getId());
// 更新
ImMessageDO updateObj = BeanUtils.toBean(updateReqVO, ImMessageDO.class);
imMessageMapper.updateById(updateObj);
}
@Override
public void deleteMessage(Long id) {
// 校验存在
validateMessageExists(id);
// 删除
imMessageMapper.deleteById(id);
}
private void validateMessageExists(Long id) {
if (imMessageMapper.selectById(id) == null) {
throw exception(MESSAGE_NOT_EXISTS);
}
}
@Override
public ImMessageDO getMessage(Long id) {
return imMessageMapper.selectById(id);
}
@Override
public PageResult<ImMessageDO> getMessagePage(ImMessagePageReqVO pageReqVO) {
return imMessageMapper.selectPage(pageReqVO);
}
@Override
public Long sendPrivateMessage(ImMessageSaveReqVO imMessageSaveReqVO) {
return 0L;
}
}

View File

@ -1,75 +0,0 @@
package cn.iocoder.yudao.module.im.service.message;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessagePageReqVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.MessageSaveReqVO;
import cn.iocoder.yudao.module.im.dal.dataobject.message.MessageDO;
import cn.iocoder.yudao.module.im.dal.mysql.message.MessageMapper;
import jakarta.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.MESSAGE_NOT_EXISTS;
/**
* 消息 Service 实现类
*
* @author 芋道源码
*/
@Service
@Validated
public class MessageServiceImpl implements MessageService {
@Resource
private MessageMapper messageMapper;
@Override
public Long createMessage(MessageSaveReqVO createReqVO) {
// 插入
MessageDO message = BeanUtils.toBean(createReqVO, MessageDO.class);
messageMapper.insert(message);
// 返回
return message.getId();
}
@Override
public void updateMessage(MessageSaveReqVO updateReqVO) {
// 校验存在
validateMessageExists(updateReqVO.getId());
// 更新
MessageDO updateObj = BeanUtils.toBean(updateReqVO, MessageDO.class);
messageMapper.updateById(updateObj);
}
@Override
public void deleteMessage(Long id) {
// 校验存在
validateMessageExists(id);
// 删除
messageMapper.deleteById(id);
}
private void validateMessageExists(Long id) {
if (messageMapper.selectById(id) == null) {
throw exception(MESSAGE_NOT_EXISTS);
}
}
@Override
public MessageDO getMessage(Long id) {
return messageMapper.selectById(id);
}
@Override
public PageResult<MessageDO> getMessagePage(MessagePageReqVO pageReqVO) {
return messageMapper.selectPage(pageReqVO);
}
@Override
public Long sendPrivateMessage(MessageSaveReqVO messageSaveReqVO) {
return 0L;
}
}

View File

@ -4,9 +4,15 @@ import cn.iocoder.yudao.framework.common.enums.UserTypeEnum;
import cn.iocoder.yudao.framework.websocket.core.listener.WebSocketMessageListener; import cn.iocoder.yudao.framework.websocket.core.listener.WebSocketMessageListener;
import cn.iocoder.yudao.framework.websocket.core.sender.WebSocketMessageSender; import cn.iocoder.yudao.framework.websocket.core.sender.WebSocketMessageSender;
import cn.iocoder.yudao.framework.websocket.core.util.WebSocketFrameworkUtils; import cn.iocoder.yudao.framework.websocket.core.util.WebSocketFrameworkUtils;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.ImConversationSaveReqVO;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.ImMessageSaveReqVO;
import cn.iocoder.yudao.module.im.enums.conversation.ImConversationTypeEnum; import cn.iocoder.yudao.module.im.enums.conversation.ImConversationTypeEnum;
import cn.iocoder.yudao.module.im.service.conversation.ImConversationService;
import cn.iocoder.yudao.module.im.service.message.ImMessageService;
import cn.iocoder.yudao.module.im.websocket.message.ImReceiveMessage; import cn.iocoder.yudao.module.im.websocket.message.ImReceiveMessage;
import cn.iocoder.yudao.module.im.websocket.message.ImSendMessage; import cn.iocoder.yudao.module.im.websocket.message.ImSendMessage;
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import org.springframework.web.socket.WebSocketSession; import org.springframework.web.socket.WebSocketSession;
@ -21,19 +27,65 @@ public class ImWebSocketMessageListener implements WebSocketMessageListener<ImSe
@Resource @Resource
private WebSocketMessageSender webSocketMessageSender; private WebSocketMessageSender webSocketMessageSender;
@Resource
private ImMessageService imMessageService;
@Resource
private AdminUserApi adminUserApi;
@Resource
private ImConversationService imConversationService;
@Override @Override
public void onMessage(WebSocketSession session, ImSendMessage message) { public void onMessage(WebSocketSession session, ImSendMessage message) {
Long fromUserId = WebSocketFrameworkUtils.getLoginUserId(session); Long fromUserId = WebSocketFrameworkUtils.getLoginUserId(session);
//1插入消息表
ImMessageSaveReqVO imMessageSaveReqVO = new ImMessageSaveReqVO();
imMessageSaveReqVO.setClientMessageId(message.getClientMessageId());
imMessageSaveReqVO.setSenderId(fromUserId);
imMessageSaveReqVO.setReceiverId(message.getReceiverId());
//查询发送人昵称和发送人头像
AdminUserRespDTO user = adminUserApi.getUser(fromUserId);
imMessageSaveReqVO.setSenderNickname(user.getNickname());
imMessageSaveReqVO.setSenderAvatar(user.getAvatar());
imMessageSaveReqVO.setConversationType(message.getConversationType());
imMessageSaveReqVO.setContentType(message.getContentType());
imMessageSaveReqVO.setConversationNo("1");
imMessageSaveReqVO.setContent(message.getContent());
//消息来源 100-用户发送200-系统发送一般是通知不能为空
imMessageSaveReqVO.setSendFrom(100);
imMessageService.createMessage(imMessageSaveReqVO);
// 私聊 // 私聊
if (message.getConversationType().equals(ImConversationTypeEnum.PRIVATE.getType())) { if (message.getConversationType().equals(ImConversationTypeEnum.PRIVATE.getType())) {
//2插入收件箱表私聊两条群聊每个群有一条
ImConversationSaveReqVO imConversationSaveReqVO = new ImConversationSaveReqVO();
imConversationSaveReqVO.setUserId(fromUserId);
imConversationSaveReqVO.setConversationType(message.getConversationType());
//单聊时用户编号群聊时群编号
imConversationSaveReqVO.setTargetId(message.getReceiverId()+"");
//会话标志 单聊s_{userId}_{targetId}需要排序 userId targetId 群聊g_groupId
imConversationSaveReqVO.setNo("s_" + fromUserId + "_" + message.getReceiverId());
imConversationSaveReqVO.setPinned(false);
imConversationService.createConversation(imConversationSaveReqVO);
ImConversationSaveReqVO imConversationSaveReqVO1 = new ImConversationSaveReqVO();
imConversationSaveReqVO1.setUserId(message.getReceiverId());
imConversationSaveReqVO1.setConversationType(message.getConversationType());
//单聊时用户编号群聊时群编号
imConversationSaveReqVO1.setTargetId(fromUserId+"");
//会话标志 单聊s_{userId}_{targetId}需要排序 userId targetId 群聊g_groupId
imConversationSaveReqVO1.setNo("s_" + message.getReceiverId() + "_" + fromUserId);
imConversationSaveReqVO1.setPinned(false);
imConversationService.createConversation(imConversationSaveReqVO1);
//3推送消息
ImReceiveMessage toMessage = new ImReceiveMessage(); ImReceiveMessage toMessage = new ImReceiveMessage();
toMessage.setToId(fromUserId); toMessage.setFromId(fromUserId);
toMessage.setConversationType(ImConversationTypeEnum.PRIVATE.getType()); toMessage.setConversationType(ImConversationTypeEnum.PRIVATE.getType());
//消息类型 toMessage.setContentType(message.getContentType());
toMessage.setType(message.getType()); toMessage.setContent(message.getContent());
toMessage.setBody(message.getBody()); webSocketMessageSender.sendObject(UserTypeEnum.ADMIN.getValue(), message.getReceiverId(), // 给指定用户
webSocketMessageSender.sendObject(UserTypeEnum.ADMIN.getValue(), message.getToId(), // 给指定用户
"im-message-receive", toMessage); "im-message-receive", toMessage);
} }
} }

View File

@ -4,20 +4,20 @@ import cn.iocoder.yudao.module.im.dal.dataobject.message.body.ImMessageBody;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data; import lombok.Data;
@Schema(description = "管理后台 - 消息发送 send") @Schema(description = "管理后台 - 消息发送 receive")
@Data @Data
public class ImReceiveMessage { public class ImReceiveMessage {
@Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Integer conversationType; // 对应 ImConversationTypeEnum 枚举 private Integer conversationType; // 对应 ImConversationTypeEnum 枚举
@Schema(description = "聊天对象,用户编号或群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024") @Schema(description = "发送人编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
private Long toId; // 根据 conversationType 区分 private Long fromId; // 根据 conversationType 区分
@Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "内容类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Integer type; // 参见 ImMessageTypeEnum 枚举 private Integer contentType; // 参见 ImMessageTypeEnum 枚举
@Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED)
private ImMessageBody body; private String content;
} }

View File

@ -2,22 +2,26 @@ package cn.iocoder.yudao.module.im.websocket.message;
import cn.iocoder.yudao.module.im.dal.dataobject.message.body.ImMessageBody; import cn.iocoder.yudao.module.im.dal.dataobject.message.body.ImMessageBody;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotEmpty;
import lombok.Data; import lombok.Data;
@Schema(description = "管理后台 - 消息发送 send") @Schema(description = "管理后台 - 消息发送 send")
@Data @Data
public class ImSendMessage { public class ImSendMessage {
@Schema(description = "客户端消息编号 uuid用于排重", requiredMode = Schema.RequiredMode.REQUIRED, example = "3331")
private String clientMessageId;
@Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "会话类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Integer conversationType; // 对应 ImConversationTypeEnum 枚举 private Integer conversationType; // 对应 ImConversationTypeEnum 枚举
@Schema(description = "聊天对象,用户编号或群编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024") @Schema(description = "接收人编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
private Long toId; // 根据 conversationType 区分 private Long receiverId; // 根据 conversationType 区分
@Schema(description = "消息类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "内容类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Integer type; // 参见 ImMessageTypeEnum 枚举 private Integer contentType; // 参见 ImMessageTypeEnum 枚举
@Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "消息内容", requiredMode = Schema.RequiredMode.REQUIRED)
private ImMessageBody body; private String content;
} }

View File

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.iocoder.yudao.module.im.dal.mysql.message.MessageMapper"> <mapper namespace="cn.iocoder.yudao.module.im.dal.mysql.message.ImMessageMapper">
<!-- <!--
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。 一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。

View File

@ -2,42 +2,35 @@ package cn.iocoder.yudao.module.im.service.conversation;
import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.boot.test.mock.mockito.MockBean;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.*; import cn.iocoder.yudao.module.im.controller.admin.conversation.vo.*;
import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ConversationDO; import cn.iocoder.yudao.module.im.dal.dataobject.conversation.ImConversationDO;
import cn.iocoder.yudao.module.im.dal.mysql.conversation.ConversationMapper; import cn.iocoder.yudao.module.im.dal.mysql.conversation.ConversationMapper;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import jakarta.annotation.Resource;
import org.springframework.context.annotation.Import; import org.springframework.context.annotation.Import;
import java.util.*;
import java.time.LocalDateTime;
import static cn.hutool.core.util.RandomUtil.*;
import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*; import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*; import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*; import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*; import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/** /**
* {@link ConversationServiceImpl} 的单元测试类 * {@link ImConversationServiceImpl} 的单元测试类
* *
* @author 芋道源码 * @author 芋道源码
*/ */
@Import(ConversationServiceImpl.class) @Import(ImConversationServiceImpl.class)
public class ConversationServiceImplTest extends BaseDbUnitTest { public class ImConversationServiceImplTest extends BaseDbUnitTest {
@Resource @Resource
private ConversationServiceImpl conversationService; private ImConversationServiceImpl conversationService;
@Resource @Resource
private ConversationMapper conversationMapper; private ConversationMapper conversationMapper;
@ -45,38 +38,38 @@ public class ConversationServiceImplTest extends BaseDbUnitTest {
@Test @Test
public void testCreateConversation_success() { public void testCreateConversation_success() {
// 准备参数 // 准备参数
ConversationSaveReqVO createReqVO = randomPojo(ConversationSaveReqVO.class).setId(null); ImConversationSaveReqVO createReqVO = randomPojo(ImConversationSaveReqVO.class).setId(null);
// 调用 // 调用
Long conversationId = conversationService.createConversation(createReqVO); Long conversationId = conversationService.createConversation(createReqVO);
// 断言 // 断言
assertNotNull(conversationId); assertNotNull(conversationId);
// 校验记录的属性是否正确 // 校验记录的属性是否正确
ConversationDO conversation = conversationMapper.selectById(conversationId); ImConversationDO conversation = conversationMapper.selectById(conversationId);
assertPojoEquals(createReqVO, conversation, "id"); assertPojoEquals(createReqVO, conversation, "id");
} }
@Test @Test
public void testUpdateConversation_success() { public void testUpdateConversation_success() {
// mock 数据 // mock 数据
ConversationDO dbConversation = randomPojo(ConversationDO.class); ImConversationDO dbConversation = randomPojo(ImConversationDO.class);
conversationMapper.insert(dbConversation);// @Sql: 先插入出一条存在的数据 conversationMapper.insert(dbConversation);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
ConversationSaveReqVO updateReqVO = randomPojo(ConversationSaveReqVO.class, o -> { ImConversationSaveReqVO updateReqVO = randomPojo(ImConversationSaveReqVO.class, o -> {
o.setId(dbConversation.getId()); // 设置更新的 ID o.setId(dbConversation.getId()); // 设置更新的 ID
}); });
// 调用 // 调用
conversationService.updateConversation(updateReqVO); conversationService.updateConversation(updateReqVO);
// 校验是否更新正确 // 校验是否更新正确
ConversationDO conversation = conversationMapper.selectById(updateReqVO.getId()); // 获取最新的 ImConversationDO conversation = conversationMapper.selectById(updateReqVO.getId()); // 获取最新的
assertPojoEquals(updateReqVO, conversation); assertPojoEquals(updateReqVO, conversation);
} }
@Test @Test
public void testUpdateConversation_notExists() { public void testUpdateConversation_notExists() {
// 准备参数 // 准备参数
ConversationSaveReqVO updateReqVO = randomPojo(ConversationSaveReqVO.class); ImConversationSaveReqVO updateReqVO = randomPojo(ImConversationSaveReqVO.class);
// 调用, 并断言异常 // 调用, 并断言异常
assertServiceException(() -> conversationService.updateConversation(updateReqVO), CONVERSATION_NOT_EXISTS); assertServiceException(() -> conversationService.updateConversation(updateReqVO), CONVERSATION_NOT_EXISTS);
@ -85,7 +78,7 @@ public class ConversationServiceImplTest extends BaseDbUnitTest {
@Test @Test
public void testDeleteConversation_success() { public void testDeleteConversation_success() {
// mock 数据 // mock 数据
ConversationDO dbConversation = randomPojo(ConversationDO.class); ImConversationDO dbConversation = randomPojo(ImConversationDO.class);
conversationMapper.insert(dbConversation);// @Sql: 先插入出一条存在的数据 conversationMapper.insert(dbConversation);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
Long id = dbConversation.getId(); Long id = dbConversation.getId();
@ -109,7 +102,7 @@ public class ConversationServiceImplTest extends BaseDbUnitTest {
@Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解 @Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解
public void testGetConversationPage() { public void testGetConversationPage() {
// mock 数据 // mock 数据
ConversationDO dbConversation = randomPojo(ConversationDO.class, o -> { // 等会查询到 ImConversationDO dbConversation = randomPojo(ImConversationDO.class, o -> { // 等会查询到
o.setUserId(null); o.setUserId(null);
o.setConversationType(null); o.setConversationType(null);
o.setTargetId(null); o.setTargetId(null);
@ -134,7 +127,7 @@ public class ConversationServiceImplTest extends BaseDbUnitTest {
// 测试 createTime 不匹配 // 测试 createTime 不匹配
conversationMapper.insert(cloneIgnoreId(dbConversation, o -> o.setCreateTime(null))); conversationMapper.insert(cloneIgnoreId(dbConversation, o -> o.setCreateTime(null)));
// 准备参数 // 准备参数
ConversationPageReqVO reqVO = new ConversationPageReqVO(); ImConversationPageReqVO reqVO = new ImConversationPageReqVO();
reqVO.setUserId(null); reqVO.setUserId(null);
reqVO.setConversationType(null); reqVO.setConversationType(null);
reqVO.setTargetId(null); reqVO.setTargetId(null);
@ -144,7 +137,7 @@ public class ConversationServiceImplTest extends BaseDbUnitTest {
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28)); reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
// 调用 // 调用
PageResult<ConversationDO> pageResult = conversationService.getConversationPage(reqVO); PageResult<ImConversationDO> pageResult = conversationService.getConversationPage(reqVO);
// 断言 // 断言
assertEquals(1, pageResult.getTotal()); assertEquals(1, pageResult.getTotal());
assertEquals(1, pageResult.getList().size()); assertEquals(1, pageResult.getList().size());

View File

@ -2,31 +2,24 @@ package cn.iocoder.yudao.module.im.service.inbox;
import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.boot.test.mock.mockito.MockBean;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.*; import cn.iocoder.yudao.module.im.controller.admin.inbox.vo.*;
import cn.iocoder.yudao.module.im.dal.dataobject.inbox.InboxDO; import cn.iocoder.yudao.module.im.dal.dataobject.inbox.ImInboxDO;
import cn.iocoder.yudao.module.im.dal.mysql.inbox.InboxMapper; import cn.iocoder.yudao.module.im.dal.mysql.inbox.InboxMapper;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import jakarta.annotation.Resource;
import org.springframework.context.annotation.Import; import org.springframework.context.annotation.Import;
import java.util.*;
import java.time.LocalDateTime;
import static cn.hutool.core.util.RandomUtil.*;
import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*; import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*; import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*; import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*; import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/** /**
* {@link InboxServiceImpl} 的单元测试类 * {@link InboxServiceImpl} 的单元测试类
@ -52,14 +45,14 @@ public class InboxServiceImplTest extends BaseDbUnitTest {
// 断言 // 断言
assertNotNull(inboxId); assertNotNull(inboxId);
// 校验记录的属性是否正确 // 校验记录的属性是否正确
InboxDO inbox = inboxMapper.selectById(inboxId); ImInboxDO inbox = inboxMapper.selectById(inboxId);
assertPojoEquals(createReqVO, inbox, "id"); assertPojoEquals(createReqVO, inbox, "id");
} }
@Test @Test
public void testUpdateInbox_success() { public void testUpdateInbox_success() {
// mock 数据 // mock 数据
InboxDO dbInbox = randomPojo(InboxDO.class); ImInboxDO dbInbox = randomPojo(ImInboxDO.class);
inboxMapper.insert(dbInbox);// @Sql: 先插入出一条存在的数据 inboxMapper.insert(dbInbox);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
InboxSaveReqVO updateReqVO = randomPojo(InboxSaveReqVO.class, o -> { InboxSaveReqVO updateReqVO = randomPojo(InboxSaveReqVO.class, o -> {
@ -69,7 +62,7 @@ public class InboxServiceImplTest extends BaseDbUnitTest {
// 调用 // 调用
inboxService.updateInbox(updateReqVO); inboxService.updateInbox(updateReqVO);
// 校验是否更新正确 // 校验是否更新正确
InboxDO inbox = inboxMapper.selectById(updateReqVO.getId()); // 获取最新的 ImInboxDO inbox = inboxMapper.selectById(updateReqVO.getId()); // 获取最新的
assertPojoEquals(updateReqVO, inbox); assertPojoEquals(updateReqVO, inbox);
} }
@ -85,7 +78,7 @@ public class InboxServiceImplTest extends BaseDbUnitTest {
@Test @Test
public void testDeleteInbox_success() { public void testDeleteInbox_success() {
// mock 数据 // mock 数据
InboxDO dbInbox = randomPojo(InboxDO.class); ImInboxDO dbInbox = randomPojo(ImInboxDO.class);
inboxMapper.insert(dbInbox);// @Sql: 先插入出一条存在的数据 inboxMapper.insert(dbInbox);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
Long id = dbInbox.getId(); Long id = dbInbox.getId();
@ -109,7 +102,7 @@ public class InboxServiceImplTest extends BaseDbUnitTest {
@Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解 @Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解
public void testGetInboxPage() { public void testGetInboxPage() {
// mock 数据 // mock 数据
InboxDO dbInbox = randomPojo(InboxDO.class, o -> { // 等会查询到 ImInboxDO dbInbox = randomPojo(ImInboxDO.class, o -> { // 等会查询到
o.setUserId(null); o.setUserId(null);
o.setMessageId(null); o.setMessageId(null);
o.setSequence(null); o.setSequence(null);
@ -132,7 +125,7 @@ public class InboxServiceImplTest extends BaseDbUnitTest {
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28)); reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
// 调用 // 调用
PageResult<InboxDO> pageResult = inboxService.getInboxPage(reqVO); PageResult<ImInboxDO> pageResult = inboxService.getInboxPage(reqVO);
// 断言 // 断言
assertEquals(1, pageResult.getTotal()); assertEquals(1, pageResult.getTotal());
assertEquals(1, pageResult.getList().size()); assertEquals(1, pageResult.getList().size());

View File

@ -2,81 +2,74 @@ package cn.iocoder.yudao.module.im.service.message;
import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.boot.test.mock.mockito.MockBean;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest; import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
import cn.iocoder.yudao.module.im.controller.admin.message.vo.*; import cn.iocoder.yudao.module.im.controller.admin.message.vo.*;
import cn.iocoder.yudao.module.im.dal.dataobject.message.MessageDO; import cn.iocoder.yudao.module.im.dal.dataobject.message.ImMessageDO;
import cn.iocoder.yudao.module.im.dal.mysql.message.MessageMapper; import cn.iocoder.yudao.module.im.dal.mysql.message.ImMessageMapper;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import jakarta.annotation.Resource;
import org.springframework.context.annotation.Import; import org.springframework.context.annotation.Import;
import java.util.*;
import java.time.LocalDateTime;
import static cn.hutool.core.util.RandomUtil.*;
import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*; import static cn.iocoder.yudao.module.im.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*; import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*; import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*; import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/** /**
* {@link MessageServiceImpl} 的单元测试类 * {@link ImMessageServiceImpl} 的单元测试类
* *
* @author 芋道源码 * @author 芋道源码
*/ */
@Import(MessageServiceImpl.class) @Import(ImMessageServiceImpl.class)
public class MessageServiceImplTest extends BaseDbUnitTest { public class ImMessageServiceImplTest extends BaseDbUnitTest {
@Resource @Resource
private MessageServiceImpl messageService; private ImMessageServiceImpl messageService;
@Resource @Resource
private MessageMapper messageMapper; private ImMessageMapper imMessageMapper;
@Test @Test
public void testCreateMessage_success() { public void testCreateMessage_success() {
// 准备参数 // 准备参数
MessageSaveReqVO createReqVO = randomPojo(MessageSaveReqVO.class).setId(null); ImMessageSaveReqVO createReqVO = randomPojo(ImMessageSaveReqVO.class).setId(null);
// 调用 // 调用
Long messageId = messageService.createMessage(createReqVO); Long messageId = messageService.createMessage(createReqVO);
// 断言 // 断言
assertNotNull(messageId); assertNotNull(messageId);
// 校验记录的属性是否正确 // 校验记录的属性是否正确
MessageDO message = messageMapper.selectById(messageId); ImMessageDO message = imMessageMapper.selectById(messageId);
assertPojoEquals(createReqVO, message, "id"); assertPojoEquals(createReqVO, message, "id");
} }
@Test @Test
public void testUpdateMessage_success() { public void testUpdateMessage_success() {
// mock 数据 // mock 数据
MessageDO dbMessage = randomPojo(MessageDO.class); ImMessageDO dbMessage = randomPojo(ImMessageDO.class);
messageMapper.insert(dbMessage);// @Sql: 先插入出一条存在的数据 imMessageMapper.insert(dbMessage);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
MessageSaveReqVO updateReqVO = randomPojo(MessageSaveReqVO.class, o -> { ImMessageSaveReqVO updateReqVO = randomPojo(ImMessageSaveReqVO.class, o -> {
o.setId(dbMessage.getId()); // 设置更新的 ID o.setId(dbMessage.getId()); // 设置更新的 ID
}); });
// 调用 // 调用
messageService.updateMessage(updateReqVO); messageService.updateMessage(updateReqVO);
// 校验是否更新正确 // 校验是否更新正确
MessageDO message = messageMapper.selectById(updateReqVO.getId()); // 获取最新的 ImMessageDO message = imMessageMapper.selectById(updateReqVO.getId()); // 获取最新的
assertPojoEquals(updateReqVO, message); assertPojoEquals(updateReqVO, message);
} }
@Test @Test
public void testUpdateMessage_notExists() { public void testUpdateMessage_notExists() {
// 准备参数 // 准备参数
MessageSaveReqVO updateReqVO = randomPojo(MessageSaveReqVO.class); ImMessageSaveReqVO updateReqVO = randomPojo(ImMessageSaveReqVO.class);
// 调用, 并断言异常 // 调用, 并断言异常
assertServiceException(() -> messageService.updateMessage(updateReqVO), MESSAGE_NOT_EXISTS); assertServiceException(() -> messageService.updateMessage(updateReqVO), MESSAGE_NOT_EXISTS);
@ -85,15 +78,15 @@ public class MessageServiceImplTest extends BaseDbUnitTest {
@Test @Test
public void testDeleteMessage_success() { public void testDeleteMessage_success() {
// mock 数据 // mock 数据
MessageDO dbMessage = randomPojo(MessageDO.class); ImMessageDO dbMessage = randomPojo(ImMessageDO.class);
messageMapper.insert(dbMessage);// @Sql: 先插入出一条存在的数据 imMessageMapper.insert(dbMessage);// @Sql: 先插入出一条存在的数据
// 准备参数 // 准备参数
Long id = dbMessage.getId(); Long id = dbMessage.getId();
// 调用 // 调用
messageService.deleteMessage(id); messageService.deleteMessage(id);
// 校验数据不存在了 // 校验数据不存在了
assertNull(messageMapper.selectById(id)); assertNull(imMessageMapper.selectById(id));
} }
@Test @Test
@ -109,7 +102,7 @@ public class MessageServiceImplTest extends BaseDbUnitTest {
@Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解 @Disabled // TODO 请修改 null 为需要的值然后删除 @Disabled 注解
public void testGetMessagePage() { public void testGetMessagePage() {
// mock 数据 // mock 数据
MessageDO dbMessage = randomPojo(MessageDO.class, o -> { // 等会查询到 ImMessageDO dbMessage = randomPojo(ImMessageDO.class, o -> { // 等会查询到
o.setClientMessageId(null); o.setClientMessageId(null);
o.setSenderId(null); o.setSenderId(null);
o.setReceiverId(null); o.setReceiverId(null);
@ -123,33 +116,33 @@ public class MessageServiceImplTest extends BaseDbUnitTest {
o.setSendFrom(null); o.setSendFrom(null);
o.setCreateTime(null); o.setCreateTime(null);
}); });
messageMapper.insert(dbMessage); imMessageMapper.insert(dbMessage);
// 测试 clientMessageId 不匹配 // 测试 clientMessageId 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setClientMessageId(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setClientMessageId(null)));
// 测试 senderId 不匹配 // 测试 senderId 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderId(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderId(null)));
// 测试 receiverId 不匹配 // 测试 receiverId 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setReceiverId(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setReceiverId(null)));
// 测试 senderNickname 不匹配 // 测试 senderNickname 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderNickname(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderNickname(null)));
// 测试 senderAvatar 不匹配 // 测试 senderAvatar 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderAvatar(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSenderAvatar(null)));
// 测试 conversationType 不匹配 // 测试 conversationType 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setConversationType(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setConversationType(null)));
// 测试 conversationNo 不匹配 // 测试 conversationNo 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setConversationNo(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setConversationNo(null)));
// 测试 contentType 不匹配 // 测试 contentType 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setContentType(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setContentType(null)));
// 测试 content 不匹配 // 测试 content 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setContent(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setContent(null)));
// 测试 sendTime 不匹配 // 测试 sendTime 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSendTime(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSendTime(null)));
// 测试 sendFrom 不匹配 // 测试 sendFrom 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSendFrom(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setSendFrom(null)));
// 测试 createTime 不匹配 // 测试 createTime 不匹配
messageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setCreateTime(null))); imMessageMapper.insert(cloneIgnoreId(dbMessage, o -> o.setCreateTime(null)));
// 准备参数 // 准备参数
MessagePageReqVO reqVO = new MessagePageReqVO(); ImMessagePageReqVO reqVO = new ImMessagePageReqVO();
reqVO.setClientMessageId(null); reqVO.setClientMessageId(null);
reqVO.setSenderId(null); reqVO.setSenderId(null);
reqVO.setReceiverId(null); reqVO.setReceiverId(null);
@ -164,7 +157,7 @@ public class MessageServiceImplTest extends BaseDbUnitTest {
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28)); reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
// 调用 // 调用
PageResult<MessageDO> pageResult = messageService.getMessagePage(reqVO); PageResult<ImMessageDO> pageResult = messageService.getMessagePage(reqVO);
// 断言 // 断言
assertEquals(1, pageResult.getTotal()); assertEquals(1, pageResult.getTotal());
assertEquals(1, pageResult.getList().size()); assertEquals(1, pageResult.getList().size());

View File

@ -41,4 +41,9 @@ public class AdminUserRespDTO {
*/ */
private String mobile; private String mobile;
/**
* 用户头像
*/
private String avatar;
} }

View File

@ -47,14 +47,14 @@ spring:
datasource: datasource:
master: master:
name: ruoyi-vue-pro name: ruoyi-vue-pro
url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 url: jdbc:mysql://chaojiniu.top:23306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例
# url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 # url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例
# url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.master.name} # PostgreSQL 连接的示例 # url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.master.name} # PostgreSQL 连接的示例
# url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 # url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例
# url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例 # url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例
# url: jdbc:dm://10.211.55.4:5236?schema=RUOYI_VUE_PRO # DM 连接的示例 # url: jdbc:dm://10.211.55.4:5236?schema=RUOYI_VUE_PRO # DM 连接的示例
username: root username: ruoyi-vue-pro
password: 123456 password: ruoyi-@h2ju02hebp
# username: sa # username: sa
# password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W # password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W
# username: SYSDBA # DM 连接的示例 # username: SYSDBA # DM 连接的示例
@ -62,23 +62,23 @@ spring:
slave: # 模拟从库,可根据自己需要修改 slave: # 模拟从库,可根据自己需要修改
name: ruoyi-vue-pro name: ruoyi-vue-pro
lazy: true # 开启懒加载,保证启动速度 lazy: true # 开启懒加载,保证启动速度
url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 url: jdbc:mysql://chaojiniu.top:23306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例
# url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 # url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.slave.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例
# url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.slave.name} # PostgreSQL 连接的示例 # url: jdbc:postgresql://127.0.0.1:5432/${spring.datasource.dynamic.datasource.slave.name} # PostgreSQL 连接的示例
# url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例 # url: jdbc:oracle:thin:@127.0.0.1:1521:xe # Oracle 连接的示例
# url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.slave.name} # SQLServer 连接的示例 # url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.slave.name} # SQLServer 连接的示例
username: root username: ruoyi-vue-pro
password: 123456 password: ruoyi-@h2ju02hebp
# username: sa # username: sa
# password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W # password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W
# Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优
data: data:
redis: redis:
host: 127.0.0.1 # 地址 host: chaojiniu.top # 地址
port: 6379 # 端口 port: 6379 # 端口
database: 0 # 数据库索引 database: 0 # 数据库索引
# password: dev # 密码,建议生产环境开启 password: fsknKD7UvQYZsyf2hXXn # 密码,建议生产环境开启
--- #################### 定时任务相关配置 #################### --- #################### 定时任务相关配置 ####################

View File

@ -185,7 +185,7 @@ yudao:
- cn.iocoder.yudao.module.mp.enums.ErrorCodeConstants - cn.iocoder.yudao.module.mp.enums.ErrorCodeConstants
- cn.iocoder.yudao.module.im.enums.ErrorCodeConstants - cn.iocoder.yudao.module.im.enums.ErrorCodeConstants
tenant: # 多租户相关配置项 tenant: # 多租户相关配置项
enable: true enable: false
ignore-urls: ignore-urls:
- /admin-api/system/tenant/get-id-by-name # 基于名字获取租户,不许带租户编号 - /admin-api/system/tenant/get-id-by-name # 基于名字获取租户,不许带租户编号
- /admin-api/system/tenant/get-by-website # 基于域名获取租户,不许带租户编号 - /admin-api/system/tenant/get-by-website # 基于域名获取租户,不许带租户编号