slack5-1770544098/services/preferences-api/internal/api/routes.go
rdev-worker a31f57382b
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
build: /implement-feature user-preferences
2026-02-08 10:47:23 +00:00

47 lines
1.6 KiB
Go

// Package api provides HTTP routing and handlers for the preferences-api service.
package api
import (
"git.threesix.ai/jordan/slack5-1770544098/pkg/app"
"git.threesix.ai/jordan/slack5-1770544098/pkg/auth"
"git.threesix.ai/jordan/slack5-1770544098/services/preferences-api/internal/api/handlers"
"git.threesix.ai/jordan/slack5-1770544098/services/preferences-api/internal/config"
"git.threesix.ai/jordan/slack5-1770544098/services/preferences-api/internal/service"
)
// RegisterRoutes registers all HTTP routes for the service.
// Routes are mounted under /api/preferences-api to match the ingress path routing.
func RegisterRoutes(application *app.App, preferencesService *service.PreferencesService) {
logger := application.Logger()
cfg := config.Load()
// Initialize handlers with injected services
healthHandler := handlers.NewHealth(logger)
prefHandler := handlers.NewPreferences(preferencesService, logger)
// Build and mount OpenAPI spec
spec := NewServiceSpec()
application.EnableDocs(spec)
// Register API routes under /api/{service-name} to match ingress path routing.
application.Route("/api/preferences-api", func(r app.Router) {
r.Get("/health", healthHandler.Check)
// Protected routes (auth required when enabled)
r.Group(func(r app.Router) {
if cfg.AuthEnabled {
r.Use(auth.Middleware(auth.MiddlewareConfig{
Validator: auth.NewJWTValidator(auth.JWTConfig{
Secret: []byte(cfg.JWTSecret),
Issuer: "slack5-1770544098",
}),
}))
}
// Preferences endpoints
r.Get("/preferences/{user_id}", app.Wrap(prefHandler.Get))
r.Put("/preferences/{user_id}", app.Wrap(prefHandler.Update))
})
})
}