Renamed Request to WebServerRequest.

This commit is contained in:
Relintai 2022-06-26 11:07:45 +02:00
parent 2a9b32847f
commit 8211115346
2 changed files with 69 additions and 70 deletions

View File

@ -1,4 +1,4 @@
#include "request.h" #include "web_server_request.h"
#include "web/http/cookie.h" #include "web/http/cookie.h"
#include "web_server.h" #include "web_server.h"
@ -10,7 +10,7 @@
#include "web_permission.h" #include "web_permission.h"
Ref<HTTPSession> Request::get_or_create_session() { Ref<HTTPSession> WebServerRequest::get_or_create_session() {
if (session.is_valid()) { if (session.is_valid()) {
return session; return session;
} }
@ -20,20 +20,20 @@ Ref<HTTPSession> Request::get_or_create_session() {
return session; return session;
} }
bool Request::can_view() const { bool WebServerRequest::can_view() const {
return (permissions & WebPermission::WEB_PERMISSION_VIEW) != 0; return (permissions & WebPermission::WEB_PERMISSION_VIEW) != 0;
} }
bool Request::can_create() const { bool WebServerRequest::can_create() const {
return (permissions & WebPermission::WEB_PERMISSION_CREATE) != 0; return (permissions & WebPermission::WEB_PERMISSION_CREATE) != 0;
} }
bool Request::can_edit() const { bool WebServerRequest::can_edit() const {
return (permissions & WebPermission::WEB_PERMISSION_EDIT) != 0; return (permissions & WebPermission::WEB_PERMISSION_EDIT) != 0;
} }
bool Request::can_delete() const { bool WebServerRequest::can_delete() const {
return (permissions & WebPermission::WEB_PERMISSION_DELETE) != 0; return (permissions & WebPermission::WEB_PERMISSION_DELETE) != 0;
} }
bool Request::has_csrf_token() { bool WebServerRequest::has_csrf_token() {
if (!session.is_valid()) { if (!session.is_valid()) {
return false; return false;
} }
@ -41,7 +41,7 @@ bool Request::has_csrf_token() {
return session->has("csrf_token"); return session->has("csrf_token");
} }
String Request::get_csrf_token() { String WebServerRequest::get_csrf_token() {
if (!session.is_valid()) { if (!session.is_valid()) {
return ""; return "";
} }
@ -55,7 +55,7 @@ String Request::get_csrf_token() {
return ""; return "";
} }
void Request::set_csrf_token(const String &value) { void WebServerRequest::set_csrf_token(const String &value) {
if (session.is_valid()) { if (session.is_valid()) {
session->add("csrf_token", value); session->add("csrf_token", value);
@ -63,7 +63,7 @@ void Request::set_csrf_token(const String &value) {
} }
} }
bool Request::validate_csrf_token() { bool WebServerRequest::validate_csrf_token() {
String param_token = get_parameter("csrf_token"); String param_token = get_parameter("csrf_token");
param_token.trim(); param_token.trim();
@ -80,49 +80,49 @@ bool Request::validate_csrf_token() {
return param_token == token; return param_token == token;
} }
const String Request::get_cookie(const String &key) { const String WebServerRequest::get_cookie(const String &key) {
static String str(0); static String str(0);
return str; return str;
} }
void Request::add_cookie(const ::Cookie &cookie) { void WebServerRequest::add_cookie(const ::Cookie &cookie) {
} }
void Request::remove_cookie(const String &key) { void WebServerRequest::remove_cookie(const String &key) {
} }
HTTPMethod Request::get_method() const { HTTPMethod WebServerRequest::get_method() const {
return HTTP_METHOD_GET; return HTTP_METHOD_GET;
} }
void Request::parse_files() { void WebServerRequest::parse_files() {
} }
int Request::get_file_count() const { int WebServerRequest::get_file_count() const {
return 0; return 0;
} }
int Request::get_file_length(const int index) const { int WebServerRequest::get_file_length(const int index) const {
return 0; return 0;
} }
const uint8_t *Request::get_file_data(const int index) const { const uint8_t *WebServerRequest::get_file_data(const int index) const {
return nullptr; return nullptr;
} }
const String Request::get_parameter(const String &key) const { const String WebServerRequest::get_parameter(const String &key) const {
static String str(0); static String str(0);
return str; return str;
} }
HTTPStatusCode Request::get_status_code() const { HTTPStatusCode WebServerRequest::get_status_code() const {
return _status_code; return _status_code;
} }
void Request::set_status_code(const HTTPStatusCode status_code) { void WebServerRequest::set_status_code(const HTTPStatusCode status_code) {
_status_code = status_code; _status_code = status_code;
} }
void Request::send_redirect(const String &location, const HTTPStatusCode status_code) { void WebServerRequest::send_redirect(const String &location, const HTTPStatusCode status_code) {
} }
void Request::compile_body() { void WebServerRequest::compile_body() {
compiled_body.ensure_capacity(body.size() + head.size() + 15 + 13 + 14 + 15 + 1); compiled_body.ensure_capacity(body.size() + head.size() + 15 + 13 + 14 + 15 + 1);
// 15 // 15
@ -148,29 +148,29 @@ void Request::compile_body() {
// response->setBody(compiled_body); // response->setBody(compiled_body);
} }
void Request::compile_and_send_body() { void WebServerRequest::compile_and_send_body() {
compile_body(); compile_body();
send(); send();
} }
void Request::send() { void WebServerRequest::send() {
// if (connection_closed) { // if (connection_closed) {
// RequestPool::return_request(this); // WebServerRequestPool::return_request(this);
// return; // return;
// } // }
// RequestPool::return_request(this); // WebServerRequestPool::return_request(this);
} }
void Request::send_file(const String &p_file_path) { void WebServerRequest::send_file(const String &p_file_path) {
// RequestPool::return_request(this); // WebServerRequestPool::return_request(this);
} }
void Request::send_error(int error_code) { void WebServerRequest::send_error(int error_code) {
server->get_web_root()->handle_error_send_request(this, error_code); server->get_web_root()->handle_error_send_request(this, error_code);
} }
void Request::reset() { void WebServerRequest::reset() {
session = nullptr; session = nullptr;
server = nullptr; server = nullptr;
_path_stack.clear(); _path_stack.clear();
@ -193,11 +193,11 @@ void Request::reset() {
reference_data.clear(); reference_data.clear();
} }
String Request::parser_get_path() { String WebServerRequest::parser_get_path() {
return ""; return "";
} }
void Request::setup_url_stack() { void WebServerRequest::setup_url_stack() {
_full_path = parser_get_path(); _full_path = parser_get_path();
String path = parser_get_path(); String path = parser_get_path();
@ -218,7 +218,7 @@ void Request::setup_url_stack() {
} }
} }
String Request::get_path(const bool beginning_slash, const bool end_slash) const { String WebServerRequest::get_path(const bool beginning_slash, const bool end_slash) const {
String path; String path;
if (beginning_slash) { if (beginning_slash) {
@ -237,15 +237,15 @@ String Request::get_path(const bool beginning_slash, const bool end_slash) const
return path; return path;
} }
const String &Request::get_path_full() const { const String &WebServerRequest::get_path_full() const {
return _full_path; return _full_path;
} }
const String &Request::get_path_segment(const uint32_t i) const { const String &WebServerRequest::get_path_segment(const uint32_t i) const {
return _path_stack[i]; return _path_stack[i];
} }
const String &Request::get_current_path_segment() const { const String &WebServerRequest::get_current_path_segment() const {
if (_path_stack_pointer >= _path_stack.size()) { if (_path_stack_pointer >= _path_stack.size()) {
// for convenience // for convenience
static const String e_str = ""; static const String e_str = "";
@ -255,7 +255,7 @@ const String &Request::get_current_path_segment() const {
return _path_stack[_path_stack_pointer]; return _path_stack[_path_stack_pointer];
} }
const String &Request::get_next_path_segment() const { const String &WebServerRequest::get_next_path_segment() const {
int pst = _path_stack_pointer + 1; int pst = _path_stack_pointer + 1;
if (pst >= _path_stack.size()) { if (pst >= _path_stack.size()) {
@ -267,15 +267,15 @@ const String &Request::get_next_path_segment() const {
return _path_stack[pst]; return _path_stack[pst];
} }
uint32_t Request::get_path_segment_count() const { uint32_t WebServerRequest::get_path_segment_count() const {
return _path_stack.size(); return _path_stack.size();
} }
uint32_t Request::get_current_segment_index() const { uint32_t WebServerRequest::get_current_segment_index() const {
return _path_stack_pointer; return _path_stack_pointer;
} }
uint32_t Request::get_remaining_segment_count() const { uint32_t WebServerRequest::get_remaining_segment_count() const {
if (_path_stack_pointer > _path_stack.size()) { if (_path_stack_pointer > _path_stack.size()) {
return 0; return 0;
} }
@ -283,15 +283,15 @@ uint32_t Request::get_remaining_segment_count() const {
return _path_stack.size() - _path_stack_pointer; return _path_stack.size() - _path_stack_pointer;
} }
void Request::pop_path() { void WebServerRequest::pop_path() {
_path_stack_pointer -= 1; _path_stack_pointer -= 1;
} }
void Request::push_path() { void WebServerRequest::push_path() {
_path_stack_pointer += 1; _path_stack_pointer += 1;
} }
String Request::get_url_root_parent(const int parent) const { String WebServerRequest::get_url_root_parent(const int parent) const {
String path = "/"; String path = "/";
for (uint32_t i = 0; i < _path_stack_pointer - parent; ++i) { for (uint32_t i = 0; i < _path_stack_pointer - parent; ++i) {
@ -302,7 +302,7 @@ String Request::get_url_root_parent(const int parent) const {
return path; return path;
} }
String Request::get_url_root() const { String WebServerRequest::get_url_root() const {
int pst = _path_stack_pointer + 1; int pst = _path_stack_pointer + 1;
if (pst > _path_stack.size()) { if (pst > _path_stack.size()) {
@ -319,7 +319,7 @@ String Request::get_url_root() const {
return path; return path;
} }
String Request::get_url_root_current() const { String WebServerRequest::get_url_root_current() const {
int pst = _path_stack_pointer + 1; int pst = _path_stack_pointer + 1;
if (pst > _path_stack.size()) { if (pst > _path_stack.size()) {
@ -336,7 +336,7 @@ String Request::get_url_root_current() const {
return path; return path;
} }
String Request::get_url_site() const { String WebServerRequest::get_url_site() const {
String path = get_host(); String path = get_host();
for (uint32_t i = _path_stack_pointer; i < _path_stack.size(); ++i) { for (uint32_t i = _path_stack_pointer; i < _path_stack.size(); ++i) {
@ -347,32 +347,32 @@ String Request::get_url_site() const {
return path; return path;
} }
String Request::get_url_root_parent(const String &add) const { String WebServerRequest::get_url_root_parent(const String &add) const {
return get_url_root_parent() + add; return get_url_root_parent() + add;
} }
String Request::get_url_root(const String &add) const { String WebServerRequest::get_url_root(const String &add) const {
return get_url_root() + add; return get_url_root() + add;
} }
String Request::get_url_site(const String &add) const { String WebServerRequest::get_url_site(const String &add) const {
return get_url_site() + add; return get_url_site() + add;
} }
String Request::get_host() const { String WebServerRequest::get_host() const {
return ""; return "";
} }
void Request::update() { void WebServerRequest::update() {
} }
void Request::pool() { void WebServerRequest::pool() {
} }
Request::Request() { WebServerRequest::WebServerRequest() {
// This value will need benchmarks, 2 MB seems to be just as fast for me as 4 MB, but 1MB is slower // This value will need benchmarks, 2 MB seems to be just as fast for me as 4 MB, but 1MB is slower
// It is a tradeoff on server memory though, as every active download will consume this amount of memory // It is a tradeoff on server memory though, as every active download will consume this amount of memory
// where the file is bigger than this number // where the file is bigger than this number
file_chunk_size = 1 << 21; // 2MB file_chunk_size = 1 << 21; // 2MB
} }
Request::~Request() { WebServerRequest::~WebServerRequest() {
} }

View File

@ -1,8 +1,8 @@
#ifndef REQUEST_H #ifndef WEB_SERVER_REQUEST_H
#define REQUEST_H #define WEB_SERVER_REQUEST_H
#include "core/containers/vector.h" #include "core/ustring.h"
#include "core/string.h" #include "core/vector.h"
#include <map> #include <map>
#include <mutex> #include <mutex>
@ -18,8 +18,7 @@ class Cookie;
class HTTPSession; class HTTPSession;
class WebPermission; class WebPermission;
//Rename to WebServerRequest class WebServerRequest {
class Request {
public: public:
WebServer *server; WebServer *server;
@ -105,8 +104,8 @@ public:
virtual void update(); virtual void update();
virtual void pool(); virtual void pool();
Request(); WebServerRequest();
virtual ~Request(); virtual ~WebServerRequest();
protected: protected:
HTTPStatusCode _status_code; HTTPStatusCode _status_code;
@ -116,13 +115,13 @@ protected:
}; };
template <class T> template <class T>
class RequestPool { class WebServerRequestPool {
public: public:
T *get_request(); T *get_request();
void return_request(T *request); void return_request(T *request);
RequestPool(); WebServerRequestPool();
~RequestPool(); ~WebServerRequestPool();
protected: protected:
std::mutex _mutex; std::mutex _mutex;
@ -130,7 +129,7 @@ protected:
}; };
template <class T> template <class T>
T *RequestPool<T>::get_request() { T *WebServerRequestPool<T>::get_request() {
_mutex.lock(); _mutex.lock();
T *request; T *request;
@ -154,18 +153,18 @@ T *RequestPool<T>::get_request() {
} }
template <class T> template <class T>
void RequestPool<T>::return_request(T *request) { void WebServerRequestPool<T>::return_request(T *request) {
_mutex.lock(); _mutex.lock();
_requests.push_back(request); _requests.push_back(request);
_mutex.unlock(); _mutex.unlock();
} }
template <class T> template <class T>
RequestPool<T>::RequestPool() { WebServerRequestPool<T>::WebServerRequestPool() {
} }
template <class T> template <class T>
RequestPool<T>::~RequestPool() { WebServerRequestPool<T>::~WebServerRequestPool() {
for (uint32_t i = 0; i < _requests.size(); ++i) { for (uint32_t i = 0; i < _requests.size(); ++i) {
delete _requests[i]; delete _requests[i];
} }