verification/internal/app/shutdown.go
2024-11-21 10:29:18 +03:00

35 lines
788 B
Go

package app
import (
"context"
"go.mongodb.org/mongo-driver/mongo"
"go.uber.org/zap"
"os"
"os/signal"
"gitea.pena/PenaSide/verification/internal/server"
"syscall"
)
func gracefulShutdown(ctx context.Context, logger *zap.Logger, httpSrvs []*server.Server, mongoDB *mongo.Database) {
interrupt := make(chan os.Signal, 1)
signal.Notify(interrupt, os.Interrupt, syscall.SIGTERM)
killSignal := <-interrupt
switch killSignal {
case os.Interrupt:
logger.Info("AppInterrupted")
case syscall.SIGTERM:
logger.Info("AppTerminated")
}
for _, srv := range httpSrvs {
if err := srv.Shutdown(ctx); err != nil {
logger.Error("HttpServerShutdown", zap.Error(err))
}
}
if err := mongoDB.Client().Disconnect(ctx); err != nil {
logger.Error("MongoDB", zap.Error(err))
}
}