api.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // Path: routes 注册路由
  2. package routes
  3. import (
  4. "github.com/gin-gonic/gin"
  5. "github.com/runningwater/gohub/app/http/controllers/api/v1/auth"
  6. "github.com/runningwater/gohub/app/http/middlewares"
  7. controllers "github.com/runningwater/gohub/app/http/controllers/api/v1"
  8. )
  9. // RegisterAPIRoutes 注册路由
  10. func RegisterAPIRoutes(router *gin.Engine) {
  11. // v1 路由组,所有 v1 版本的路由都放在这里
  12. v1 := router.Group("/v1")
  13. // 全局限流中间件:每小时限流。这里是所有 API (根据 IP)请求加起来。
  14. // 作为参考 Github API 每小时最多 60 个请求(根据 IP)。
  15. // 测试时,可以调高一点。
  16. v1.Use(middlewares.LimitIP("200-H"))
  17. {
  18. authGroup := v1.Group("/auth")
  19. {
  20. suc := new(auth.SignupController)
  21. vcc := new(auth.VerifyCodeController)
  22. // 注册手机号是否已存在
  23. authGroup.POST("/signup/phone/exist", middlewares.GuestJWT(), middlewares.LimitIP("60-H"), suc.IsPhoneExist)
  24. // 注册邮箱是否已存在
  25. authGroup.POST("/signup/email/exist", middlewares.GuestJWT(), middlewares.LimitIP("60-H"), suc.IsEmailExist)
  26. // 注册用户
  27. authGroup.POST("/signup/using-phone", suc.SignupUsingPhone)
  28. authGroup.POST("/signup/using-email", suc.SignupUsingEmail)
  29. // 显示图片验证码
  30. authGroup.POST("/verify_code/captcha", middlewares.LimitIP("50-H"), vcc.ShowCaptcha)
  31. // 发送手机验证码
  32. authGroup.POST("/verify_code/phone", middlewares.LimitIP("20-H"), vcc.SendUsingPhone)
  33. // 发送邮箱验证码
  34. authGroup.POST("/verify_code/email", middlewares.LimitIP("20-H"), vcc.SendUsingEmail)
  35. logc := new(auth.LoginController)
  36. // 手机号登录
  37. authGroup.POST("/login/using-phone", logc.LoginByPhone)
  38. // 账号登录,支持手机号,email 和用户名登录
  39. authGroup.POST("/login/using-password", logc.LoginByPassword)
  40. // 刷新 Access Token
  41. authGroup.POST("/login/refresh-token", logc.RefreshToken)
  42. // 重置密码
  43. pc := new(auth.PasswordController)
  44. // 使用手机重置密码
  45. authGroup.POST("/password-reset/using-phone", middlewares.LimitPerRoute("20-H"), pc.ResetByPhone)
  46. uc := new(controllers.UsersController)
  47. // 当前登录用户信息
  48. authGroup.GET("/user", middlewares.AuthJWT(), uc.CurrentUser)
  49. }
  50. }
  51. }