use std::collections::HashMap;
#[derive(Clone, Debug)]
pub struct Request {
parsed_body: Option<String>,
headers: HashMap<String, String>,
status_line: Vec<String>,
body: Vec<u8>,
wildcard: Option<String>,
is_http2: bool,
}
#[derive(Clone, Debug)]
pub enum BodyType {
ASCII(String),
Bytes(Vec<u8>),
}
impl Request {
pub fn new(
raw_body: Vec<u8>,
raw_headers: Vec<String>,
status_line: Vec<String>,
wildcard: Option<String>,
) -> Request {
let raw_body_clone = raw_body.clone();
let ascii_body = match std::str::from_utf8(&raw_body_clone) {
Ok(s) => Some(s),
Err(_) => {
#[cfg(feature = "log")]
log::debug!("Not an ASCII body");
None
}
};
let mut headers: HashMap<String, String> = HashMap::new();
#[cfg(feature = "log")]
log::trace!("Headers: {:#?}", raw_headers);
for i in raw_headers.iter() {
let mut iter = i.split(": ");
let key = iter.next().unwrap();
let value = iter.next().unwrap();
headers.insert(key.to_string(), value.to_string());
}
#[cfg(feature = "log")]
log::trace!("Request headers: {:?}", headers);
if let Some(b) = ascii_body {
Request {
parsed_body: Some(b.to_string()),
body: raw_body,
headers,
status_line,
wildcard,
is_http2: false,
}
} else {
Request {
body: raw_body,
parsed_body: None,
headers,
status_line,
wildcard,
is_http2: false,
}
}
}
pub(crate) fn set_wildcard(&mut self, w: Option<String>) -> &Self {
self.wildcard = w;
self
}
pub fn get_raw_body(&self) -> &Vec<u8> {
&self.body
}
pub fn get_parsed_body(&self) -> Option<&String> {
self.parsed_body.as_ref()
}
pub fn get_headers(&self) -> &HashMap<String, String> {
&self.headers
}
pub fn get_status_line(&self) -> &Vec<String> {
&self.status_line
}
pub fn get_wildcard(&self) -> Option<&String> {
self.wildcard.as_ref()
}
pub fn get_http2(&self) -> bool {
self.is_http2
}
pub fn set_http2(mut self, w: bool) -> Self {
self.is_http2 = w;
self
}
}