2019-03-09 15:37:23 +00:00
|
|
|
use std::{env, io};
|
|
|
|
|
2018-11-28 06:12:04 +00:00
|
|
|
use actix_http::http::HeaderValue;
|
|
|
|
use actix_http::HttpMessage;
|
|
|
|
use actix_http::{h1, Error, Request, Response};
|
2018-12-11 02:08:33 +00:00
|
|
|
use actix_server::Server;
|
|
|
|
use actix_service::NewService;
|
2018-11-28 06:12:04 +00:00
|
|
|
use bytes::Bytes;
|
2018-11-28 05:45:08 +00:00
|
|
|
use futures::Future;
|
2018-12-11 02:08:33 +00:00
|
|
|
use log::info;
|
2018-11-28 05:45:08 +00:00
|
|
|
|
2019-02-13 21:52:11 +00:00
|
|
|
fn handle_request(mut req: Request) -> impl Future<Item = Response, Error = Error> {
|
2019-02-07 19:06:05 +00:00
|
|
|
req.body().limit(512).from_err().and_then(|bytes: Bytes| {
|
2018-11-28 06:12:04 +00: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 05:45:08 +00:00
|
|
|
}
|
|
|
|
|
2019-03-09 15:37:23 +00:00
|
|
|
fn main() -> io::Result<()> {
|
2018-11-28 05:45:08 +00:00
|
|
|
env::set_var("RUST_LOG", "echo=info");
|
|
|
|
env_logger::init();
|
|
|
|
|
2018-12-11 02:08:33 +00:00
|
|
|
Server::build()
|
2018-11-28 06:12:04 +00: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(|_| ())
|
2019-03-09 15:37:23 +00:00
|
|
|
})?
|
|
|
|
.run()
|
2018-11-28 05:45:08 +00:00
|
|
|
}
|