refactor(api): restructured API for type safety, maintainability and docs generation

- These changes makes the API incombatible with previous versions
- Added new types for error handling, success responses, and health checks.
- Updated health check logic to utilize the new types for better clarity and structure.
- Refactored existing handlers to improve response consistency and error handling.
- Updated Makefile to include a new target for generating API types from Swagger.
- Updated "new agent" API to respond an encrypted cert pair
This commit is contained in:
yusing
2025-08-16 13:04:05 +08:00
parent fce9ce21c9
commit 35a3e3fef6
149 changed files with 13173 additions and 2173 deletions

View File

@@ -4,18 +4,20 @@ import (
"context"
"net/http"
"net/url"
"github.com/yusing/go-proxy/internal/types"
)
type RouteContext struct{}
var routeContextKey = RouteContext{}
func WithRouteContext(r *http.Request, route HTTPRoute) *http.Request {
func WithRouteContext(r *http.Request, route types.HTTPRoute) *http.Request {
return r.WithContext(context.WithValue(r.Context(), routeContextKey, route))
}
func TryGetRoute(r *http.Request) HTTPRoute {
if route, ok := r.Context().Value(routeContextKey).(HTTPRoute); ok {
func TryGetRoute(r *http.Request) types.HTTPRoute {
if route, ok := r.Context().Value(routeContextKey).(types.HTTPRoute); ok {
return route
}
return nil