1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
use std;
use std::collections::HashMap;
#[allow(dead_code)]
pub struct Response {
pub http_version: String,
pub status_code: u16,
pub status_message: String,
pub headers: HashMap<String, String>,
pub body: String
}
impl Response {
pub fn new(headers: &str, body: &str) -> Response {
let mut http_version = String::new();
let mut status_code: u16 = 0;
let mut status_message = String::new();
let mut refined_headers: HashMap<String, String> = HashMap::new();
let lines: Vec<&str> = headers.split("\r\n").collect();
let mut index = 0;
for line in lines.iter() {
index += 1;
if index == 1 {
let items: Vec<&str> = line.split(" ").collect();
if items.len() < 2 { continue; }
http_version = items[0].to_string();
status_code = match std::str::FromStr::from_str(items[1]) {
Ok(i) => i,
Err(_) => 0
};
status_message = Response::get_status_message(status_code);
continue;
}
let items: Vec<&str> = line.split(": ").collect();
if items.len() != 2 { continue; }
let key = items[0].to_string();
let value = items[1].to_string();
refined_headers.insert(key, value);
}
let response = Response {
http_version: http_version,
status_code: status_code,
status_message: status_message,
headers: refined_headers,
body: body.to_string()
};
return response;
}
fn get_status_message(status_code: u16) -> String {
let status_message = match status_code {
100 => "Continue",
101 => "Switching Protocols",
103 => "Checkpoint",
200 => "OK",
201 => "Crated",
202 => "Accepted",
203 => "Non-Authoritative Information",
204 => "No Content",
205 => "Reset Content",
206 => "Partial Content",
300 => "Multiple Choices",
301 => "Moved Permanently",
302 => "Found",
303 => "See Other",
304 => "Not Modified",
306 => "Switch Proxy",
307 => "Temporary Redirect",
308 => "Resume Incomplete",
400 => "Bad Request",
401 => "Unauthorized",
402 => "Payment Required",
403 => "Forbidden",
404 => "Not Found",
405 => "Method Not Allowed",
406 => "Not Acceptable",
407 => "Proxy Authentication Required",
408 => "Request Timeout",
409 => "Conflict",
410 => "Gone",
411 => "Length Required",
412 => "Precondition Failed",
413 => "Request Entity Too Large",
414 => "Request-URI Too Long",
415 => "Unsupported Media Type",
416 => "Requested Range Not Satisfiable",
417 => "Expectation Failed",
500 => "Internal Server Error",
501 => "Not Implemented",
502 => "Bad Gateway",
503 => "Service Unavailable",
504 => "Gateway Timeout",
505 => "HTTP Version Not Supported",
511 => "Network Authentication Required",
_ => ""
};
return status_message.to_string();
}
}