Files
kouiz/cmd/kouiz/main.go
2025-06-10 21:09:58 +02:00

50 lines
1.1 KiB
Go

package main
import (
"context"
"log/slog"
"os"
"os/signal"
"forge.cadoles.com/wpetit/kouiz/internal/config"
"forge.cadoles.com/wpetit/kouiz/internal/setup"
"github.com/pkg/errors"
)
func main() {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
conf, err := config.Parse()
if err != nil {
slog.ErrorContext(ctx, "could not parse config", slog.Any("error", errors.WithStack(err)))
os.Exit(1)
}
slog.SetLogLoggerLevel(slog.Level(conf.Logger.Level))
slog.DebugContext(ctx, "using configuration", slog.Any("config", conf))
sig := make(chan os.Signal, 1)
signal.Notify(sig, os.Interrupt)
go func() {
slog.InfoContext(ctx, "use ctrl+c to interrupt")
<-sig
cancel()
}()
server, err := setup.NewHTTPServerFromConfig(ctx, conf)
if err != nil {
slog.ErrorContext(ctx, "could not setup http server", slog.Any("error", errors.WithStack(err)))
os.Exit(1)
}
slog.InfoContext(ctx, "starting server", slog.Any("address", conf.HTTP.Address))
if err := server.Run(ctx); err != nil {
slog.Error("could not run server", slog.Any("error", errors.WithStack(err)))
os.Exit(1)
}
}