package main import ( "context" "os" "os/signal" "syscall" "time" "github.com/rs/zerolog/log" "route256/notifier/internal/app" ) func main() { srv, err := app.NewApp(os.Getenv("CONFIG_FILE")) if err != nil { log.Fatal().Err(err).Msg("failed creating app") } ctx, stop := signal.NotifyContext(context.Background(), syscall.SIGINT, syscall.SIGTERM) defer stop() srv.Run(ctx) <-ctx.Done() log.Info().Msg("shutdown signal received") shutdownCtx, cancel := context.WithTimeout(context.Background(), 10*time.Second) defer cancel() if err := srv.Shutdown(shutdownCtx); err != nil { log.Error().Err(err).Msg("graceful shutdown failed") } else { log.Info().Msg("server stopped gracefully") } }