All checks were successful
Build and Publish Docker Image / deploy (push) Successful in 1m41s
- Implement storage backend deletion, which automatically resets default storage settings and user-specific overrides when a backend is removed. - Add unit tests covering the delete action and its cleanup side effects. - Improve admin UI responsiveness, fixing table scrolling, flex wrapping, and text truncation for long storage backend names. - Update security documentation to clarify trusted proxy configurations and explain how trusted proxies are protected from automatic bans.
73 lines
1.9 KiB
Go
73 lines
1.9 KiB
Go
package httpserver
|
|
|
|
import (
|
|
"log/slog"
|
|
"net/http"
|
|
|
|
"warpbox.dev/backend/libs/config"
|
|
"warpbox.dev/backend/libs/handlers"
|
|
"warpbox.dev/backend/libs/jobs"
|
|
"warpbox.dev/backend/libs/middleware"
|
|
"warpbox.dev/backend/libs/services"
|
|
"warpbox.dev/backend/libs/web"
|
|
)
|
|
|
|
func New(cfg config.Config, logger *slog.Logger) (*http.Server, error) {
|
|
renderer, err := web.NewRenderer(cfg.TemplateDir, cfg.AppName, cfg.AppVersion, cfg.BaseURL)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
uploadService, err := services.NewUploadService(cfg.MaxUploadSize, cfg.DataDir, cfg.BaseURL, logger)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
authService, err := services.NewAuthService(uploadService.DB(), cfg.BaseURL)
|
|
if err != nil {
|
|
uploadService.Close()
|
|
return nil, err
|
|
}
|
|
settingsService, err := services.NewSettingsService(uploadService.DB(), cfg.DefaultSettings)
|
|
if err != nil {
|
|
uploadService.Close()
|
|
return nil, err
|
|
}
|
|
banService, err := services.NewBanService(uploadService.DB())
|
|
if err != nil {
|
|
uploadService.Close()
|
|
return nil, err
|
|
}
|
|
stopJobs := jobs.StartAll(cfg, logger, uploadService, banService)
|
|
app := handlers.NewApp(cfg, logger, renderer, uploadService, authService, settingsService, banService)
|
|
|
|
router := http.NewServeMux()
|
|
app.RegisterRoutes(router)
|
|
|
|
handler := middleware.Chain(
|
|
router,
|
|
middleware.Recoverer(logger),
|
|
middleware.RequestID,
|
|
middleware.SecurityHeaders,
|
|
middleware.Gzip,
|
|
middleware.ClientIP(cfg.TrustedProxies),
|
|
middleware.Logger(logger),
|
|
middleware.Bans(logger, banService, cfg.TrustedProxies),
|
|
)
|
|
|
|
server := &http.Server{
|
|
Addr: cfg.Addr,
|
|
Handler: handler,
|
|
ReadTimeout: cfg.ReadTimeout,
|
|
WriteTimeout: cfg.WriteTimeout,
|
|
IdleTimeout: cfg.IdleTimeout,
|
|
}
|
|
server.RegisterOnShutdown(func() {
|
|
stopJobs()
|
|
if err := uploadService.Close(); err != nil {
|
|
logger.Error("failed to close upload service", "source", "shutdown", "severity", "error", "error", err.Error())
|
|
}
|
|
})
|
|
|
|
return server, nil
|
|
}
|