main.go 897 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. package main
  2. import (
  3. "context"
  4. "flag"
  5. "os"
  6. "os/signal"
  7. "syscall"
  8. "realtime-gateway/internal/config"
  9. "realtime-gateway/internal/gateway"
  10. "realtime-gateway/internal/logging"
  11. )
  12. func main() {
  13. configPath := flag.String("config", "./config/dev.json", "path to config file")
  14. flag.Parse()
  15. cfg, err := config.Load(*configPath)
  16. if err != nil {
  17. panic(err)
  18. }
  19. logger := logging.New()
  20. app, err := gateway.NewServer(cfg, logger)
  21. if err != nil {
  22. logger.Error("failed to create server", "error", err)
  23. os.Exit(1)
  24. }
  25. ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt, syscall.SIGTERM)
  26. defer stop()
  27. errCh := make(chan error, 1)
  28. go func() {
  29. errCh <- app.Run(ctx)
  30. }()
  31. select {
  32. case <-ctx.Done():
  33. logger.Info("shutdown signal received")
  34. case err := <-errCh:
  35. if err != nil {
  36. logger.Error("server stopped with error", "error", err)
  37. os.Exit(1)
  38. }
  39. }
  40. }