1
0
mirror of https://github.com/actix/examples synced 2025-01-23 14:24:35 +01:00
examples/state/src/main.rs

53 lines
1.7 KiB
Rust
Raw Normal View History

2018-05-02 06:20:43 -07:00
#![cfg_attr(feature = "cargo-clippy", allow(needless_pass_by_value))]
//! 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.
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};
/// 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()))
}
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
// 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()
.start();
println!("Started http server: 127.0.0.1:8080");
let _ = sys.run();
}