| Crates.io | goose-http |
| lib.rs | goose-http |
| version | 0.1.0 |
| created_at | 2025-11-03 21:26:11.390865+00 |
| updated_at | 2025-11-03 21:26:11.390865+00 |
| description | HTTP/1.1 server for Rust implementing RFC 9110/9111/9112 semantics, caching, and range handling |
| homepage | |
| repository | https://github.com/goosewin/goose-http |
| max_upload_size | |
| id | 1915295 |
| size | 191,295 |
Goose HTTP is a from-scratch implementation of an HTTP/1.1 server written in Rust. It adheres to the 2022 HTTPbis specification split:
The project is intentionally minimal but complete—it implements message framing, request parsing, conditional requests, Range handling, caching semantics, connection management, and a fully asynchronous runtime using Tokio.
cargo for building and runningcargo build
cargo run --bin compliance_harness -- --help
The compliance harness binds to 127.0.0.1:18080 by default and exposes sample
routes that exercise validators, range requests, and caching semantics. It is
used to drive the conformance suites under scripts/compliance/.
cargo test
Unit tests cover parsers, caching helpers, and range utilities. Integration
tests in tests/http_flow.rs spin up the server to verify Expect: 100-continue, pipelined responses, and multi-range responses end-to-end.
src/conn/: Connection state machine, keep-alive & pipelining logic, timeout
handling, conditional request evaluation.src/parse/: Request-line, header parsing, and body framing (Content-Length &
chunked) strictly following RFC 9112.src/encode/: Response serialization including chunked transfer-coding,
trailers, and mandatory headers (Date, Connection).src/cache/: Cache-Control parsing, freshness calculations, Age defaults.src/range/: Range header parsing and satisfiable range computation.src/request/ & src/response/: Typed representations of HTTP messages with
convenience builders.src/server/: Tokio accept loop, connection orchestration, configurable
timeouts and structured logging.src/log/: Tracing-based logging façade with lazy initialisation.src/bin/compliance_harness.rs: Compliance test harness used for automated
suites.Logging is powered by the tracing crate.
Call goose_http::log::init() once during application startup (the demo binary
does this automatically). Environment-based filtering is supported via
RUST_LOG.
This project is released under the CC0-1.0 license. See LICENSE for details.