| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  | #ifndef RC_API_REQUEST_H
 | 
					
						
							|  |  |  | #define RC_API_REQUEST_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rc_error.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  | #include <stddef.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A block of memory for variable length data (like strings and arrays). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  | typedef struct rc_api_buffer_chunk_t { | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  |   /* The current location where data is being written */ | 
					
						
							|  |  |  |   char* write; | 
					
						
							|  |  |  |   /* The first byte past the end of data where writing cannot occur */ | 
					
						
							|  |  |  |   char* end; | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  |   /* The first byte of the data */ | 
					
						
							|  |  |  |   char* start; | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  |   /* The next block in the allocated memory chain */ | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  |   struct rc_api_buffer_chunk_t* next; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | rc_api_buffer_chunk_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A preallocated block of memory for variable length data (like strings and arrays). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct rc_api_buffer_t { | 
					
						
							|  |  |  |   /* The chunk data (will point at the local data member) */ | 
					
						
							|  |  |  |   struct rc_api_buffer_chunk_t chunk; | 
					
						
							|  |  |  |   /* Small chunk of memory pre-allocated for the chunk */ | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  |   char data[256]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | rc_api_buffer_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A constructed request to send to the retroachievements server. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct rc_api_request_t { | 
					
						
							|  |  |  |   /* The URL to send the request to (contains protocol, host, path, and query args) */ | 
					
						
							|  |  |  |   const char* url; | 
					
						
							|  |  |  |   /* Additional query args that should be sent via a POST command. If null, GET may be used */ | 
					
						
							|  |  |  |   const char* post_data; | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  |   /* The HTTP Content-Type of the POST data. */ | 
					
						
							|  |  |  |   const char* content_type; | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /* Storage for the url and post_data */ | 
					
						
							|  |  |  |   rc_api_buffer_t buffer; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | rc_api_request_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Common attributes for all server responses. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct rc_api_response_t { | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  |   /* Server-provided success indicator (non-zero on success, zero on failure) */ | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  |   int succeeded; | 
					
						
							|  |  |  |   /* Server-provided message associated to the failure */ | 
					
						
							|  |  |  |   const char* error_message; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Storage for the response data */ | 
					
						
							|  |  |  |   rc_api_buffer_t buffer; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | rc_api_response_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void rc_api_destroy_request(rc_api_request_t* request); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void rc_api_set_host(const char* hostname); | 
					
						
							|  |  |  | void rc_api_set_image_host(const char* hostname); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-09 09:39:42 +00:00
										 |  |  | typedef struct rc_api_server_response_t { | 
					
						
							|  |  |  |   /* Pointer to the data returned from the server */ | 
					
						
							|  |  |  |   const char* body; | 
					
						
							|  |  |  |   /* Length of data returned from the server (Content-Length) */ | 
					
						
							|  |  |  |   size_t body_length; | 
					
						
							|  |  |  |   /* HTTP status code returned from the server */ | 
					
						
							|  |  |  |   int http_status_code; | 
					
						
							|  |  |  | } rc_api_server_response_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-18 12:46:12 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* RC_API_REQUEST_H */
 |