You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
58 lines
2.2 KiB
58 lines
2.2 KiB
package routes |
|
|
|
import ( |
|
"gofaster/internal/auth/controller" |
|
"gofaster/internal/auth/repository" |
|
"gofaster/internal/auth/service" |
|
"gofaster/internal/shared/jwt" |
|
"gofaster/internal/shared/middleware" |
|
|
|
"github.com/gin-gonic/gin" |
|
"gorm.io/gorm" |
|
) |
|
|
|
// RegisterAuthRoutes 注册认证相关路由 |
|
func RegisterAuthRoutes(r *gin.RouterGroup, db *gorm.DB, jwtConfig middleware.JWTConfig) { |
|
// 创建仓储层实例 |
|
userRepo := repository.NewUserRepository(db) |
|
captchaRepo := repository.NewCaptchaRepository(db) |
|
passwordPolicyRepo := repository.NewPasswordPolicyRepository(db) |
|
passwordHistoryRepo := repository.NewPasswordHistoryRepository(db) |
|
passwordResetRepo := repository.NewPasswordResetRepository(db) |
|
|
|
// 创建JWT管理器 |
|
jwtManager := jwt.NewJWTManager(jwtConfig.SecretKey, jwtConfig.Issuer) |
|
|
|
// 创建服务层实例 |
|
authService := service.NewAuthService(userRepo, captchaRepo, jwtManager) |
|
userService := service.NewUserService(userRepo) |
|
passwordService := service.NewPasswordService(userService, passwordPolicyRepo, passwordHistoryRepo, passwordResetRepo) |
|
|
|
// 创建控制器实例 |
|
authController := controller.NewAuthController(authService) |
|
passwordController := controller.NewPasswordController(passwordService, userService) |
|
|
|
// 认证路由组 |
|
auth := r.Group("/auth") |
|
{ |
|
// 公开接口(无需认证) |
|
auth.POST("/login", authController.Login) // 用户登录 |
|
auth.GET("/captcha", authController.GenerateCaptcha) // 生成验证码 |
|
|
|
// 密码策略相关接口(无需认证) |
|
auth.GET("/password-policy", passwordController.GetPasswordPolicy) // 获取密码策略 |
|
auth.POST("/validate-password", passwordController.ValidatePassword) // 验证密码强度 |
|
|
|
// 需要认证的接口 |
|
auth.Use(middleware.JWTAuth(jwtConfig)) |
|
{ |
|
auth.POST("/logout", authController.Logout) // 用户登出 |
|
auth.POST("/refresh", authController.RefreshToken) // 刷新令牌 |
|
auth.GET("/userinfo", authController.GetUserInfo) // 获取用户信息 |
|
|
|
// 密码管理接口 |
|
auth.POST("/change-password", passwordController.ChangePassword) // 修改密码 |
|
auth.GET("/password-status", passwordController.CheckPasswordStatus) // 检查密码状态 |
|
} |
|
} |
|
}
|
|
|