From 3f253365b7a70e85307197fa8ce85ee009aa3252 Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Sat, 7 Oct 2017 00:53:36 -0700 Subject: [PATCH] readme --- README.md | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) diff --git a/README.md b/README.md index 547033e7f..9fb1c7b4a 100644 --- a/README.md +++ b/README.md @@ -20,3 +20,56 @@ To use `actix-http`, add this to your `Cargo.toml`: actix-http = { git = "https://github.com/fafhrd91/actix-http.git" } ``` +## Example + +```rust +extern crate actix; +extern crate actix_http; +extern crate futures; +use std::net; +use std::str::FromStr; + +use actix::prelude::*; +use actix_http::*; + +// Route +struct MyRoute; + +impl Actor for MyRoute { + type Context = HttpContext; +} + +impl Route for MyRoute { + type State = (); + + fn request(req: HttpRequest, + payload: Option, + ctx: &mut HttpContext) -> HttpMessage + { + Self::http_reply(req, httpcodes::HTTPOk) + } +} + +fn main() { + let system = System::new("test".to_owned()); + + // create routing map with `MyRoute` route + let mut routes = RoutingMap::default(); + routes.add_resource("/") + .post::(); + + // start http server + let http = HttpServer::new(routes); + http.serve::<()>( + &net::SocketAddr::from_str("127.0.0.1:8880").unwrap()).unwrap(); + + // stop system + Arbiter::handle().spawn_fn(|| { + Arbiter::system().send(msgs::SystemExit(0)); + futures::future::ok(()) + }); + + system.run(); + println!("Done"); +} +```