1
0
mirror of https://github.com/actix/actix-extras.git synced 2024-11-23 15:51:06 +01:00
Go to file
2017-10-29 21:49:16 -07:00
examples better handler function ergonimics 2017-10-29 21:39:59 -07:00
src better handler function ergonimics 2017-10-29 21:39:59 -07:00
tests better handler function ergonimics 2017-10-29 21:39:59 -07:00
.appveyor.yml cargo clean for appvoyer 2017-10-16 20:05:54 -07:00
.gitignore multipart implementation 2017-10-18 23:43:50 -07:00
.travis.yml refactor Payload stream 2017-10-26 23:14:33 -07:00
build.rs add optional skeptic 2017-10-26 06:12:23 -07:00
Cargo.toml add HttpContext::drain() 2017-10-29 06:05:31 -07:00
CHANGES.md stop http actor on write_eof 2017-10-29 20:51:06 -07:00
cov.sh more tests 2017-10-22 17:33:24 -07:00
LICENSE prep work 2017-09-30 09:10:03 -07:00
Makefile add optional skeptic 2017-10-26 06:12:23 -07:00
README.md add sockjs server link 2017-10-29 21:49:16 -07:00

Actix web Build Status Build status codecov crates.io

Asynchronous web framework for Actix.


Actix web is licensed under the Apache-2.0 license.

Features

  • HTTP 1.1 and 1.0 support
  • Streaming and pipelining support
  • Keep-alive and slow requests support
  • WebSockets support
  • Configurable request routing
  • Multipart streams
  • Middlewares

Usage

To use actix-web, add this to your Cargo.toml:

[dependencies]
actix-web = "0.1"

Example

extern crate actix;
extern crate actix_web;
extern crate env_logger;

use actix::*;
use actix_web::*;


struct MyWebSocket;

impl Actor for MyWebSocket {
    type Context = HttpContext<Self>;
}

impl Route for MyWebSocket {
    type State = ();

    fn request(req: &mut HttpRequest,
               payload: Payload, ctx: &mut HttpContext<Self>) -> RouteResult<Self>
    {
        let resp = ws::handshake(req)?;
        ctx.start(resp);
        ctx.add_stream(ws::WsStream::new(payload));
        Reply::async(MyWebSocket)
    }
}

impl StreamHandler<ws::Message> for MyWebSocket {
    fn started(&mut self, ctx: &mut Self::Context) {
        println!("WebSocket session openned");
    }

    fn finished(&mut self, ctx: &mut Self::Context) {
        println!("WebSocket session closed");
    }
}

impl Handler<ws::Message> for MyWebSocket {
    fn handle(&mut self, msg: ws::Message, ctx: &mut HttpContext<Self>)
              -> Response<Self, ws::Message>
    {
        println!("WS: {:?}", msg);
        match msg {
            ws::Message::Ping(msg) => ws::WsWriter::pong(ctx, msg),
            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(
        Application::default("/")
            // enable logger
            .middleware(Logger::new(None))
            // websocket route
            .resource("/ws/", |r| r.get::<MyWebSocket>())
            .route_handler("/", StaticFiles::new("examples/static/", true)))
        .serve::<_, ()>("127.0.0.1:8080").unwrap();

    println!("Started http server: 127.0.0.1:8080");
    Arbiter::system().send(msgs::SystemExit(0));
    let _ = sys.run();
}