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:
2025-10-19 10:54:45 +05:00
parent a36b0aa933
commit 6422d85727
9 changed files with 1907 additions and 163 deletions
+109 -68
View File
@@ -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
}
}