2017-11-27 06:18:38 +01:00
|
|
|
#![cfg_attr(feature="cargo-clippy", allow(needless_pass_by_value))]
|
2018-01-16 19:59:33 +01:00
|
|
|
//! There are two level of statefulness in actix-web. Application has state
|
2017-10-23 20:48:06 +02:00
|
|
|
//! 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;
|
|
|
|
|
2018-01-01 06:55:25 +01:00
|
|
|
use std::cell::Cell;
|
|
|
|
|
2018-03-31 03:54:38 +02:00
|
|
|
use actix::prelude::*;
|
|
|
|
use actix_web::{
|
2018-03-31 09:16:55 +02:00
|
|
|
http, server, ws, middleware, App, HttpRequest, HttpResponse};
|
2017-10-23 20:48:06 +02:00
|
|
|
|
2018-01-01 06:55:25 +01:00
|
|
|
/// Application state
|
2017-10-23 20:48:06 +02:00
|
|
|
struct AppState {
|
|
|
|
counter: Cell<usize>,
|
|
|
|
}
|
|
|
|
|
2018-03-24 07:35:52 +01:00
|
|
|
/// simple handle
|
2018-03-31 08:37:15 +02:00
|
|
|
fn index(req: HttpRequest<AppState>) -> HttpResponse {
|
2017-10-23 20:48:06 +02:00
|
|
|
println!("{:?}", req);
|
2017-11-27 06:18:38 +01:00
|
|
|
req.state().counter.set(req.state().counter.get() + 1);
|
2017-11-29 19:31:24 +01:00
|
|
|
|
2018-03-31 03:54:38 +02:00
|
|
|
HttpResponse::Ok().body(format!("Num of requests: {}", req.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 {
|
2018-01-14 03:58:17 +01:00
|
|
|
type Context = ws::WebsocketContext<Self, AppState>;
|
2017-10-23 20:48:06 +02:00
|
|
|
}
|
2017-11-27 06:18:38 +01:00
|
|
|
|
2018-03-02 20:29:55 +01:00
|
|
|
impl StreamHandler<ws::Message, ws::ProtocolError> for MyWebSocket {
|
2018-01-05 23:01:19 +01:00
|
|
|
|
|
|
|
fn handle(&mut self, msg: ws::Message, ctx: &mut Self::Context) {
|
2017-10-23 20:48:06 +02:00
|
|
|
self.counter += 1;
|
|
|
|
println!("WS({}): {:?}", self.counter, msg);
|
|
|
|
match msg {
|
2018-01-14 03:58:17 +01:00
|
|
|
ws::Message::Ping(msg) => ctx.pong(&msg),
|
2018-02-13 04:15:39 +01:00
|
|
|
ws::Message::Text(text) => ctx.text(text),
|
2018-01-14 03:58:17 +01:00
|
|
|
ws::Message::Binary(bin) => ctx.binary(bin),
|
2018-02-27 20:31:54 +01:00
|
|
|
ws::Message::Close(_) => {
|
2017-10-23 20:48:06 +02:00
|
|
|
ctx.stop();
|
|
|
|
}
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
::std::env::set_var("RUST_LOG", "actix_web=info");
|
|
|
|
let _ = env_logger::init();
|
|
|
|
let sys = actix::System::new("ws-example");
|
|
|
|
|
2018-03-31 03:54:38 +02:00
|
|
|
let _ = server::new(
|
2018-03-31 09:16:55 +02:00
|
|
|
|| App::with_state(AppState{counter: Cell::new(0)})
|
2017-10-23 20:48:06 +02:00
|
|
|
// enable logger
|
2017-12-27 04:59:41 +01:00
|
|
|
.middleware(middleware::Logger::default())
|
2017-10-23 20:48:06 +02:00
|
|
|
// websocket route
|
2017-12-04 22:32:05 +01:00
|
|
|
.resource(
|
2017-12-06 20:00:39 +01:00
|
|
|
"/ws/", |r|
|
2018-03-31 03:54:38 +02:00
|
|
|
r.method(http::Method::GET).f(
|
|
|
|
|req| ws::start(req, MyWebSocket{counter: 0})))
|
2017-10-23 20:48:06 +02:00
|
|
|
// register simple handler, handle all methods
|
2017-12-06 17:03:08 +01:00
|
|
|
.resource("/", |r| r.f(index)))
|
2017-12-17 21:35:04 +01:00
|
|
|
.bind("127.0.0.1:8080").unwrap()
|
2017-12-19 18:08:36 +01:00
|
|
|
.start();
|
2017-10-23 20:48:06 +02:00
|
|
|
|
|
|
|
println!("Started http server: 127.0.0.1:8080");
|
|
|
|
let _ = sys.run();
|
|
|
|
}
|