api/internal/app/handler.go

102 lines
2.2 KiB
Go
Raw Normal View History

2025-07-06 17:59:18 +03:00
package app
import (
"context"
"github.com/gin-gonic/gin"
log "github.com/sirupsen/logrus"
2025-10-01 19:32:56 +03:00
"google.golang.org/grpc"
2025-07-06 17:59:18 +03:00
"merch-parser-api/internal/interfaces"
2025-10-01 19:32:56 +03:00
"net"
2025-07-06 17:59:18 +03:00
"net/http"
"time"
)
type App struct {
2025-10-01 19:32:56 +03:00
host string
address string
apiPrefix string
modules []interfaces.Module
routerHandler interfaces.Router
router *gin.Engine
grpcServer *grpc.Server
grpcServerPort string
grpcClientPort string
2025-07-06 17:59:18 +03:00
}
type Deps struct {
2025-10-01 19:32:56 +03:00
Host string
Port string
ApiPrefix string
Modules []interfaces.Module
RouterHandler interfaces.Router
GrpcServer *grpc.Server
GrpcServerPort string
GrpcClientPort string
2025-07-06 17:59:18 +03:00
}
func NewApp(deps Deps) *App {
app := &App{
2025-10-01 19:32:56 +03:00
host: deps.Host,
address: deps.Host + ":" + deps.Port,
apiPrefix: deps.ApiPrefix,
routerHandler: deps.RouterHandler,
modules: deps.Modules,
grpcServer: deps.GrpcServer,
grpcServerPort: deps.GrpcServerPort,
grpcClientPort: deps.GrpcClientPort,
2025-07-06 17:59:18 +03:00
}
app.router = app.routerHandler.Set()
2025-07-06 22:24:06 +03:00
apiRoutes := app.router.Group(app.apiPrefix)
apiRoutes.GET("/", func(c *gin.Context) {
c.String(http.StatusOK, "API is ready")
})
2025-09-10 22:00:11 +03:00
for _, m := range app.modules {
if hasRoutes, ok := m.(interfaces.ModuleRoutes); ok {
2025-09-14 19:33:09 +03:00
hasRoutes.RegisterRoutes(apiRoutes, app.routerHandler.AuthMW(), app.routerHandler.RefreshMW())
2025-09-10 22:00:11 +03:00
}
}
2025-07-06 17:59:18 +03:00
return app
}
func (a *App) Run(ctx context.Context) error {
server := &http.Server{
Addr: a.address,
Handler: a.router,
}
serverErr := make(chan error, 1)
go func() {
log.Info("Starting server on: ", a.address)
serverErr <- server.ListenAndServe()
}()
2025-10-01 19:32:56 +03:00
go func() {
listener, err := net.Listen("tcp", net.JoinHostPort(a.host, a.grpcServerPort))
if err != nil {
log.WithField("err", err).Fatal("gRPC Server | Listener")
}
err = a.grpcServer.Serve(listener)
if err != nil {
log.WithField("err", err).Fatal("gRPC Server | Serve")
}
}()
log.Info("Starting gRPC server on port: ", a.grpcServerPort)
2025-07-06 17:59:18 +03:00
select {
case <-ctx.Done():
log.Info("Shutting down server")
shutdownCtx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
return server.Shutdown(shutdownCtx)
case err := <-serverErr:
return err
}
}