2019-03-09 16:37:23 +01:00
|
|
|
use std::{env, io};
|
|
|
|
|
2018-11-28 07:12:04 +01:00
|
|
|
use actix_http::http::HeaderValue;
|
2019-11-19 13:54:19 +01:00
|
|
|
use actix_http::{Error, HttpService, Request, Response};
|
2018-12-11 03:08:33 +01:00
|
|
|
use actix_server::Server;
|
2019-03-17 09:02:51 +01:00
|
|
|
use bytes::BytesMut;
|
2021-03-11 04:48:38 +01:00
|
|
|
use futures_util::StreamExt as _;
|
2018-12-11 03:08:33 +01:00
|
|
|
use log::info;
|
2018-11-28 06:45:08 +01:00
|
|
|
|
2019-11-19 13:54:19 +01:00
|
|
|
async fn handle_request(mut req: Request) -> Result<Response, Error> {
|
|
|
|
let mut body = BytesMut::new();
|
|
|
|
while let Some(item) = req.payload().next().await {
|
|
|
|
body.extend_from_slice(&item?)
|
|
|
|
}
|
|
|
|
|
|
|
|
info!("request body: {:?}", body);
|
|
|
|
Ok(Response::Ok()
|
2021-01-15 03:11:10 +01:00
|
|
|
.insert_header(("x-head", HeaderValue::from_static("dummy value!")))
|
2019-11-19 13:54:19 +01:00
|
|
|
.body(body))
|
2018-11-28 06:45:08 +01:00
|
|
|
}
|
|
|
|
|
2020-01-06 16:15:04 +01:00
|
|
|
#[actix_rt::main]
|
|
|
|
async 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", || {
|
2019-12-02 12:33:11 +01:00
|
|
|
HttpService::build().finish(handle_request).tcp()
|
2019-03-09 16:37:23 +01:00
|
|
|
})?
|
|
|
|
.run()
|
2020-01-06 16:15:04 +01:00
|
|
|
.await
|
2018-11-28 06:45:08 +01:00
|
|
|
}
|