feat(quota): 新增用户额度总计模块

增加用户免费体验额度配置,支持新用户注册时的额度分配功能
This commit is contained in:
2025-12-16 16:59:56 +08:00
parent cd6eca9cbb
commit 495485cc07
7 changed files with 137 additions and 0 deletions

View File

@@ -0,0 +1,12 @@
package com.yolo.keyborad.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.yolo.keyborad.model.entity.KeyboardUserQuotaTotal;
/*
* @author: ziin
* @date: 2025/12/16 16:00
*/
public interface KeyboardUserQuotaTotalMapper extends BaseMapper<KeyboardUserQuotaTotal> {
}

View File

@@ -0,0 +1,64 @@
package com.yolo.keyborad.model.entity;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.v3.oas.annotations.media.Schema;
import java.util.Date;
import lombok.Data;
/*
* @author: ziin
* @date: 2025/12/16 16:00
*/
/**
* 用户免费功能永久总次数额度表(所有功能共用)
*/
@Schema(description="用户免费功能永久总次数额度表(所有功能共用)")
@Data
@TableName(value = "keyboard_user_quota_total")
public class KeyboardUserQuotaTotal {
/**
* 用户唯一ID对应系统用户
*/
@TableId(value = "user_id", type = IdType.AUTO)
@Schema(description="用户唯一ID对应系统用户")
private Long userId;
/**
* 免费体验的永久总次数上限(可通过运营活动增加)
*/
@TableField(value = "total_quota")
@Schema(description="免费体验的永久总次数上限(可通过运营活动增加)")
private Integer totalQuota;
/**
* 已消耗的免费次数
*/
@TableField(value = "used_quota")
@Schema(description="已消耗的免费次数")
private Integer usedQuota;
/**
* 乐观锁版本号(并发控制预留字段)
*/
@TableField(value = "version")
@Schema(description="乐观锁版本号(并发控制预留字段)")
private Integer version;
/**
* 首次创建额度记录的时间(通常为注册时间)
*/
@TableField(value = "created_at")
@Schema(description="首次创建额度记录的时间(通常为注册时间)")
private Date createdAt;
/**
* 最近一次额度发生变化的时间(消耗或赠送)
*/
@TableField(value = "updated_at")
@Schema(description="最近一次额度发生变化的时间(消耗或赠送)")
private Date updatedAt;
}

View File

@@ -0,0 +1,13 @@
package com.yolo.keyborad.service;
import com.yolo.keyborad.model.entity.KeyboardUserQuotaTotal;
import com.baomidou.mybatisplus.extension.service.IService;
/*
* @author: ziin
* @date: 2025/12/16 16:00
*/
public interface KeyboardUserQuotaTotalService extends IService<KeyboardUserQuotaTotal>{
}

View File

@@ -0,0 +1,18 @@
package com.yolo.keyborad.service.impl;
import org.springframework.stereotype.Service;
import org.springframework.beans.factory.annotation.Autowired;
import java.util.List;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yolo.keyborad.model.entity.KeyboardUserQuotaTotal;
import com.yolo.keyborad.mapper.KeyboardUserQuotaTotalMapper;
import com.yolo.keyborad.service.KeyboardUserQuotaTotalService;
/*
* @author: ziin
* @date: 2025/12/16 16:00
*/
@Service
public class KeyboardUserQuotaTotalServiceImpl extends ServiceImpl<KeyboardUserQuotaTotalMapper, KeyboardUserQuotaTotal> implements KeyboardUserQuotaTotalService{
}

View File

@@ -76,6 +76,12 @@ mailgun:
from-email: no-reply@yourdomain.com # 发件人邮箱 from-email: no-reply@yourdomain.com # 发件人邮箱
from-name: Key Of Love # 发件人名称(可选) from-name: Key Of Love # 发件人名称(可选)
# 用户注册配置
user:
register:
# 新用户注册时的免费体验额度
free-trial-credits: 5
############## Sa-Token 配置 (文档: https://sa-token.cc) ############## ############## Sa-Token 配置 (文档: https://sa-token.cc) ##############

View File

@@ -28,3 +28,9 @@ logging:
max-size: 10MB max-size: 10MB
# 保留的日志文件数量 # 保留的日志文件数量
max-history: 30 max-history: 30
# 用户注册配置
user:
register:
# 新用户注册时的免费体验额度
free-trial-credits: 5

View File

@@ -0,0 +1,18 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.yolo.keyborad.mapper.KeyboardUserQuotaTotalMapper">
<resultMap id="BaseResultMap" type="com.yolo.keyborad.model.entity.KeyboardUserQuotaTotal">
<!--@mbg.generated-->
<!--@Table keyboard_user_quota_total-->
<id column="user_id" jdbcType="BIGINT" property="userId" />
<result column="total_quota" jdbcType="INTEGER" property="totalQuota" />
<result column="used_quota" jdbcType="INTEGER" property="usedQuota" />
<result column="version" jdbcType="INTEGER" property="version" />
<result column="created_at" jdbcType="TIMESTAMP" property="createdAt" />
<result column="updated_at" jdbcType="TIMESTAMP" property="updatedAt" />
</resultMap>
<sql id="Base_Column_List">
<!--@mbg.generated-->
user_id, total_quota, used_quota, version, created_at, updated_at
</sql>
</mapper>