// 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)) }) }) }