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
use crate::mime_type::MimeType;
use crate::range::Range;
use crate::request::Request;
use crate::response::{Response, STATUS_CODE_REASON_PHRASE};
use crate::symbol::SYMBOL;

pub struct IndexController;

impl IndexController {
    pub const INDEX_FILEPATH: &'static str = "index.html";

    pub fn is_matching_request(request: &Request) -> bool {
        request.request_uri == SYMBOL.slash
    }

    pub fn process_request(_request: &Request, mut response: Response) -> Response {
        response.status_code = *STATUS_CODE_REASON_PHRASE.n200_ok.status_code;
        response.reason_phrase = STATUS_CODE_REASON_PHRASE.n200_ok.reason_phrase.to_string();


        let boxed_content_range =
            Range::get_content_range_of_a_file(IndexController::INDEX_FILEPATH);

        if boxed_content_range.is_ok() {
            let content_range = boxed_content_range.unwrap();
            let content_range_list = vec![content_range];
            response.content_range_list = content_range_list;
        } else {
            let error = boxed_content_range.err().unwrap();
            let mime_type = MimeType::TEXT_HTML.to_string();
            let content_range = Range::get_content_range(
                Vec::from(error.as_bytes()),
                mime_type
            );

            let content_range_list = vec![content_range];
            response.content_range_list = content_range_list;
            response.status_code = *STATUS_CODE_REASON_PHRASE.n500_internal_server_error.status_code;
            response.reason_phrase = STATUS_CODE_REASON_PHRASE.n500_internal_server_error.reason_phrase.to_string();
        }


        response
    }
}