http.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. package server
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "github.com/go-nunu/nunu-layout/internal/handler"
  5. "github.com/go-nunu/nunu-layout/internal/middleware"
  6. "github.com/go-nunu/nunu-layout/pkg/log"
  7. "github.com/go-nunu/nunu-layout/pkg/resp"
  8. )
  9. func NewServerHTTP(
  10. log *log.Logger,
  11. jwt *middleware.JWT,
  12. userHandler *handler.UserHandler,
  13. ) *gin.Engine {
  14. gin.SetMode(gin.ReleaseMode)
  15. r := gin.Default()
  16. r.Use(
  17. middleware.RequestLogMiddleware(log),
  18. middleware.CORSMiddleware(),
  19. middleware.NoAuth(log),
  20. middleware.ResponseLogMiddleware(log),
  21. //middleware.SignMiddleware(log),
  22. )
  23. r.GET("/", func(ctx *gin.Context) {
  24. resp.HandleSuccess(ctx, map[string]interface{}{
  25. "say": "Hi Nunu!",
  26. })
  27. })
  28. noAuthRouter := r.Use(middleware.NoAuth(log))
  29. {
  30. noAuthRouter.GET("/user", userHandler.GetUserById)
  31. }
  32. // 严格权限路由
  33. strictAuthRouter := r.Use(middleware.StrictAuth(jwt, log))
  34. {
  35. strictAuthRouter.PUT("/user", userHandler.UpdateUser)
  36. }
  37. // 非严格权限路由
  38. noStrictAuthRouter := r.Use(middleware.NoStrictAuth(jwt, log))
  39. {
  40. noStrictAuthRouter.POST("/user", userHandler.CreateUser)
  41. }
  42. return r
  43. }