feat: refactor http

This commit is contained in:
Rogee
2024-12-06 16:53:33 +08:00
parent 7d9ec4ef81
commit 29894cff9c
6 changed files with 82 additions and 30 deletions

View File

@@ -1,16 +1,22 @@
package http package http
import ( import (
"backend/modules/medias"
"backend/modules/middlewares" "backend/modules/middlewares"
"backend/modules/users" "backend/modules/users"
"backend/providers/app" "backend/providers/app"
"backend/providers/http" "backend/providers/http"
"backend/providers/jwt"
"backend/providers/postgres" "backend/providers/postgres"
"backend/providers/storage"
"backend/providers/wechat"
"git.ipao.vip/rogeecn/atom" "git.ipao.vip/rogeecn/atom"
"git.ipao.vip/rogeecn/atom/container" "git.ipao.vip/rogeecn/atom/container"
"git.ipao.vip/rogeecn/atom/contracts" "git.ipao.vip/rogeecn/atom/contracts"
log "github.com/sirupsen/logrus" "github.com/gofiber/fiber/v3"
"github.com/gofiber/fiber/v3/log"
"github.com/samber/lo"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"go.uber.org/dig" "go.uber.org/dig"
) )
@@ -20,12 +26,17 @@ func defaultProviders(providers ...container.ProviderContainer) container.Provid
app.DefaultProvider(), app.DefaultProvider(),
http.DefaultProvider(), http.DefaultProvider(),
postgres.DefaultProvider(), postgres.DefaultProvider(),
jwt.DefaultProvider(),
}, providers...) }, providers...)
} }
func Command() atom.Option { func Command() atom.Option {
providers := defaultProviders().With( providers := defaultProviders(
wechat.DefaultProvider(),
storage.DefaultProvider(),
).With(
users.Provide, users.Provide,
medias.Provide,
) )
return atom.Command( return atom.Command(
@@ -49,17 +60,35 @@ type Http struct {
func Serve(cmd *cobra.Command, args []string) error { func Serve(cmd *cobra.Command, args []string) error {
return container.Container.Invoke(func(http Http) error { return container.Container.Invoke(func(http Http) error {
for _, route := range http.Routes {
if err := route.Register(); err != nil {
log.Fatal(err)
}
}
mid := http.Middlewares mid := http.Middlewares
http.Service.Engine.Use(mid.Verify) http.Service.Engine.Use(mid.Verify)
http.Service.Engine.Use(mid.AuthUserInfo) http.Service.Engine.Use(mid.AuthUserInfo)
http.Service.Engine.Use(mid.SilentAuth) http.Service.Engine.Use(mid.SilentAuth)
mounts := map[string][]string{
"/t/{tenant}": {"users", "medias"},
}
for _, route := range http.Routes {
r := route.Register()
if app, ok := r.(*fiber.App); ok {
match := false
for prefix, groups := range mounts {
log.Infof("mount %s to %s", prefix, route.Name())
if lo.Contains(groups, route.Name()) {
match = true
http.Service.Engine.Use(prefix, app)
break
}
}
_ = match
if !match {
log.Infof("mount / to %s", route.Name())
http.Service.Engine.Use(app)
}
}
}
return http.Service.Serve() return http.Service.Serve()
}) })
} }

View File

@@ -1,7 +1,6 @@
package medias package medias
import ( import (
"backend/providers/http"
"backend/providers/storage" "backend/providers/storage"
"database/sql" "database/sql"
@@ -25,11 +24,12 @@ func Provide(opts ...opt.Option) error {
if err := container.Container.Provide(func( if err := container.Container.Provide(func(
controller *Controller, controller *Controller,
http *http.Service,
) (contracts.HttpRoute, error) { ) (contracts.HttpRoute, error) {
obj := &Router{ obj := &Router{
controller: controller, controller: controller,
http: http, }
if err := obj.Prepare(); err != nil {
return nil, err
} }
return obj, nil return obj, nil
}, atom.GroupRoutes); err != nil { }, atom.GroupRoutes); err != nil {

View File

@@ -1,8 +1,6 @@
package medias package medias
import ( import (
"backend/providers/http"
_ "git.ipao.vip/rogeecn/atom" _ "git.ipao.vip/rogeecn/atom"
_ "git.ipao.vip/rogeecn/atom/contracts" _ "git.ipao.vip/rogeecn/atom/contracts"
"github.com/gofiber/fiber/v3" "github.com/gofiber/fiber/v3"
@@ -11,16 +9,28 @@ import (
// @provider:except contracts.HttpRoute atom.GroupRoutes // @provider:except contracts.HttpRoute atom.GroupRoutes
type Router struct { type Router struct {
http *http.Service app *fiber.App `inject:"false"`
group fiber.Router `inject:"false"`
log *log.Entry `inject:"false"`
controller *Controller controller *Controller
} }
func (r *Router) Register() error { func (r *Router) Name() string {
group := r.http.Engine.Group("medias") return "medias"
log.Infof("register route group: %s", group.(*fiber.Group).Prefix) }
group.Get("", r.controller.List)
group.Get("{id}", r.controller.Show) func (r *Router) Prepare() error {
r.log = log.WithField("http.group", r.Name())
r.app = fiber.New()
r.group = r.app.Group(r.Name())
return nil return nil
} }
func (r *Router) Register() any {
r.group.Get("", r.controller.List)
r.group.Get("{id}", r.controller.Show)
return r.app
}

View File

@@ -1,7 +1,6 @@
package users package users
import ( import (
"backend/providers/http"
"database/sql" "database/sql"
"git.ipao.vip/rogeecn/atom" "git.ipao.vip/rogeecn/atom"
@@ -24,11 +23,12 @@ func Provide(opts ...opt.Option) error {
if err := container.Container.Provide(func( if err := container.Container.Provide(func(
controller *Controller, controller *Controller,
http *http.Service,
) (contracts.HttpRoute, error) { ) (contracts.HttpRoute, error) {
obj := &Router{ obj := &Router{
controller: controller, controller: controller,
http: http, }
if err := obj.Prepare(); err != nil {
return nil, err
} }
return obj, nil return obj, nil
}, atom.GroupRoutes); err != nil { }, atom.GroupRoutes); err != nil {

View File

@@ -1,8 +1,6 @@
package users package users
import ( import (
"backend/providers/http"
_ "git.ipao.vip/rogeecn/atom" _ "git.ipao.vip/rogeecn/atom"
_ "git.ipao.vip/rogeecn/atom/contracts" _ "git.ipao.vip/rogeecn/atom/contracts"
"github.com/gofiber/fiber/v3" "github.com/gofiber/fiber/v3"
@@ -11,15 +9,27 @@ import (
// @provider:except contracts.HttpRoute atom.GroupRoutes // @provider:except contracts.HttpRoute atom.GroupRoutes
type Router struct { type Router struct {
http *http.Service app *fiber.App `inject:"false"`
group fiber.Router `inject:"false"`
log *log.Entry `inject:"false"`
controller *Controller controller *Controller
} }
func (r *Router) Register() error { func (r *Router) Prepare() error {
group := r.http.Engine.Group("users") r.log = log.WithField("http.group", r.Name())
log.Infof("register route group: %s", group.(*fiber.Group).Prefix) r.app = fiber.New()
group.Get("", r.controller.List) r.group = r.app.Group(r.Name())
return nil return nil
} }
func (r *Router) Name() string {
return "users"
}
func (r *Router) Register() any {
r.group.Get("", r.controller.List)
return r.app
}

View File

@@ -83,6 +83,9 @@ func Provide(opts ...opt.Option) error {
TimeZone: "Asia/Shanghai", TimeZone: "Asia/Shanghai",
})) }))
return &Service{Engine: engine, conf: &config}, nil return &Service{
Engine: engine,
conf: &config,
}, nil
}, o.DiOptions()...) }, o.DiOptions()...)
} }