Compare commits
2 Commits
52a1094144
...
5a5af706e5
| Author | SHA1 | Date | |
|---|---|---|---|
| 5a5af706e5 | |||
| 09b7862971 |
@@ -49,4 +49,7 @@ public interface ErrorCodeConstants {
|
||||
ErrorCode POINTS_PENDING_NOT_FOUND = new ErrorCode(1_030_003_004, "预扣记录不存在");
|
||||
ErrorCode POINTS_PENDING_ALREADY_CONFIRMED = new ErrorCode(1_030_003_005, "预扣记录已确认或已取消");
|
||||
|
||||
// ========== TikToken相关错误码 1-030-004-000 ==========
|
||||
ErrorCode TIK_TOKEN_NOT_EXISTS = new ErrorCode(1_030_004_001, "TikToken不存在");
|
||||
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
package cn.iocoder.yudao.module.tik.muye.aimodelconfig.dal;
|
||||
|
||||
import lombok.*;
|
||||
import java.math.BigDecimal;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
||||
|
||||
@@ -45,18 +44,6 @@ public class AiModelConfigDO extends BaseDO {
|
||||
* 状态(0-禁用 1-启用)
|
||||
*/
|
||||
private Integer status;
|
||||
/**
|
||||
* 温度参数
|
||||
*/
|
||||
private BigDecimal temperature;
|
||||
/**
|
||||
* 回复数Token数
|
||||
*/
|
||||
private Integer maxTokens;
|
||||
/**
|
||||
* 每日请求次数
|
||||
*/
|
||||
private Integer dailyLimit;
|
||||
/**
|
||||
* 模型类型(image-图像 text-文本 video-视频 audio-音频)
|
||||
*/
|
||||
@@ -65,22 +52,6 @@ public class AiModelConfigDO extends BaseDO {
|
||||
* 消耗积分
|
||||
*/
|
||||
private Integer consumePoints;
|
||||
/**
|
||||
* 最大文本数量
|
||||
*/
|
||||
private Integer maxTextLength;
|
||||
/**
|
||||
* 图片最大像素
|
||||
*/
|
||||
private String maxImageSize;
|
||||
/**
|
||||
* 视频最大时长(秒)
|
||||
*/
|
||||
private Integer maxVideoDuration;
|
||||
/**
|
||||
* 视频最大质量
|
||||
*/
|
||||
private String maxVideoQuality;
|
||||
/**
|
||||
* 备注
|
||||
*/
|
||||
|
||||
@@ -25,15 +25,8 @@ public interface AiModelConfigMapper extends BaseMapperX<AiModelConfigDO> {
|
||||
.eqIfPresent(AiModelConfigDO::getPlatform, reqVO.getPlatform())
|
||||
.eqIfPresent(AiModelConfigDO::getApiKey, reqVO.getApiKey())
|
||||
.eqIfPresent(AiModelConfigDO::getStatus, reqVO.getStatus())
|
||||
.eqIfPresent(AiModelConfigDO::getTemperature, reqVO.getTemperature())
|
||||
.eqIfPresent(AiModelConfigDO::getMaxTokens, reqVO.getMaxTokens())
|
||||
.eqIfPresent(AiModelConfigDO::getDailyLimit, reqVO.getDailyLimit())
|
||||
.eqIfPresent(AiModelConfigDO::getModelType, reqVO.getModelType())
|
||||
.eqIfPresent(AiModelConfigDO::getConsumePoints, reqVO.getConsumePoints())
|
||||
.eqIfPresent(AiModelConfigDO::getMaxTextLength, reqVO.getMaxTextLength())
|
||||
.eqIfPresent(AiModelConfigDO::getMaxImageSize, reqVO.getMaxImageSize())
|
||||
.eqIfPresent(AiModelConfigDO::getMaxVideoDuration, reqVO.getMaxVideoDuration())
|
||||
.eqIfPresent(AiModelConfigDO::getMaxVideoQuality, reqVO.getMaxVideoQuality())
|
||||
.eqIfPresent(AiModelConfigDO::getRemark, reqVO.getRemark())
|
||||
.betweenIfPresent(AiModelConfigDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(AiModelConfigDO::getId));
|
||||
|
||||
@@ -1,10 +1,8 @@
|
||||
package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import cn.iocoder.yudao.framework.common.pojo.PageParam;
|
||||
import java.math.BigDecimal;
|
||||
import cn.iocoder.yudao.framework.common.pojo.SortablePageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@@ -12,7 +10,8 @@ import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_
|
||||
|
||||
@Schema(description = "管理后台 - AI模型配置分页 Request VO")
|
||||
@Data
|
||||
public class AiModelConfigPageReqVO extends PageParam {
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
public class AiModelConfigPageReqVO extends SortablePageParam {
|
||||
|
||||
@Schema(description = "模型名称", example = "李四")
|
||||
private String modelName;
|
||||
@@ -29,33 +28,12 @@ public class AiModelConfigPageReqVO extends PageParam {
|
||||
@Schema(description = "状态(0-禁用 1-启用)", example = "2")
|
||||
private Integer status;
|
||||
|
||||
@Schema(description = "温度参数")
|
||||
private BigDecimal temperature;
|
||||
|
||||
@Schema(description = "回复数Token数")
|
||||
private Integer maxTokens;
|
||||
|
||||
@Schema(description = "每日请求次数")
|
||||
private Integer dailyLimit;
|
||||
|
||||
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", example = "2")
|
||||
private String modelType;
|
||||
|
||||
@Schema(description = "消耗积分")
|
||||
private Integer consumePoints;
|
||||
|
||||
@Schema(description = "最大文本数量")
|
||||
private Integer maxTextLength;
|
||||
|
||||
@Schema(description = "图片最大像素")
|
||||
private String maxImageSize;
|
||||
|
||||
@Schema(description = "视频最大时长(秒)")
|
||||
private Integer maxVideoDuration;
|
||||
|
||||
@Schema(description = "视频最大质量")
|
||||
private String maxVideoQuality;
|
||||
|
||||
@Schema(description = "备注", example = "随便")
|
||||
private String remark;
|
||||
|
||||
|
||||
@@ -2,9 +2,6 @@ package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import java.math.BigDecimal;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
import cn.idev.excel.annotation.*;
|
||||
|
||||
@@ -37,18 +34,6 @@ public class AiModelConfigRespVO {
|
||||
@ExcelProperty("状态(0-禁用 1-启用)")
|
||||
private Integer status;
|
||||
|
||||
@Schema(description = "温度参数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("温度参数")
|
||||
private BigDecimal temperature;
|
||||
|
||||
@Schema(description = "回复数Token数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("回复数Token数")
|
||||
private Integer maxTokens;
|
||||
|
||||
@Schema(description = "每日请求次数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("每日请求次数")
|
||||
private Integer dailyLimit;
|
||||
|
||||
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@ExcelProperty("模型类型(image-图像 text-文本 video-视频 audio-音频)")
|
||||
private String modelType;
|
||||
@@ -57,22 +42,6 @@ public class AiModelConfigRespVO {
|
||||
@ExcelProperty("消耗积分")
|
||||
private Integer consumePoints;
|
||||
|
||||
@Schema(description = "最大文本数量", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("最大文本数量")
|
||||
private Integer maxTextLength;
|
||||
|
||||
@Schema(description = "图片最大像素", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("图片最大像素")
|
||||
private String maxImageSize;
|
||||
|
||||
@Schema(description = "视频最大时长(秒)", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("视频最大时长(秒)")
|
||||
private Integer maxVideoDuration;
|
||||
|
||||
@Schema(description = "视频最大质量", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("视频最大质量")
|
||||
private String maxVideoQuality;
|
||||
|
||||
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "随便")
|
||||
@ExcelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
@@ -2,9 +2,7 @@ package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Schema(description = "管理后台 - AI模型配置新增/修改 Request VO")
|
||||
@Data
|
||||
@@ -29,43 +27,18 @@ public class AiModelConfigSaveReqVO {
|
||||
private String apiKey;
|
||||
|
||||
@Schema(description = "状态(0-禁用 1-启用)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@NotNull(message = "状态(0-禁用 1-启用)不能为空")
|
||||
@NotNull(message = "状态不能为空")
|
||||
private Integer status;
|
||||
|
||||
@Schema(description = "温度参数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "温度参数不能为空")
|
||||
private BigDecimal temperature;
|
||||
|
||||
@Schema(description = "回复数Token数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "回复数Token数不能为空")
|
||||
private Integer maxTokens;
|
||||
|
||||
@Schema(description = "每日请求次数", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "每日请求次数不能为空")
|
||||
private Integer dailyLimit;
|
||||
|
||||
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@NotEmpty(message = "模型类型(image-图像 text-文本 video-视频 audio-音频)不能为空")
|
||||
@NotEmpty(message = "模型类型不能为空")
|
||||
private String modelType;
|
||||
|
||||
@Schema(description = "消耗积分", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "消耗积分不能为空")
|
||||
private Integer consumePoints;
|
||||
|
||||
@Schema(description = "最大文本数量")
|
||||
private Integer maxTextLength;
|
||||
|
||||
@Schema(description = "图片最大像素")
|
||||
private String maxImageSize;
|
||||
|
||||
@Schema(description = "视频最大时长(秒)")
|
||||
private Integer maxVideoDuration;
|
||||
|
||||
@Schema(description = "视频最大质量")
|
||||
private String maxVideoQuality;
|
||||
|
||||
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "随便")
|
||||
@NotEmpty(message = "备注不能为空")
|
||||
@Schema(description = "备注", example = "随便")
|
||||
private String remark;
|
||||
|
||||
}
|
||||
@@ -1,5 +1,7 @@
|
||||
package cn.iocoder.yudao.module.tik.muye.points.service;
|
||||
|
||||
import cn.iocoder.yudao.module.member.dal.dataobject.user.MemberUserDO;
|
||||
import cn.iocoder.yudao.module.member.service.user.MemberUserService;
|
||||
import cn.iocoder.yudao.module.tik.muye.aimodelconfig.dal.AiModelConfigDO;
|
||||
import cn.iocoder.yudao.module.tik.muye.aimodelconfig.mapper.AiModelConfigMapper;
|
||||
import cn.iocoder.yudao.module.tik.muye.memberuserprofile.dal.MemberUserProfileDO;
|
||||
@@ -43,6 +45,9 @@ public class PointsServiceImpl implements PointsService {
|
||||
@Resource
|
||||
private PointRecordMapper pointRecordMapper;
|
||||
|
||||
@Resource
|
||||
private MemberUserService memberUserService;
|
||||
|
||||
@Override
|
||||
public AiModelConfigDO getConfig(String platform, String modelCode) {
|
||||
AiModelConfigDO config = aiModelConfigMapper.selectByPlatformAndModelCode(platform, modelCode);
|
||||
@@ -72,9 +77,14 @@ public class PointsServiceImpl implements PointsService {
|
||||
// 2. 查询扣减后余额
|
||||
MemberUserProfileDO profile = memberUserProfileMapper.selectByUserId(userId);
|
||||
|
||||
// 2.1 获取用户手机号
|
||||
MemberUserDO user = memberUserService.getUser(Long.parseLong(userId));
|
||||
String mobile = user != null ? user.getMobile() : "";
|
||||
|
||||
// 3. 创建积分记录(已确认状态)
|
||||
PointRecordDO record = PointRecordDO.builder()
|
||||
.userId(Long.parseLong(userId))
|
||||
.mobile(mobile)
|
||||
.type("decrease")
|
||||
.pointAmount(-points)
|
||||
.balance(profile.getRemainingPoints())
|
||||
@@ -98,9 +108,14 @@ public class PointsServiceImpl implements PointsService {
|
||||
// 2. 查询当前余额
|
||||
MemberUserProfileDO profile = memberUserProfileMapper.selectByUserId(userId);
|
||||
|
||||
// 2.1 获取用户手机号
|
||||
MemberUserDO user = memberUserService.getUser(Long.parseLong(userId));
|
||||
String mobile = user != null ? user.getMobile() : "";
|
||||
|
||||
// 3. 创建预扣记录(待确认状态)
|
||||
PointRecordDO record = PointRecordDO.builder()
|
||||
.userId(Long.parseLong(userId))
|
||||
.mobile(mobile)
|
||||
.type("decrease")
|
||||
.pointAmount(-points)
|
||||
.balance(profile.getRemainingPoints())
|
||||
|
||||
@@ -0,0 +1,68 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.controller;
|
||||
|
||||
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.service.TikTokenService;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import jakarta.annotation.Resource;
|
||||
import jakarta.validation.Valid;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
||||
|
||||
@Tag(name = "管理后台 - TikToken 管理")
|
||||
@RestController
|
||||
@RequestMapping("/admin-api/tik/token")
|
||||
@Validated
|
||||
public class TikTokenAdminController {
|
||||
|
||||
@Resource
|
||||
private TikTokenService tikTokenService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建TikToken")
|
||||
@PreAuthorize("@ss.hasPermission('tik:token:create')")
|
||||
public CommonResult<Long> create(@Valid @RequestBody TikTokenSaveReqVO reqVO) {
|
||||
return success(tikTokenService.create(reqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新TikToken")
|
||||
@PreAuthorize("@ss.hasPermission('tik:token:update')")
|
||||
public CommonResult<Boolean> update(@Valid @RequestBody TikTokenSaveReqVO reqVO) {
|
||||
tikTokenService.update(reqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除TikToken")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('tik:token:delete')")
|
||||
public CommonResult<Boolean> delete(@RequestParam("id") Long id) {
|
||||
tikTokenService.delete(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获取TikToken详情")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('tik:token:query')")
|
||||
public CommonResult<TikTokenVO> get(@RequestParam("id") Long id) {
|
||||
return success(tikTokenService.get(id));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "分页查询TikToken列表")
|
||||
@PreAuthorize("@ss.hasPermission('tik:token:query')")
|
||||
public CommonResult<PageResult<TikTokenVO>> getPage(@Valid TikTokenPageReqVO reqVO) {
|
||||
return success(tikTokenService.getPage(reqVO));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -1,6 +1,9 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.mapper;
|
||||
|
||||
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.tik.tikhup.vo.TikTokenPageReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@@ -15,4 +18,12 @@ public interface TikTokenMapper extends BaseMapperX<TikTokenVO> {
|
||||
return selectOne("interface_type",interfaceType);
|
||||
}
|
||||
|
||||
default PageResult<TikTokenVO> selectPage(TikTokenPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TikTokenVO>()
|
||||
.likeIfPresent(TikTokenVO::getPlatformUrl, reqVO.getPlatformUrl())
|
||||
.eqIfPresent(TikTokenVO::getInterfaceType, reqVO.getInterfaceType())
|
||||
.likeIfPresent(TikTokenVO::getInterfaceDesc, reqVO.getInterfaceDesc())
|
||||
.orderByDesc(TikTokenVO::getId));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,39 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.service;
|
||||
|
||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
|
||||
import jakarta.validation.Valid;
|
||||
|
||||
/**
|
||||
* TikToken 管理Service接口
|
||||
*/
|
||||
public interface TikTokenService {
|
||||
|
||||
/**
|
||||
* 分页查询TikToken列表
|
||||
*/
|
||||
PageResult<TikTokenVO> getPage(TikTokenPageReqVO reqVO);
|
||||
|
||||
/**
|
||||
* 创建TikToken
|
||||
*/
|
||||
Long create(@Valid TikTokenSaveReqVO reqVO);
|
||||
|
||||
/**
|
||||
* 更新TikToken
|
||||
*/
|
||||
void update(@Valid TikTokenSaveReqVO reqVO);
|
||||
|
||||
/**
|
||||
* 删除TikToken
|
||||
*/
|
||||
void delete(Long id);
|
||||
|
||||
/**
|
||||
* 获取TikToken详情
|
||||
*/
|
||||
TikTokenVO get(Long id);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,62 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.service;
|
||||
|
||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.mapper.TikTokenMapper;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
|
||||
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
|
||||
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.tik.enums.ErrorCodeConstants.TIK_TOKEN_NOT_EXISTS;
|
||||
|
||||
/**
|
||||
* TikToken 管理Service实现类
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class TikTokenServiceImpl implements TikTokenService {
|
||||
|
||||
@Resource
|
||||
private TikTokenMapper tikTokenMapper;
|
||||
|
||||
@Override
|
||||
public PageResult<TikTokenVO> getPage(TikTokenPageReqVO reqVO) {
|
||||
return tikTokenMapper.selectPage(reqVO);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long create(TikTokenSaveReqVO reqVO) {
|
||||
TikTokenVO token = BeanUtils.toBean(reqVO, TikTokenVO.class);
|
||||
tikTokenMapper.insert(token);
|
||||
return token.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void update(TikTokenSaveReqVO reqVO) {
|
||||
validateExists(reqVO.getId());
|
||||
TikTokenVO token = BeanUtils.toBean(reqVO, TikTokenVO.class);
|
||||
tikTokenMapper.updateById(token);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void delete(Long id) {
|
||||
validateExists(id);
|
||||
tikTokenMapper.deleteById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TikTokenVO get(Long id) {
|
||||
return tikTokenMapper.selectById(id);
|
||||
}
|
||||
|
||||
private void validateExists(Long id) {
|
||||
if (tikTokenMapper.selectById(id) == null) {
|
||||
throw exception(TIK_TOKEN_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.vo;
|
||||
|
||||
import cn.iocoder.yudao.framework.common.pojo.SortablePageParam;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
|
||||
@Schema(description = "管理后台 - TikToken 分页 Request VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
public class TikTokenPageReqVO extends SortablePageParam {
|
||||
|
||||
@Schema(description = "平台URL", example = "https://api.tikhub.io")
|
||||
private String platformUrl;
|
||||
|
||||
@Schema(description = "接口类型", example = "crawler")
|
||||
private String interfaceType;
|
||||
|
||||
@Schema(description = "接口描述", example = "抖音视频爬虫接口")
|
||||
private String interfaceDesc;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package cn.iocoder.yudao.module.tik.tikhup.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import jakarta.validation.constraints.NotEmpty;
|
||||
import lombok.Data;
|
||||
|
||||
@Schema(description = "管理后台 - TikToken 创建/更新 Request VO")
|
||||
@Data
|
||||
public class TikTokenSaveReqVO {
|
||||
|
||||
@Schema(description = "编号", example = "1")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "平台URL", requiredMode = Schema.RequiredMode.REQUIRED, example = "https://api.tikhub.io")
|
||||
@NotEmpty(message = "平台URL不能为空")
|
||||
private String platformUrl;
|
||||
|
||||
@Schema(description = "接口类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "crawler")
|
||||
@NotEmpty(message = "接口类型不能为空")
|
||||
private String interfaceType;
|
||||
|
||||
@Schema(description = "接口描述", example = "抖音视频爬虫接口")
|
||||
private String interfaceDesc;
|
||||
|
||||
}
|
||||
@@ -17,10 +17,10 @@ public class TikTokenVO extends TenantBaseDO {
|
||||
@TableField(value = "platform_url")
|
||||
private String platformUrl;
|
||||
|
||||
@TableField(value = "platform_token")
|
||||
private String platformToken;
|
||||
|
||||
@TableField(value = "interface_type")
|
||||
private String interfaceType;
|
||||
|
||||
@TableField(value = "interface_desc")
|
||||
private String interfaceDesc;
|
||||
|
||||
}
|
||||
|
||||
@@ -1,25 +1,17 @@
|
||||
import request from '@/config/axios'
|
||||
import type { Dayjs } from 'dayjs';
|
||||
|
||||
/** AI模型配置信息 */
|
||||
export interface AiModelConfig {
|
||||
id: number; // 主键
|
||||
modelName?: string; // 模型名称
|
||||
modelCode?: string; // 模型标识/编码
|
||||
platform?: string; // 所属平台
|
||||
apiKey?: string; // API秘钥
|
||||
status?: number; // 状态(0-禁用 1-启用)
|
||||
temperature?: number; // 温度参数
|
||||
maxTokens?: number; // 回复数Token数
|
||||
dailyLimit?: number; // 每日请求次数
|
||||
modelType?: string; // 模型类型(image-图像 text-文本 video-视频 audio-音频)
|
||||
consumePoints?: number; // 消耗积分
|
||||
maxTextLength?: number; // 最大文本数量
|
||||
maxImageSize?: string; // 图片最大像素
|
||||
maxVideoDuration?: number; // 视频最大时长(秒)
|
||||
maxVideoQuality?: string; // 视频最大质量
|
||||
remark?: string; // 备注
|
||||
}
|
||||
id: number // 主键
|
||||
modelName?: string // 模型名称
|
||||
modelCode?: string // 模型标识/编码
|
||||
platform?: string // 所属平台
|
||||
apiKey?: string // API秘钥
|
||||
status?: number // 状态(0-禁用 1-启用)
|
||||
modelType?: string // 模型类型(image-图像 text-文本 video-视频 audio-音频)
|
||||
consumePoints?: number // 消耗积分
|
||||
remark?: string // 备注
|
||||
}
|
||||
|
||||
// AI模型配置 API
|
||||
export const AiModelConfigApi = {
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
import request from '@/config/axios'
|
||||
import type { Dayjs } from 'dayjs';
|
||||
|
||||
/** tikhup管理信息 */
|
||||
export interface Token {
|
||||
platformUrl?: string; // 平台URL
|
||||
platformToken?: string; // 平台Token
|
||||
id: number; // 主键ID
|
||||
}
|
||||
platformUrl?: string; // 平台URL
|
||||
interfaceType?: string; // 接口类型
|
||||
interfaceDesc?: string; // 接口描述
|
||||
id: number; // 主键ID
|
||||
}
|
||||
|
||||
// tikhup管理 API
|
||||
export const TokenApi = {
|
||||
|
||||
@@ -25,15 +25,6 @@
|
||||
<el-radio value="0">禁用</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="温度参数" prop="temperature">
|
||||
<el-input v-model="formData.temperature" placeholder="请输入温度参数" />
|
||||
</el-form-item>
|
||||
<el-form-item label="回复数Token数" prop="maxTokens">
|
||||
<el-input v-model="formData.maxTokens" placeholder="请输入回复数Token数" />
|
||||
</el-form-item>
|
||||
<el-form-item label="每日请求次数" prop="dailyLimit">
|
||||
<el-input v-model="formData.dailyLimit" placeholder="请输入每日请求次数" />
|
||||
</el-form-item>
|
||||
<el-form-item label="模型类型" prop="modelType">
|
||||
<el-radio-group v-model="formData.modelType">
|
||||
<el-radio value="image">图像</el-radio>
|
||||
@@ -46,18 +37,6 @@
|
||||
<el-form-item label="消耗积分" prop="consumePoints">
|
||||
<el-input v-model="formData.consumePoints" placeholder="请输入消耗积分" />
|
||||
</el-form-item>
|
||||
<el-form-item label="最大文本数量" prop="maxTextLength">
|
||||
<el-input v-model="formData.maxTextLength" placeholder="请输入最大文本数量" />
|
||||
</el-form-item>
|
||||
<el-form-item label="图片最大像素" prop="maxImageSize">
|
||||
<el-input v-model="formData.maxImageSize" placeholder="请输入图片最大像素" />
|
||||
</el-form-item>
|
||||
<el-form-item label="视频最大时长(秒)" prop="maxVideoDuration">
|
||||
<el-input v-model="formData.maxVideoDuration" placeholder="请输入视频最大时长(秒)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="视频最大质量" prop="maxVideoQuality">
|
||||
<el-input v-model="formData.maxVideoQuality" placeholder="请输入视频最大质量" />
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark">
|
||||
<el-input v-model="formData.remark" placeholder="请输入备注" />
|
||||
</el-form-item>
|
||||
@@ -88,15 +67,8 @@ const formData = ref({
|
||||
platform: undefined,
|
||||
apiKey: undefined,
|
||||
status: undefined,
|
||||
temperature: undefined,
|
||||
maxTokens: undefined,
|
||||
dailyLimit: undefined,
|
||||
modelType: undefined,
|
||||
consumePoints: undefined,
|
||||
maxTextLength: undefined,
|
||||
maxImageSize: undefined,
|
||||
maxVideoDuration: undefined,
|
||||
maxVideoQuality: undefined,
|
||||
remark: undefined,
|
||||
})
|
||||
const formRules = reactive({
|
||||
@@ -104,9 +76,6 @@ const formRules = reactive({
|
||||
modelCode: [{ required: true, message: '模型标识/编码不能为空', trigger: 'blur' }],
|
||||
platform: [{ required: true, message: '所属平台不能为空', trigger: 'blur' }],
|
||||
status: [{ required: true, message: '状态不能为空', trigger: 'blur' }],
|
||||
temperature: [{ required: true, message: '温度参数不能为空', trigger: 'blur' }],
|
||||
maxTokens: [{ required: true, message: '回复数Token数不能为空', trigger: 'blur' }],
|
||||
dailyLimit: [{ required: true, message: '每日请求次数不能为空', trigger: 'blur' }],
|
||||
modelType: [{ required: true, message: '模型类型不能为空', trigger: 'change' }],
|
||||
consumePoints: [{ required: true, message: '消耗积分不能为空', trigger: 'blur' }],
|
||||
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
|
||||
@@ -164,15 +133,8 @@ const resetForm = () => {
|
||||
platform: undefined,
|
||||
apiKey: undefined,
|
||||
status: undefined,
|
||||
temperature: undefined,
|
||||
maxTokens: undefined,
|
||||
dailyLimit: undefined,
|
||||
modelType: undefined,
|
||||
consumePoints: undefined,
|
||||
maxTextLength: undefined,
|
||||
maxImageSize: undefined,
|
||||
maxVideoDuration: undefined,
|
||||
maxVideoQuality: undefined,
|
||||
remark: undefined,
|
||||
}
|
||||
formRef.value?.resetFields()
|
||||
|
||||
@@ -118,15 +118,8 @@
|
||||
</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="温度参数" align="center" prop="temperature" />
|
||||
<el-table-column label="回复数Token数" align="center" prop="maxTokens" />
|
||||
<el-table-column label="每日请求次数" align="center" prop="dailyLimit" />
|
||||
<el-table-column label="模型类型" align="center" prop="modelType" />
|
||||
<el-table-column label="消耗积分" align="center" prop="consumePoints" />
|
||||
<el-table-column label="最大文本数量" align="center" prop="maxTextLength" />
|
||||
<el-table-column label="图片最大像素" align="center" prop="maxImageSize" />
|
||||
<el-table-column label="视频最大时长(秒)" align="center" prop="maxVideoDuration" />
|
||||
<el-table-column label="视频最大质量" align="center" prop="maxVideoQuality" />
|
||||
<el-table-column label="备注" align="center" prop="remark" />
|
||||
<el-table-column label="操作" align="center" min-width="120px">
|
||||
<template #default="scope">
|
||||
|
||||
@@ -13,14 +13,14 @@
|
||||
<el-form-item label="手机号" prop="mobile">
|
||||
<el-input v-model="formData.mobile" placeholder="请输入手机号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="变动类型(increase-增加 decrease-减少)" prop="type">
|
||||
<el-form-item label="变动类型" prop="type">
|
||||
<el-radio-group v-model="formData.type">
|
||||
<el-radio value="increase">增加</el-radio>
|
||||
<el-radio value="decrease">减少</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="变动积分数量(正数为增加,负数为减少)" prop="pointAmount">
|
||||
<el-input v-model="formData.pointAmount" placeholder="请输入变动积分数量(正数为增加,负数为减少)" />
|
||||
<el-form-item label="变动积分数量" prop="pointAmount">
|
||||
<el-input v-model="formData.pointAmount" placeholder="正数为增加,负数为减少" />
|
||||
</el-form-item>
|
||||
<el-form-item label="变动后余额" prop="balance">
|
||||
<el-input v-model="formData.balance" placeholder="请输入变动后余额" />
|
||||
@@ -28,7 +28,7 @@
|
||||
<el-form-item label="变动原因" prop="reason">
|
||||
<el-input v-model="formData.reason" placeholder="请输入变动原因" />
|
||||
</el-form-item>
|
||||
<el-form-item label="业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)" prop="bizType">
|
||||
<el-form-item label="业务类型" prop="bizType">
|
||||
<el-radio-group v-model="formData.bizType">
|
||||
<el-radio value="signin">签到</el-radio>
|
||||
<el-radio value="recharge">充值</el-radio>
|
||||
@@ -78,11 +78,11 @@ const formData = ref({
|
||||
const formRules = reactive({
|
||||
userId: [{ required: true, message: '用户编号不能为空', trigger: 'blur' }],
|
||||
mobile: [{ required: true, message: '手机号不能为空', trigger: 'blur' }],
|
||||
type: [{ required: true, message: '变动类型(increase-增加 decrease-减少)不能为空', trigger: 'change' }],
|
||||
pointAmount: [{ required: true, message: '变动积分数量(正数为增加,负数为减少)不能为空', trigger: 'blur' }],
|
||||
type: [{ required: true, message: '变动类型不能为空', trigger: 'change' }],
|
||||
pointAmount: [{ required: true, message: '变动积分数量不能为空', trigger: 'blur' }],
|
||||
balance: [{ required: true, message: '变动后余额不能为空', trigger: 'blur' }],
|
||||
reason: [{ required: true, message: '变动原因不能为空', trigger: 'blur' }],
|
||||
bizType: [{ required: true, message: '业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)不能为空', trigger: 'change' }],
|
||||
bizType: [{ required: true, message: '业务类型不能为空', trigger: 'change' }],
|
||||
bizId: [{ required: true, message: '业务关联ID不能为空', trigger: 'blur' }],
|
||||
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
|
||||
})
|
||||
|
||||
@@ -106,11 +106,12 @@
|
||||
<el-table-column type="selection" width="55" />
|
||||
<el-table-column label="用户编号" align="center" prop="userId" />
|
||||
<el-table-column label="手机号" align="center" prop="mobile" />
|
||||
<el-table-column label="变动类型(increase-增加 decrease-减少)" align="center" prop="type" />
|
||||
<el-table-column label="变动积分数量(正数为增加,负数为减少)" align="center" prop="pointAmount" />
|
||||
<el-table-column label="变动类型" align="center" prop="type" />
|
||||
<el-table-column label="变动积分数量" align="center" prop="pointAmount" />
|
||||
<el-table-column label="变动后余额" align="center" prop="balance" />
|
||||
<el-table-column label="变动原因" align="center" prop="reason" />
|
||||
<el-table-column label="业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)" align="center" prop="bizType" />
|
||||
<!-- (signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送) -->
|
||||
<el-table-column label="业务类型" align="center" prop="bizType" />
|
||||
<el-table-column label="业务关联ID" align="center" prop="bizId" />
|
||||
<el-table-column label="备注" align="center" prop="remark" />
|
||||
<el-table-column label="操作" align="center" min-width="120px">
|
||||
|
||||
@@ -16,8 +16,8 @@
|
||||
<el-form-item label="连续签到奖励积分" prop="bonusPoints">
|
||||
<el-input v-model="formData.bonusPoints" placeholder="请输入连续签到奖励积分" />
|
||||
</el-form-item>
|
||||
<el-form-item label="重置签到天数(0表示不重置)" prop="resetDays">
|
||||
<el-input v-model="formData.resetDays" placeholder="请输入重置签到天数(0表示不重置)" />
|
||||
<el-form-item label="重置签到天数" prop="resetDays">
|
||||
<el-input v-model="formData.resetDays" placeholder="请输入重置签到天数" />
|
||||
</el-form-item>
|
||||
<el-form-item label="调整原因" prop="adjustReason">
|
||||
<el-input v-model="formData.adjustReason" placeholder="请输入调整原因" />
|
||||
@@ -28,7 +28,7 @@
|
||||
<el-form-item label="操作人账号" prop="operatorName">
|
||||
<el-input v-model="formData.operatorName" placeholder="请输入操作人账号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="状态(0-禁用 1-启用)" prop="status">
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-radio-group v-model="formData.status">
|
||||
<el-radio value="0">禁用</el-radio>
|
||||
<el-radio value="1">启用</el-radio>
|
||||
@@ -73,11 +73,11 @@ const formRules = reactive({
|
||||
dailyPoints: [{ required: true, message: '每日签到赠送积分不能为空', trigger: 'blur' }],
|
||||
continuousDays: [{ required: true, message: '连续签到天数不能为空', trigger: 'blur' }],
|
||||
bonusPoints: [{ required: true, message: '连续签到奖励积分不能为空', trigger: 'blur' }],
|
||||
resetDays: [{ required: true, message: '重置签到天数(0表示不重置)不能为空', trigger: 'blur' }],
|
||||
resetDays: [{ required: true, message: '重置签到天数不能为空', trigger: 'blur' }],
|
||||
adjustReason: [{ required: true, message: '调整原因不能为空', trigger: 'blur' }],
|
||||
operatorId: [{ required: true, message: '操作人用户编号不能为空', trigger: 'blur' }],
|
||||
operatorName: [{ required: true, message: '操作人账号不能为空', trigger: 'blur' }],
|
||||
status: [{ required: true, message: '状态(0-禁用 1-启用)不能为空', trigger: 'blur' }],
|
||||
status: [{ required: true, message: '状态不能为空', trigger: 'change' }],
|
||||
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
|
||||
})
|
||||
const formRef = ref() // 表单 Ref
|
||||
|
||||
@@ -35,10 +35,10 @@
|
||||
class="!w-240px"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="重置签到天数(0表示不重置)" prop="resetDays">
|
||||
<el-form-item label="重置签到天数" prop="resetDays">
|
||||
<el-input
|
||||
v-model="queryParams.resetDays"
|
||||
placeholder="请输入重置签到天数(0表示不重置)"
|
||||
placeholder="请输入重置签到天数"
|
||||
clearable
|
||||
@keyup.enter="handleQuery"
|
||||
class="!w-240px"
|
||||
@@ -106,11 +106,14 @@
|
||||
<el-table-column label="每日签到赠送积分" align="center" prop="dailyPoints" />
|
||||
<el-table-column label="连续签到天数" align="center" prop="continuousDays" />
|
||||
<el-table-column label="连续签到奖励积分" align="center" prop="bonusPoints" />
|
||||
<el-table-column label="重置签到天数(0表示不重置)" align="center" prop="resetDays" />
|
||||
<el-table-column label="重置天数" align="center" prop="resetDays">
|
||||
<template #default="scope">{{ scope.row.resetDays || '不重置' }}</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="调整原因" align="center" prop="adjustReason" />
|
||||
<el-table-column label="操作人用户编号" align="center" prop="operatorId" />
|
||||
<el-table-column label="操作人账号" align="center" prop="operatorName" />
|
||||
<el-table-column label="状态(0-禁用 1-启用)" align="center" prop="status" />
|
||||
<el-table-column label="操作人" align="center" prop="operatorName" />
|
||||
<el-table-column label="状态" align="center" prop="status">
|
||||
<template #default="scope">{{ scope.row.status === '1' ? '启用' : '禁用' }}</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="备注" align="center" prop="remark" />
|
||||
<el-table-column label="操作" align="center" min-width="120px">
|
||||
<template #default="scope">
|
||||
|
||||
@@ -10,8 +10,11 @@
|
||||
<el-form-item label="平台URL" prop="platformUrl">
|
||||
<el-input v-model="formData.platformUrl" placeholder="请输入平台URL" />
|
||||
</el-form-item>
|
||||
<el-form-item label="平台Token" prop="platformToken">
|
||||
<el-input v-model="formData.platformToken" placeholder="请输入平台Token" />
|
||||
<el-form-item label="接口类型" prop="interfaceType">
|
||||
<el-input v-model="formData.interfaceType" placeholder="请输入接口类型" />
|
||||
</el-form-item>
|
||||
<el-form-item label="接口描述" prop="interfaceDesc">
|
||||
<el-input v-model="formData.interfaceDesc" placeholder="请输入接口描述" />
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<template #footer>
|
||||
@@ -35,12 +38,13 @@ const formLoading = ref(false) // 表单的加载中:1)修改时的数据加
|
||||
const formType = ref('') // 表单的类型:create - 新增;update - 修改
|
||||
const formData = ref({
|
||||
platformUrl: undefined,
|
||||
platformToken: undefined,
|
||||
interfaceType: undefined,
|
||||
interfaceDesc: undefined,
|
||||
id: undefined,
|
||||
})
|
||||
const formRules = reactive({
|
||||
platformUrl: [{ required: true, message: '平台URL不能为空', trigger: 'blur' }],
|
||||
platformToken: [{ required: true, message: '平台Token不能为空', trigger: 'blur' }],
|
||||
interfaceType: [{ required: true, message: '接口类型不能为空', trigger: 'blur' }],
|
||||
})
|
||||
const formRef = ref() // 表单 Ref
|
||||
|
||||
@@ -90,7 +94,8 @@ const submitForm = async () => {
|
||||
const resetForm = () => {
|
||||
formData.value = {
|
||||
platformUrl: undefined,
|
||||
platformToken: undefined,
|
||||
interfaceType: undefined,
|
||||
interfaceDesc: undefined,
|
||||
id: undefined,
|
||||
}
|
||||
formRef.value?.resetFields()
|
||||
|
||||
@@ -17,10 +17,10 @@
|
||||
class="!w-240px"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="平台Token" prop="platformToken">
|
||||
<el-form-item label="接口类型" prop="interfaceType">
|
||||
<el-input
|
||||
v-model="queryParams.platformToken"
|
||||
placeholder="请输入平台Token"
|
||||
v-model="queryParams.interfaceType"
|
||||
placeholder="请输入接口类型"
|
||||
clearable
|
||||
@keyup.enter="handleQuery"
|
||||
class="!w-240px"
|
||||
@@ -82,8 +82,8 @@
|
||||
>
|
||||
<el-table-column type="selection" width="55" />
|
||||
<el-table-column label="平台URL" align="center" prop="platformUrl" />
|
||||
<el-table-column label="平台Token" align="center" prop="platformToken" />
|
||||
<el-table-column label="主键ID" align="center" prop="id" />
|
||||
<el-table-column label="接口类型" align="center" prop="interfaceType" />
|
||||
<el-table-column label="接口描述" align="center" prop="interfaceDesc" />
|
||||
<el-table-column
|
||||
label="创建时间"
|
||||
align="center"
|
||||
@@ -145,7 +145,8 @@ const queryParams = reactive({
|
||||
pageNo: 1,
|
||||
pageSize: 10,
|
||||
platformUrl: undefined,
|
||||
platformToken: undefined,
|
||||
interfaceType: undefined,
|
||||
interfaceDesc: undefined,
|
||||
createTime: [],
|
||||
})
|
||||
const queryFormRef = ref() // 搜索的表单
|
||||
@@ -189,7 +190,6 @@ const handleDelete = async (id: number) => {
|
||||
// 发起删除
|
||||
await TokenApi.deleteToken(id)
|
||||
message.success(t('common.delSuccess'))
|
||||
currentRow.value = {}
|
||||
// 刷新列表
|
||||
await getList()
|
||||
} catch {}
|
||||
|
||||
Reference in New Issue
Block a user