aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSven-Hendrik Haase <svenstaro@gmail.com>2021-02-28 00:36:16 +0000
committerSven-Hendrik Haase <svenstaro@gmail.com>2021-02-28 00:36:16 +0000
commit31e2be249e6563abd755469cf8c24920d6481990 (patch)
tree963d0b07e5d01c726d2330ef18887eee3410aa18 /src
parentAdd CHANGELOG entry for custom headers (diff)
downloadminiserve-31e2be249e6563abd755469cf8c24920d6481990.tar.gz
miniserve-31e2be249e6563abd755469cf8c24920d6481990.zip
Re-do the way setting multiple headers works
Diffstat (limited to 'src')
-rw-r--r--src/args.rs12
-rw-r--r--src/main.rs17
2 files changed, 12 insertions, 17 deletions
diff --git a/src/args.rs b/src/args.rs
index 7710cce..8fdb067 100644
--- a/src/args.rs
+++ b/src/args.rs
@@ -120,9 +120,9 @@ struct CliArgs {
#[structopt(short = "t", long = "title")]
title: Option<String>,
- /// Custom header from user
- #[structopt(long = "header", parse(try_from_str = parse_header))]
- header: Option<HeaderMap>,
+ /// Set custom header for responses
+ #[structopt(long = "header", parse(try_from_str = parse_header), number_of_values = 1)]
+ header: Vec<HeaderMap>,
}
/// Checks wether an interface is valid, i.e. it can be parsed into an IP address
@@ -178,15 +178,13 @@ fn parse_auth(src: &str) -> Result<auth::RequiredAuth, ContextualError> {
/// Custom header parser (allow multiple headers input)
pub fn parse_header(src: &str) -> Result<HeaderMap, httparse::Error> {
- // Max customized header is limitted to 16
- let mut headers = [httparse::EMPTY_HEADER; 16];
+ let mut headers = [httparse::EMPTY_HEADER; 1];
let mut header = src.to_string();
header.push('\n');
httparse::parse_headers(header.as_bytes(), &mut headers)?;
let mut header_map = HeaderMap::new();
-
- for h in headers.iter() {
+ if let Some(h) = headers.first() {
if h.name != httparse::EMPTY_HEADER.name {
header_map.insert(
HeaderName::from_bytes(&Bytes::copy_from_slice(h.name.as_bytes())).unwrap(),
diff --git a/src/main.rs b/src/main.rs
index 44298d7..a407136 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -91,7 +91,7 @@ pub struct MiniserveConfig {
pub title: Option<String>,
/// If specified, header will be added
- pub header: Option<HeaderMap>,
+ pub header: Vec<HeaderMap>,
}
fn main() {
@@ -287,18 +287,15 @@ async fn run() -> Result<(), ContextualError> {
fn configure_header(conf: &MiniserveConfig) -> middleware::DefaultHeaders {
let headers = conf.clone().header;
- match headers {
- Some(headers) => {
- let mut default_headers = middleware::DefaultHeaders::new();
- for (header_name, header_value) in headers.into_iter() {
- if let Some(header_name) = header_name {
- default_headers = default_headers.header(&header_name, header_value);
- }
+ let mut default_headers = middleware::DefaultHeaders::new();
+ for header in headers {
+ for (header_name, header_value) in header.into_iter() {
+ if let Some(header_name) = header_name {
+ default_headers = default_headers.header(&header_name, header_value);
}
- default_headers
}
- _ => middleware::DefaultHeaders::new(),
}
+ default_headers
}
/// Configures the Actix application