2022-06-25 01:55:54 +02:00
|
|
|
#ifndef WEB_SERVER_H
|
|
|
|
#define WEB_SERVER_H
|
|
|
|
|
2022-06-26 21:34:29 +02:00
|
|
|
#include "core/os/rw_lock.h"
|
|
|
|
#include "scene/main/node.h"
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-06-26 21:34:29 +02:00
|
|
|
class WebServerRequest;
|
2022-06-25 01:55:54 +02:00
|
|
|
class WebNode;
|
2022-06-27 14:16:23 +02:00
|
|
|
class WebRoot;
|
|
|
|
class HTTPSessionManager;
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-06-26 21:34:29 +02:00
|
|
|
class WebServer : public Node {
|
|
|
|
GDCLASS(WebServer, Node);
|
2022-06-25 01:55:54 +02:00
|
|
|
|
|
|
|
public:
|
2022-07-07 21:44:14 +02:00
|
|
|
enum {
|
|
|
|
NOTIFICATION_WEB_SERVER_STARTED = 2000,
|
|
|
|
NOTIFICATION_WEB_SERVER_STOPPED = 2001,
|
|
|
|
NOTIFICATION_WEB_SERVER_WRITE_LOCK_ACQUIRED = 2002,
|
|
|
|
};
|
2022-06-26 21:34:29 +02:00
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
bool get_is_running();
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
WebNode *get_web_root();
|
2022-06-26 21:34:29 +02:00
|
|
|
Node *get_web_root_bind();
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-06-27 14:16:23 +02:00
|
|
|
HTTPSessionManager *get_session_manager();
|
|
|
|
Node *get_session_manager_bind();
|
|
|
|
|
2022-06-27 01:03:01 +02:00
|
|
|
void server_handle_request(Ref<WebServerRequest> request);
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
// The server is expected to be running in a heavily multi threaded setting,
|
|
|
|
// if you want to safely change to root, or to heavily change the tree
|
|
|
|
// you need to lock the tree, however triggering a change like this using a web interface
|
|
|
|
// from withing a server would cause a deadlock, so if you want to do something like this
|
|
|
|
// you can call request_write_lock() while handling a request, then
|
|
|
|
// do the desired change when your node receives NOTIFICATION_WEB_SERVER_WRITE_LOCK_ACQUIRED
|
|
|
|
// Also note that every WebNode has a lock similar to this for the same reason,
|
|
|
|
// if you want to only change a certain WebNode's children, only lock that particular node.
|
2022-06-26 21:34:29 +02:00
|
|
|
void request_write_lock();
|
2022-06-25 01:55:54 +02:00
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
void refresh_root();
|
|
|
|
|
2022-06-27 14:16:23 +02:00
|
|
|
void start();
|
|
|
|
void stop();
|
|
|
|
|
|
|
|
virtual void _start();
|
|
|
|
virtual void _stop();
|
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
String get_configuration_warning() const;
|
|
|
|
|
2022-06-25 01:55:54 +02:00
|
|
|
WebServer();
|
2022-06-26 21:34:29 +02:00
|
|
|
~WebServer();
|
2022-06-25 01:55:54 +02:00
|
|
|
|
|
|
|
protected:
|
2022-07-07 21:44:14 +02:00
|
|
|
void _notification(int p_what);
|
|
|
|
|
2022-06-26 21:34:29 +02:00
|
|
|
static void _bind_methods();
|
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
bool _is_running;
|
2022-06-26 21:34:29 +02:00
|
|
|
|
2022-07-07 21:44:14 +02:00
|
|
|
WebNode *_web_root;
|
2022-06-27 14:16:23 +02:00
|
|
|
HTTPSessionManager *_session_manager;
|
|
|
|
|
2022-06-27 14:59:09 +02:00
|
|
|
//TODO this should be atomic
|
2022-06-26 21:34:29 +02:00
|
|
|
bool _write_lock_requested;
|
|
|
|
RWLock _rw_lock;
|
2022-06-25 01:55:54 +02:00
|
|
|
};
|
|
|
|
|
2022-06-26 21:34:29 +02:00
|
|
|
#endif
|