1
0
mirror of https://github.com/actix/actix-extras.git synced 2024-11-24 07:53:00 +01:00
actix-extras/examples/echo2.rs

36 lines
1.0 KiB
Rust
Raw Normal View History

use std::{env, io};
2018-11-28 07:12:04 +01:00
use actix_http::http::HeaderValue;
use actix_http::HttpMessage;
use actix_http::{h1, Error, Request, Response};
2018-12-11 03:08:33 +01:00
use actix_server::Server;
use actix_service::NewService;
2018-11-28 07:12:04 +01:00
use bytes::Bytes;
2018-11-28 06:45:08 +01:00
use futures::Future;
2018-12-11 03:08:33 +01:00
use log::info;
2018-11-28 06:45:08 +01:00
2019-02-13 22:52:11 +01:00
fn handle_request(mut req: Request) -> impl Future<Item = Response, Error = Error> {
req.body().limit(512).from_err().and_then(|bytes: Bytes| {
2018-11-28 07:12:04 +01:00
info!("request body: {:?}", bytes);
let mut res = Response::Ok();
res.header("x-head", HeaderValue::from_static("dummy value!"));
Ok(res.body(bytes))
})
2018-11-28 06:45:08 +01:00
}
fn main() -> io::Result<()> {
2018-11-28 06:45:08 +01:00
env::set_var("RUST_LOG", "echo=info");
env_logger::init();
2018-12-11 03:08:33 +01:00
Server::build()
2018-11-28 07:12:04 +01:00
.bind("echo", "127.0.0.1:8080", || {
h1::H1Service::build()
.client_timeout(1000)
.client_disconnect(1000)
.server_hostname("localhost")
.finish(|_req: Request| handle_request(_req))
.map(|_| ())
})?
.run()
2018-11-28 06:45:08 +01:00
}