A web framework for Rust.
Go to file
Matthew Pomes 02680076eb Drop Rocket inside the tokio async context when using launch
Moves error printing and the implicit drop inside the tokio runtime
when using the `#[launch]` attribute.
2024-08-23 16:29:27 -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 Drop Rocket inside the tokio async context when using launch 2024-08-23 16:29:27 -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 Strip body and content-length on 204, body on 304. 2024-08-23 16:18:48 -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
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
Cargo.toml Use workspace lints. Resolve new nightly warnings. 2024-05-20 13:39:14 -05: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

README.md

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.