Files
fn_registry/functions/infra/http_logger_middleware.md
T
egutierrez b074313c01 feat: funciones impuras HTTP — response, parse, logger, router, serve
Seis funciones de servidor HTTP con tests usando httptest:
- HTTPJSONResponse: escribe JSON con Content-Type y status code
- HTTPErrorResponse: escribe HTTPError como JSON estructurado
- HTTPParseBody: decode JSON con limite de bytes y campos estrictos
- HTTPLoggerMiddleware: loguea method/path/status/duration a io.Writer
- HTTPRouter: crea ServeMux con rutas Go 1.22+ (METHOD /path)
- HTTPServe: ListenAndServe con graceful shutdown por contexto

23 tests pasando, solo stdlib net/http.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-13 01:57:47 +02:00

1.5 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports params output tested tests test_file_path file_path
http_logger_middleware function go infra 1.0.0 impure func HTTPLoggerMiddleware(logger io.Writer) Middleware Retorna un Middleware que loguea metodo, path, status code y duracion de cada request HTTP. El formato es: METHOD /path STATUS DURACIONms
http
logger
middleware
logging
server
infra
Middleware_go_infra
Middleware_go_infra
false error_go_core
fmt
io
net/http
time
name desc
logger io.Writer donde se escriben las lineas de log (ej: os.Stderr, un archivo, bytes.Buffer)
Middleware que intercepta cada request, llama al siguiente handler, y loguea los detalles al terminar true
loguea metodo y path del request
loguea el status code de la respuesta
loguea la duracion en milisegundos
functions/infra/http_server_test.go functions/infra/http_logger_middleware.go

Ejemplo

logger := HTTPLoggerMiddleware(os.Stderr)
chain := HTTPMiddlewareChain(logger)
// Cada request imprime: GET /api/users 200 5ms
http.ListenAndServe(":8080", chain(mux))

Notas

Captura el status code con un responseWriter envolvente que intercepta WriteHeader. Si el handler no llama WriteHeader explicitamente, el status por defecto es 200. El logger recibe cualquier io.Writer — util para tests usando bytes.Buffer o para escribir a archivos de log.