From eff4edb6fa557785605d55b147126c661db095c3 Mon Sep 17 00:00:00 2001 From: Cameron Dershem Date: Wed, 26 Jun 2019 02:59:20 -0400 Subject: [PATCH] Middleware section is done-ish. --- content/docs/middleware.md | 87 ++++++++++------------ examples/middleware/src/default_headers.rs | 30 +++++--- examples/middleware/src/errorhandler.rs | 30 +++++--- examples/middleware/src/logger.rs | 15 +++- examples/middleware/src/main.rs | 24 ++++-- examples/middleware/src/user_sessions.rs | 38 +++++----- 6 files changed, 122 insertions(+), 102 deletions(-) diff --git a/content/docs/middleware.md b/content/docs/middleware.md index ef02106..0a9537e 100644 --- a/content/docs/middleware.md +++ b/content/docs/middleware.md @@ -6,9 +6,9 @@ weight: 220 # Middleware -Actix's middleware system allows us to add additional behavior to request/response processing. -Middleware can hook into an incoming request process, enabling us to modify requests -as well as halt request processing to return a response early. +Actix-web's middleware system allows us to add additional behavior to request/response +processing. Middleware can hook into an incoming request process, enabling us to modify +requests as well as halt request processing to return a response early. Middleware can also hook into response processing. @@ -19,31 +19,32 @@ Typically, middleware is involved in the following actions: * Modify application state * Access external services (redis, logging, sessions) -Middleware is registered for each application and executed in same order as registration. -In general, a *middleware* is a type that implements the [*Service trait*][servicetrait] and -[*Transform trait*][transformtrait]. Each method in the traits has a default -implementation. Each method can return a result immediately or a *future* object. +Middleware is registered for each `App`, `scope`, or `Resource` and executed in opposite +order as registration. In general, a *middleware* is a type that implements the +[*Service trait*][servicetrait] and [*Transform trait*][transformtrait]. Each method in +the traits has a default implementation. Each method can return a result immediately +or a *future* object. The following demonstrates creating a simple middleware: -{{< include-example example="middleware" file="main.rs" section="main" >}} +{{< include-example example="middleware" file="main.rs" section="simple" >}} -> Actix provides several useful middlewares, such as *logging*, *user sessions*, etc. +> Actix-web provides several useful middlewares, such as *logging*, *user sessions*, +> *compress*, etc. # Logging -Logging is implemented as a middleware. -It is common to register a logging middleware as the first middleware for the application. -Logging middleware must be registered for each application. +Logging is implemented as a middleware. It is common to register a logging middleware +as the first middleware for the application. Logging middleware must be registered for +each application. The `Logger` middleware uses the standard log crate to log information. You should enable logger -for *actix_web* package to see access log ([env_logger][envlogger] -or similar). +for *actix_web* package to see access log ([env_logger][envlogger] or similar). ## Usage -Create `Logger` middleware with the specified `format`. -Default `Logger` can be created with `default` method, it uses the default format: +Create `Logger` middleware with the specified `format`. Default `Logger` can be created +with `default` method, it uses the default format: ```ignore %a %t "%r" %s %b "%{Referer}i" "%{User-Agent}i" %T @@ -60,29 +61,18 @@ INFO:actix_web::middleware::logger: 127.0.0.1:59947 [02/Dec/2017:00:22:40 -0800] ## Format - `%%` The percent sign - - `%a` Remote IP-address (IP-address of proxy if using reverse proxy) - - `%t` Time when the request was started to process - - `%P` The process ID of the child that serviced the request - - `%r` First line of request - - `%s` Response status code - - `%b` Size of response in bytes, including HTTP headers - - `%T` Time taken to serve the request, in seconds with floating fraction in .06f format - - `%D` Time taken to serve the request, in milliseconds - - `%{FOO}i` request.headers['FOO'] - - `%{FOO}o` response.headers['FOO'] - - `%{FOO}e` os.environ['FOO'] +- `%%` The percent sign +- `%a` Remote IP-address (IP-address of proxy if using reverse proxy) +- `%t` Time when the request was started to process +- `%P` The process ID of the child that serviced the request +- `%r` First line of request +- `%s` Response status code +- `%b` Size of response in bytes, including HTTP headers +- `%T` Time taken to serve the request, in seconds with floating fraction in .06f format +- `%D` Time taken to serve the request, in milliseconds +- `%{FOO}i` request.headers['FOO'] +- `%{FOO}o` response.headers['FOO'] +- `%{FOO}e` os.environ['FOO'] ## Default headers @@ -94,8 +84,9 @@ a specified header. ## User sessions -Actix provides a general solution for session management. The [**actix-session**][actixsession] -middleware can be used with different backend types to store session data in different backends. +Actix-web provides a general solution for session management. The +[**actix-session**][actixsession] middleware can be used with different backend types +to store session data in different backends. > By default, only cookie session backend is implemented. Other backend implementations > can be added. @@ -115,8 +106,8 @@ The constructors take a key as an argument. This is the private key for cookie s when this value is changed, all session data is lost. In general, you create a `SessionStorage` middleware and initialize it with specific -backend implementation, such as a `CookieSession`. To access session data, -[*HttpRequest::session()*][requestsession] must be used. This method returns a +backend implementation, such as a `CookieSession`. To access session data the +[`Session`][requestsession] extractor must be used. This method returns a [*Session*][sessionobj] object, which allows us to get or set session data. {{< include-example example="middleware" file="user_sessions.rs" section="user-session" >}} @@ -132,10 +123,10 @@ into a response. {{< include-example example="middleware" file="errorhandler.rs" section="error-handler" >}} -[sessionobj]: ../../actix-web/actix_web/middleware/session/struct.Session.html -[requestsession]: ../../actix-web/actix_web/middleware/session/trait.RequestSession.html#tymethod.session -[cookiesession]: ../../actix-web/actix_web/middleware/session/struct.CookieSessionBackend.html +[sessionobj]: https://docs.rs/actix-session/0.1.1/actix_session/struct.Session.html +[requestsession]: https://docs.rs/actix-session/0.1.1/actix_session/struct.Session.html +[cookiesession]: https://docs.rs/actix-session/0.1.1/actix_session/struct.CookieSession.html [actixsession]: https://docs.rs/actix-session/0.1.1/actix_session/ [envlogger]: https://docs.rs/env_logger/*/env_logger/ -[servicetrait]: ../../actix-web/actix_web/dev/trait.Service.html -[transformtrait]: ../../actix-web/actix_web/dev/trait.Transform.html +[servicetrait]: https://docs.rs/actix-web/1.0.2/actix_web/dev/trait.Service.html +[transformtrait]: https://docs.rs/actix-web/1.0.2/actix_web/dev/trait.Transform.html diff --git a/examples/middleware/src/default_headers.rs b/examples/middleware/src/default_headers.rs index cf14468..d998a15 100644 --- a/examples/middleware/src/default_headers.rs +++ b/examples/middleware/src/default_headers.rs @@ -1,16 +1,24 @@ // -use actix_web::{http, middleware, web, App, HttpResponse}; +use actix_web::{http, middleware, HttpResponse}; pub fn main() { - App::new() - .wrap(middleware::DefaultHeaders::new().header("X-Version", "0.2")) - .service( - web::resource("/test") - .route(web::get().to(|| HttpResponse::Ok())) - .route( - web::method(http::Method::HEAD) - .to(|| HttpResponse::MethodNotAllowed()), - ), - ); + use actix_web::{web, App, HttpServer}; + + HttpServer::new(|| { + App::new() + .wrap(middleware::DefaultHeaders::new().header("X-Version", "0.2")) + .service( + web::resource("/test") + .route(web::get().to(|| HttpResponse::Ok())) + .route( + web::method(http::Method::HEAD) + .to(|| HttpResponse::MethodNotAllowed()), + ), + ) + }) + .bind("127.0.0.1:8088") + .unwrap() + .run() + .unwrap(); } // diff --git a/examples/middleware/src/errorhandler.rs b/examples/middleware/src/errorhandler.rs index 6d33db5..dacef6e 100644 --- a/examples/middleware/src/errorhandler.rs +++ b/examples/middleware/src/errorhandler.rs @@ -1,6 +1,6 @@ // use actix_web::middleware::errhandlers::{ErrorHandlerResponse, ErrorHandlers}; -use actix_web::{dev, http, web, App, HttpResponse, Result}; +use actix_web::{dev, http, HttpResponse, Result}; fn render_500(mut res: dev::ServiceResponse) -> Result> { res.response_mut().headers_mut().insert( @@ -11,15 +11,23 @@ fn render_500(mut res: dev::ServiceResponse) -> Result diff --git a/examples/middleware/src/logger.rs b/examples/middleware/src/logger.rs index 8a5cecd..254e5d1 100644 --- a/examples/middleware/src/logger.rs +++ b/examples/middleware/src/logger.rs @@ -1,14 +1,21 @@ // use actix_web::middleware::Logger; -use actix_web::App; use env_logger; pub fn main() { + use actix_web::{App, HttpServer}; + std::env::set_var("RUST_LOG", "actix_web=info"); env_logger::init(); - App::new() - .wrap(Logger::default()) - .wrap(Logger::new("%a %{User-Agent}i")); + HttpServer::new(|| { + App::new() + .wrap(Logger::default()) + .wrap(Logger::new("%a %{User-Agent}i")) + }) + .bind("127.0.0.1:8088") + .unwrap() + .run() + .unwrap(); } // diff --git a/examples/middleware/src/main.rs b/examples/middleware/src/main.rs index d39d2d8..22ed711 100644 --- a/examples/middleware/src/main.rs +++ b/examples/middleware/src/main.rs @@ -2,9 +2,10 @@ pub mod default_headers; pub mod errorhandler; pub mod logger; pub mod user_sessions; -//
+ +// use actix_service::{Service, Transform}; -use actix_web::{dev::ServiceRequest, dev::ServiceResponse, web, App, Error}; +use actix_web::{dev::ServiceRequest, dev::ServiceResponse, Error}; use futures::future::{ok, FutureResult}; use futures::{Future, Poll}; @@ -63,10 +64,19 @@ where })) } } -//
+// + fn main() { - App::new().wrap(SayHi).service( - web::resource("/") - .to(|| "Hello, middleware! Check the console where the server is run."), - ); + use actix_web::{web, App, HttpServer}; + + HttpServer::new(|| { + App::new().wrap(SayHi).service( + web::resource("/") + .to(|| "Hello, middleware! Check the console where the server is run."), + ) + }) + .bind("127.0.0.1:8088") + .unwrap() + .run() + .unwrap(); } diff --git a/examples/middleware/src/user_sessions.rs b/examples/middleware/src/user_sessions.rs index d51c740..b4f99ff 100644 --- a/examples/middleware/src/user_sessions.rs +++ b/examples/middleware/src/user_sessions.rs @@ -1,37 +1,33 @@ // use actix_session::{CookieSession, Session}; -use actix_web::{middleware::Logger, web, App, HttpRequest, HttpServer, Result}; +use actix_web::{web, App, Error, HttpResponse, HttpServer}; -/// simple index handler with session -fn index(session: Session, req: HttpRequest) -> Result<&'static str> { - println!("{:?}", req); - - // RequestSession trait is used for session access - let mut counter = 1; +pub fn index(session: Session) -> Result { + // access session data if let Some(count) = session.get::("counter")? { - println!("SESSION value: {}", count); - counter = count + 1; - session.set("counter", counter)?; + session.set("counter", count + 1)?; } else { - session.set("counter", counter)?; + session.set("counter", 1)?; } - Ok("welcome!") + Ok(HttpResponse::Ok().body(format!( + "Count is {:?}!", + session.get::("counter")?.unwrap() + ))) } -pub fn main() -> std::io::Result<()> { - std::env::set_var("RUST_LOG", "actix_web=info"); - env_logger::init(); - +pub fn main() { HttpServer::new(|| { App::new() - // enable logger - .wrap(Logger::default()) - // cookie session middleware - .wrap(CookieSession::signed(&[0; 32]).secure(false)) + .wrap( + CookieSession::signed(&[0; 32]) // <- create cookie based session middleware + .secure(false), + ) .service(web::resource("/").to(index)) }) - .bind("127.0.0.1:8080")? + .bind("127.0.0.1:8088") + .unwrap() .run() + .unwrap(); } //