#include "application.h" #include #include #include "request.h" #include "file_cache.h" #include #include #include void Application::load_settings() { } void Application::setup_routes() { default_error_handler_func = Application::default_fallback_error_handler; error_handler_map[404] = Application::default_404_error_handler; } void Application::setup_middleware() { middlewares.push_back(HandlerInstance([this](Object *instance, Request *request){ this->default_routing_middleware(instance, request); })); } void Application::default_routing_middleware(Object *instance, Request *request) { std::string path = request->http_parser->getPath(); if (FileCache::get_singleton()->wwwroot_has_file(path)) { send_file(path, request); return; } HandlerInstance handler_data; //std::function func; //if (path == "/") { if (request->get_path_segment_count() == 0) { //quick shortcut handler_data = index_func; } else { const std::string main_route = request->get_current_path_segment(); handler_data = main_route_map[main_route]; request->push_path(); } if (!handler_data.handler_func) { send_error(404, request); return; } request->handler_instance = handler_data; request->next_stage(); } void Application::default_fallback_error_handler(int error_code, Request *request) { request->response->setBody(default_generic_error_body); request->send(); } void Application::default_404_error_handler(int error_code, Request *request) { request->response->setBody(default_error_404_body); request->send(); } void Application::handle_request(Request *request) { request->middleware_stack = &middlewares; //note that middlewares handle the routing -> Application::default_routing_middleware by default request->next_stage(); } void Application::send_error(int error_code, Request *request) { std::function func = error_handler_map[error_code]; if (!func) { default_error_handler_func(error_code, request); return; } func(error_code, request); } void Application::send_file(const std::string &path, Request *request) { std::string fp = FileCache::get_singleton()->wwwroot + path; request->send_file(fp); } void Application::migrate() { } void Application::register_request_update(Request *request) { std::lock_guard lock(_update_registered_requests_mutex); _update_registered_requests.push_back(request); } void Application::unregister_request_update(Request *request) { std::lock_guard lock(_update_registered_requests_mutex); std::size_t s = _update_registered_requests.size(); for (std::size_t i = 0; i < s; ++i) { Request *r = _update_registered_requests[i]; if (r == request) { _update_registered_requests[i] = _update_registered_requests[s - 1]; _update_registered_requests.pop_back(); return; } } } void Application::update() { for (std::size_t i = 0; i < _update_registered_requests.size(); ++i) { Request *r = _update_registered_requests[i]; r->update(); } } Application::Application() { } Application::~Application() { main_route_map.clear(); error_handler_map.clear(); middlewares.clear(); } std::string Application::default_error_404_body = "404 :("; std::string Application::default_generic_error_body = "Internal server error! :(";