mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-25 18:39:18 +01:00
Renamed Request to WebServerRequest.
This commit is contained in:
parent
2a9b32847f
commit
8211115346
@ -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() {
|
||||||
}
|
}
|
@ -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];
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user