v0.7.7 - Prevent sql attacks and rate limiting on subscriptions
This commit is contained in:
@@ -55,6 +55,16 @@ struct subscription {
|
||||
struct subscription* session_next; // Next subscription for this session
|
||||
};
|
||||
|
||||
// Per-IP connection tracking
|
||||
typedef struct ip_connection_info {
|
||||
char ip_address[CLIENT_IP_MAX_LENGTH]; // IP address
|
||||
int active_connections; // Number of active connections from this IP
|
||||
int total_subscriptions; // Total subscriptions across all connections from this IP
|
||||
time_t first_connection; // When first connection from this IP was established
|
||||
time_t last_activity; // Last activity timestamp from this IP
|
||||
struct ip_connection_info* next; // Next in linked list
|
||||
} ip_connection_info_t;
|
||||
|
||||
// Global subscription manager
|
||||
struct subscription_manager {
|
||||
subscription_t* active_subscriptions; // Head of global subscription list
|
||||
@@ -65,6 +75,10 @@ struct subscription_manager {
|
||||
int max_subscriptions_per_client; // Default: 20
|
||||
int max_total_subscriptions; // Default: 5000
|
||||
|
||||
// Per-IP connection tracking
|
||||
ip_connection_info_t* ip_connections; // Head of per-IP connection list
|
||||
pthread_mutex_t ip_tracking_lock; // Thread safety for IP tracking
|
||||
|
||||
// Statistics
|
||||
uint64_t total_created; // Lifetime subscription count
|
||||
uint64_t total_events_broadcast; // Lifetime event broadcast count
|
||||
@@ -81,6 +95,13 @@ int event_matches_filter(cJSON* event, subscription_filter_t* filter);
|
||||
int event_matches_subscription(cJSON* event, subscription_t* subscription);
|
||||
int broadcast_event_to_subscriptions(cJSON* event);
|
||||
|
||||
// Per-IP connection tracking functions
|
||||
ip_connection_info_t* get_or_create_ip_connection(const char* client_ip);
|
||||
void update_ip_connection_activity(const char* client_ip);
|
||||
void remove_ip_connection(const char* client_ip);
|
||||
int get_total_subscriptions_for_ip(const char* client_ip);
|
||||
int get_active_connections_for_ip(const char* client_ip);
|
||||
|
||||
// Database logging functions
|
||||
void log_subscription_created(const subscription_t* sub);
|
||||
void log_subscription_closed(const char* sub_id, const char* client_ip, const char* reason);
|
||||
|
||||
Reference in New Issue
Block a user