chat角色增加,角色列表

This commit is contained in:
cherishsince 2024-04-24 16:48:14 +08:00
parent c75e415b61
commit 410893bc29
5 changed files with 131 additions and 6 deletions

View File

@ -0,0 +1,29 @@
package cn.iocoder.yudao.module.ai.convert;
import cn.iocoder.yudao.module.ai.dal.dataobject.AiChatRoleDO;
import cn.iocoder.yudao.module.ai.vo.ChatRoleListRes;
import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers;
import java.util.List;
/**
* 聊天 对话 convert
*
* @author fansili
* @time 2024/4/18 16:39
* @since 1.0
*/
@Mapper
public interface ChatRoleConvert {
ChatRoleConvert INSTANCE = Mappers.getMapper(ChatRoleConvert.class);
/**
* 转换 - ChatRoleListRes
*
* @param roleList
* @return
*/
List<ChatRoleListRes> convertChatRoleListRes(List<AiChatRoleDO> roleList);
}

View File

@ -1,8 +1,11 @@
package cn.iocoder.yudao.module.ai.service; package cn.iocoder.yudao.module.ai.service;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.ai.vo.*; import cn.iocoder.yudao.module.ai.vo.*;
import java.util.List;
/** /**
* chat 角色 * chat 角色
* *
@ -17,7 +20,7 @@ public interface ChatRoleService {
* @param req * @param req
* @return * @return
*/ */
CommonResult<ChatRoleListRes> list(ChatRoleListReq req); PageResult<ChatRoleListRes> list(ChatRoleListReq req);
/** /**
* chat角色 - 添加 * chat角色 - 添加

View File

@ -1,12 +1,19 @@
package cn.iocoder.yudao.module.ai.service.impl; package cn.iocoder.yudao.module.ai.service.impl;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.hutool.core.util.StrUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.ai.convert.ChatRoleConvert;
import cn.iocoder.yudao.module.ai.dal.dataobject.AiChatRoleDO;
import cn.iocoder.yudao.module.ai.mapper.AiChatRoleMapper;
import cn.iocoder.yudao.module.ai.service.ChatRoleService; import cn.iocoder.yudao.module.ai.service.ChatRoleService;
import cn.iocoder.yudao.module.ai.vo.*; import cn.iocoder.yudao.module.ai.vo.*;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.util.List;
/** /**
* chat 角色 * chat 角色
* *
@ -18,10 +25,25 @@ import org.springframework.stereotype.Service;
@Slf4j @Slf4j
public class ChatRoleServiceImpl implements ChatRoleService { public class ChatRoleServiceImpl implements ChatRoleService {
private final AiChatRoleMapper aiChatRoleMapper;
@Override @Override
public CommonResult<ChatRoleListRes> list(ChatRoleListReq req) { public PageResult<ChatRoleListRes> list(ChatRoleListReq req) {
return null; // 查询条件
LambdaQueryWrapperX<AiChatRoleDO> queryWrapperX = new LambdaQueryWrapperX<>();
// search 查询
if (!StrUtil.isBlank(req.getSearch())) {
queryWrapperX.eq(AiChatRoleDO::getRoleName, req.getSearch());
}
// 默认排序id desc
queryWrapperX.orderByDesc(AiChatRoleDO::getId);
//
PageResult<AiChatRoleDO> aiChatRoleDOPageResult = aiChatRoleMapper.selectPage(req, queryWrapperX);
Long total = aiChatRoleDOPageResult.getTotal();
List<AiChatRoleDO> roleList = aiChatRoleDOPageResult.getList();
// 换货res
List<ChatRoleListRes> chatRoleListResList = ChatRoleConvert.INSTANCE.convertChatRoleListRes(roleList);
return new PageResult<>(chatRoleListResList, total);
} }
@Override @Override

View File

@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.ai.vo;
import cn.iocoder.yudao.framework.common.pojo.PageParam; import cn.iocoder.yudao.framework.common.pojo.PageParam;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotNull;
import lombok.Data; import lombok.Data;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
@ -15,6 +16,39 @@ import lombok.experimental.Accessors;
@Accessors(chain = true) @Accessors(chain = true)
public class ChatRoleAddReq extends PageParam { public class ChatRoleAddReq extends PageParam {
@Schema(description = "查询") @NotNull
private String search; @Schema(description = "模型编号,关联到角色使用的特定模型")
private String modelId;
@NotNull
@Schema(description = "角色名,角色的显示名称")
private String roleName;
@NotNull
@Schema(description = "角色介绍,详细描述角色的功能或用途")
private String roleIntroduce;
@NotNull
@Schema(description = "角色来源,如 system系统预置、customer用户自定义")
private String roleSource;
@NotNull
@Schema(description = "分类,角色所属的类别,如娱乐、创作等")
private String classify;
@NotNull
@Schema(description = "发布状态0表示仅自己可见1表示公开2表示禁用")
private String visibility;
@NotNull
@Schema(description = "生成时的Top-K采样候选集大小")
private Double topK;
@NotNull
@Schema(description = "生成时使用的核采样方法的概率阈值")
private Double topP;
@NotNull
@Schema(description = "用于控制随机性和多样性的温度参数")
private Double temperature;
} }

View File

@ -1,5 +1,6 @@
package cn.iocoder.yudao.module.ai.vo; package cn.iocoder.yudao.module.ai.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data; import lombok.Data;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
@ -12,4 +13,40 @@ import lombok.experimental.Accessors;
@Data @Data
@Accessors(chain = true) @Accessors(chain = true)
public class ChatRoleListRes { public class ChatRoleListRes {
@Schema(description = "id")
private Long id;
@Schema(description = "用户id")
private Long userId;
@Schema(description = "模型id")
private String modelId;
@Schema(description = "角色名字")
private String roleName;
@Schema(description = "角色介绍,详细描述角色的功能或用途")
private String roleIntroduce;
@Schema(description = "角色来源,如 system系统预置、customer用户自定义")
private String roleSource;
@Schema(description = "分类,角色所属的类别,如娱乐、创作等")
private String classify;
@Schema(description = "发布状态0表示仅自己可见1表示公开2表示禁用")
private String visibility;
@Schema(description = "生成时的Top-K采样候选集大小")
private Double topK;
@Schema(description = "生成时使用的核采样方法的概率阈值")
private Double topP;
@Schema(description = "用于控制随机性和多样性的温度参数")
private Double temperature;
@Schema(description = "角色的使用次数统计")
private Integer useCount;
} }