A web framework for Rust.
Go to file
Sergio Benitez 327b1ad064 Allow sync drops for 'sync_db_pools' connections.
Prior to this commit, connections from 'sync_db_pools' assumed that they
were being dropped in an async context. This is overwhelmingly the
common case as connections are typically dropped immediately after
request processing. Nothing requires this, however, so holding a
connection beyond the scope of the async context was possible (i.e. by
storing a connection in managed state). Given the connection's `Drop`
impl calls `spawn_blocking`, this resulted in a panic on drop.

This commit resolves the issue by modifying `Drop` so that it calls
`spawn_blocking` only when it is executing inside an async context. If
not, the connection is dropped normally, without `spawn_blocking`.
2024-08-18 20:03:01 -07:00
.github Fix Windows CI: update vcpkg dependency bundle. 2024-08-16 02:24:20 -07:00
benchmarks Finalize 'tracing' migration. 2024-06-03 15:02:44 -07:00
contrib Allow sync drops for 'sync_db_pools' connections. 2024-08-18 20:03:01 -07:00
core Fix various docstring typos. 2024-08-17 19:37:19 -07:00
docs Fix wrong URL in guide (configuration) 2024-08-07 21:36:52 -05:00
examples Update 'h3' and 's2n_quic' dependencies. 2024-08-16 16:12:12 -07:00
scripts Add '--help' flag to testing script. 2024-08-09 22:22:25 -07:00
testbench Fix support for HTTP extension methods. 2024-08-17 04:25:49 -07:00
.gitattributes Reorganize and upgrade markup in site docs. 2024-02-28 23:41:02 -08:00
.gitignore Add sqlite aux files to gitignore. 2022-02-23 13:53:26 -08:00
.rustfmt.toml Add '.rustfmt.toml' disabling formatting. 2023-11-28 10:22:22 +01:00
Cargo.toml Use workspace lints. Resolve new nightly warnings. 2024-05-20 13:39:14 -05:00
CHANGELOG.md Add 0.5.1 CHANGELOG entry. 2024-05-23 15:48:35 -05:00
CONTRIBUTING.md Add CONTRIBUTING and update README accordingly. 2024-08-17 19:09:55 -07:00
LICENSE-APACHE Update copyright in LICENSE files. 2020-06-03 23:02:05 -07:00
LICENSE-MIT Update copyright in LICENSE files. 2020-06-03 23:02:05 -07:00
README.md Add CONTRIBUTING and update README accordingly. 2024-08-17 19:09:55 -07:00

Rocket

Build Status Rocket Homepage Current Crates.io Version Matrix: #rocket:mozilla.org

Rocket is an async web framework for Rust with a focus on usability, security, extensibility, and speed.

#[macro_use] extern crate rocket;

#[get("/<name>/<age>")]
fn hello(name: &str, age: u8) -> String {
    format!("Hello, {} year old named {}!", age, name)
}

#[launch]
fn rocket() -> _ {
    rocket::build().mount("/hello", routes![hello])
}

Visiting localhost:8000/hello/John/58, for example, will trigger the hello route resulting in the string Hello, 58 year old named John! being sent to the browser. If an <age> string was passed in that can't be parsed as a u8, the route won't get called, resulting in a 404 error.

Documentation

Rocket is extensively documented:

Documentation for the master branch is available at https://rocket.rs/master and https://api.rocket.rs/master.

Documentation for major release version ${x} is available at https://[api.]rocket.rs/v${x}. For example, the v0.4 docs are available at https://rocket.rs/v0.4 and https://api.rocket.rs/v0.4.

Finally, API docs for active git branches are available at https://api.rocket.rs/${branch}. For example, API docs for the master branch are available at https://api.rocket.rs/master. Branch rustdocs are built and deployed on every commit.

Examples

The examples directory contains complete crates that showcase Rocket's features and usage. Each example can be compiled and run with Cargo. For instance, the following sequence of commands builds and runs the hello example:

cd examples/hello
cargo run

Getting Help

If you find yourself needing help outside of the documentation, you may:

Contributing

Contributions are absolutely, positively welcomed and encouraged! If you're interested in contributing code, please first read CONTRIBUTING for complete guidelines. Additionally, you could:

  1. Submit a feature request or bug report as an issue.
  2. Ask for improved documentation as an issue.
  3. Comment on issues that require feedback.
  4. Answers questions in GitHub discussions questions.
  5. Share a project in GitHub discussions show & tell.

License

Rocket is licensed under either of the following, at your option:

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Rocket by you shall be dual licensed under the MIT License and Apache License, Version 2.0, without any additional terms or conditions.

The Rocket website docs are licensed under separate terms. Any contribution intentionally submitted for inclusion in the Rocket website docs by you shall be licensed under those terms.