treasurer/internal/app/app.go

127 lines
2.9 KiB
Go
Raw Normal View History

2023-06-13 13:22:51 +00:00
package app
import (
"context"
2023-06-19 23:19:28 +00:00
"errors"
2023-06-13 13:22:51 +00:00
"fmt"
"gitea.pena/PenaSide/common/closer"
"gitea.pena/PenaSide/common/mongo"
"gitea.pena/PenaSide/treasurer/internal/server/grpc"
"gitea.pena/PenaSide/treasurer/internal/server/http"
2023-06-13 13:22:51 +00:00
"time"
2024-12-16 13:47:40 +00:00
"gitea.pena/PenaSide/treasurer/internal/initialize"
"gitea.pena/PenaSide/treasurer/internal/worker"
"go.uber.org/zap"
2023-06-13 13:22:51 +00:00
)
func Run(ctx context.Context, config initialize.Config, logger *zap.Logger) (appErr error) {
2023-06-19 23:19:28 +00:00
defer func() {
if recovered := recover(); recovered != nil {
appErr = errors.New("recovered panic on application run")
logger.Error("recovered panic on application run", zap.Any("recovered", recovered))
}
}()
ctx, cancel := context.WithCancel(ctx)
2023-06-19 23:51:36 +00:00
defer cancel()
shutdownGroup := closer.NewCloserGroup()
mongoDB, err := mongo.Connect(ctx, &mongo.ConnectDeps{
2023-06-13 13:22:51 +00:00
Configuration: &config.Database,
Timeout: 10 * time.Second,
})
if err != nil {
return fmt.Errorf("failed connection to db: %w", err)
2023-06-13 13:22:51 +00:00
}
repositories, err := initialize.NewRepositories(initialize.RepositoriesDeps{
Logger: logger,
Database: mongoDB,
})
if err != nil {
return err
2023-06-13 13:22:51 +00:00
}
clients, err := initialize.NewClients(initialize.ClientsDeps{
Logger: logger,
Config: config,
2023-06-13 13:22:51 +00:00
})
if err != nil {
return err
2023-06-13 13:22:51 +00:00
}
services, err := initialize.NewServices(initialize.ServicesDeps{
Logger: logger,
Repositories: *repositories,
Clients: *clients,
Config: config,
2023-06-13 13:22:51 +00:00
})
if err != nil {
return err
2023-06-13 13:22:51 +00:00
}
2023-06-19 19:39:34 +00:00
workers, err := initialize.NewWorkers(initialize.WorkersDeps{
2025-06-12 08:59:43 +00:00
Logger: logger,
Service: services.Mock,
2023-06-19 19:39:34 +00:00
})
if err != nil {
return err
2023-06-19 19:39:34 +00:00
}
2023-06-13 13:22:51 +00:00
controllers, err := initialize.NewControllers(initialize.ControllersDeps{
2025-06-14 05:59:36 +00:00
Logger: logger,
Services: *services,
Repositories: *repositories,
2023-06-13 13:22:51 +00:00
})
if err != nil {
return err
2023-06-13 13:22:51 +00:00
}
httpServer := http.NewServer(http.ServerConfig{
Logger: logger,
2025-06-11 15:23:43 +00:00
Controllers: []http.Controller{controllers.YandexStatusREST, controllers.PaymentRest},
2023-06-13 13:22:51 +00:00
})
grpcServer, err := grpc.NewGRPC(logger)
2023-06-13 13:22:51 +00:00
if err != nil {
return err
2023-06-13 13:22:51 +00:00
}
grpcServer.Register(controllers.PaymentGRPC)
go func() {
if err := httpServer.Start(config.HttpURL); err != nil {
logger.Error("Client server startup error", zap.Error(err))
cancel()
}
}()
go grpcServer.Run(config.GrpcURL)
2023-06-19 19:39:34 +00:00
go worker.Run(ctx, workers)
2023-06-13 13:22:51 +00:00
httpServer.ListRoutes()
shutdownGroup.Add(closer.CloserFunc(mongoDB.Client().Disconnect))
shutdownGroup.Add(closer.CloserFunc(httpServer.Shutdown))
shutdownGroup.Add(closer.CloserFunc(grpcServer.Stop))
2023-06-13 13:22:51 +00:00
<-ctx.Done()
timeoutCtx, timeoutCancel := context.WithTimeout(context.Background(), 10*time.Second)
defer timeoutCancel()
if err := shutdownGroup.Call(timeoutCtx); err != nil {
if errors.Is(err, context.DeadlineExceeded) {
logger.Error("Shutdown timed out", zap.Error(err))
} else {
logger.Error("Failed to shutdown services gracefully", zap.Error(err))
}
return err
2023-06-13 13:22:51 +00:00
}
logger.Info("Application has stopped")
2023-06-13 13:22:51 +00:00
return nil
}