Attempt to track requests better. New requests need to be flagged as such. Still trying to chase tunnel instability.
git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4412 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
parent
85acac3a30
commit
f1b55ddd64
89
src/ssb.c
89
src/ssb.c
@ -624,6 +624,20 @@ static bool _tf_ssb_connection_get_request_callback(tf_ssb_connection_t* connect
|
|||||||
|
|
||||||
void tf_ssb_connection_add_request(tf_ssb_connection_t* connection, int32_t request_number, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data, tf_ssb_connection_t* dependent_connection)
|
void tf_ssb_connection_add_request(tf_ssb_connection_t* connection, int32_t request_number, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data, tf_ssb_connection_t* dependent_connection)
|
||||||
{
|
{
|
||||||
|
tf_ssb_request_t* existing = connection->requests_count ? bsearch(&request_number, connection->requests, connection->requests_count, sizeof(tf_ssb_request_t), _request_compare) : NULL;
|
||||||
|
if (existing)
|
||||||
|
{
|
||||||
|
assert(!existing->callback);
|
||||||
|
assert(!existing->cleanup);
|
||||||
|
assert(!existing->user_data);
|
||||||
|
assert(!existing->dependent_connection);
|
||||||
|
existing->callback = callback;
|
||||||
|
existing->cleanup = cleanup;
|
||||||
|
existing->user_data = user_data;
|
||||||
|
existing->dependent_connection = dependent_connection;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
tf_ssb_connection_remove_request(connection, request_number);
|
tf_ssb_connection_remove_request(connection, request_number);
|
||||||
tf_ssb_request_t request =
|
tf_ssb_request_t request =
|
||||||
{
|
{
|
||||||
@ -643,6 +657,7 @@ void tf_ssb_connection_add_request(tf_ssb_connection_t* connection, int32_t requ
|
|||||||
connection->requests_count++;
|
connection->requests_count++;
|
||||||
|
|
||||||
connection->ssb->request_count++;
|
connection->ssb->request_count++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _message_request_compare(const void* a, const void* b)
|
static int _message_request_compare(const void* a, const void* b)
|
||||||
@ -714,8 +729,19 @@ void tf_ssb_connection_rpc_send(tf_ssb_connection_t* connection, uint8_t flags,
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (flags & k_ssb_rpc_flag_new_request)
|
||||||
|
{
|
||||||
|
assert(request_number > 0);
|
||||||
|
assert(!_tf_ssb_connection_get_request_callback(connection, request_number, NULL, NULL));
|
||||||
|
}
|
||||||
|
else if (!_tf_ssb_connection_get_request_callback(connection, request_number, NULL, NULL))
|
||||||
|
{
|
||||||
|
tf_printf("Dropping message with no active request (%d): %.*s\n", request_number, (int)size, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
uint8_t* combined = tf_malloc(9 + size);
|
uint8_t* combined = tf_malloc(9 + size);
|
||||||
*combined = flags;
|
*combined = flags & k_ssb_rpc_mask_send;
|
||||||
uint32_t u32size = htonl((uint32_t)size);
|
uint32_t u32size = htonl((uint32_t)size);
|
||||||
memcpy(combined + 1, &u32size, sizeof(u32size));
|
memcpy(combined + 1, &u32size, sizeof(u32size));
|
||||||
uint32_t rn = htonl((uint32_t)request_number);
|
uint32_t rn = htonl((uint32_t)request_number);
|
||||||
@ -723,20 +749,20 @@ void tf_ssb_connection_rpc_send(tf_ssb_connection_t* connection, uint8_t flags,
|
|||||||
memcpy(combined + 1 + 2 * sizeof(uint32_t), message, size);
|
memcpy(combined + 1 + 2 * sizeof(uint32_t), message, size);
|
||||||
if (connection->ssb->verbose)
|
if (connection->ssb->verbose)
|
||||||
{
|
{
|
||||||
tf_printf(MAGENTA "%s RPC SEND" RESET " flags=%x RN=%d: [%zd B] %.*s\n", connection->name, flags, request_number, size, (flags & k_ssb_rpc_mask_type) == k_ssb_rpc_flag_binary ? 0 : (int)size, message);
|
tf_printf(MAGENTA "%s RPC SEND" RESET " flags=%x RN=%d: [%zd B] %.*s\n", connection->name, flags & k_ssb_rpc_mask_send, request_number, size, (flags & k_ssb_rpc_mask_type) == k_ssb_rpc_flag_binary ? 0 : (int)size, message);
|
||||||
}
|
}
|
||||||
_tf_ssb_connection_add_debug_message(connection, true, flags, request_number, message, size);
|
_tf_ssb_connection_add_debug_message(connection, true, flags & k_ssb_rpc_mask_send, request_number, message, size);
|
||||||
_tf_ssb_connection_box_stream_send(connection, combined, 1 + 2 * sizeof(uint32_t) + size);
|
_tf_ssb_connection_box_stream_send(connection, combined, 1 + 2 * sizeof(uint32_t) + size);
|
||||||
tf_free(combined);
|
tf_free(combined);
|
||||||
connection->ssb->rpc_out++;
|
connection->ssb->rpc_out++;
|
||||||
if (request_number > 0 && callback)
|
if (flags & k_ssb_rpc_flag_end_error)
|
||||||
|
{
|
||||||
|
tf_ssb_connection_remove_request(connection, request_number);
|
||||||
|
}
|
||||||
|
else if (flags & k_ssb_rpc_flag_new_request)
|
||||||
{
|
{
|
||||||
tf_ssb_connection_add_request(connection, request_number, callback, cleanup, user_data, NULL);
|
tf_ssb_connection_add_request(connection, request_number, callback, cleanup, user_data, NULL);
|
||||||
}
|
}
|
||||||
else if (cleanup)
|
|
||||||
{
|
|
||||||
cleanup(connection->ssb, user_data);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void tf_ssb_connection_rpc_send_json(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, JSValue message, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data)
|
void tf_ssb_connection_rpc_send_json(tf_ssb_connection_t* connection, uint8_t flags, int32_t request_number, JSValue message, tf_ssb_rpc_callback_t* callback, tf_ssb_callback_cleanup_t* cleanup, void* user_data)
|
||||||
@ -747,7 +773,7 @@ void tf_ssb_connection_rpc_send_json(tf_ssb_connection_t* connection, uint8_t fl
|
|||||||
const char* json_string = JS_ToCStringLen(context, &size, json);
|
const char* json_string = JS_ToCStringLen(context, &size, json);
|
||||||
tf_ssb_connection_rpc_send(
|
tf_ssb_connection_rpc_send(
|
||||||
connection,
|
connection,
|
||||||
k_ssb_rpc_flag_json | (flags & k_ssb_rpc_flag_stream) | (flags & k_ssb_rpc_flag_end_error),
|
k_ssb_rpc_flag_json | (flags & ~k_ssb_rpc_mask_type),
|
||||||
request_number,
|
request_number,
|
||||||
(const uint8_t*)json_string,
|
(const uint8_t*)json_string,
|
||||||
size,
|
size,
|
||||||
@ -1474,6 +1500,7 @@ static void _tf_ssb_connection_rpc_recv(tf_ssb_connection_t* connection, uint8_t
|
|||||||
{
|
{
|
||||||
connection->ssb->rpc_in++;
|
connection->ssb->rpc_in++;
|
||||||
_tf_ssb_connection_add_debug_message(connection, false, flags, request_number, message, size);
|
_tf_ssb_connection_add_debug_message(connection, false, flags, request_number, message, size);
|
||||||
|
bool close_connection = false;
|
||||||
if (size == 0)
|
if (size == 0)
|
||||||
{
|
{
|
||||||
_tf_ssb_connection_close(connection, "rpc recv zero");
|
_tf_ssb_connection_close(connection, "rpc recv zero");
|
||||||
@ -1491,25 +1518,6 @@ static void _tf_ssb_connection_rpc_recv(tf_ssb_connection_t* connection, uint8_t
|
|||||||
JSValue val = JS_ParseJSON(context, (const char*)message, size, NULL);
|
JSValue val = JS_ParseJSON(context, (const char*)message, size, NULL);
|
||||||
|
|
||||||
if (!JS_IsUndefined(val))
|
if (!JS_IsUndefined(val))
|
||||||
{
|
|
||||||
bool found = false;
|
|
||||||
if (JS_IsObject(val))
|
|
||||||
{
|
|
||||||
for (tf_ssb_rpc_callback_node_t* it = connection->ssb->rpc; it; it = it->next)
|
|
||||||
{
|
|
||||||
if (_tf_ssb_name_equals(context, val, it->name))
|
|
||||||
{
|
|
||||||
tf_trace_begin(connection->ssb->trace, it->flattened_name);
|
|
||||||
PRE_CALLBACK(connection->ssb, it->callback);
|
|
||||||
it->callback(connection, flags, request_number, val, message, size, it->user_data);
|
|
||||||
POST_CALLBACK(connection->ssb, it->callback);
|
|
||||||
tf_trace_end(connection->ssb->trace);
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found)
|
|
||||||
{
|
{
|
||||||
tf_ssb_rpc_callback_t* callback = NULL;
|
tf_ssb_rpc_callback_t* callback = NULL;
|
||||||
void* user_data = NULL;
|
void* user_data = NULL;
|
||||||
@ -1526,17 +1534,36 @@ static void _tf_ssb_connection_rpc_recv(tf_ssb_connection_t* connection, uint8_t
|
|||||||
tf_trace_end(connection->ssb->trace);
|
tf_trace_end(connection->ssb->trace);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (!_tf_ssb_name_equals(context, val, (const char*[]) { "Error", NULL }))
|
else if (JS_IsObject(val))
|
||||||
|
{
|
||||||
|
bool found = false;
|
||||||
|
tf_ssb_connection_add_request(connection, -request_number, NULL, NULL, NULL, NULL);
|
||||||
|
for (tf_ssb_rpc_callback_node_t* it = connection->ssb->rpc; it; it = it->next)
|
||||||
|
{
|
||||||
|
if (_tf_ssb_name_equals(context, val, it->name))
|
||||||
|
{
|
||||||
|
tf_trace_begin(connection->ssb->trace, it->flattened_name);
|
||||||
|
PRE_CALLBACK(connection->ssb, it->callback);
|
||||||
|
it->callback(connection, flags, request_number, val, message, size, it->user_data);
|
||||||
|
POST_CALLBACK(connection->ssb, it->callback);
|
||||||
|
tf_trace_end(connection->ssb->trace);
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!found)
|
||||||
{
|
{
|
||||||
char buffer[256];
|
char buffer[256];
|
||||||
_tf_ssb_name_to_string(context, val, buffer, sizeof(buffer));
|
_tf_ssb_name_to_string(context, val, buffer, sizeof(buffer));
|
||||||
tf_ssb_connection_rpc_send_error_method_not_allowed(connection, flags, -request_number, buffer);
|
tf_ssb_connection_rpc_send_error_method_not_allowed(connection, flags, -request_number, buffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
tf_printf("Failed to parse %.*s\n", (int)size, message);
|
tf_printf("Failed to parse %.*s\n", (int)size, message);
|
||||||
|
close_connection = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
JS_FreeValue(context, val);
|
JS_FreeValue(context, val);
|
||||||
@ -1568,9 +1595,9 @@ static void _tf_ssb_connection_rpc_recv(tf_ssb_connection_t* connection, uint8_t
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & k_ssb_rpc_flag_end_error)
|
if (close_connection)
|
||||||
{
|
{
|
||||||
tf_ssb_connection_remove_request(connection, -request_number);
|
tf_ssb_connection_close(connection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,6 +15,11 @@ enum
|
|||||||
|
|
||||||
k_ssb_rpc_flag_end_error = 0x4,
|
k_ssb_rpc_flag_end_error = 0x4,
|
||||||
k_ssb_rpc_flag_stream = 0x8,
|
k_ssb_rpc_flag_stream = 0x8,
|
||||||
|
k_ssb_rpc_mask_message = 0xC,
|
||||||
|
|
||||||
|
k_ssb_rpc_mask_send = 0xf,
|
||||||
|
|
||||||
|
k_ssb_rpc_flag_new_request = 0x10,
|
||||||
|
|
||||||
k_ssb_blob_bytes_max = 5 * 1024 * 1024,
|
k_ssb_blob_bytes_max = 5 * 1024 * 1024,
|
||||||
};
|
};
|
||||||
|
@ -1096,7 +1096,7 @@ static JSValue _tf_ssb_createTunnel(JSContext* context, JSValueConst this_val, i
|
|||||||
JS_SetPropertyUint32(context, args, 0, arg);
|
JS_SetPropertyUint32(context, args, 0, arg);
|
||||||
JS_SetPropertyStr(context, message, "args", args);
|
JS_SetPropertyStr(context, message, "args", args);
|
||||||
JS_SetPropertyStr(context, message, "type", JS_NewString(context, "duplex"));
|
JS_SetPropertyStr(context, message, "type", JS_NewString(context, "duplex"));
|
||||||
tf_ssb_connection_rpc_send_json(connection, k_ssb_rpc_flag_stream, request_number, message, NULL, NULL, NULL);
|
tf_ssb_connection_rpc_send_json(connection, k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request, request_number, message, NULL, NULL, NULL);
|
||||||
JS_FreeValue(context, message);
|
JS_FreeValue(context, message);
|
||||||
|
|
||||||
tf_ssb_connection_tunnel_create(ssb, portal_id, request_number, target_id);
|
tf_ssb_connection_tunnel_create(ssb, portal_id, request_number, target_id);
|
||||||
|
@ -351,7 +351,7 @@ static void _tf_ssb_rpc_tunnel_connect(tf_ssb_connection_t* connection, uint8_t
|
|||||||
|
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
target_connection,
|
target_connection,
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
tunnel_request_number,
|
tunnel_request_number,
|
||||||
message,
|
message,
|
||||||
NULL,
|
NULL,
|
||||||
@ -565,7 +565,7 @@ static void _tf_ssb_rpc_connection_blobs_get(tf_ssb_connection_t* connection, co
|
|||||||
|
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connection,
|
connection,
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
tf_ssb_connection_next_request_number(connection),
|
tf_ssb_connection_next_request_number(connection),
|
||||||
message,
|
message,
|
||||||
_tf_ssb_rpc_connection_blobs_get_callback,
|
_tf_ssb_rpc_connection_blobs_get_callback,
|
||||||
@ -756,7 +756,7 @@ static void _tf_ssb_rpc_connection_tunnel_isRoom_callback(tf_ssb_connection_t* c
|
|||||||
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connection,
|
connection,
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
tf_ssb_connection_next_request_number(connection),
|
tf_ssb_connection_next_request_number(connection),
|
||||||
message,
|
message,
|
||||||
_tf_ssb_rpc_connection_room_attendants_callback,
|
_tf_ssb_rpc_connection_room_attendants_callback,
|
||||||
@ -1074,7 +1074,7 @@ static void _tf_ssb_rpc_send_ebt_replicate(tf_ssb_connection_t* connection)
|
|||||||
int32_t request_number = tf_ssb_connection_next_request_number(connection);
|
int32_t request_number = tf_ssb_connection_next_request_number(connection);
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connection,
|
connection,
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
request_number,
|
request_number,
|
||||||
message,
|
message,
|
||||||
_tf_ssb_rpc_ebt_replicate_client,
|
_tf_ssb_rpc_ebt_replicate_client,
|
||||||
@ -1111,7 +1111,7 @@ static void _tf_ssb_rpc_connections_changed_callback(tf_ssb_t* ssb, tf_ssb_chang
|
|||||||
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connection,
|
connection,
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
tf_ssb_connection_next_request_number(connection),
|
tf_ssb_connection_next_request_number(connection),
|
||||||
message,
|
message,
|
||||||
_tf_ssb_rpc_connection_blobs_createWants_callback,
|
_tf_ssb_rpc_connection_blobs_createWants_callback,
|
||||||
@ -1129,7 +1129,7 @@ static void _tf_ssb_rpc_connections_changed_callback(tf_ssb_t* ssb, tf_ssb_chang
|
|||||||
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
JS_SetPropertyStr(context, message, "args", JS_NewArray(context));
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connection,
|
connection,
|
||||||
0,
|
k_ssb_rpc_flag_new_request,
|
||||||
tf_ssb_connection_next_request_number(connection),
|
tf_ssb_connection_next_request_number(connection),
|
||||||
message,
|
message,
|
||||||
_tf_ssb_rpc_connection_tunnel_isRoom_callback,
|
_tf_ssb_rpc_connection_tunnel_isRoom_callback,
|
||||||
|
@ -443,7 +443,7 @@ void tf_ssb_test_rooms(const tf_test_options_t* options)
|
|||||||
|
|
||||||
tf_ssb_connection_rpc_send_json(
|
tf_ssb_connection_rpc_send_json(
|
||||||
connections[0],
|
connections[0],
|
||||||
k_ssb_rpc_flag_stream,
|
k_ssb_rpc_flag_stream | k_ssb_rpc_flag_new_request,
|
||||||
tunnel_request_number,
|
tunnel_request_number,
|
||||||
message,
|
message,
|
||||||
NULL,
|
NULL,
|
||||||
|
Loading…
Reference in New Issue
Block a user