feat: refactor http
This commit is contained in:
@@ -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()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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
|
||||||
|
}
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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
|
||||||
|
}
|
||||||
|
|||||||
@@ -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()...)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user