1
0
mirror of https://github.com/actix/actix-extras.git synced 2025-01-24 07:43:49 +01:00

152 lines
4.8 KiB
Rust
Raw Normal View History

2017-10-21 19:35:50 -07:00
#![allow(unused_variables)]
2017-11-26 17:30:35 -08:00
#![cfg_attr(feature="cargo-clippy", allow(needless_pass_by_value))]
2017-10-21 19:35:50 -07:00
extern crate actix;
extern crate actix_web;
extern crate env_logger;
2017-11-03 13:35:34 -07:00
extern crate futures;
2017-12-19 00:18:57 -08:00
use futures::Stream;
2017-10-21 19:35:50 -07:00
2018-01-20 20:12:24 -08:00
use std::{io, env};
2017-10-21 19:35:50 -07:00
use actix_web::*;
2017-12-26 19:59:41 -08:00
use actix_web::middleware::RequestSession;
2017-11-30 14:42:20 -08:00
use futures::future::{FutureResult, result};
2018-01-05 16:32:36 -08:00
2018-01-06 16:43:59 +01:00
/// favicon handler
fn favicon(req: HttpRequest) -> Result<fs::NamedFile> {
Ok(fs::NamedFile::open("../static/favicon.ico")?)
}
2017-10-21 19:35:50 -07:00
2018-01-06 16:43:59 +01:00
/// simple index handler
2017-11-26 21:18:38 -08:00
fn index(mut req: HttpRequest) -> Result<HttpResponse> {
2017-10-21 19:35:50 -07:00
println!("{:?}", req);
2018-01-06 16:43:59 +01:00
// example of ...
2017-12-19 00:18:57 -08: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 01:24:49 -08:00
}
}
2017-11-26 17:30:35 -08:00
// session
2018-01-06 16:43:59 +01:00
let mut counter = 1;
2017-11-26 17:30:35 -08:00
if let Some(count) = req.session().get::<i32>("counter")? {
println!("SESSION value: {}", count);
2018-01-06 16:43:59 +01:00
counter = count + 1;
req.session().set("counter", counter)?;
2017-11-26 17:30:35 -08:00
} else {
2018-01-06 16:43:59 +01:00
req.session().set("counter", counter)?;
2017-11-26 17:30:35 -08:00
}
2018-01-06 16:43:59 +01:00
// html
let html = format!(r#"<!DOCTYPE html><html><head><title>actix - basics</title><link rel="shortcut icon" type="image/x-icon" href="/favicon.ico" /></head>
<body>
<h1>Welcome <img width="30px" height="30px" src="/static/actixLogo.png" /></h1>
session counter = {}
</body>
</html>"#, counter);
// response
Ok(HttpResponse::build(StatusCode::OK)
.content_type("text/html; charset=utf-8")
.body(&html).unwrap())
}
/// 404 handler
fn p404(req: HttpRequest) -> Result<HttpResponse> {
// html
2018-01-20 20:12:24 -08:00
let html = r#"<!DOCTYPE html><html><head><title>actix - basics</title><link rel="shortcut icon" type="image/x-icon" href="/favicon.ico" /></head>
2018-01-06 16:43:59 +01:00
<body>
<a href="index.html">back to home</a>
<h1>404</h1>
</body>
2018-01-20 20:12:24 -08:00
</html>"#;
2018-01-06 16:43:59 +01:00
// response
Ok(HttpResponse::build(StatusCode::NOT_FOUND)
.content_type("text/html; charset=utf-8")
2018-01-20 20:12:24 -08:00
.body(html).unwrap())
2017-10-21 19:35:50 -07:00
}
2018-01-06 16:43:59 +01:00
2017-11-27 16:41:37 -08:00
/// async handler
2017-11-30 14:42:20 -08:00
fn index_async(req: HttpRequest) -> FutureResult<HttpResponse, Error>
2017-11-03 13:35:34 -07:00
{
println!("{:?}", req);
2017-11-30 14:42:20 -08: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 13:35:34 -07:00
}
2017-11-27 16:41:37 -08:00
/// handler with path parameters like `/user/{name}/`
2017-11-26 21:18:38 -08:00
fn with_param(req: HttpRequest) -> Result<HttpResponse>
2017-10-29 21:39:59 -07:00
{
2017-10-21 19:35:50 -07:00
println!("{:?}", req);
Ok(HttpResponse::Ok()
2017-10-29 21:39:59 -07:00
.content_type("test/plain")
.body(format!("Hello {}!", req.match_info().get("name").unwrap()))?)
2017-10-21 19:35:50 -07:00
}
fn main() {
2018-01-20 20:12:24 -08:00
env::set_var("RUST_LOG", "actix_web=debug");
env::set_var("RUST_BACKTRACE", "1");
env_logger::init();
2017-12-18 13:41:52 -08:00
let sys = actix::System::new("basic-example");
2017-10-21 19:35:50 -07:00
let addr = HttpServer::new(
|| Application::new()
// enable logger
2017-12-26 19:59:41 -08:00
.middleware(middleware::Logger::default())
2017-11-26 17:30:35 -08:00
// cookie session middleware
2017-12-26 19:59:41 -08:00
.middleware(middleware::SessionStorage::new(
middleware::CookieSessionBackend::build(&[0; 32])
2017-11-26 17:30:35 -08:00
.secure(false)
.finish()
))
2018-01-06 16:43:59 +01:00
// register favicon
.resource("/favicon.ico", |r| r.f(favicon))
2017-12-04 14:53:40 -08:00
// register simple route, handle all methods
.resource("/index.html", |r| r.f(index))
2017-12-01 23:32:15 -08:00
// with path parameters
.resource("/user/{name}/", |r| r.method(Method::GET).f(with_param))
2017-11-03 13:35:34 -07:00
// async handler
.resource("/async/{name}", |r| r.method(Method::GET).a(index_async))
.resource("/test", |r| r.f(|req| {
2017-11-29 13:26:55 -08:00
match *req.method() {
Method::GET => httpcodes::HTTPOk,
Method::POST => httpcodes::HTTPMethodNotAllowed,
_ => httpcodes::HTTPNotFound,
}
2017-12-04 14:53:40 -08:00
}))
2018-01-20 20:12:24 -08:00
.resource("/error.html", |r| r.f(|req| {
error::ErrorBadRequest(io::Error::new(io::ErrorKind::Other, "test"))
}))
2017-10-21 19:35:50 -07:00
// static files
2018-01-02 19:37:33 -08:00
.handler("/static/", fs::StaticFiles::new("../static/", true))
2017-12-07 22:54:44 -08:00
// redirect
.resource("/", |r| r.method(Method::GET).f(|req| {
println!("{:?}", req);
2017-12-26 14:36:03 -08:00
HttpResponse::Found()
2017-12-07 22:54:44 -08:00
.header("LOCATION", "/index.html")
2017-12-20 16:32:31 -08:00
.finish()
2018-01-06 16:43:59 +01:00
}))
// default
.default_resource(|r| {
r.method(Method::GET).f(p404);
r.route().p(pred::Not(pred::Get())).f(|req| httpcodes::HTTPMethodNotAllowed);
}))
.bind("127.0.0.1:8080").expect("Can not bind to 127.0.0.1:8080")
.shutdown_timeout(0) // <- Set shutdown timeout to 0 seconds (default 60s)
2017-12-19 09:08:36 -08:00
.start();
2017-10-21 19:35:50 -07:00
2017-12-19 09:51:28 -08:00
println!("Starting http server: 127.0.0.1:8080");
2017-10-21 19:35:50 -07:00
let _ = sys.run();
}