| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-20 21:41:37 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** \defgroup ssb SSB | 
					
						
							|  |  |  | ** Everything about SSB, SHS, and MUXRPC happens here. | 
					
						
							|  |  |  | ** @{ | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-21 21:36:51 +00:00
										 |  |  | #include "quickjs.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | #include <stdbool.h>
 | 
					
						
							|  |  |  | #include <stddef.h>
 | 
					
						
							|  |  |  | #include <stdint.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_binary = 0x0, | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_utf8 = 0x1, | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_json = 0x2, | 
					
						
							|  |  |  | 	k_ssb_rpc_mask_type = 0x3, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_end_error = 0x4, | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_stream = 0x8, | 
					
						
							| 
									
										
										
										
											2023-08-20 19:55:59 +00:00
										 |  |  | 	k_ssb_rpc_mask_message = 0xC, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	k_ssb_rpc_mask_send = 0xf, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	k_ssb_rpc_flag_new_request = 0x10, | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	k_ssb_blob_bytes_max = 5 * 1024 * 1024, | 
					
						
							| 
									
										
										
										
											2024-08-14 21:07:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	k_ssb_peer_exchange_expires_seconds = 60 * 60, | 
					
						
							| 
									
										
										
										
											2025-01-08 20:16:17 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	k_max_private_message_recipients = 8, | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-13 13:28:48 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Flags affecting signature verification. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | typedef enum _tf_ssb_verify_flags_t | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	k_tf_ssb_verify_flag_debug = 1, | 
					
						
							|  |  |  | } tf_ssb_verify_flags_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** The type of change to a set of connections. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef enum _tf_ssb_change_t | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	k_tf_ssb_change_create, | 
					
						
							|  |  |  | 	k_tf_ssb_change_connect, | 
					
						
							|  |  |  | 	k_tf_ssb_change_remove, | 
					
						
							| 
									
										
										
										
											2024-05-02 19:02:23 -04:00
										 |  |  | 	k_tf_ssb_change_update, | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | } tf_ssb_change_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 20:02:46 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** The origin of a broadcast entry. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-08-14 19:23:01 -04:00
										 |  |  | typedef enum _tf_ssb_broadcast_origin_t | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	k_tf_ssb_broadcast_origin_discovery, | 
					
						
							|  |  |  | 	k_tf_ssb_broadcast_origin_room, | 
					
						
							|  |  |  | 	k_tf_ssb_broadcast_origin_peer_exchange, | 
					
						
							|  |  |  | } tf_ssb_broadcast_origin_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-17 13:21:33 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Flags describing the structure of a message. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-03-13 19:40:09 -04:00
										 |  |  | typedef enum _tf_ssb_message_flags_t | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-03-17 13:21:33 -04:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	** The sequence field precedes the author field if specified.  The | 
					
						
							|  |  |  | 	** other way around, otherwise. | 
					
						
							|  |  |  | 	*/ | 
					
						
							| 
									
										
										
										
											2024-03-13 19:40:09 -04:00
										 |  |  | 	k_tf_ssb_message_flag_sequence_before_author = 1, | 
					
						
							|  |  |  | } tf_ssb_message_flags_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Flags affecting an SSB connection. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | typedef enum _tf_ssb_connect_flags_t | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	k_tf_ssb_connect_flag_one_shot = 0x1, | 
					
						
							| 
									
										
										
										
											2025-01-04 17:08:36 -05:00
										 |  |  | 	k_tf_ssb_connect_flag_do_not_store = 0x2, | 
					
						
							| 
									
										
										
										
											2025-01-19 16:00:37 -05:00
										 |  |  | 	k_tf_ssb_connect_flag_use_invite = 0x4, | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | } tf_ssb_connect_flags_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** An SSB instance. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef struct _tf_ssb_t tf_ssb_t; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** An SSB connection. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef struct _tf_ssb_connection_t tf_ssb_connection_t; | 
					
						
							| 
									
										
										
										
											2025-01-03 13:59:25 -05:00
										 |  |  | /** A connection's EBT state. */ | 
					
						
							|  |  |  | typedef struct _tf_ssb_ebt_t tf_ssb_ebt_t; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** A trace instance. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef struct _tf_trace_t tf_trace_t; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** An SQLite database handle. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef struct sqlite3 sqlite3; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** An event loop. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | typedef struct uv_loop_s uv_loop_t; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /** A socket address. */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | struct sockaddr_in; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | enum | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 	k_id_base64_len = 57, | 
					
						
							|  |  |  | 	k_id_bin_len = 32, | 
					
						
							| 
									
										
										
										
											2022-11-28 02:18:58 +00:00
										 |  |  | 	k_blob_id_len = 53, | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Statistics about an SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | typedef struct _tf_ssb_stats_t | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of active connections. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	int connections; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of active hosts discovered by network broadcast. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	int broadcasts; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of messages stored. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	int messages_stored; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of blobs stored. */ | 
					
						
							| 
									
										
										
										
											2023-01-18 22:52:54 +00:00
										 |  |  | 	int blobs_stored; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of RPC messages received. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	int rpc_in; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of RPC messages sent. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	int rpc_out; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of active RPC requests. */ | 
					
						
							| 
									
										
										
										
											2022-07-09 22:00:33 +00:00
										 |  |  | 	int request_count; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Number of callbacks registered. */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 	struct | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int rpc; | 
					
						
							|  |  |  | 		int connections_changed; | 
					
						
							|  |  |  | 		int message_added; | 
					
						
							|  |  |  | 		int blob_want_added; | 
					
						
							|  |  |  | 		int broadcasts_changed; | 
					
						
							|  |  |  | 	} callbacks; | 
					
						
							|  |  |  | } tf_ssb_stats_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** State about requesting blobs. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | typedef struct _tf_ssb_blob_wants_t | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** The request number of the blob.wants RPC call. */ | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | 	int32_t request_number; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** The number of blob wants we are waiting for a response to. */ | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | 	int wants_sent; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** The last blob ID considered. */ | 
					
						
							| 
									
										
										
										
											2024-01-11 01:38:30 +00:00
										 |  |  | 	char last_id[k_blob_id_len]; | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | } tf_ssb_blob_wants_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A queue for storing messages. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | typedef struct _tf_ssb_store_queue_t | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** The first node in the queue. */ | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | 	void* head; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** The last node in the queue. */ | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | 	void* tail; | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 	/** Whether the queue is currently running. */ | 
					
						
							| 
									
										
										
										
											2024-01-11 01:38:30 +00:00
										 |  |  | 	bool running; | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | } tf_ssb_store_queue_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Create an SSB instance. | 
					
						
							|  |  |  | ** @param loop The event loop to use or NULL to create a new one. | 
					
						
							|  |  |  | ** @param context The JS context to use or NULL to create a new one. | 
					
						
							|  |  |  | ** @param db_path The path to the SQLite database to use. | 
					
						
							|  |  |  | ** @param network_key The SSB network key to use or NULL to use the standard key. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-03-02 15:01:09 -05:00
										 |  |  | tf_ssb_t* tf_ssb_create(uv_loop_t* loop, JSContext* context, const char* db_path, const char* network_key); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Destroy an SSB instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance to destroy. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_destroy(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-16 12:41:48 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Checking if the SSB instance is in the process of shutting down. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return true If the SSB instance is shutting down. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_is_shutting_down(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Start optional periodic work. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-11-08 23:03:21 +00:00
										 |  |  | void tf_ssb_start_periodic(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Control logging verbosity. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param verbose True to log messages for every RPC message sent and received. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-11-09 00:28:34 +00:00
										 |  |  | void tf_ssb_set_verbose(tf_ssb_t* ssb, bool verbose); | 
					
						
							| 
									
										
										
										
											2023-11-08 23:03:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-14 21:37:11 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Reduce logging verbosity. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param quiet Disable unnecessary messages. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_set_quiet(tf_ssb_t* ssb, bool quiet); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Acquire an SQLite database for unrestricted reading.  Release qith tf_ssb_release_db_reader(). | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return A database with full read access to the database. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-02-08 01:29:44 +00:00
										 |  |  | sqlite3* tf_ssb_acquire_db_reader(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Acquire an SQLite database for restricted reading.  Release qith | 
					
						
							|  |  |  | ** tf_ssb_release_db_reader(). | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return A database with read access to a safe subset of the database. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-25 19:41:54 +00:00
										 |  |  | sqlite3* tf_ssb_acquire_db_reader_restricted(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Release a database acquired with tf_ssb_acquire_db_reader() or | 
					
						
							|  |  |  | ** tf_ssb_acquire_db_reader_restricted(). | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param db The database. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-02-08 01:29:44 +00:00
										 |  |  | void tf_ssb_release_db_reader(tf_ssb_t* ssb, sqlite3* db); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Acquire an SQLite database with full write access to the database.  Release | 
					
						
							|  |  |  | ** with tf_ssb_release_db_writer(). | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The writable database. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-06-15 00:27:49 +00:00
										 |  |  | sqlite3* tf_ssb_acquire_db_writer(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Release a database acquired with tf_ssb_acquire_db_writer(). | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param db The database. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-06-15 00:27:49 +00:00
										 |  |  | void tf_ssb_release_db_writer(tf_ssb_t* ssb, sqlite3* db); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the SSB instance's event loop. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The loop. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | uv_loop_t* tf_ssb_get_loop(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Generate a public/private key pair for the SSB instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_generate_keys(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Generate a public/private key pair and store in buffers. | 
					
						
							|  |  |  | ** @param[out] out_public Buffer to receive the public key. | 
					
						
							|  |  |  | ** @param public_size Size of the public key buffer. | 
					
						
							|  |  |  | ** @param[out] out_private Buffer to receive the private key. | 
					
						
							|  |  |  | ** @param private_size Size of the private key buffer. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-07-14 01:01:14 +00:00
										 |  |  | void tf_ssb_generate_keys_buffer(char* out_public, size_t public_size, char* out_private, size_t private_size); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the private key of the SSB instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param[out] out_private Buffer to receive the private key. | 
					
						
							|  |  |  | ** @param private_size The size of the private key buffer. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-06-01 22:53:44 +00:00
										 |  |  | void tf_ssb_get_private_key(tf_ssb_t* ssb, uint8_t* out_private, size_t private_size); | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Set the trace instance to use for the SSB instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param trace The trace instance to use. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_set_trace(tf_ssb_t* ssb, tf_trace_t* trace); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the SSB instance's trace instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The trace instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | tf_trace_t* tf_ssb_get_trace(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the SSB istance's JS context. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The JS context. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | JSContext* tf_ssb_get_context(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Begin listening for SSB discovery messages. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param linger True if listening for broadcasts should keep the event loop alive. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_broadcast_listener_start(tf_ssb_t* ssb, bool linger); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Begin sending SSB discovevry messages. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 13:48:28 +00:00
										 |  |  | void tf_ssb_broadcast_sender_start(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Run the SSB instance until there is no work to do or stopped. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_run(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Sign an SSB message. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param author The author's public key. | 
					
						
							|  |  |  | ** @param private_key The author's private key. | 
					
						
							|  |  |  | ** @param message The message to sign. | 
					
						
							| 
									
										
										
										
											2024-06-16 07:51:06 -04:00
										 |  |  | ** @param previous_id The ID of the previous message in the feed.  Optional. | 
					
						
							|  |  |  | ** @param previous_sequence The sequence number of the previous message in the feed.  Optional. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | ** @return The signed message. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2025-06-11 20:12:23 -04:00
										 |  |  | JSValue tf_ssb_sign_message(tf_ssb_t* ssb, const char* author, const uint8_t* private_key, JSValue message, const char* previous_id, int32_t previous_sequence); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the server's identity. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param[out] out_id A buffer populated with the identity. | 
					
						
							|  |  |  | ** @param out_id_size The size of the identity buffer. | 
					
						
							|  |  |  | ** @return True if the identity was successfully retrieved. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | bool tf_ssb_whoami(tf_ssb_t* ssb, char* out_id, size_t out_id_size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Call a callback for each active host discovered by network discovery broadcast. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback. | 
					
						
							|  |  |  | ** @param user_data User data for the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-08-14 19:40:20 -04:00
										 |  |  | void tf_ssb_visit_broadcasts(tf_ssb_t* ssb, | 
					
						
							|  |  |  | 	void (*callback)(const char* host, const struct sockaddr_in* addr, tf_ssb_broadcast_origin_t origin, tf_ssb_connection_t* tunnel, const uint8_t* pub, void* user_data), | 
					
						
							|  |  |  | 	void* user_data); | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 21:07:16 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Add a broadcast entry. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param connection The connection string to add. | 
					
						
							|  |  |  | ** @param origin The origin of the broadcast entry. | 
					
						
							|  |  |  | ** @param expires_seconds How long the broadcast entry should last. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_add_broadcast(tf_ssb_t* ssb, const char* connection, tf_ssb_broadcast_origin_t origin, int64_t expires_seconds); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the identities of all active connections. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return A NULL-terminated array of SSB identities.  Free with tf_free(). | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | const char** tf_ssb_get_connection_ids(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Retrieve a list of active connections. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param[out] out_connections An array to be populated with the connections. | 
					
						
							|  |  |  | ** @param out_connections_count The size of the connections array. | 
					
						
							|  |  |  | ** @return The number of connections populated in out_connections. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | int tf_ssb_get_connections(tf_ssb_t* ssb, tf_ssb_connection_t** out_connections, int out_connections_count); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 22:12:41 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Callback for completing establishing a connection. | 
					
						
							|  |  |  | ** @param connection The established connection if successful or null. | 
					
						
							|  |  |  | ** @param reason The reason for failure if the connection failed. | 
					
						
							|  |  |  | ** @param user_data User data. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | typedef void(tf_ssb_connect_callback_t)(tf_ssb_connection_t* connection, const char* reason, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Establish an SHS connection with a host. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param host The host name or address. | 
					
						
							|  |  |  | ** @param port The host's SHS port. | 
					
						
							|  |  |  | ** @param key The host's SSB identity. | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | ** @param connect_flags Flags affecting the connection. | 
					
						
							| 
									
										
										
										
											2024-11-11 22:12:41 -05:00
										 |  |  | ** @param callback Completion callback. | 
					
						
							|  |  |  | ** @param user_data User data to be passed to the callback. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-11-11 22:12:41 -05:00
										 |  |  | void tf_ssb_connect(tf_ssb_t* ssb, const char* host, int port, const uint8_t* key, int connect_flags, tf_ssb_connect_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Establish an SHS connection with a host by string address. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param address The address. | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | ** @param connect_flags Flags affecting the connection. | 
					
						
							| 
									
										
										
										
											2024-11-11 22:12:41 -05:00
										 |  |  | ** @param callback Completion callback. | 
					
						
							|  |  |  | ** @param user_data User data to be passed to the callback. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-11-11 22:12:41 -05:00
										 |  |  | void tf_ssb_connect_str(tf_ssb_t* ssb, const char* address, int connect_flags, tf_ssb_connect_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Begin listening for SHS connections on the given port. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param port The port number. | 
					
						
							| 
									
										
										
										
											2024-03-07 21:03:14 -05:00
										 |  |  | ** @return The assigned port on success or 0 on failure. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-03-07 21:03:14 -05:00
										 |  |  | int tf_ssb_server_open(tf_ssb_t* ssb, int port); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-25 09:50:28 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Determine the port that a server is listening on. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The port number, or 0 if not bound. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | int tf_ssb_server_get_port(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Stop listening for SHS connections. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_server_close(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Close all active SHS connections. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | ** @param reason Reason for the close. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | void tf_ssb_close_all(tf_ssb_t* ssb, const char* reason); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Send a graceful close message to all active SHS connections. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_send_close(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Convert an SSB identity from string to binary. | 
					
						
							|  |  |  | ** @param[out] bin A buffer to receive the binary identity. | 
					
						
							|  |  |  | ** @param str The string identity. | 
					
						
							|  |  |  | ** @return True if the conversion was successful. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | bool tf_ssb_id_str_to_bin(uint8_t* bin, const char* str); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Convert an SSB identity from binary to string. | 
					
						
							|  |  |  | ** @param[out] str A buffer to receive the identity string. | 
					
						
							|  |  |  | ** @param str_size The size of the string buffer. | 
					
						
							|  |  |  | ** @param bin The binary identity. | 
					
						
							|  |  |  | ** @return True if the conversion was successful. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | bool tf_ssb_id_bin_to_str(char* str, size_t str_size, const uint8_t* bin); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Verify a message's signature and remove the signature if successful. | 
					
						
							|  |  |  | ** @param context A JS context. | 
					
						
							|  |  |  | ** @param val The message. | 
					
						
							| 
									
										
										
										
											2025-04-13 13:28:48 -04:00
										 |  |  | ** @param verify_flags Verification options of type tf_ssb_verify_flags_t. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | ** @param[out] out_id A buffer to receive the message's identity. | 
					
						
							|  |  |  | ** @param out_id_size The size of out_id. | 
					
						
							|  |  |  | ** @param[out] out_signature A buffer to receive the message's signature. | 
					
						
							|  |  |  | ** @param out_signature_size The size of out_signature. | 
					
						
							| 
									
										
										
										
											2024-03-13 19:40:09 -04:00
										 |  |  | ** @param[out] out_flags tf_ssb_message_flags_t describing the message. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | ** @return True if the signature is valid and was successfully extracted. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2025-04-13 13:28:48 -04:00
										 |  |  | bool tf_ssb_verify_and_strip_signature( | 
					
						
							|  |  |  | 	JSContext* context, JSValue val, int verify_flags, char* out_id, size_t out_id_size, char* out_signature, size_t out_signature_size, int* out_flags); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Determine the message identifier. | 
					
						
							|  |  |  | ** @param context A JS context. | 
					
						
							|  |  |  | ** @param message The message. | 
					
						
							|  |  |  | ** @param[out] out_id A buffer to receive the identifier. | 
					
						
							|  |  |  | ** @param out_id_size The size of out_id. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | void tf_ssb_calculate_message_id(JSContext* context, JSValue message, char* out_id, size_t out_id_size); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** A function called on completion of tf_ssb_verify_strip_and_store_message(). | 
					
						
							|  |  |  | ** @param id The stored message identifier. | 
					
						
							|  |  |  | ** @param verified True if the message was verified successfully. | 
					
						
							|  |  |  | ** @param is_new True if the message was newly added to the database. | 
					
						
							|  |  |  | ** @param user_data The user data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_verify_strip_store_callback_t)(const char* id, bool verified, bool is_new, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Verify a message's signature, remove the signature, and store the message in the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param value The message. | 
					
						
							|  |  |  | ** @param callback A callback called when the operation completed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | void tf_ssb_verify_strip_and_store_message(tf_ssb_t* ssb, JSValue value, tf_ssb_verify_strip_store_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Check if a connection is an outgoing connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return True if the connection is outgoing. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 00:25:38 +00:00
										 |  |  | bool tf_ssb_connection_is_client(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the hostname of the remote end of a connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The hostname or address. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | const char* tf_ssb_connection_get_host(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get a connection's remote port number. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The port number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | int tf_ssb_connection_get_port(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** If a connection is a tunnel, get its parent connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The parent connection if the connection is tunneled or NULL. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-25 18:22:09 +00:00
										 |  |  | tf_ssb_connection_t* tf_ssb_connection_get_tunnel(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get a connection's SSB instance. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | tf_ssb_t* tf_ssb_connection_get_ssb(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get a connection's JS context. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The JS context. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | JSContext* tf_ssb_connection_get_context(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Close a connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							| 
									
										
										
										
											2024-12-26 20:12:04 -05:00
										 |  |  | ** @param reason Human-readable reason for closing the connection. | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-12-26 20:12:04 -05:00
										 |  |  | void tf_ssb_connection_close(tf_ssb_connection_t* connection, const char* reason); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Check whether a connection is connected. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return True if the connection is alive. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-17 02:17:29 +00:00
										 |  |  | bool tf_ssb_connection_is_connected(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-02 12:35:58 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Check whether a connection is in the process of closing. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return True if the connection is closing. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_connection_is_closing(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the next outgoing request number for a connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The next request number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | int32_t tf_ssb_connection_next_request_number(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get an active connection by its identity. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param id The SSB identity. | 
					
						
							|  |  |  | ** @return The connection if found or NULL. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-11-02 23:34:44 +00:00
										 |  |  | tf_ssb_connection_t* tf_ssb_connection_get(tf_ssb_t* ssb, const char* id); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the SSB identity of a connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @param[out] out_id A buffer to be populated with the identity. | 
					
						
							|  |  |  | ** @param out_id_size The size of out_id. | 
					
						
							|  |  |  | ** @return True if the identity was retrieved. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-01-02 18:10:00 +00:00
										 |  |  | bool tf_ssb_connection_get_id(tf_ssb_connection_t* connection, char* out_id, size_t out_id_size); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the JS object representing a connection. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The object. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-09-06 17:50:38 +00:00
										 |  |  | JSValue tf_ssb_connection_get_object(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when a callback is cleaned up. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param user_data User data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_callback_cleanup_t)(tf_ssb_t* ssb, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when the connection list changes. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param change The type of change. | 
					
						
							|  |  |  | ** @param connection The connection that changed. | 
					
						
							|  |  |  | ** @param user_data User data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_connections_changed_callback_t)(tf_ssb_t* ssb, tf_ssb_change_t change, tf_ssb_connection_t* connection, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a callback when the connection list changes. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback to register. | 
					
						
							|  |  |  | ** @param cleanup The cleanup callback to register. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callbacks. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_add_connections_changed_callback(tf_ssb_t* ssb, tf_ssb_connections_changed_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-03 18:12:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback when the connection list changes. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback. | 
					
						
							|  |  |  | ** @param user_data The user data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_remove_connections_changed_callback(tf_ssb_t* ssb, tf_ssb_connections_changed_callback_t* callback, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when a new broadcast is received or one expires. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param user_data The user data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_broadcasts_changed_callback_t)(tf_ssb_t* ssb, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a callback when broadcasts change. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param cleanup A function to call when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_add_broadcasts_changed_callback(tf_ssb_t* ssb, tf_ssb_broadcasts_changed_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback registered for when broadcasts changed. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param user_data The user data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_remove_broadcasts_changed_callback(tf_ssb_t* ssb, tf_ssb_broadcasts_changed_callback_t* callback, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when a message is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							| 
									
										
										
										
											2025-03-16 22:04:06 -04:00
										 |  |  | ** @param author The author identity. | 
					
						
							|  |  |  | ** @param sequence The message sequence number. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param id The message identifier. | 
					
						
							|  |  |  | ** @param user_data The user data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2025-06-11 20:12:23 -04:00
										 |  |  | typedef void(tf_ssb_message_added_callback_t)(tf_ssb_t* ssb, const char* author, int32_t sequence, const char* id, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a callback called when a message is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param cleanup A function to call when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-11 00:05:07 +00:00
										 |  |  | void tf_ssb_add_message_added_callback(tf_ssb_t* ssb, tf_ssb_message_added_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback registered for when a message is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param user_data User data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-11 00:05:07 +00:00
										 |  |  | void tf_ssb_remove_message_added_callback(tf_ssb_t* ssb, tf_ssb_message_added_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Call all callbacks registered for when a message is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							| 
									
										
										
										
											2025-03-16 22:04:06 -04:00
										 |  |  | ** @param author The message author's identity. | 
					
						
							|  |  |  | ** @param sequence The message sequence number. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param id The message identity added. | 
					
						
							|  |  |  | ** @param message_with_keys The message added in the format required if keys are requested. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2025-06-11 20:12:23 -04:00
										 |  |  | void tf_ssb_notify_message_added(tf_ssb_t* ssb, const char* author, int32_t sequence, const char* id, JSValue message_with_keys); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-08-13 18:26:42 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when a blob is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param id The blob identifier. | 
					
						
							|  |  |  | ** @param user_data The user data. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | typedef void(tf_ssb_blob_stored_callback_t)(tf_ssb_t* ssb, const char* id, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a callback called when a blob is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param cleanup A function to call when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_add_blob_stored_callback(tf_ssb_t* ssb, tf_ssb_blob_stored_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback registered for when a blob is added to the database. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback function. | 
					
						
							|  |  |  | ** @param user_data User data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_remove_blob_stored_callback(tf_ssb_t* ssb, tf_ssb_blob_stored_callback_t* callback, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Record that a new blob was stored. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param id The identity of the newly stored blob. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-18 22:52:54 +00:00
										 |  |  | void tf_ssb_notify_blob_stored(tf_ssb_t* ssb, const char* id); | 
					
						
							| 
									
										
										
										
											2021-11-11 00:05:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A callback called when a blob is newly requested. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param id The blob identity. | 
					
						
							|  |  |  | ** @param user_data The user data. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_blob_want_added_callback_t)(tf_ssb_t* ssb, const char* id, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a function to be called when a blob is newly requested. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback. | 
					
						
							|  |  |  | ** @param cleanup A function to call when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_add_blob_want_added_callback(tf_ssb_t* ssb, tf_ssb_blob_want_added_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback registered for when a blob is newly requested. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param callback The callback to remove. | 
					
						
							|  |  |  | ** @param user_data The user data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_remove_blob_want_added_callback(tf_ssb_t* ssb, tf_ssb_blob_want_added_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Call all callbacks registered for when a blob is newly requested. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param id The requested blob identity. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-09-06 17:50:38 +00:00
										 |  |  | void tf_ssb_notify_blob_want_added(tf_ssb_t* ssb, const char* id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A function called when a MUXRPC request is made. | 
					
						
							|  |  |  | ** @param connection The SSB connection. | 
					
						
							|  |  |  | ** @param flags The RPC flags. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							|  |  |  | ** @param args Request arguments. | 
					
						
							|  |  |  | ** @param message The raw message data. | 
					
						
							|  |  |  | ** @param size The size of the raw message data. | 
					
						
							|  |  |  | ** @param user_data User data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | typedef void(tf_ssb_rpc_callback_t)(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, JSValue args, const uint8_t* message, size_t size, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a MUXRPC callback by name. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							| 
									
										
										
										
											2024-10-02 18:46:12 -04:00
										 |  |  | ** @param name The RPC name as a .-separated string. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param callback The callback. | 
					
						
							|  |  |  | ** @param cleanup A function to be called when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-02 18:46:12 -04:00
										 |  |  | void tf_ssb_add_rpc_callback(tf_ssb_t* ssb, const char* name, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a MUXRPC callback. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param name The NULL-terminated name. | 
					
						
							|  |  |  | ** @param callback The callback to remove. | 
					
						
							|  |  |  | ** @param user_data The user data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | void tf_ssb_remove_rpc_callback(tf_ssb_t* ssb, const char** name, tf_ssb_rpc_callback_t* callback, void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Send a MUXRPC message. | 
					
						
							|  |  |  | ** @param connection The connection on which to send the message. | 
					
						
							|  |  |  | ** @param flags The message flags. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							| 
									
										
										
										
											2024-05-02 19:02:23 -04:00
										 |  |  | ** @param new_request_name The name of the request if it is new. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param message The message payload. | 
					
						
							|  |  |  | ** @param size The size of the message. | 
					
						
							|  |  |  | ** @param callback A callback to call if a response is received. | 
					
						
							|  |  |  | ** @param cleanup A callback to call if the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | ** @return true If the message was queued to send, false if the connection or request were invalid. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | bool tf_ssb_connection_rpc_send(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, const char* new_request_name, const uint8_t* message, size_t size, | 
					
						
							| 
									
										
										
										
											2024-05-02 20:10:56 -04:00
										 |  |  | 	tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Send a JSON MUXRPC message. | 
					
						
							|  |  |  | ** @param connection The connection on which to send the message. | 
					
						
							|  |  |  | ** @param flags The message flags. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							| 
									
										
										
										
											2024-05-02 19:02:23 -04:00
										 |  |  | ** @param new_request_name The name of the request if it is new. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param message The JS message payload. | 
					
						
							|  |  |  | ** @param callback A callback to call if a response is received. | 
					
						
							|  |  |  | ** @param cleanup A callback to call if the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | ** @return true If the message was queued to send, false if the connection or request were invalid. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | bool tf_ssb_connection_rpc_send_json(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, const char* new_request_name, JSValue message, | 
					
						
							| 
									
										
										
										
											2024-05-02 20:10:56 -04:00
										 |  |  | 	tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Send a MUXRPC error message. | 
					
						
							|  |  |  | ** @param connection The connection on which to send the message. | 
					
						
							|  |  |  | ** @param flags The message flags. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							|  |  |  | ** @param error The error string. | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | ** @return true If the message was queued to send, false if the connection or request were invalid. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | bool tf_ssb_connection_rpc_send_error(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, const char* error); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Send a MUXRPC "method not allowed" error message. | 
					
						
							|  |  |  | ** @param connection The connection on which to send the message. | 
					
						
							|  |  |  | ** @param flags The message flags. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							|  |  |  | ** @param name The name of the not-allowed method. | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | ** @return true If the message was queued to send, false if the connection or request were invalid. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-23 14:13:55 -04:00
										 |  |  | bool tf_ssb_connection_rpc_send_error_method_not_allowed(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, const char* name); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register a callback to be called when a message is received for the given | 
					
						
							|  |  |  | ** request number. | 
					
						
							|  |  |  | ** @param connection The connection on which to register the callback. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							| 
									
										
										
										
											2024-05-02 19:02:23 -04:00
										 |  |  | ** @param name The name of the RPC request. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param callback The callback. | 
					
						
							|  |  |  | ** @param cleanup The function to call when the callback is removed. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | ** @param dependent_connection A connection, which, if removed, invalidates this request. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-05-02 20:10:56 -04:00
										 |  |  | void tf_ssb_connection_add_request(tf_ssb_connection_t* connection, int32_t request_number, const char* name, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, | 
					
						
							|  |  |  | 	void* user_data, tf_ssb_connection_t* dependent_connection); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a callback registered to be called when a message is received for the | 
					
						
							|  |  |  | ** given request number. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-18 23:43:49 +00:00
										 |  |  | void tf_ssb_connection_remove_request(tf_ssb_connection_t* connection, int32_t request_number); | 
					
						
							| 
									
										
										
										
											2022-11-02 23:34:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-02 19:02:23 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get a debug representation of active requests. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The active requests as a JS object. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | JSValue tf_ssb_connection_requests_to_object(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** A function scheduled to be run later. | 
					
						
							|  |  |  | ** @param connection The owning connection. | 
					
						
							| 
									
										
										
										
											2024-12-27 15:02:52 -05:00
										 |  |  | ** @param skip Whether the work ought to be skipped, because it is being replaced. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param user_data User data registered with the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-12-27 15:02:52 -05:00
										 |  |  | typedef void(tf_ssb_scheduled_callback_t)(tf_ssb_connection_t* connection, bool skip, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2024-06-02 12:38:12 -04:00
										 |  |  | ** Schedule work to be run when the connection is next idle. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param connection The owning connection. | 
					
						
							| 
									
										
										
										
											2024-12-27 15:51:33 -05:00
										 |  |  | ** @param key A key identifying the work.  If work by the same key already exists, the new request will be discarded. | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | ** @param callback The callback to call. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-12-27 15:02:52 -05:00
										 |  |  | void tf_ssb_connection_schedule_idle(tf_ssb_connection_t* connection, const char* key, tf_ssb_scheduled_callback_t* callback, void* user_data); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Schedule work to run on a worker thread. | 
					
						
							|  |  |  | ** @param connection The owning connection. | 
					
						
							|  |  |  | ** @param work_callback The callback to run on a thread. | 
					
						
							|  |  |  | ** @param after_work_callback The callback to run on the main thread when the work is complete. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-02-15 23:35:01 +00:00
										 |  |  | void tf_ssb_connection_run_work(tf_ssb_connection_t* connection, void (*work_callback)(tf_ssb_connection_t* connection, void* user_data), | 
					
						
							| 
									
										
										
										
											2024-02-17 19:22:02 +00:00
										 |  |  | 	void (*after_work_callback)(tf_ssb_connection_t* connection, int result, void* user_data), void* user_data); | 
					
						
							| 
									
										
										
										
											2023-01-17 02:17:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-08 21:00:37 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Schedule work to run on a worker thread. | 
					
						
							|  |  |  | ** @param ssb The owning SSB instance. | 
					
						
							|  |  |  | ** @param work_callback The callback to run on a thread. | 
					
						
							|  |  |  | ** @param after_work_callback The callback to run on the main thread when the work is complete. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_run_work( | 
					
						
							|  |  |  | 	tf_ssb_t* ssb, void (*work_callback)(tf_ssb_t* ssb, void* user_data), void (*after_work_callback)(tf_ssb_t* ssb, int result, void* user_data), void* user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Register for new messages on a connection. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param author The author for whom to request new messages. | 
					
						
							|  |  |  | ** @param request_number The MUXRPC request on which to send new messages. | 
					
						
							|  |  |  | ** @param keys Whether to send with keys. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 17:45:15 +00:00
										 |  |  | void tf_ssb_connection_add_new_message_request(tf_ssb_connection_t* connection, const char* author, int32_t request_number, bool keys); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a request for new messages on a connection. | 
					
						
							|  |  |  | ** @param connection the SHS connection. | 
					
						
							|  |  |  | ** @param author The author for whom to no longer request new messages. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 20:01:35 +00:00
										 |  |  | void tf_ssb_connection_remove_new_message_request(tf_ssb_connection_t* connection, const char* author); | 
					
						
							| 
									
										
										
										
											2023-01-08 17:45:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get whether we are an attendant on a room connection. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @return True if this is an attendant connection. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 00:25:38 +00:00
										 |  |  | bool tf_ssb_connection_is_attendant(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the request number used to notify of room attendant changes. | 
					
						
							|  |  |  | ** @param connection the SHS connection. | 
					
						
							|  |  |  | ** @return A request number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 00:25:38 +00:00
										 |  |  | int32_t tf_ssb_connection_get_attendant_request_number(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Register for attendant change notifications on a connection. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param attendant Whether this connection will be an attendant. | 
					
						
							|  |  |  | ** @param request_number The request number on which to send attendant changes. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 00:25:38 +00:00
										 |  |  | void tf_ssb_connection_set_attendant(tf_ssb_connection_t* connection, bool attendant, int request_number); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-11 09:23:12 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Register for endpoint change notifications on a connection. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param endpoint Whether this connection will be an endpoint. | 
					
						
							|  |  |  | ** @param request_number The request number on which to send endpoint changes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_connection_set_endpoint(tf_ssb_connection_t* connection, bool endpoint, int request_number); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get whether we are a potential tunnel endpoint. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @return True if this is an endpoint connection. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_connection_is_endpoint(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the request number used to notify of tunnel endpoint changes. | 
					
						
							|  |  |  | ** @param connection the SHS connection. | 
					
						
							|  |  |  | ** @return A request number. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | int32_t tf_ssb_connection_get_endpoint_request_number(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Clear all attendants from a room. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 00:25:38 +00:00
										 |  |  | void tf_ssb_connection_clear_room_attendants(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Add a room attendant. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param id The attendant identifier. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-11-02 23:34:44 +00:00
										 |  |  | void tf_ssb_connection_add_room_attendant(tf_ssb_connection_t* connection, const char* id); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Remove a room attendant. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param id The attendanr identifier. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-11-02 23:34:44 +00:00
										 |  |  | void tf_ssb_connection_remove_room_attendant(tf_ssb_connection_t* connection, const char* id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Create a tunnel. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param portal_id The identity of the tunnel intermediary. | 
					
						
							|  |  |  | ** @param request_number The tunnel request. | 
					
						
							|  |  |  | ** @param target_id The identity being tunneled to. | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | ** @param connect_flags Flags affecting the connection. | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | ** @return The new tunnel connection. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | tf_ssb_connection_t* tf_ssb_connection_tunnel_create(tf_ssb_t* ssb, const char* portal_id, int32_t request_number, const char* target_id, int connect_flags); | 
					
						
							| 
									
										
										
										
											2021-11-07 22:28:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the request number on which to send EBT responses. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @return The request number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 20:01:35 +00:00
										 |  |  | int32_t tf_ssb_connection_get_ebt_request_number(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2024-03-06 21:13:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Set the request number on which to send EBT responses. | 
					
						
							|  |  |  | ** @param connection The SHS connection. | 
					
						
							|  |  |  | ** @param request_number The request number. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-08 20:01:35 +00:00
										 |  |  | void tf_ssb_connection_set_ebt_request_number(tf_ssb_connection_t* connection, int32_t request_number); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get the JS class ID of the SSB connection class. | 
					
						
							|  |  |  | ** @return The class ID | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2021-09-06 17:50:38 +00:00
										 |  |  | JSClassID tf_ssb_get_connection_class_id(); | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get general statistics about an SSB instance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param[out] out_stats Populated with performance statistics. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2022-02-05 20:18:58 +00:00
										 |  |  | void tf_ssb_get_stats(tf_ssb_t* ssb, tf_ssb_stats_t* out_stats); | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get information about requested blobs. | 
					
						
							|  |  |  | ** @param connection An SHS connection. | 
					
						
							|  |  |  | ** @return Blob wants information. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-01-05 00:52:23 +00:00
										 |  |  | tf_ssb_blob_wants_t* tf_ssb_connection_get_blob_wants_state(tf_ssb_connection_t* connection); | 
					
						
							| 
									
										
										
										
											2023-01-22 20:37:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Record whether the calling thread is busy. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param busy True if the calling thread is now busy. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-17 00:01:59 +00:00
										 |  |  | void tf_ssb_record_thread_busy(tf_ssb_t* ssb, bool busy); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Get an estimate of utilization of all running threads. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The utilization percent. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-17 00:01:59 +00:00
										 |  |  | float tf_ssb_get_average_thread_percent(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2023-04-19 23:05:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the queue of messages in the progress of being stored. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The queue. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-07-20 01:02:50 +00:00
										 |  |  | tf_ssb_store_queue_t* tf_ssb_get_store_queue(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2023-08-03 00:30:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Increment the SSB instance's ref count.  Prevents it from being destroyed | 
					
						
							|  |  |  | ** until it reaches zero. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-03 00:30:48 +00:00
										 |  |  | void tf_ssb_ref(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Decrement the SSB instance's ref count.  May destroy the instance when the | 
					
						
							|  |  |  | ** count returns to zero. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-08-03 00:30:48 +00:00
										 |  |  | void tf_ssb_unref(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2023-10-08 14:25:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Record whether the calling thread is the main thread or not.  Some | 
					
						
							|  |  |  | ** operations are disallowed on the main thread for performance. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param main_thread Whether the calling thread is the main thread. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-10-11 15:44:40 +00:00
										 |  |  | void tf_ssb_set_main_thread(tf_ssb_t* ssb, bool main_thread); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get whether the running server is operating a room. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return True if the server is a room. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-10-11 15:44:40 +00:00
										 |  |  | bool tf_ssb_is_room(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Set whether the running server is operating a room. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param is_room Whether to run a room. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-10-11 15:44:40 +00:00
										 |  |  | void tf_ssb_set_is_room(tf_ssb_t* ssb, bool is_room); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 20:02:46 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get whether the running server supports replication of messages and blobs. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return True if the server is a replicator. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_is_replicator(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Set whether the running server supports replication of messages and blobs. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param is_replicator Whether to support replication. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_set_is_replicator(tf_ssb_t* ssb, bool is_replicator); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 21:07:16 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get whether the running server participates in peer exchange. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return True if the server participates in peer exchange. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_is_peer_exchange(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Set whether the running server participates in peer exchange. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param is_peer_exchange Whether to participate in peer exchange. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_set_is_peer_exchange(tf_ssb_t* ssb, bool is_peer_exchange); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the name of the room hosted by the running server. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @return The room name or NULL. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-10-11 15:44:40 +00:00
										 |  |  | const char* tf_ssb_get_room_name(tf_ssb_t* ssb); | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Set the name of the room hosted by the running server. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param room_name The name of the room. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2023-10-11 15:44:40 +00:00
										 |  |  | void tf_ssb_set_room_name(tf_ssb_t* ssb, const char* room_name); | 
					
						
							| 
									
										
										
										
											2024-01-27 13:48:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 20:57:38 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Schedule work to be run after a time delay. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param delay_ms The duration to wait in milliseconds. | 
					
						
							|  |  |  | ** @param callback The callback to call to run the work. | 
					
						
							|  |  |  | ** @param user_data User data to pass to the callback. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2024-01-27 13:48:16 +00:00
										 |  |  | void tf_ssb_schedule_work(tf_ssb_t* ssb, int delay_ms, void (*callback)(tf_ssb_t* ssb, void* user_data), void* user_data); | 
					
						
							| 
									
										
										
										
											2024-02-20 21:41:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-02 20:11:36 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Verify a signature. | 
					
						
							|  |  |  | ** @param public_key The public key for which the message was signed. | 
					
						
							|  |  |  | ** @param payload The signed payload. | 
					
						
							|  |  |  | ** @param payload_length The length of the signed payload in bytes. | 
					
						
							|  |  |  | ** @param signature The signature. | 
					
						
							|  |  |  | ** @param signature_is_urlb64 True if the signature is in URL base64 format, otherwise standard base64. | 
					
						
							|  |  |  | ** @return true If the message was successfully verified. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_hmacsha256_verify(const char* public_key, const void* payload, size_t payload_length, const char* signature, bool signature_is_urlb64); | 
					
						
							| 
									
										
										
										
											2024-03-31 16:15:50 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-22 19:53:33 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Adjust read backpressure.  If it gets too high, TCP receive will be paused | 
					
						
							|  |  |  | ** until it lowers. | 
					
						
							|  |  |  | ** @param connection The connection on which to affect backpressure. | 
					
						
							|  |  |  | ** @param delta The change in backpressure.  Higher will eventually pause | 
					
						
							|  |  |  | ** receive.  Lower will resume it. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_connection_adjust_read_backpressure(tf_ssb_connection_t* connection, int delta); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-02 12:38:12 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Adjust write count.  Work scheduled by tf_ssb_connection_schedule_idle will | 
					
						
							|  |  |  | ** only start when this reaches zero. | 
					
						
							|  |  |  | ** @param connection The connection on which to affect backpressure. | 
					
						
							|  |  |  | ** @param delta The change in write count.  Higher will pause processing | 
					
						
							|  |  |  | ** scheduled idle work queue.  Lower will resume it. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_connection_adjust_write_count(tf_ssb_connection_t* connection, int delta); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-24 17:23:22 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get the reason why a connection is going away. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return The reason or NULL. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | const char* tf_ssb_connection_get_destroy_reason(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-06 11:14:37 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Initiate a tunnel connection. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | ** @param portal_id The public key of the instance through which to tunnel. | 
					
						
							|  |  |  | ** @param target_id The public key of the instance with which to establish a connection. | 
					
						
							|  |  |  | ** @param connect_flags Flags affecting the connection. | 
					
						
							|  |  |  | ** @return true if the tunnel instance was found. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | bool tf_ssb_tunnel_create(tf_ssb_t* ssb, const char* portal_id, const char* target_id, int connect_flags); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | ** Initiate a one time sync operation. | 
					
						
							|  |  |  | ** @param ssb The SSB instance. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | void tf_ssb_sync_start(tf_ssb_t* ssb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-06 11:50:49 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get a connection's flags. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | int tf_ssb_connection_get_flags(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-03 13:59:25 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Get a connection's EBT state. | 
					
						
							|  |  |  | ** @param connection The connection. | 
					
						
							|  |  |  | ** @return the EBT state for the connection. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | tf_ssb_ebt_t* tf_ssb_connection_get_ebt(tf_ssb_connection_t* connection); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-08 20:16:17 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  | ** Encrypt a private message to a set of recipients. | 
					
						
							|  |  |  | ** @param private_key The private key of the author. | 
					
						
							|  |  |  | ** @param recipients A list of recipient identities. | 
					
						
							|  |  |  | ** @param recipients_count The number of recipients in recipients. | 
					
						
							|  |  |  | ** @param message The plain text to post. | 
					
						
							|  |  |  | ** @param message_size The length in bytes of message. | 
					
						
							|  |  |  | ** @return A secret box string.  Free with tf_free(). | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | char* tf_ssb_private_message_encrypt(uint8_t* private_key, const char** recipients, int recipients_count, const char* message, size_t message_size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-20 21:41:37 -05:00
										 |  |  | /** @} */ |