api/cmd/main.go

103 lines
2.4 KiB
Go
Raw Normal View History

2025-07-06 17:59:18 +03:00
package main
import (
"context"
log "github.com/sirupsen/logrus"
"merch-parser-api/config"
2025-07-06 22:24:06 +03:00
_ "merch-parser-api/docs" //for swagger
2025-09-18 17:09:39 +03:00
"merch-parser-api/internal/api/merch"
2025-07-06 22:24:06 +03:00
"merch-parser-api/internal/api/user"
2025-07-06 17:59:18 +03:00
"merch-parser-api/internal/app"
2025-07-06 22:24:06 +03:00
"merch-parser-api/internal/interfaces"
2025-07-07 17:49:09 +03:00
"merch-parser-api/internal/provider/auth"
"merch-parser-api/internal/provider/token"
2025-07-06 17:59:18 +03:00
"merch-parser-api/internal/router"
"merch-parser-api/pkg/db"
2025-07-06 22:24:06 +03:00
"merch-parser-api/pkg/utils"
2025-07-06 17:59:18 +03:00
)
2025-07-06 22:24:06 +03:00
// @Title Merch Parser
// @BasePath /api/v2
2025-07-07 17:49:09 +03:00
// @Version 2.0.0-alpha
2025-07-06 22:24:06 +03:00
// @SecurityDefinitions.apikey BearerAuth
// @In header
// @Name Authorization
2025-07-07 17:49:09 +03:00
// @Description Введите "Bearer {your_token}" для аутентификации
2025-07-06 17:59:18 +03:00
func main() {
2025-07-07 17:49:09 +03:00
log.Debug("Starting merch-parser-api")
2025-07-06 17:59:18 +03:00
//setup config
//c := config.NewConfig()
c := config.DevConfig()
ctx := context.Background()
2025-07-07 17:49:09 +03:00
//log level
config.LogSetup(c.AppConf.LogLvl)
2025-07-06 17:59:18 +03:00
database, err := db.Connection(c)
if err != nil {
log.WithError(err).Fatal("Main | Error connecting to database")
}
2025-07-07 17:49:09 +03:00
//base providers
jwtProvider := token.NewJWT(token.Deps{
SecretKey: c.JWTConf.Secret,
Issuer: c.JWTConf.Issuer,
AccessExpire: c.JWTConf.AccessExpire,
RefreshExpire: c.JWTConf.RefreshExpire,
})
log.Debug("JWT provider initialized")
2025-07-06 17:59:18 +03:00
2025-07-07 17:49:09 +03:00
utilsProvider := utils.NewUtils()
log.Debug("Utils provider initialized")
//deps providers
2025-07-06 17:59:18 +03:00
routerHandler := router.NewRouter(router.Deps{
2025-09-29 21:49:25 +03:00
ApiPrefix: c.AppConf.ApiPrefix,
GinMode: c.AppConf.GinMode,
TokenProv: jwtProvider,
AllowedOrigins: c.AppConf.AllowedOrigins,
2025-07-06 17:59:18 +03:00
})
2025-07-07 17:49:09 +03:00
log.Debug("Router handler initialized")
2025-07-06 17:59:18 +03:00
2025-07-07 17:49:09 +03:00
authProvider := auth.NewHandler(auth.Deps{
DB: database,
JwtProvider: jwtProvider,
Utils: utilsProvider,
})
log.Debug("Auth provider initialized")
2025-07-06 22:24:06 +03:00
//register app modules
users := user.NewHandler(user.Deps{
2025-09-10 23:28:35 +03:00
Auth: authProvider,
DB: database,
Utils: utilsProvider,
ApiPrefix: c.AppConf.ApiPrefix,
2025-07-06 22:24:06 +03:00
})
2025-09-18 17:09:39 +03:00
merchModule := merch.NewHandler(merch.Deps{
DB: database,
Utils: utilsProvider,
})
2025-07-06 22:24:06 +03:00
//collect modules
modules := []interfaces.Module{
users,
2025-09-18 17:09:39 +03:00
merchModule,
2025-07-06 22:24:06 +03:00
}
2025-07-06 17:59:18 +03:00
//keep last
appl := app.NewApp(app.Deps{
2025-07-06 22:24:06 +03:00
Host: c.AppConf.Host,
Port: c.AppConf.Port,
ApiPrefix: c.AppConf.ApiPrefix,
RouterHandler: routerHandler,
Modules: modules,
2025-07-06 17:59:18 +03:00
})
err = appl.Run(ctx)
if err != nil {
log.WithError(err).Fatal("Main | Error starting app")
return
}
}