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"
|
2025-06-19 07:58:09 +00:00
|
|
|
"gitea.pena/PenaSide/common/closer"
|
2025-06-03 13:31:31 +00:00
|
|
|
"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"
|
2025-06-03 13:31:31 +00:00
|
|
|
"go.uber.org/zap"
|
2023-06-13 13:22:51 +00:00
|
|
|
)
|
|
|
|
|
2025-06-03 13:31:31 +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))
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
ctx, cancel := context.WithCancel(ctx)
|
2023-06-19 23:51:36 +00:00
|
|
|
defer cancel()
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
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,
|
|
|
|
})
|
2025-06-03 13:31:31 +00:00
|
|
|
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 {
|
2025-06-03 13:31:31 +00:00
|
|
|
return err
|
2023-06-13 13:22:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
clients, err := initialize.NewClients(initialize.ClientsDeps{
|
2025-06-03 13:31:31 +00:00
|
|
|
Logger: logger,
|
|
|
|
Config: config,
|
2023-06-13 13:22:51 +00:00
|
|
|
})
|
|
|
|
if err != nil {
|
2025-06-03 13:31:31 +00:00
|
|
|
return err
|
2023-06-13 13:22:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
services, err := initialize.NewServices(initialize.ServicesDeps{
|
2025-06-03 13:31:31 +00:00
|
|
|
Logger: logger,
|
|
|
|
Repositories: *repositories,
|
|
|
|
Clients: *clients,
|
|
|
|
Config: config,
|
2023-06-13 13:22:51 +00:00
|
|
|
})
|
|
|
|
if err != nil {
|
2025-06-03 13:31:31 +00:00
|
|
|
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 {
|
2025-06-03 13:31:31 +00:00
|
|
|
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 {
|
2025-06-03 13:31:31 +00:00
|
|
|
return err
|
2023-06-13 13:22:51 +00:00
|
|
|
}
|
|
|
|
|
2025-06-03 13:31:31 +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
|
|
|
})
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
grpcServer, err := grpc.NewGRPC(logger)
|
2023-06-13 13:22:51 +00:00
|
|
|
if err != nil {
|
2025-06-03 13:31:31 +00:00
|
|
|
return err
|
2023-06-13 13:22:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
grpcServer.Register(controllers.PaymentGRPC)
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
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
|
|
|
|
2025-06-04 12:55:42 +00:00
|
|
|
httpServer.ListRoutes()
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
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()
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2025-06-03 13:31:31 +00:00
|
|
|
logger.Info("Application has stopped")
|
2023-06-13 13:22:51 +00:00
|
|
|
return nil
|
|
|
|
}
|