2024-08-22 00:44:48 +02:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-08-22 13:47:16 +02:00
|
|
|
"fmt"
|
2024-08-22 00:44:48 +02:00
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/assets"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/config"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/db"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/handlers"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/i18n"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/internal/oidc"
|
|
|
|
webinternal "git.tijl.dev/tijl/tijl.dev/internal/web"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/modules/logger"
|
|
|
|
"git.tijl.dev/tijl/tijl.dev/modules/web"
|
2024-08-22 12:57:38 +02:00
|
|
|
webf "git.tijl.dev/tijl/tijl.dev/web"
|
2024-08-22 00:44:48 +02:00
|
|
|
"github.com/gofiber/contrib/fiberzerolog"
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"github.com/gofiber/template/html/v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Listen() {
|
|
|
|
// Load initial context
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
// setup logger
|
|
|
|
log.Load()
|
|
|
|
// Load config
|
|
|
|
config.Load()
|
|
|
|
// Load database
|
|
|
|
db.Load()
|
|
|
|
// Setup oidc
|
|
|
|
oidc.Load(ctx)
|
|
|
|
// Load assets
|
|
|
|
assets.Load()
|
|
|
|
// Load translations
|
|
|
|
i18n.Load()
|
|
|
|
// setup handler
|
|
|
|
handlers.Setup()
|
|
|
|
// setup web
|
|
|
|
webinternal.Load()
|
|
|
|
|
|
|
|
// Init templating engine
|
2024-08-22 12:57:38 +02:00
|
|
|
engine := html.NewFileSystem(http.FS(webf.ViewsEmbed), ".html")
|
|
|
|
engine.Directory = "views"
|
2024-08-22 00:44:48 +02:00
|
|
|
engine.AddFunc("icon", assets.Svg)
|
|
|
|
|
|
|
|
// Init fiber
|
|
|
|
app := fiber.New(fiber.Config{
|
|
|
|
Views: engine,
|
|
|
|
DisableStartupMessage: true,
|
|
|
|
})
|
|
|
|
app.Use(fiberzerolog.New(fiberzerolog.Config{
|
|
|
|
Logger: &log.Logger,
|
|
|
|
}))
|
|
|
|
|
|
|
|
// Setup routes
|
|
|
|
web.Setup(app)
|
|
|
|
|
|
|
|
// Listen web server
|
2024-08-22 13:47:16 +02:00
|
|
|
log.Info().Int("port", config.Config.Port).Str("host", config.Config.Host).Msg("listening...")
|
|
|
|
if err := app.Listen(fmt.Sprintf("%v:%v", config.Config.Host, config.Config.Port)); err != nil {
|
2024-08-22 00:44:48 +02:00
|
|
|
log.Fatal().Err(err).Msg("Fiber app error")
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|