ascii-chat 0.8.38
Real-time terminal-based video chat with ASCII art conversion
Loading...
Searching...
No Matches
errors.c File Reference

Network error handling utilities implementation. More...

Go to the source code of this file.

Functions

asciichat_error_t send_error_packet (socket_t sockfd, asciichat_error_t error_code)
 
asciichat_error_t send_error_packet_message (socket_t sockfd, asciichat_error_t error_code, const char *message)
 
bool check_and_record_rate_limit (rate_limiter_t *rate_limiter, const char *client_ip, rate_event_type_t event_type, socket_t client_socket, const char *operation_name)
 
bool check_and_record_packet_rate_limit (rate_limiter_t *rate_limiter, const char *client_ip, socket_t client_socket, packet_type_t packet_type)
 

Detailed Description

Network error handling utilities implementation.

Definition in file errors.c.

Function Documentation

◆ check_and_record_packet_rate_limit()

bool check_and_record_packet_rate_limit ( rate_limiter_t *  rate_limiter,
const char *  client_ip,
socket_t  client_socket,
packet_type_t  packet_type 
)

Definition at line 54 of file errors.c.

55 {
56 // Map packet type to rate event type
57 rate_event_type_t event_type;
58 const char *packet_name;
59
60 switch (packet_type) {
61 case PACKET_TYPE_IMAGE_FRAME:
62 event_type = RATE_EVENT_IMAGE_FRAME;
63 packet_name = "IMAGE_FRAME";
64 break;
65
66 case PACKET_TYPE_AUDIO_BATCH:
67 case PACKET_TYPE_AUDIO_OPUS_BATCH:
68 event_type = RATE_EVENT_AUDIO;
69 packet_name = "AUDIO";
70 break;
71
72 case PACKET_TYPE_PING:
73 case PACKET_TYPE_PONG:
74 event_type = RATE_EVENT_PING;
75 packet_name = "PING";
76 break;
77
78 case PACKET_TYPE_CLIENT_JOIN:
79 event_type = RATE_EVENT_CLIENT_JOIN;
80 packet_name = "CLIENT_JOIN";
81 break;
82
83 case PACKET_TYPE_CLIENT_CAPABILITIES:
84 case PACKET_TYPE_STREAM_START:
85 case PACKET_TYPE_STREAM_STOP:
86 case PACKET_TYPE_CLIENT_LEAVE:
87 event_type = RATE_EVENT_CONTROL;
88 packet_name = "CONTROL";
89 break;
90
91 default:
92 // No rate limiting for other packet types
93 return true;
94 }
95
96 // Use the existing check_and_record_rate_limit function
97 return check_and_record_rate_limit(rate_limiter, client_ip, event_type, client_socket, packet_name);
98}
bool check_and_record_rate_limit(rate_limiter_t *rate_limiter, const char *client_ip, rate_event_type_t event_type, socket_t client_socket, const char *operation_name)
Definition errors.c:38

References check_and_record_rate_limit().

Referenced by process_decrypted_packet().

◆ check_and_record_rate_limit()

bool check_and_record_rate_limit ( rate_limiter_t *  rate_limiter,
const char *  client_ip,
rate_event_type_t  event_type,
socket_t  client_socket,
const char *  operation_name 
)

Definition at line 38 of file errors.c.

39 {
40 bool allowed = false;
41 asciichat_error_t rate_check = rate_limiter_check(rate_limiter, client_ip, event_type, NULL, &allowed);
42
43 if (rate_check != ASCIICHAT_OK || !allowed) {
44 send_error_packet_message(client_socket, ERROR_RATE_LIMITED, "Rate limit exceeded. Please try again later.");
45 log_warn("Rate limit exceeded for %s from %s", operation_name, client_ip);
46 return false;
47 }
48
49 // Record the rate limit event
50 rate_limiter_record(rate_limiter, client_ip, event_type);
51 return true;
52}
asciichat_error_t send_error_packet_message(socket_t sockfd, asciichat_error_t error_code, const char *message)
Definition errors.c:15
asciichat_error_t rate_limiter_record(rate_limiter_t *limiter, const char *ip_address, rate_event_type_t event_type)
Definition rate_limit.c:145
asciichat_error_t rate_limiter_check(rate_limiter_t *limiter, const char *ip_address, rate_event_type_t event_type, const rate_limit_config_t *config, bool *allowed)
Definition rate_limit.c:128

References rate_limiter_check(), rate_limiter_record(), and send_error_packet_message().

Referenced by check_and_record_packet_rate_limit().

◆ send_error_packet()

asciichat_error_t send_error_packet ( socket_t  sockfd,
asciichat_error_t  error_code 
)

Definition at line 11 of file errors.c.

11 {
12 return send_error_packet_message(sockfd, error_code, asciichat_error_string(error_code));
13}
asciichat_error_t error_code

References error_code, and send_error_packet_message().

◆ send_error_packet_message()

asciichat_error_t send_error_packet_message ( socket_t  sockfd,
asciichat_error_t  error_code,
const char *  message 
)

Definition at line 15 of file errors.c.

15 {
16 if (sockfd == INVALID_SOCKET_VALUE) {
17 return SET_ERRNO(ERROR_INVALID_PARAM, "Invalid socket");
18 }
19
20 if (!message) {
21 message = asciichat_error_string(error_code);
22 }
23
24 // Construct ACIP error packet
25 acip_error_t error = {0};
26 error.error_code = (uint8_t)error_code;
27 SAFE_STRNCPY(error.error_message, message, sizeof(error.error_message));
28
29 // Send error packet
30 int result = send_packet(sockfd, PACKET_TYPE_ACIP_ERROR, &error, sizeof(error));
31 if (result < 0) {
32 return SET_ERRNO(ERROR_NETWORK, "Failed to send error packet");
33 }
34
35 return ASCIICHAT_OK;
36}
int send_packet(socket_t sockfd, packet_type_t type, const void *data, size_t len)
Send a basic packet without encryption.
Definition packet.c:753

References error_code, and send_packet().

Referenced by check_and_record_rate_limit(), and send_error_packet().