From 4255b9ee054a13c56fb123ead66d7a35722e337f Mon Sep 17 00:00:00 2001 From: ziin Date: Wed, 24 Dec 2025 15:57:05 +0800 Subject: [PATCH] =?UTF-8?q?feat(user-call-log):=20=E6=96=B0=E5=A2=9E?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E8=B0=83=E7=94=A8=E6=97=A5=E5=BF=97=E7=AE=A1?= =?UTF-8?q?=E7=90=86=E5=8A=9F=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 新增用户调用日志模块,包含Controller、DO、Mapper、Service及VO等完整结构,支持记录用户每次调用的token、模型、耗时与成功率信息,并补充对应错误码常量。 --- .../KeyboardUserCallLogController.java | 104 ++++++++++++++++++ .../vo/KeyboardUserCallLogPageReqVO.java | 52 +++++++++ .../vo/KeyboardUserCallLogRespVO.java | 67 +++++++++++ .../vo/KeyboardUserCallLogSaveReqVO.java | 61 ++++++++++ .../usercalllog/KeyboardUserCallLogDO.java | 80 ++++++++++++++ .../KeyboardUserCallLogMapper.java | 37 +++++++ .../KeyboardUserCallLogService.java | 62 +++++++++++ .../KeyboardUserCallLogServiceImpl.java | 85 ++++++++++++++ .../KeyboardProductItemsMapper.xml | 2 +- .../usercalllog/KeyboardUserCallLogMapper.xml | 12 ++ .../KeyboardUserPurchaseRecordsMapper.xml | 2 +- .../userwallet/KeyboardUserWalletMapper.xml | 2 +- .../infra/enums/ErrorCodeConstants.java | 1 + 13 files changed, 564 insertions(+), 3 deletions(-) create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/KeyboardUserCallLogController.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogPageReqVO.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogRespVO.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogSaveReqVO.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/dal/dataobject/usercalllog/KeyboardUserCallLogDO.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/dal/mysql/usercalllog/KeyboardUserCallLogMapper.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogService.java create mode 100644 keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogServiceImpl.java create mode 100644 keyboard-server/src/main/resources/mapper/usercalllog/KeyboardUserCallLogMapper.xml diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/KeyboardUserCallLogController.java b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/KeyboardUserCallLogController.java new file mode 100644 index 0000000..1455d8c --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/KeyboardUserCallLogController.java @@ -0,0 +1,104 @@ +package com.yolo.keyboard.controller.admin.usercalllog; + +import org.springframework.web.bind.annotation.*; +import jakarta.annotation.Resource; +import org.springframework.validation.annotation.Validated; +import org.springframework.security.access.prepost.PreAuthorize; +import io.swagger.v3.oas.annotations.tags.Tag; +import io.swagger.v3.oas.annotations.Parameter; +import io.swagger.v3.oas.annotations.Operation; + +import jakarta.validation.constraints.*; +import jakarta.validation.*; +import jakarta.servlet.http.*; +import java.util.*; +import java.io.IOException; + +import com.yolo.keyboard.framework.common.pojo.PageParam; +import com.yolo.keyboard.framework.common.pojo.PageResult; +import com.yolo.keyboard.framework.common.pojo.CommonResult; +import com.yolo.keyboard.framework.common.util.object.BeanUtils; +import static com.yolo.keyboard.framework.common.pojo.CommonResult.success; + +import com.yolo.keyboard.framework.excel.core.util.ExcelUtils; + +import com.yolo.keyboard.framework.apilog.core.annotation.ApiAccessLog; +import static com.yolo.keyboard.framework.apilog.core.enums.OperateTypeEnum.*; + +import com.yolo.keyboard.controller.admin.usercalllog.vo.*; +import com.yolo.keyboard.dal.dataobject.usercalllog.KeyboardUserCallLogDO; +import com.yolo.keyboard.service.usercalllog.KeyboardUserCallLogService; + +@Tag(name = "管理后台 - 用户每次调用日志(用于记录token、模型、耗时、成功率等)") +@RestController +@RequestMapping("/keyboard/user-call-log") +@Validated +public class KeyboardUserCallLogController { + + @Resource + private KeyboardUserCallLogService userCallLogService; + + @PostMapping("/create") + @Operation(summary = "创建用户每次调用日志(用于记录token、模型、耗时、成功率等)") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:create')") + public CommonResult createUserCallLog(@Valid @RequestBody KeyboardUserCallLogSaveReqVO createReqVO) { + return success(userCallLogService.createUserCallLog(createReqVO)); + } + + @PutMapping("/update") + @Operation(summary = "更新用户每次调用日志(用于记录token、模型、耗时、成功率等)") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:update')") + public CommonResult updateUserCallLog(@Valid @RequestBody KeyboardUserCallLogSaveReqVO updateReqVO) { + userCallLogService.updateUserCallLog(updateReqVO); + return success(true); + } + + @DeleteMapping("/delete") + @Operation(summary = "删除用户每次调用日志(用于记录token、模型、耗时、成功率等)") + @Parameter(name = "id", description = "编号", required = true) + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:delete')") + public CommonResult deleteUserCallLog(@RequestParam("id") Long id) { + userCallLogService.deleteUserCallLog(id); + return success(true); + } + + @DeleteMapping("/delete-list") + @Parameter(name = "ids", description = "编号", required = true) + @Operation(summary = "批量删除用户每次调用日志(用于记录token、模型、耗时、成功率等)") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:delete')") + public CommonResult deleteUserCallLogList(@RequestParam("ids") List ids) { + userCallLogService.deleteUserCallLogListByIds(ids); + return success(true); + } + + @GetMapping("/get") + @Operation(summary = "获得用户每次调用日志(用于记录token、模型、耗时、成功率等)") + @Parameter(name = "id", description = "编号", required = true, example = "1024") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:query')") + public CommonResult getUserCallLog(@RequestParam("id") Long id) { + KeyboardUserCallLogDO userCallLog = userCallLogService.getUserCallLog(id); + return success(BeanUtils.toBean(userCallLog, KeyboardUserCallLogRespVO.class)); + } + + @GetMapping("/page") + @Operation(summary = "获得用户每次调用日志(用于记录token、模型、耗时、成功率等)分页") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:query')") + public CommonResult> getUserCallLogPage(@Valid KeyboardUserCallLogPageReqVO pageReqVO) { + PageResult pageResult = userCallLogService.getUserCallLogPage(pageReqVO); + return success(BeanUtils.toBean(pageResult, KeyboardUserCallLogRespVO.class)); + } + + @GetMapping("/export-excel") + @Operation(summary = "导出用户每次调用日志(用于记录token、模型、耗时、成功率等) Excel") + @PreAuthorize("@ss.hasPermission('keyboard:user-call-log:export')") + @ApiAccessLog(operateType = EXPORT) + public void exportUserCallLogExcel(@Valid KeyboardUserCallLogPageReqVO pageReqVO, + HttpServletResponse response) throws IOException { + pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); + List list = userCallLogService.getUserCallLogPage(pageReqVO).getList(); + // 导出 Excel + ExcelUtils.write(response, "用户每次调用日志(用于记录token、模型、耗时、成功率等).xls", "数据", KeyboardUserCallLogRespVO.class, + BeanUtils.toBean(list, KeyboardUserCallLogRespVO.class)); + } + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogPageReqVO.java b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogPageReqVO.java new file mode 100644 index 0000000..74233b1 --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogPageReqVO.java @@ -0,0 +1,52 @@ +package com.yolo.keyboard.controller.admin.usercalllog.vo; + +import lombok.*; +import java.util.*; +import io.swagger.v3.oas.annotations.media.Schema; +import com.yolo.keyboard.framework.common.pojo.PageParam; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; + +import static com.yolo.keyboard.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; + +@Schema(description = "管理后台 - 用户每次调用日志(用于记录token、模型、耗时、成功率等)分页 Request VO") +@Data +public class KeyboardUserCallLogPageReqVO extends PageParam { + + @Schema(description = "用户ID", example = "22552") + private Long userId; + + @Schema(description = "幂等请求ID,避免重试导致重复记录", example = "12645") + private String requestId; + + @Schema(description = "调用功能来源") + private String feature; + + @Schema(description = "调用的模型名称") + private String model; + + @Schema(description = "输入token数") + private Integer inputTokens; + + @Schema(description = "输出token数") + private Integer outputTokens; + + @Schema(description = "总token数(input+output)") + private Integer totalTokens; + + @Schema(description = "调用是否成功") + private Boolean success; + + @Schema(description = "调用耗时(毫秒)") + private Integer latencyMs; + + @Schema(description = "失败错误码(可空)") + private String errorCode; + + @Schema(description = "调用记录创建时间") + private LocalDateTime createdAt; + + @Schema(description = "生成 id", example = "2813") + private String genId; + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogRespVO.java b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogRespVO.java new file mode 100644 index 0000000..23b3fc6 --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogRespVO.java @@ -0,0 +1,67 @@ +package com.yolo.keyboard.controller.admin.usercalllog.vo; + +import io.swagger.v3.oas.annotations.media.Schema; +import lombok.*; +import java.util.*; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; +import cn.idev.excel.annotation.*; + +@Schema(description = "管理后台 - 用户每次调用日志(用于记录token、模型、耗时、成功率等) Response VO") +@Data +@ExcelIgnoreUnannotated +public class KeyboardUserCallLogRespVO { + + @Schema(description = "主键 id", requiredMode = Schema.RequiredMode.REQUIRED, example = "32537") + @ExcelProperty("主键 id") + private Long id; + + @Schema(description = "用户ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "22552") + @ExcelProperty("用户ID") + private Long userId; + + @Schema(description = "幂等请求ID,避免重试导致重复记录", requiredMode = Schema.RequiredMode.REQUIRED, example = "12645") + @ExcelProperty("幂等请求ID,避免重试导致重复记录") + private String requestId; + + @Schema(description = "调用功能来源", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("调用功能来源") + private String feature; + + @Schema(description = "调用的模型名称") + @ExcelProperty("调用的模型名称") + private String model; + + @Schema(description = "输入token数", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("输入token数") + private Integer inputTokens; + + @Schema(description = "输出token数", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("输出token数") + private Integer outputTokens; + + @Schema(description = "总token数(input+output)", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("总token数(input+output)") + private Integer totalTokens; + + @Schema(description = "调用是否成功", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("调用是否成功") + private Boolean success; + + @Schema(description = "调用耗时(毫秒)") + @ExcelProperty("调用耗时(毫秒)") + private Integer latencyMs; + + @Schema(description = "失败错误码(可空)") + @ExcelProperty("失败错误码(可空)") + private String errorCode; + + @Schema(description = "调用记录创建时间", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("调用记录创建时间") + private LocalDateTime createdAt; + + @Schema(description = "生成 id", example = "2813") + @ExcelProperty("生成 id") + private String genId; + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogSaveReqVO.java b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogSaveReqVO.java new file mode 100644 index 0000000..7d5ec7d --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/controller/admin/usercalllog/vo/KeyboardUserCallLogSaveReqVO.java @@ -0,0 +1,61 @@ +package com.yolo.keyboard.controller.admin.usercalllog.vo; + +import io.swagger.v3.oas.annotations.media.Schema; +import lombok.*; +import java.util.*; +import jakarta.validation.constraints.*; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; + +@Schema(description = "管理后台 - 用户每次调用日志(用于记录token、模型、耗时、成功率等)新增/修改 Request VO") +@Data +public class KeyboardUserCallLogSaveReqVO { + + @Schema(description = "主键 id", requiredMode = Schema.RequiredMode.REQUIRED, example = "32537") + private Long id; + + @Schema(description = "用户ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "22552") + @NotNull(message = "用户ID不能为空") + private Long userId; + + @Schema(description = "幂等请求ID,避免重试导致重复记录", requiredMode = Schema.RequiredMode.REQUIRED, example = "12645") + @NotEmpty(message = "幂等请求ID,避免重试导致重复记录不能为空") + private String requestId; + + @Schema(description = "调用功能来源", requiredMode = Schema.RequiredMode.REQUIRED) + @NotEmpty(message = "调用功能来源不能为空") + private String feature; + + @Schema(description = "调用的模型名称") + private String model; + + @Schema(description = "输入token数", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "输入token数不能为空") + private Integer inputTokens; + + @Schema(description = "输出token数", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "输出token数不能为空") + private Integer outputTokens; + + @Schema(description = "总token数(input+output)", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "总token数(input+output)不能为空") + private Integer totalTokens; + + @Schema(description = "调用是否成功", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "调用是否成功不能为空") + private Boolean success; + + @Schema(description = "调用耗时(毫秒)") + private Integer latencyMs; + + @Schema(description = "失败错误码(可空)") + private String errorCode; + + @Schema(description = "调用记录创建时间", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "调用记录创建时间不能为空") + private LocalDateTime createdAt; + + @Schema(description = "生成 id", example = "2813") + private String genId; + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/dal/dataobject/usercalllog/KeyboardUserCallLogDO.java b/keyboard-server/src/main/java/com/yolo/keyboard/dal/dataobject/usercalllog/KeyboardUserCallLogDO.java new file mode 100644 index 0000000..6a104f9 --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/dal/dataobject/usercalllog/KeyboardUserCallLogDO.java @@ -0,0 +1,80 @@ +package com.yolo.keyboard.dal.dataobject.usercalllog; + +import com.yolo.keyboard.framework.tenant.core.aop.TenantIgnore; +import lombok.*; +import java.util.*; +import java.time.LocalDateTime; +import com.baomidou.mybatisplus.annotation.*; +import com.yolo.keyboard.framework.mybatis.core.dataobject.BaseDO; + +/** + * 用户每次调用日志(用于记录token、模型、耗时、成功率等) DO + * + * @author Ziin + */ +@TableName("keyboard_user_call_log") +@KeySequence("keyboard_user_call_log_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。 +@Data +@ToString(callSuper = true) +@Builder +@NoArgsConstructor +@AllArgsConstructor +@TenantIgnore +public class KeyboardUserCallLogDO{ + + /** + * 主键 id + */ + @TableId + private Long id; + /** + * 用户ID + */ + private Long userId; + /** + * 幂等请求ID,避免重试导致重复记录 + */ + private String requestId; + /** + * 调用功能来源 + */ + private String feature; + /** + * 调用的模型名称 + */ + private String model; + /** + * 输入token数 + */ + private Integer inputTokens; + /** + * 输出token数 + */ + private Integer outputTokens; + /** + * 总token数(input+output) + */ + private Integer totalTokens; + /** + * 调用是否成功 + */ + private Boolean success; + /** + * 调用耗时(毫秒) + */ + private Integer latencyMs; + /** + * 失败错误码(可空) + */ + private String errorCode; + /** + * 调用记录创建时间 + */ + private LocalDateTime createdAt; + /** + * 生成 id + */ + private String genId; + + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/dal/mysql/usercalllog/KeyboardUserCallLogMapper.java b/keyboard-server/src/main/java/com/yolo/keyboard/dal/mysql/usercalllog/KeyboardUserCallLogMapper.java new file mode 100644 index 0000000..2e0f558 --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/dal/mysql/usercalllog/KeyboardUserCallLogMapper.java @@ -0,0 +1,37 @@ +package com.yolo.keyboard.dal.mysql.usercalllog; + +import java.util.*; + +import com.yolo.keyboard.framework.common.pojo.PageResult; +import com.yolo.keyboard.framework.mybatis.core.query.LambdaQueryWrapperX; +import com.yolo.keyboard.framework.mybatis.core.mapper.BaseMapperX; +import com.yolo.keyboard.dal.dataobject.usercalllog.KeyboardUserCallLogDO; +import org.apache.ibatis.annotations.Mapper; +import com.yolo.keyboard.controller.admin.usercalllog.vo.*; + +/** + * 用户每次调用日志(用于记录token、模型、耗时、成功率等) Mapper + * + * @author Ziin + */ +@Mapper +public interface KeyboardUserCallLogMapper extends BaseMapperX { + + default PageResult selectPage(KeyboardUserCallLogPageReqVO reqVO) { + return selectPage(reqVO, new LambdaQueryWrapperX() + .eqIfPresent(KeyboardUserCallLogDO::getUserId, reqVO.getUserId()) + .eqIfPresent(KeyboardUserCallLogDO::getRequestId, reqVO.getRequestId()) + .eqIfPresent(KeyboardUserCallLogDO::getFeature, reqVO.getFeature()) + .eqIfPresent(KeyboardUserCallLogDO::getModel, reqVO.getModel()) + .eqIfPresent(KeyboardUserCallLogDO::getInputTokens, reqVO.getInputTokens()) + .eqIfPresent(KeyboardUserCallLogDO::getOutputTokens, reqVO.getOutputTokens()) + .eqIfPresent(KeyboardUserCallLogDO::getTotalTokens, reqVO.getTotalTokens()) + .eqIfPresent(KeyboardUserCallLogDO::getSuccess, reqVO.getSuccess()) + .eqIfPresent(KeyboardUserCallLogDO::getLatencyMs, reqVO.getLatencyMs()) + .eqIfPresent(KeyboardUserCallLogDO::getErrorCode, reqVO.getErrorCode()) + .eqIfPresent(KeyboardUserCallLogDO::getCreatedAt, reqVO.getCreatedAt()) + .eqIfPresent(KeyboardUserCallLogDO::getGenId, reqVO.getGenId()) + .orderByDesc(KeyboardUserCallLogDO::getId)); + } + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogService.java b/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogService.java new file mode 100644 index 0000000..411151d --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogService.java @@ -0,0 +1,62 @@ +package com.yolo.keyboard.service.usercalllog; + +import java.util.*; +import jakarta.validation.*; +import com.yolo.keyboard.controller.admin.usercalllog.vo.*; +import com.yolo.keyboard.dal.dataobject.usercalllog.KeyboardUserCallLogDO; +import com.yolo.keyboard.framework.common.pojo.PageResult; +import com.yolo.keyboard.framework.common.pojo.PageParam; + +/** + * 用户每次调用日志(用于记录token、模型、耗时、成功率等) Service 接口 + * + * @author Ziin + */ +public interface KeyboardUserCallLogService { + + /** + * 创建用户每次调用日志(用于记录token、模型、耗时、成功率等) + * + * @param createReqVO 创建信息 + * @return 编号 + */ + Long createUserCallLog(@Valid KeyboardUserCallLogSaveReqVO createReqVO); + + /** + * 更新用户每次调用日志(用于记录token、模型、耗时、成功率等) + * + * @param updateReqVO 更新信息 + */ + void updateUserCallLog(@Valid KeyboardUserCallLogSaveReqVO updateReqVO); + + /** + * 删除用户每次调用日志(用于记录token、模型、耗时、成功率等) + * + * @param id 编号 + */ + void deleteUserCallLog(Long id); + + /** + * 批量删除用户每次调用日志(用于记录token、模型、耗时、成功率等) + * + * @param ids 编号 + */ + void deleteUserCallLogListByIds(List ids); + + /** + * 获得用户每次调用日志(用于记录token、模型、耗时、成功率等) + * + * @param id 编号 + * @return 用户每次调用日志(用于记录token、模型、耗时、成功率等) + */ + KeyboardUserCallLogDO getUserCallLog(Long id); + + /** + * 获得用户每次调用日志(用于记录token、模型、耗时、成功率等)分页 + * + * @param pageReqVO 分页查询 + * @return 用户每次调用日志(用于记录token、模型、耗时、成功率等)分页 + */ + PageResult getUserCallLogPage(KeyboardUserCallLogPageReqVO pageReqVO); + +} \ No newline at end of file diff --git a/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogServiceImpl.java b/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogServiceImpl.java new file mode 100644 index 0000000..0df7a82 --- /dev/null +++ b/keyboard-server/src/main/java/com/yolo/keyboard/service/usercalllog/KeyboardUserCallLogServiceImpl.java @@ -0,0 +1,85 @@ +package com.yolo.keyboard.service.usercalllog; + +import cn.hutool.core.collection.CollUtil; +import org.springframework.stereotype.Service; +import jakarta.annotation.Resource; +import org.springframework.validation.annotation.Validated; +import org.springframework.transaction.annotation.Transactional; + +import java.util.*; +import com.yolo.keyboard.controller.admin.usercalllog.vo.*; +import com.yolo.keyboard.dal.dataobject.usercalllog.KeyboardUserCallLogDO; +import com.yolo.keyboard.framework.common.pojo.PageResult; +import com.yolo.keyboard.framework.common.pojo.PageParam; +import com.yolo.keyboard.framework.common.util.object.BeanUtils; + +import com.yolo.keyboard.dal.mysql.usercalllog.KeyboardUserCallLogMapper; + +import static com.yolo.keyboard.framework.common.exception.util.ServiceExceptionUtil.exception; +import static com.yolo.keyboard.framework.common.util.collection.CollectionUtils.convertList; +import static com.yolo.keyboard.framework.common.util.collection.CollectionUtils.diffList; +import static com.yolo.keyboard.module.infra.enums.ErrorCodeConstants.USER_CALL_LOG_NOT_EXISTS; + +/** + * 用户每次调用日志(用于记录token、模型、耗时、成功率等) Service 实现类 + * + * @author Ziin + */ +@Service +@Validated +public class KeyboardUserCallLogServiceImpl implements KeyboardUserCallLogService { + + @Resource + private KeyboardUserCallLogMapper userCallLogMapper; + + @Override + public Long createUserCallLog(KeyboardUserCallLogSaveReqVO createReqVO) { + // 插入 + KeyboardUserCallLogDO userCallLog = BeanUtils.toBean(createReqVO, KeyboardUserCallLogDO.class); + userCallLogMapper.insert(userCallLog); + + // 返回 + return userCallLog.getId(); + } + + @Override + public void updateUserCallLog(KeyboardUserCallLogSaveReqVO updateReqVO) { + // 校验存在 + validateUserCallLogExists(updateReqVO.getId()); + // 更新 + KeyboardUserCallLogDO updateObj = BeanUtils.toBean(updateReqVO, KeyboardUserCallLogDO.class); + userCallLogMapper.updateById(updateObj); + } + + @Override + public void deleteUserCallLog(Long id) { + // 校验存在 + validateUserCallLogExists(id); + // 删除 + userCallLogMapper.deleteById(id); + } + + @Override + public void deleteUserCallLogListByIds(List ids) { + // 删除 + userCallLogMapper.deleteByIds(ids); + } + + + private void validateUserCallLogExists(Long id) { + if (userCallLogMapper.selectById(id) == null) { + throw exception(USER_CALL_LOG_NOT_EXISTS); + } + } + + @Override + public KeyboardUserCallLogDO getUserCallLog(Long id) { + return userCallLogMapper.selectById(id); + } + + @Override + public PageResult getUserCallLogPage(KeyboardUserCallLogPageReqVO pageReqVO) { + return userCallLogMapper.selectPage(pageReqVO); + } + +} \ No newline at end of file diff --git a/keyboard-server/src/main/resources/mapper/productitems/KeyboardProductItemsMapper.xml b/keyboard-server/src/main/resources/mapper/productitems/KeyboardProductItemsMapper.xml index bd2feef..df4e0a9 100644 --- a/keyboard-server/src/main/resources/mapper/productitems/KeyboardProductItemsMapper.xml +++ b/keyboard-server/src/main/resources/mapper/productitems/KeyboardProductItemsMapper.xml @@ -1,6 +1,6 @@ - + + + \ No newline at end of file diff --git a/keyboard-server/src/main/resources/mapper/userpurchaserecords/KeyboardUserPurchaseRecordsMapper.xml b/keyboard-server/src/main/resources/mapper/userpurchaserecords/KeyboardUserPurchaseRecordsMapper.xml index 9ed70ec..d41df45 100644 --- a/keyboard-server/src/main/resources/mapper/userpurchaserecords/KeyboardUserPurchaseRecordsMapper.xml +++ b/keyboard-server/src/main/resources/mapper/userpurchaserecords/KeyboardUserPurchaseRecordsMapper.xml @@ -1,6 +1,6 @@ - +