From cbb92993b592e6b68dbce7f283fb73d19fd1793e Mon Sep 17 00:00:00 2001 From: Tyler Murphy Date: Sun, 2 Jul 2023 18:45:41 -0400 Subject: hi --- src/http/request.rs | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 src/http/request.rs (limited to 'src/http/request.rs') diff --git a/src/http/request.rs b/src/http/request.rs new file mode 100644 index 0000000..5ba72c9 --- /dev/null +++ b/src/http/request.rs @@ -0,0 +1,52 @@ +use super::{method::Method, uri::URI, header::HeaderMap}; + +#[derive(Debug, Clone)] +pub struct Request { + pub method: Method, + pub uri: URI, + pub headers: HeaderMap, + pub body: Option +} + +impl Request { + pub fn serialize(req: &str) -> Option { + let mut lines = req.split('\n').to_owned(); + + let Some(head) = lines.next() else { + eprintln!("missing head str"); + return None + }; + + let mut parts = head.trim().split(" "); + + let Some(method_str) = parts.next() else { + eprintln!("missing method str"); + return None + }; + + let Some(method) = Method::serialize(method_str.trim()) else { + eprintln!("invalid http method"); + return None + }; + + let Some(uri_str) = parts.next() else { + eprintln!("missing uri str"); + return None + }; + + let Some(uri) = URI::serialize(uri_str.trim()) else { + eprintln!("invalid http uri"); + return None + }; + + let headers = HeaderMap::serialize(&mut lines); + let body: String = lines.collect(); + + Some(Self { + method, + uri, + headers, + body: if body.len() > 0 { Some(body) } else { None }, + }) + } +} -- cgit v1.2.3-freya