1
0
mirror of https://github.com/actix/actix-extras.git synced 2024-12-25 04:05:20 +01:00
actix-extras/examples/basic.rs

101 lines
3.1 KiB
Rust
Raw Normal View History

2017-10-22 04:35:50 +02:00
#![allow(unused_variables)]
2017-11-27 02:30:35 +01:00
#![cfg_attr(feature="cargo-clippy", allow(needless_pass_by_value))]
2017-10-22 04:35:50 +02:00
extern crate actix;
extern crate actix_web;
extern crate env_logger;
2017-11-03 21:35:34 +01:00
extern crate futures;
2017-12-19 09:18:57 +01:00
use futures::Stream;
2017-10-22 04:35:50 +02:00
use actix_web::*;
2017-11-27 02:30:35 +01:00
use actix_web::middlewares::RequestSession;
2017-11-30 23:42:20 +01:00
use futures::future::{FutureResult, result};
2017-10-22 04:35:50 +02:00
2017-11-28 01:41:37 +01:00
/// simple handler
2017-11-27 06:18:38 +01:00
fn index(mut req: HttpRequest) -> Result<HttpResponse> {
2017-10-22 04:35:50 +02:00
println!("{:?}", req);
2017-12-19 09:18:57 +01:00
if let Ok(ch) = req.payload_mut().readany().poll() {
if let futures::Async::Ready(Some(d)) = ch {
println!("{}", String::from_utf8_lossy(d.as_ref()));
2017-11-06 10:24:49 +01:00
}
}
2017-11-27 02:30:35 +01:00
// session
if let Some(count) = req.session().get::<i32>("counter")? {
println!("SESSION value: {}", count);
req.session().set("counter", count+1)?;
} else {
req.session().set("counter", 1)?;
}
2017-12-05 22:31:06 +01:00
Ok("Welcome!".into())
2017-10-22 04:35:50 +02:00
}
2017-11-28 01:41:37 +01:00
/// async handler
2017-11-30 23:42:20 +01:00
fn index_async(req: HttpRequest) -> FutureResult<HttpResponse, Error>
2017-11-03 21:35:34 +01:00
{
println!("{:?}", req);
2017-11-30 23:42:20 +01:00
result(HttpResponse::Ok()
.content_type("text/html")
.body(format!("Hello {}!", req.match_info().get("name").unwrap()))
.map_err(|e| e.into()))
2017-11-03 21:35:34 +01:00
}
2017-11-28 01:41:37 +01:00
/// handler with path parameters like `/user/{name}/`
2017-11-27 06:18:38 +01:00
fn with_param(req: HttpRequest) -> Result<HttpResponse>
2017-10-30 05:39:59 +01:00
{
2017-10-22 04:35:50 +02:00
println!("{:?}", req);
Ok(HttpResponse::Ok()
2017-10-30 05:39:59 +01:00
.content_type("test/plain")
.body(format!("Hello {}!", req.match_info().get("name").unwrap()))?)
2017-10-22 04:35:50 +02:00
}
fn main() {
::std::env::set_var("RUST_LOG", "actix_web=info");
let _ = env_logger::init();
2017-12-18 22:41:52 +01:00
let sys = actix::System::new("basic-example");
2017-10-22 04:35:50 +02:00
HttpServer::new(
|| Application::new()
// enable logger
2017-11-24 00:17:16 +01:00
.middleware(middlewares::Logger::default())
2017-11-27 02:30:35 +01:00
// cookie session middleware
.middleware(middlewares::SessionStorage::new(
middlewares::CookieSessionBackend::build(&[0; 32])
.secure(false)
.finish()
))
2017-12-04 23:53:40 +01:00
// register simple route, handle all methods
.resource("/index.html", |r| r.f(index))
2017-12-02 08:32:15 +01:00
// with path parameters
.resource("/user/{name}/", |r| r.method(Method::GET).f(with_param))
2017-11-03 21:35:34 +01:00
// async handler
.resource("/async/{name}", |r| r.method(Method::GET).a(index_async))
.resource("/test", |r| r.f(|req| {
2017-11-29 22:26:55 +01:00
match *req.method() {
Method::GET => httpcodes::HTTPOk,
Method::POST => httpcodes::HTTPMethodNotAllowed,
_ => httpcodes::HTTPNotFound,
}
2017-12-04 23:53:40 +01:00
}))
2017-10-22 04:35:50 +02:00
// static files
2017-12-08 21:29:28 +01:00
.resource("/static/{tail:.*}",
|r| r.h(fs::StaticFiles::new("tail", "examples/static/", true)))
2017-12-08 07:54:44 +01:00
// redirect
.resource("/", |r| r.method(Method::GET).f(|req| {
println!("{:?}", req);
httpcodes::HTTPFound
.build()
.header("LOCATION", "/index.html")
.body(Body::Empty)
})))
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-22 04:35:50 +02:00
2017-12-19 18:51:28 +01:00
println!("Starting http server: 127.0.0.1:8080");
2017-10-22 04:35:50 +02:00
let _ = sys.run();
}