1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2024-12-16 21:26:34 +00:00
Actix Web is a powerful, pragmatic, and extremely fast web framework for Rust.
Find a file
Jens Reimann 1c703ac1d4 Allow using Option<Middleware> to enable/disable a middleware
Currently, there is `Condition`, which accepts a boolean
(to enable/disable) and an instance to the actual middleware.
The downside of that is, that such a middleware needs to be constructed
in any case. Even if the middleware is used or not.

However, the middleware is not used when it is disabled. Only the type
seems required. So this PR adds a `from_option` function, which allows
passing in an `Option` instead of boolean and instance. If the option
"is some" it is enabled. Otherwise, not.
2022-06-29 16:49:58 +02:00
.cargo add macro feature (#2619) 2022-02-01 02:35:05 +00:00
.github Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-files Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-http Expose option for setting TLS handshake timeout (#2752) 2022-06-27 02:57:21 +00:00
actix-http-test Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-multipart Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-router Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-test Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
actix-web Allow using Option<Middleware> to enable/disable a middleware 2022-06-29 16:49:58 +02:00
actix-web-actors Improve documentation for actix-web-actors (#2788) 2022-06-26 16:45:02 +00:00
actix-web-codegen Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
awc Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
docs/graphs bump actix-codec to 0.5 2022-02-15 20:49:10 +00:00
scripts fix workers doc 2022-02-08 06:58:33 +00:00
.gitignore Various refactorings (#2281) 2021-06-26 15:33:43 +01:00
.prettierrc.json update 4.0 migration guide 2022-02-02 03:42:07 +00:00
Cargo.toml fix vmanifest 2022-02-01 00:33:41 +00:00
CHANGES.md prepare releases: actix-http 3.0.0 and actix-web 4.0.0 (#2663) 2022-02-25 18:46:35 +00:00
clippy.toml Bump up MSRV to 1.57 (#2789) 2022-06-22 12:08:06 +01:00
CODE_OF_CONDUCT.md use dash hyphenation in markdown 2021-12-22 08:21:30 +00:00
codecov.yml migrate integration testing to new crate (#2112) 2021-04-02 08:26:59 +01:00
LICENSE-APACHE the big three point oh (#1668) 2020-09-11 13:50:10 +01:00
LICENSE-MIT update year in MIT license (#2143) 2021-04-09 01:28:35 +01:00
README.md move actix-web to own dir 2022-02-01 00:30:41 +00:00
rustfmt.toml change rustfmt line width to 96 2021-02-11 23:03:17 +00:00

Actix Web

Actix Web is a powerful, pragmatic, and extremely fast web framework for Rust

crates.io Documentation MSRV MIT or Apache 2.0 licensed Dependency Status
CI codecov downloads Chat on Discord

Features

  • Supports HTTP/1.x and HTTP/2
  • Streaming and pipelining
  • Powerful request routing with optional macros
  • Full Tokio compatibility
  • Keep-alive and slow requests handling
  • Client/server WebSockets support
  • Transparent content compression/decompression (br, gzip, deflate, zstd)
  • Multipart streams
  • Static assets
  • SSL support using OpenSSL or Rustls
  • Middlewares (Logger, Session, CORS, etc)
  • Integrates with the awc HTTP client
  • Runs on stable Rust 1.57+

Documentation

Example

Dependencies:

[dependencies]
actix-web = "4"

Code:

use actix_web::{get, web, App, HttpServer, Responder};

#[get("/hello/{name}")]
async fn greet(name: web::Path<String>) -> impl Responder {
    format!("Hello {name}!")
}

#[actix_web::main] // or #[tokio::main]
async fn main() -> std::io::Result<()> {
    HttpServer::new(|| {
        App::new().service(greet)
    })
    .bind(("127.0.0.1", 8080))?
    .run()
    .await
}

More Examples

You may consider checking out this directory for more examples.

Benchmarks

One of the fastest web frameworks available according to the TechEmpower Framework Benchmark.

License

This project is licensed under either of the following licenses, at your option:

Code of Conduct

Contribution to the actix-web repo is organized under the terms of the Contributor Covenant. The Actix team promises to intervene to uphold that code of conduct.