Nexus/pkg/internal/web/server.go

65 lines
1.6 KiB
Go
Raw Normal View History

package web
2024-10-19 22:36:33 +08:00
import (
2025-02-25 00:22:46 +08:00
"time"
"git.solsynth.dev/hypernet/nexus/pkg/internal/auth"
"git.solsynth.dev/hypernet/nexus/pkg/internal/web/api"
2024-10-19 22:36:33 +08:00
"github.com/goccy/go-json"
2025-03-01 13:07:33 +08:00
"github.com/gofiber/contrib/fiberzerolog"
2024-10-19 22:36:33 +08:00
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/cors"
"github.com/gofiber/fiber/v2/middleware/idempotency"
2025-02-25 00:22:46 +08:00
"github.com/gofiber/fiber/v2/middleware/limiter"
2024-10-19 22:36:33 +08:00
"github.com/rs/zerolog/log"
"github.com/spf13/viper"
)
type WebApp struct {
2024-10-19 22:36:33 +08:00
app *fiber.App
}
func NewServer() *WebApp {
2024-10-19 22:36:33 +08:00
app := fiber.New(fiber.Config{
DisableStartupMessage: true,
EnableIPValidation: true,
2025-03-01 13:22:38 +08:00
ServerHeader: "HyperNet.Nexus",
AppName: "HyperNet.Nexus",
2024-10-19 22:36:33 +08:00
ProxyHeader: fiber.HeaderXForwardedFor,
JSONEncoder: json.Marshal,
JSONDecoder: json.Unmarshal,
BodyLimit: 512 * 1024 * 1024 * 1024, // 512 TiB
EnablePrintRoutes: viper.GetBool("debug.print_routes"),
})
2025-03-01 13:07:33 +08:00
app.Use(fiberzerolog.New(fiberzerolog.Config{
Logger: &log.Logger,
}))
2024-10-19 22:36:33 +08:00
app.Use(idempotency.New())
app.Use(cors.New(cors.Config{
AllowCredentials: true,
AllowMethods: "GET,POST,HEAD,PUT,DELETE,PATCH",
AllowOriginsFunc: func(origin string) bool {
return true
},
}))
app.Use(auth.ContextMiddleware)
2025-02-25 00:22:46 +08:00
app.Use(limiter.New(limiter.Config{
Max: viper.GetInt("rate_limit"),
Expiration: 60 * time.Second,
LimiterMiddleware: limiter.SlidingWindow{},
}))
2025-03-01 13:07:33 +08:00
api.MapControllers(app)
2024-10-19 22:36:33 +08:00
return &WebApp{app}
2024-10-19 22:36:33 +08:00
}
func (v *WebApp) Listen() {
2024-10-19 22:36:33 +08:00
if err := v.app.Listen(viper.GetString("bind")); err != nil {
log.Fatal().Err(err).Msg("An error occurred when starting server...")
}
}