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