modified: serv_nginx/api_bb/internal/database/migrate.go
new file: serv_nginx/api_bb/internal/handlers/event_handler.go new file: serv_nginx/api_bb/internal/handlers/event_registration_handler.go modified: serv_nginx/api_bb/internal/handlers/handlers.go modified: serv_nginx/api_bb/internal/models/event.go modified: serv_nginx/api_bb/internal/routes/routes.go new file: serv_nginx/api_bb/internal/service/event_registration_service.go new file: serv_nginx/api_bb/internal/service/event_service.go new file: serv_nginx/api_bb/pkg/middleware/admin_middleware.go add admin middleware, add event and eventRegistration handlers, routes, services, EndPoints
This commit is contained in:
@@ -24,7 +24,7 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
}
|
||||
|
||||
// handler
|
||||
allHandler := handlers.NewHandler(db, config)
|
||||
h := handlers.NewHandler(db, config)
|
||||
|
||||
// Serve static files (avatars)
|
||||
r.Handle("/uploads/*", http.StripPrefix("/uploads/",
|
||||
@@ -43,8 +43,8 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
|
||||
// Health routes
|
||||
r.Route("/api", func(r chi.Router) {
|
||||
r.Get("/health", allHandler.HealthHandler().HealthCheck)
|
||||
r.Get("/check", allHandler.HealthHandler().Check)
|
||||
r.Get("/health", h.HealthHandler().HealthCheck)
|
||||
r.Get("/check", h.HealthHandler().Check)
|
||||
})
|
||||
|
||||
// API v1 routes
|
||||
@@ -52,9 +52,17 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
|
||||
// Public auth routes
|
||||
r.Route("/auth", func(r chi.Router) {
|
||||
r.Post("/register", allHandler.AuthHandler().Register)
|
||||
r.Post("/login", allHandler.AuthHandler().Login)
|
||||
r.Post("/logout", allHandler.AuthHandler().Logout)
|
||||
r.Post("/register", h.AuthHandler().Register)
|
||||
r.Post("/login", h.AuthHandler().Login)
|
||||
r.Post("/logout", h.AuthHandler().Logout)
|
||||
})
|
||||
|
||||
// Публичные маршруты для достижений (если нужны)
|
||||
r.Route("/achievements", func(r chi.Router) {
|
||||
// Публичные маршруты для просмотра достижений других пользователей
|
||||
r.Get("/user/{userID}", h.UserAchievementHandler().GetPublicUserAchievements)
|
||||
r.Get("/user/{userID}/summary", h.UserAchievementHandler().GetPublicUserAchievementsSummary)
|
||||
r.Get("/user/{userID}/recent", h.UserAchievementHandler().GetPublicRecentAchievements)
|
||||
})
|
||||
|
||||
// Protected routes
|
||||
@@ -63,70 +71,70 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
r.Use(middleware.RequireAuth)
|
||||
|
||||
// user profile routes
|
||||
r.Get("/profile", allHandler.UserHandler().GetProfile)
|
||||
r.Post("/editProfile", allHandler.UserHandler().UpdateProfile)
|
||||
r.Get("/", allHandler.UserHandler().GetUsers)
|
||||
r.Get("/profile", h.UserHandler().GetProfile)
|
||||
r.Post("/editProfile", h.UserHandler().UpdateProfile)
|
||||
r.Get("/", h.UserHandler().GetUsers)
|
||||
|
||||
// Все операции с аватарами теперь через AvatarHandler
|
||||
r.Route("/avatars", func(r chi.Router) {
|
||||
r.Post("/upload", allHandler.AvatarHandler().UploadAvatar)
|
||||
r.Delete("/delete", allHandler.AvatarHandler().DeleteAvatar)
|
||||
r.Get("/{filename}", allHandler.AvatarHandler().GetAvatar)
|
||||
r.Post("/upload", h.AvatarHandler().UploadAvatar)
|
||||
r.Delete("/delete", h.AvatarHandler().DeleteAvatar)
|
||||
r.Get("/{filename}", h.AvatarHandler().GetAvatar)
|
||||
})
|
||||
|
||||
r.Route("/stats", func(r chi.Router) {
|
||||
r.Get("/", allHandler.UserStatsHandler().GetUserStats)
|
||||
r.Get("/{userID}", allHandler.UserStatsHandler().GetUserStatsByID)
|
||||
r.Post("/workout", allHandler.UserStatsHandler().IncrementWorkout)
|
||||
r.Put("/personal-best", allHandler.UserStatsHandler().UpdatePersonalBest)
|
||||
r.Post("/weekly/reset", allHandler.UserStatsHandler().ResetWeeklyDistance)
|
||||
r.Post("/monthly/reset", allHandler.UserStatsHandler().ResetMonthlyDistance)
|
||||
r.Get("/", h.UserStatsHandler().GetUserStats)
|
||||
r.Get("/{userID}", h.UserStatsHandler().GetUserStatsByID)
|
||||
r.Post("/workout", h.UserStatsHandler().IncrementWorkout)
|
||||
r.Put("/personal-best", h.UserStatsHandler().UpdatePersonalBest)
|
||||
r.Post("/weekly/reset", h.UserStatsHandler().ResetWeeklyDistance)
|
||||
r.Post("/monthly/reset", h.UserStatsHandler().ResetMonthlyDistance)
|
||||
})
|
||||
|
||||
// Маршруты для тренировок
|
||||
r.Route("/workouts", func(r chi.Router) {
|
||||
r.Post("/", allHandler.UserWorkoutHandler().CreateWorkout)
|
||||
r.Get("/", allHandler.UserWorkoutHandler().GetWorkouts)
|
||||
r.Get("/stats", allHandler.UserWorkoutHandler().GetWorkoutStats)
|
||||
r.Get("/type/{type}", allHandler.UserWorkoutHandler().GetWorkoutsByType)
|
||||
|
||||
r.Post("/", h.UserWorkoutHandler().CreateWorkout)
|
||||
r.Get("/", h.UserWorkoutHandler().GetWorkouts)
|
||||
r.Get("/stats", h.UserWorkoutHandler().GetWorkoutStats)
|
||||
r.Get("/type/{type}", h.UserWorkoutHandler().GetWorkoutsByType)
|
||||
|
||||
r.Route("/{id}", func(r chi.Router) {
|
||||
r.Get("/", allHandler.UserWorkoutHandler().GetWorkoutByID)
|
||||
r.Put("/", allHandler.UserWorkoutHandler().UpdateWorkout)
|
||||
r.Delete("/", allHandler.UserWorkoutHandler().DeleteWorkout)
|
||||
r.Get("/", h.UserWorkoutHandler().GetWorkoutByID)
|
||||
r.Put("/", h.UserWorkoutHandler().UpdateWorkout)
|
||||
r.Delete("/", h.UserWorkoutHandler().DeleteWorkout)
|
||||
})
|
||||
})
|
||||
|
||||
// Маршруты для достижений (achievements)
|
||||
r.Route("/achievements", func(r chi.Router) {
|
||||
// Создание нового достижения
|
||||
r.Post("/", allHandler.UserAchievementHandler().CreateAchievement)
|
||||
|
||||
r.Post("/", h.UserAchievementHandler().CreateAchievement)
|
||||
|
||||
// Получение всех достижений пользователя
|
||||
r.Get("/", allHandler.UserAchievementHandler().GetUserAchievements)
|
||||
|
||||
r.Get("/", h.UserAchievementHandler().GetUserAchievements)
|
||||
|
||||
// Получение сводки по достижениям
|
||||
r.Get("/summary", allHandler.UserAchievementHandler().GetUserAchievementsSummary)
|
||||
|
||||
r.Get("/summary", h.UserAchievementHandler().GetUserAchievementsSummary)
|
||||
|
||||
// Получение последних достижений (с опциональным лимитом)
|
||||
r.Get("/recent", allHandler.UserAchievementHandler().GetRecentAchievements)
|
||||
|
||||
r.Get("/recent", h.UserAchievementHandler().GetRecentAchievements)
|
||||
|
||||
// Получение достижений по типу
|
||||
r.Get("/type/{type}", allHandler.UserAchievementHandler().GetAchievementsByType)
|
||||
|
||||
r.Get("/type/{type}", h.UserAchievementHandler().GetAchievementsByType)
|
||||
|
||||
// Операции с конкретным достижением
|
||||
r.Route("/{id}", func(r chi.Router) {
|
||||
// Получение достижения по ID
|
||||
r.Get("/", allHandler.UserAchievementHandler().GetAchievementByID)
|
||||
|
||||
r.Get("/", h.UserAchievementHandler().GetAchievementByID)
|
||||
|
||||
// Обновление достижения
|
||||
r.Put("/", allHandler.UserAchievementHandler().UpdateAchievement)
|
||||
|
||||
r.Put("/", h.UserAchievementHandler().UpdateAchievement)
|
||||
|
||||
// Удаление достижения
|
||||
r.Delete("/", allHandler.UserAchievementHandler().DeleteAchievement)
|
||||
|
||||
r.Delete("/", h.UserAchievementHandler().DeleteAchievement)
|
||||
|
||||
// Подтверждение достижения
|
||||
r.Patch("/verify", allHandler.UserAchievementHandler().VerifyAchievement)
|
||||
r.Patch("/verify", h.UserAchievementHandler().VerifyAchievement)
|
||||
})
|
||||
})
|
||||
})
|
||||
@@ -134,10 +142,10 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
r.Route("/news", func(r chi.Router) {
|
||||
|
||||
// Публичные маршруты
|
||||
r.Get("/", allHandler.NewsHandler().GetNews)
|
||||
r.Get("/{id}", allHandler.NewsHandler().GetNewsByID)
|
||||
r.Get("/{id}/comments", allHandler.NewsHandler().GetComments)
|
||||
r.Get("/check", allHandler.HealthHandler().Check)
|
||||
r.Get("/", h.NewsHandler().GetNews)
|
||||
r.Get("/{id}", h.NewsHandler().GetNewsByID)
|
||||
r.Get("/{id}/comments", h.NewsHandler().GetComments)
|
||||
r.Get("/check", h.HealthHandler().Check)
|
||||
|
||||
// Защищенные маршруты
|
||||
r.Group(func(r chi.Router) {
|
||||
@@ -145,44 +153,77 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
r.Use(middleware.RequireAuth)
|
||||
|
||||
// News EndPoints
|
||||
r.Post("/", allHandler.NewsHandler().CreateNews)
|
||||
r.Put("/{id}", allHandler.NewsHandler().UpdateNews)
|
||||
r.Delete("/{id}", allHandler.NewsHandler().DeleteNews)
|
||||
r.Get("/my/news", allHandler.NewsHandler().GetUserNews)
|
||||
r.Post("/", h.NewsHandler().CreateNews)
|
||||
r.Put("/{id}", h.NewsHandler().UpdateNews)
|
||||
r.Delete("/{id}", h.NewsHandler().DeleteNews)
|
||||
r.Get("/my/news", h.NewsHandler().GetUserNews)
|
||||
|
||||
r.Post("/{id}/comments", allHandler.NewsHandler().CreateComment)
|
||||
r.Delete("/comments/{commentId}", allHandler.NewsHandler().DeleteComment)
|
||||
r.Post("/{id}/comments", h.NewsHandler().CreateComment)
|
||||
r.Delete("/comments/{commentId}", h.NewsHandler().DeleteComment)
|
||||
|
||||
r.Get("/check", allHandler.HealthHandler().Check)
|
||||
r.Get("/check", h.HealthHandler().Check)
|
||||
})
|
||||
})
|
||||
|
||||
// Маршруты для отзывов
|
||||
r.Route("/reviews", func(r chi.Router) {
|
||||
// Публичные маршруты
|
||||
r.Get("/", allHandler.ReviewHandler().GetReviews)
|
||||
r.Get("/stats", allHandler.ReviewHandler().GetReviewsStats)
|
||||
r.Get("/{id}", allHandler.ReviewHandler().GetReviewByID)
|
||||
r.Get("/", h.ReviewHandler().GetReviews)
|
||||
r.Get("/stats", h.ReviewHandler().GetReviewsStats)
|
||||
r.Get("/{id}", h.ReviewHandler().GetReviewByID)
|
||||
|
||||
// Защищенные маршруты
|
||||
r.Group(func(r chi.Router) {
|
||||
r.Use(middleware.AuthMiddleware(jwtService, userRepo))
|
||||
r.Use(middleware.RequireAuth)
|
||||
|
||||
r.Post("/", allHandler.ReviewHandler().CreateReview)
|
||||
r.Get("/my", allHandler.ReviewHandler().GetMyReviews)
|
||||
r.Put("/{id}", allHandler.ReviewHandler().UpdateReview)
|
||||
r.Delete("/{id}", allHandler.ReviewHandler().DeleteReview)
|
||||
r.Post("/", h.ReviewHandler().CreateReview)
|
||||
r.Get("/my", h.ReviewHandler().GetMyReviews)
|
||||
r.Put("/{id}", h.ReviewHandler().UpdateReview)
|
||||
r.Delete("/{id}", h.ReviewHandler().DeleteReview)
|
||||
})
|
||||
})
|
||||
|
||||
// Публичные маршруты для достижений (если нужны)
|
||||
r.Route("/achievements", func(r chi.Router) {
|
||||
// Публичные маршруты для просмотра достижений других пользователей
|
||||
r.Get("/user/{userID}", allHandler.UserAchievementHandler().GetPublicUserAchievements)
|
||||
r.Get("/user/{userID}/summary", allHandler.UserAchievementHandler().GetPublicUserAchievementsSummary)
|
||||
r.Get("/user/{userID}/recent", allHandler.UserAchievementHandler().GetPublicRecentAchievements)
|
||||
r.Route("/events", func(r chi.Router) {
|
||||
|
||||
// Публичные маршруты
|
||||
r.Get("/", h.EventHandler().GetAllEvents)
|
||||
r.Get("/upcoming", h.EventHandler().GetUpcomingEvents)
|
||||
r.Get("/type/{type}", h.EventHandler().GetEventsByType)
|
||||
r.Get("/{id}", h.EventHandler().GetEvent)
|
||||
r.Get("/{eventId}/availability", h.EventRegistrationHandler().CheckEventAvailability)
|
||||
|
||||
// Защищенные маршруты (требуют аутентификации)
|
||||
r.Group(func(r chi.Router) {
|
||||
r.Use(middleware.AuthMiddleware(jwtService, userRepo))
|
||||
r.Use(middleware.RequireAuth)
|
||||
|
||||
// Регистрации пользователя
|
||||
r.Post("/register", h.EventRegistrationHandler().RegisterForEvent)
|
||||
r.Get("/my/registrations", h.EventRegistrationHandler().GetUserRegistrations)
|
||||
r.Delete("/registrations/{id}", h.EventRegistrationHandler().CancelRegistration)
|
||||
r.Get("/registrations/{id}", h.EventRegistrationHandler().GetRegistration)
|
||||
})
|
||||
|
||||
// Админские маршруты
|
||||
r.Group(func(r chi.Router) {
|
||||
r.Use(middleware.AuthMiddleware(jwtService, userRepo))
|
||||
r.Use(middleware.RequireAuth)
|
||||
r.Use(middleware.AdminMiddleware)
|
||||
|
||||
// Управление событиями
|
||||
r.Post("/", h.EventHandler().CreateEvent)
|
||||
r.Put("/{id}", h.EventHandler().UpdateEvent)
|
||||
r.Delete("/{id}", h.EventHandler().DeleteEvent)
|
||||
r.Patch("/{id}/registration-status", h.EventHandler().ToggleRegistrationStatus)
|
||||
|
||||
// Управление регистрациями
|
||||
r.Get("/{eventId}/registrations", h.EventRegistrationHandler().GetEventRegistrations)
|
||||
r.Patch("/registrations/{id}/status", h.EventRegistrationHandler().UpdateRegistrationStatus)
|
||||
r.Patch("/registrations/{id}/result-time", h.EventRegistrationHandler().UpdateResultTime)
|
||||
})
|
||||
})
|
||||
|
||||
})
|
||||
|
||||
// Логируем все зарегистрированные маршруты
|
||||
@@ -190,4 +231,4 @@ func SetupRouter(db *gorm.DB, config *config.Config) http.Handler {
|
||||
routeLogger.LogRoutes(r)
|
||||
|
||||
return r
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user