This commit adds support for HTTP/3 and QUIC under a disabled-by-default feature `http3-preview`. The current implementation depends on modified versions of h3 and s2n-quic-h3 which will need to be upstreamed and published before a release is possible. During the course of development various facets of Rocket's internal connection handling and recent listener APIs were improved. The complete list of changes included in this PR is: * A `shutdown` module was introduced. * `config::Shutdown` was renamed to `ShutdownConfig` and moved to `shutdown` while being re-exported from `config`. * `ListenerAddr` is now called `Endpoint`. Various methods which previously referred to "addresses" now refer to "endpoints". * `Rocket::endpoint()` was renamed to `Rocket::endpoints()` and now returns an iterator over the endpoints Rocket is listening on. * `Endpoint` acquired various query utility methods. * The `{set_}remote()` methods now take/produce `Endpoint`s. * `TlsBindable` only accepts single-phase internal interfaces. * Bind error messages include candidate endpoint info when possible. * The warning message when a secret key is not configured now includes information about its effect on private cookies. Internal changes include: * Config module tests were moved to `config/tests.rs`. * The cancellable I/O implementation was significantly simplified. * The `TripWire` implementation was simplified. * Individual shutdown stages can now be awaited on via `Stages`. * The `Shield` implementation was simplified. Resolves #2723. |
||
---|---|---|
.. | ||
chat | ||
config | ||
cookies | ||
databases | ||
error-handling | ||
fairings | ||
forms | ||
hello | ||
manual-routing | ||
pastebin | ||
responders | ||
serialization | ||
state | ||
static-files | ||
templating | ||
testing | ||
tls | ||
todo | ||
upgrade | ||
Cargo.toml | ||
README.md |
Rocket Examples
This directory contains projects showcasing Rocket's features.
Applications
-
A simple, API-only pastebin application, similar to https://paste.rs. Stores pastes locally on the file system. Implements a custom parameter guard,
PasteId
, to parse and validate paste identifiers. -
A todo app with a web UI to add, delete, and mark/unmark items. Uses a SQLite database driven by diesel. Runs migrations automatically at start-up. Uses tera to render templates.
-
A real-time, multi-room chat application using Server-Sent Events (SSE) and JavaScript's
EventSource
. Supports automatic reconnection with exponential backoff and live connection status.
Feature Examples
-
config
- Illustrates how to extract values from a RocketFigment
, how to store and retrieve an application specific configuration in managed state usingAdHoc::config()
, and how to set configuration values inRocket.toml
. -
cookies
- Uses cookies to create a client-side message box. Uses private cookies for a session-based authentication. -
databases
- Implements a CRUD-like "blog" JSON API backed by a SQLite database driven by each ofsqlx
,diesel
, andrusqlite
. Runs migrations automatically for the former two drivers. Usescontrib
database support for all drivers (rocket_db_pools
for the first;rocket_sync_db_pools
for the other latter two). -
error-handling
- Exhibits the use of scoped catchers; contains commented out lines that will cause a launch-time error with code to custom-display the error. -
fairings
- Exemplifies creating a customCounter
fairing and usingAdHoc
fairings. -
forms
- Showcases all of Rocket's form support features including multipart file uploads, ad-hoc validations, field renaming, and use of form context for staged forms. -
hello
- Basic example of Rocket's core features: route declaration with path and query parameters, both simple and compound, mounting, launching, testing, and returning simple responses. Also showcases using UTF-8 in route declarations and responses. -
manual-routing
- An example eschewing Rocket's codegen in favor of manual routing. This should be seen as last-ditch effort, much likeunsafe
in Rust, as manual routing also eschews many of Rocket's automatic web security guarantees. -
responders
- Illustrates the use of many of Rocket's built-in responders:Stream
,Redirect
,File
,NamedFile
,content
for manually setting Content-Types, andEither
. In the process, showcases usingTempFile
for raw uploads. Also illustrates the creation of a custom, derivedResponder
. -
serialization
- Showcases JSON and MessagePack (de)serialization support by implementing a CRUD-like message API in JSON and a simply read/echo API in MessagePack. Showcases UUID parsing support. -
state
- Illustrates the use of request-local state and managed state. Uses request-local state to cache "expensive" per-request operations. Uses managed state to implement a simple index hit counter. Also uses managed state to store, retrieve, and push/pop from a concurrent queue. -
static-files
- UsesFileServer
to serve static files. Also creates asecond
manual yet safe version. -
templating
- Illustrates usingcontrib
templates
support with identical examples for handlebars and tera. -
testing
- Uses Rocket'slocal
libraries to test an application. Showcases necessary use of theasync
Client
. Note that all examples contains tests, themselves serving as examples for how to test Rocket applications. -
tls
- Illustrates configuring TLS with a variety of key pair kinds. -
upgrade
- Uses the connection upgrade API to implement WebSocket support using tungstenite.