zadmin/cmd/server/main.go

52 lines
1.2 KiB
Go

package main
import (
"context"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"git.mziesel.nl/mans/zadmin/internal/config"
"git.mziesel.nl/mans/zadmin/internal/database"
"git.mziesel.nl/mans/zadmin/internal/logger"
"git.mziesel.nl/mans/zadmin/internal/server"
"github.com/nats-io/nats.go"
)
func main() {
cfg := config.LoadServerConfig()
log := logger.NewConsoleLogger()
database := database.NewDatabase(cfg.DatabaseURL, log)
natsConn, err := nats.Connect(cfg.NATSURL, nats.UserInfo(cfg.NATSUser, cfg.NATSPass))
if err != nil {
log.Fatal(err)
}
srv := server.NewServer(database, natsConn, log)
go func() {
if err := srv.Start(cfg.ListenAddress); err != nil && err != http.ErrServerClosed {
srv.Logger.Fatal(err)
}
}()
// Wait for interrupt signal to gracefully shutdown the server
sigChan := make(chan os.Signal, 1)
signal.Notify(sigChan, syscall.SIGINT, syscall.SIGTERM)
<-sigChan
// Create a context with a timeout for the shutdown
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
// Shutdown the server
if err := srv.Shutdown(ctx); err != nil {
srv.Logger.Fatal("Server forced to shutdown:", err)
}
srv.Logger.Info("Server exited gracefully")
}