api/internal/app/handler.go

69 lines
1.3 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"
"merch-parser-api/internal/interfaces"
"net/http"
"time"
)
type App struct {
address string
2025-07-06 22:24:06 +03:00
apiPrefix string
modules []interfaces.Module
2025-07-06 17:59:18 +03:00
routerHandler interfaces.Router
router *gin.Engine
}
type Deps struct {
2025-07-06 22:24:06 +03:00
Host string
Port string
ApiPrefix string
Modules []interfaces.Module
RouterHandler interfaces.Router
2025-07-06 17:59:18 +03:00
}
func NewApp(deps Deps) *App {
app := &App{
address: deps.Host + ":" + deps.Port,
2025-07-06 22:24:06 +03:00
apiPrefix: deps.ApiPrefix,
routerHandler: deps.RouterHandler,
modules: deps.Modules,
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-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()
}()
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
}
}