2018-05-02 06:20:43 -07:00
|
|
|
#![cfg_attr(feature = "cargo-clippy", allow(needless_pass_by_value))]
|
2018-04-13 09:18:42 +08:00
|
|
|
//! There are two level of statefulness in actix-web. Application has state
|
|
|
|
//! that is shared across all handlers within same Application.
|
|
|
|
//! And individual handler can have state.
|
2018-05-02 06:20:43 -07:00
|
|
|
//!
|
2018-05-08 11:08:43 -07:00
|
|
|
//! > **Note**: http server accepts an application factory rather than an
|
|
|
|
//! application > instance. Http server constructs an application instance for
|
|
|
|
//! each thread, > thus application state
|
|
|
|
//! > must be constructed multiple times. If you want to share state between
|
|
|
|
//! different > threads, a shared object should be used, e.g. `Arc`.
|
2018-05-02 06:20:43 -07:00
|
|
|
//!
|
|
|
|
//! Check [user guide](https://actix.rs/book/actix-web/sec-2-application.html) for more info.
|
2018-04-13 09:18:42 +08:00
|
|
|
|
|
|
|
extern crate actix;
|
|
|
|
extern crate actix_web;
|
|
|
|
extern crate env_logger;
|
|
|
|
|
|
|
|
use std::cell::Cell;
|
|
|
|
|
2018-05-08 11:08:43 -07:00
|
|
|
use actix_web::{middleware, server, App, HttpRequest, HttpResponse};
|
2018-04-13 09:18:42 +08:00
|
|
|
|
|
|
|
/// Application state
|
|
|
|
struct AppState {
|
|
|
|
counter: Cell<usize>,
|
|
|
|
}
|
|
|
|
|
|
|
|
/// simple handle
|
|
|
|
fn index(req: HttpRequest<AppState>) -> HttpResponse {
|
|
|
|
println!("{:?}", req);
|
|
|
|
req.state().counter.set(req.state().counter.get() + 1);
|
|
|
|
|
2018-05-20 21:03:29 -07:00
|
|
|
HttpResponse::Ok().body(format!("Num of requests: {}", req.state().counter.get()))
|
2018-04-13 09:18:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
::std::env::set_var("RUST_LOG", "actix_web=info");
|
|
|
|
env_logger::init();
|
|
|
|
let sys = actix::System::new("ws-example");
|
|
|
|
|
2018-05-02 06:20:43 -07:00
|
|
|
server::new(|| {
|
|
|
|
App::with_state(AppState{counter: Cell::new(0)}) // <- create app with state
|
2018-04-13 09:18:42 +08:00
|
|
|
// enable logger
|
|
|
|
.middleware(middleware::Logger::default())
|
|
|
|
// register simple handler, handle all methods
|
2018-05-02 06:20:43 -07:00
|
|
|
.resource("/", |r| r.f(index))
|
|
|
|
}).bind("127.0.0.1:8080")
|
|
|
|
.unwrap()
|
2018-04-13 09:18:42 +08:00
|
|
|
.start();
|
|
|
|
|
|
|
|
println!("Started http server: 127.0.0.1:8080");
|
|
|
|
let _ = sys.run();
|
|
|
|
}
|