50 lines
1.1 KiB
Go
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)
|
|
}
|
|
}
|