feat: initial commit
This commit is contained in:
49
cmd/clearcase/main.go
Normal file
49
cmd/clearcase/main.go
Normal file
@ -0,0 +1,49 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"context"
|
||||
"log/slog"
|
||||
"os"
|
||||
"os/signal"
|
||||
|
||||
"forge.cadoles.com/wpetit/clearcase/internal/config"
|
||||
"forge.cadoles.com/wpetit/clearcase/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)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user