Enable CI
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
2025-03-28 16:38:05 +01:00
parent f363ed1ff0
commit ec56fcd876
4 changed files with 889 additions and 482 deletions

View File

@ -1,11 +1,10 @@
use actix_web::{App, Error, error, HttpRequest, HttpResponse, HttpServer, web};
use actix_web::web::Payload;
use actix_web::{App, Error, HttpRequest, HttpResponse, HttpServer, error, web};
use clap::Parser;
use futures::StreamExt;
const MAX_BODY_SIZE: usize = 262_144; // max payload size is 256k
/// Simple HTTP responder
#[derive(Parser, Debug)]
#[clap(author, version, about, long_about = None)]
@ -16,7 +15,9 @@ struct Args {
}
async fn handler(req: HttpRequest, mut payload: Payload) -> Result<HttpResponse, Error> {
let mut headers = req.headers().iter()
let mut headers = req
.headers()
.iter()
.map(|h| format!("{}: {}", h.0.as_str(), h.1.to_str().unwrap_or_default()))
.collect::<Vec<_>>();
headers.sort();
@ -31,7 +32,6 @@ async fn handler(req: HttpRequest, mut payload: Payload) -> Result<HttpResponse,
body.extend_from_slice(&chunk);
}
let response = format!(
"Remote Peer: {}\nVerb: {}\nPath: {}\nQuery: {}\n\n=== Headers ===\n{}\n\n=== Body ===\n{}",
req.peer_addr().expect("Missing remote peer address!"),
@ -42,9 +42,7 @@ async fn handler(req: HttpRequest, mut payload: Payload) -> Result<HttpResponse,
String::from_utf8_lossy(&body)
);
Ok(HttpResponse::Ok()
.content_type("text/plain")
.body(response))
Ok(HttpResponse::Ok().content_type("text/plain").body(response))
}
#[actix_web::main]
@ -55,11 +53,18 @@ async fn main() -> std::io::Result<()> {
log::info!("Will listen on {}...", args.listen_address);
HttpServer::new(|| {
App::new()
.route("{tail:.*}", web::route().to(handler))
})
HttpServer::new(|| App::new().route("{tail:.*}", web::route().to(handler)))
.bind(args.listen_address)?
.run()
.await
}
#[cfg(test)]
mod test {
use crate::Args;
#[test]
fn verify_cli() {
use clap::CommandFactory;
Args::command().debug_assert()
}
}