1
0
mirror of https://github.com/fafhrd91/actix-web synced 2024-11-24 08:22:59 +01:00
actix-web/examples/state.rs

86 lines
2.5 KiB
Rust
Raw Normal View History

2017-10-23 20:48:06 +02:00
//! There are two level of statfulness in actix-web. Application has state
//! that is shared across all handlers within same Application.
//! And individual handler can have state.
extern crate actix;
extern crate actix_web;
extern crate env_logger;
use actix::*;
use actix_web::*;
use std::cell::Cell;
struct AppState {
counter: Cell<usize>,
}
/// somple handle
2017-11-27 05:32:12 +01:00
fn index(req: HttpRequest, state: &AppState) -> HttpResponse {
2017-10-23 20:48:06 +02:00
println!("{:?}", req);
state.counter.set(state.counter.get() + 1);
httpcodes::HTTPOk.with_body(
2017-10-24 08:25:32 +02:00
format!("Num of requests: {}", state.counter.get()))
2017-10-23 20:48:06 +02:00
}
/// `MyWebSocket` counts how many messages it receives from peer,
/// websocket-client.py could be used for tests
struct MyWebSocket {
counter: usize,
}
impl Actor for MyWebSocket {
type Context = HttpContext<Self>;
}
impl Route for MyWebSocket {
/// Shared application state
type State = AppState;
2017-11-27 05:32:12 +01:00
fn request(mut req: HttpRequest, ctx: &mut HttpContext<Self>) -> RouteResult<Self>
2017-10-23 20:48:06 +02:00
{
2017-11-27 05:32:12 +01:00
let resp = ws::handshake(&req)?;
2017-10-23 20:48:06 +02:00
ctx.start(resp);
2017-11-27 05:32:12 +01:00
ctx.add_stream(ws::WsStream::new(&mut req));
2017-10-23 20:48:06 +02:00
Reply::async(MyWebSocket{counter: 0})
}
}
impl StreamHandler<ws::Message> for MyWebSocket {}
impl Handler<ws::Message> for MyWebSocket {
fn handle(&mut self, msg: ws::Message, ctx: &mut HttpContext<Self>)
-> Response<Self, ws::Message>
{
self.counter += 1;
println!("WS({}): {:?}", self.counter, msg);
match msg {
2017-10-30 03:49:59 +01:00
ws::Message::Ping(msg) => ws::WsWriter::pong(ctx, &msg),
2017-10-23 20:48:06 +02:00
ws::Message::Text(text) => ws::WsWriter::text(ctx, &text),
ws::Message::Binary(bin) => ws::WsWriter::binary(ctx, bin),
ws::Message::Closed | ws::Message::Error => {
ctx.stop();
}
_ => (),
}
Self::empty()
}
}
fn main() {
::std::env::set_var("RUST_LOG", "actix_web=info");
let _ = env_logger::init();
let sys = actix::System::new("ws-example");
HttpServer::new(
2017-11-27 02:30:35 +01:00
Application::build("/", AppState{counter: Cell::new(0)})
2017-10-23 20:48:06 +02:00
// enable logger
2017-11-10 21:29:54 +01:00
.middleware(middlewares::Logger::default())
2017-10-23 20:48:06 +02:00
// websocket route
.resource("/ws/", |r| r.get::<MyWebSocket>())
// register simple handler, handle all methods
.handler("/", index))
.serve::<_, ()>("127.0.0.1:8080").unwrap();
println!("Started http server: 127.0.0.1:8080");
let _ = sys.run();
}