demo
This commit is contained in:
55
internal/router/router.go
Normal file
55
internal/router/router.go
Normal file
@@ -0,0 +1,55 @@
|
||||
package router
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
"gitea.starryskymeow.cn/B309/datamarket/internal/handler"
|
||||
"gitea.starryskymeow.cn/B309/datamarket/internal/service"
|
||||
"github.com/go-chi/chi/v5"
|
||||
"github.com/go-chi/chi/v5/middleware"
|
||||
)
|
||||
|
||||
func New(svc *service.Service) http.Handler {
|
||||
r := chi.NewRouter()
|
||||
|
||||
r.Use(middleware.RequestID)
|
||||
r.Use(middleware.RealIP)
|
||||
r.Use(middleware.Logger)
|
||||
r.Use(middleware.Recoverer)
|
||||
r.Use(middleware.Timeout(60 * time.Second))
|
||||
|
||||
r.Route("/api", func(r chi.Router) {
|
||||
r.Route("/assets", func(r chi.Router) {
|
||||
r.Post("/", handler.CreateAsset(svc))
|
||||
r.Get("/", handler.ListAssets(svc))
|
||||
r.Get("/{id}", handler.GetAsset(svc))
|
||||
r.Put("/{id}/status", handler.UpdateAssetStatus(svc))
|
||||
})
|
||||
|
||||
r.Route("/pricing", func(r chi.Router) {
|
||||
r.Post("/", handler.CreatePricing(svc))
|
||||
r.Get("/{id}", handler.GetPricing(svc))
|
||||
})
|
||||
|
||||
r.Route("/validations", func(r chi.Router) {
|
||||
r.Post("/", handler.CreateValidation(svc))
|
||||
r.Get("/{id}", handler.GetValidation(svc))
|
||||
})
|
||||
|
||||
r.Route("/orders", func(r chi.Router) {
|
||||
r.Post("/", handler.CreateOrder(svc))
|
||||
r.Get("/", handler.ListOrders(svc))
|
||||
r.Get("/{id}", handler.GetOrder(svc))
|
||||
r.Put("/{id}/status", handler.UpdateOrderStatus(svc))
|
||||
})
|
||||
|
||||
r.Route("/admin", func(r chi.Router) {
|
||||
r.Get("/assets", handler.AdminListAssets(svc))
|
||||
r.Get("/validations", handler.AdminListValidations(svc))
|
||||
r.Get("/orders", handler.AdminListOrders(svc))
|
||||
})
|
||||
})
|
||||
|
||||
return r
|
||||
}
|
||||
Reference in New Issue
Block a user