- 支持创建/编辑/删除优惠码,设置赠送金额和使用限制 - 注册页面实时验证优惠码并显示赠送金额 - 支持 URL 参数自动填充 (?promo=CODE) - 添加优惠码验证接口速率限制 - 使用数据库行锁防止并发超限 - 新增后台优惠码管理页面,支持复制注册链接
49 lines
1.3 KiB
Go
49 lines
1.3 KiB
Go
package routes
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/Wei-Shaw/sub2api/internal/handler"
|
|
"github.com/Wei-Shaw/sub2api/internal/middleware"
|
|
servermiddleware "github.com/Wei-Shaw/sub2api/internal/server/middleware"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/redis/go-redis/v9"
|
|
)
|
|
|
|
// RegisterAuthRoutes 注册认证相关路由
|
|
func RegisterAuthRoutes(
|
|
v1 *gin.RouterGroup,
|
|
h *handler.Handlers,
|
|
jwtAuth servermiddleware.JWTAuthMiddleware,
|
|
redisClient *redis.Client,
|
|
) {
|
|
// 创建速率限制器
|
|
rateLimiter := middleware.NewRateLimiter(redisClient)
|
|
|
|
// 公开接口
|
|
auth := v1.Group("/auth")
|
|
{
|
|
auth.POST("/register", h.Auth.Register)
|
|
auth.POST("/login", h.Auth.Login)
|
|
auth.POST("/send-verify-code", h.Auth.SendVerifyCode)
|
|
// 优惠码验证接口添加速率限制:每分钟最多 10 次
|
|
auth.POST("/validate-promo-code", rateLimiter.Limit("validate-promo", 10, time.Minute), h.Auth.ValidatePromoCode)
|
|
auth.GET("/oauth/linuxdo/start", h.Auth.LinuxDoOAuthStart)
|
|
auth.GET("/oauth/linuxdo/callback", h.Auth.LinuxDoOAuthCallback)
|
|
}
|
|
|
|
// 公开设置(无需认证)
|
|
settings := v1.Group("/settings")
|
|
{
|
|
settings.GET("/public", h.Setting.GetPublicSettings)
|
|
}
|
|
|
|
// 需要认证的当前用户信息
|
|
authenticated := v1.Group("")
|
|
authenticated.Use(gin.HandlerFunc(jwtAuth))
|
|
{
|
|
authenticated.GET("/auth/me", h.Auth.GetCurrentUser)
|
|
}
|
|
}
|