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

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

14
.drone.yml Normal file
View File

@ -0,0 +1,14 @@
---
kind: pipeline
type: docker
name: default
steps:
- name: cargo_check
image: rust
commands:
- rustup component add clippy
- cargo clippy -- -D warnings
- cargo test

1324
Cargo.lock generated

File diff suppressed because it is too large Load Diff

View File

@ -1,13 +1,13 @@
[package]
name = "req_responder"
version = "0.1.0"
edition = "2021"
edition = "2024"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
log = "0.4.17"
env_logger = "0.9.0"
clap = { version = "3.1.15", features = ["derive", "env"] }
env_logger = "0.11.7"
clap = { version = "4.5.34", features = ["derive", "env"] }
actix-web = "4"
futures = "0.3.21"

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()
}
}