summaryrefslogtreecommitdiff
path: root/spider/src/response.rs
diff options
context:
space:
mode:
Diffstat (limited to 'spider/src/response.rs')
-rw-r--r--spider/src/response.rs51
1 files changed, 37 insertions, 14 deletions
diff --git a/spider/src/response.rs b/spider/src/response.rs
index 35b2f00..3873315 100644
--- a/spider/src/response.rs
+++ b/spider/src/response.rs
@@ -1,34 +1,57 @@
use std::collections::HashMap;
use std::fmt;
-// TODO(andrew): add more flexible status structure.
-// (Possibly with enum variants?)
+use crate::http_status::get_status_text;
+
pub struct Response {
- status: i32,
+ code: u16,
headers: HashMap<String, String>,
- body: String
+ body: Vec<u8>,
}
+// TODO(andrew): add more constructors for different content types.
impl Response {
- pub fn new(body: &str) -> Response {
- let headers: HashMap<String, String> = HashMap::new();
+ pub fn html(html: String, status_code: u16) -> Response {
+ let mut headers = HashMap::new();
+ headers.insert( String::from("Content-Type")
+ , String::from("text/html") );
+
return Response {
- status: 200,
+ code: status_code,
headers: headers,
- body: String::from(body)
+ body: html.as_bytes().to_vec(),
};
}
- pub fn format<'a>(&self) -> &'a [u8] {
- // TODO(andrew): replace placeholder response with actual
- // formatted response;
- let s = "HTTP/1.1 200 OK\r\nConnection: keep-alive\r\nContent-Type: text/html\r\n\r\n<i>Hello</i>";
- return s.as_bytes();
+ pub fn format<'a>(&self) -> Vec<u8> {
+ let status_text = match get_status_text(self.code) {
+ Some(text) => text,
+ None => String::from("UNDEFINED")
+ };
+
+ let mut data = Vec::new();
+
+ let first_line = format!("HTTP/1.1 {} {}", self.code, status_text);
+ let headers = format_headers(&self.headers);
+ let head = format!("{}\r\n{}\r\n", first_line, headers);
+
+ data.extend_from_slice(head.as_bytes());
+ data.extend_from_slice(&self.body);
+ return data;
}
}
impl fmt::Display for Response {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- return write!(f, "Response({})", self.status);
+ return write!(f, "Response({})", self.code);
+ }
+}
+
+fn format_headers(headers: &HashMap<String, String>) -> String {
+ let mut result = String::new();
+ for (key, value) in headers.iter() {
+ let line = format!("{}: {}\r\n", key, value);
+ result.push_str(&line);
}
+ return result;
}