I think that's all the leaks accounted for though not yet fixed.

git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4799 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
Cory McWilliams 2024-01-27 15:45:51 +00:00
parent 08b5ade8ec
commit 923d6f9835
7 changed files with 22 additions and 16 deletions

View File

@ -67,11 +67,8 @@ function socket(request, response, client) {
if (process && process.task) { if (process && process.task) {
process.task.kill(); process.task.kill();
} }
} if (process) {
process.timeout = 0;
response.onError = async function(error) {
if (process && process.task) {
process.task.kill();
} }
} }
@ -157,7 +154,7 @@ function socket(request, response, client) {
process.lastPing = now; process.lastPing = now;
} }
if (again) { if (again && process.timeout) {
setTimeout(ping, process.timeout); setTimeout(ping, process.timeout);
} }
} }

View File

@ -983,7 +983,7 @@ loadSettings().then(function() {
} }
httpd.all("/login", auth.handler); httpd.all("/login", auth.handler);
httpd.all("/app/socket", app.socket); httpd.all("/app/socket", app.socket);
httpd.all("", function(request, response) { httpd.all("", function default_http_handler(request, response) {
let match; let match;
if (request.uri === "/" || request.uri === "") { if (request.uri === "/" || request.uri === "") {
try { try {

View File

@ -378,7 +378,7 @@ static void _http_add_body_bytes(tf_http_connection_t* connection, const void* d
tf_trace_begin(connection->http->trace, connection->trace_name ? connection->trace_name : "http"); tf_trace_begin(connection->http->trace, connection->trace_name ? connection->trace_name : "http");
connection->callback(request); connection->callback(request);
tf_trace_end(connection->http->trace); tf_trace_end(connection->http->trace);
tf_http_request_release(request); tf_http_request_unref(request);
} }
} }
} }
@ -695,6 +695,10 @@ void tf_http_destroy(tf_http_t* http)
tf_free(http->handlers); tf_free(http->handlers);
http->handlers_count = 0; http->handlers_count = 0;
for (int i = 0; i < http->connections_count; i++)
{
_http_connection_destroy(http->connections[i], "tf_http_destroy");
}
tf_free(http->connections); tf_free(http->connections);
http->connections_count = 0; http->connections_count = 0;
@ -894,7 +898,7 @@ void tf_http_request_ref(tf_http_request_t* request)
request->connection->ref_count++; request->connection->ref_count++;
} }
void tf_http_request_release(tf_http_request_t* request) void tf_http_request_unref(tf_http_request_t* request)
{ {
if (--request->connection->ref_count == 0) if (--request->connection->ref_count == 0)
{ {
@ -903,6 +907,7 @@ void tf_http_request_release(tf_http_request_t* request)
_http_reset_connection(request->connection); _http_reset_connection(request->connection);
} }
} }
if (--request->ref_count == 0) if (--request->ref_count == 0)
{ {
request->connection->request = NULL; request->connection->request = NULL;

View File

@ -47,7 +47,7 @@ void tf_http_set_user_data(tf_http_t* http, void* user_data, tf_http_cleanup_t*
void* tf_http_get_user_data(tf_http_t* http); void* tf_http_get_user_data(tf_http_t* http);
void tf_http_request_ref(tf_http_request_t* request); void tf_http_request_ref(tf_http_request_t* request);
void tf_http_request_release(tf_http_request_t* request); void tf_http_request_unref(tf_http_request_t* request);
const char* tf_http_request_get_header(tf_http_request_t* request, const char* name); const char* tf_http_request_get_header(tf_http_request_t* request, const char* name);
void tf_http_request_send(tf_http_request_t* request, const void* data, size_t size); void tf_http_request_send(tf_http_request_t* request, const void* data, size_t size);
void tf_http_request_websocket_upgrade(tf_http_request_t* request); void tf_http_request_websocket_upgrade(tf_http_request_t* request);

View File

@ -163,7 +163,7 @@ static JSValue _httpd_response_send(JSContext* context, JSValueConst this_val, i
return JS_UNDEFINED; return JS_UNDEFINED;
} }
static void _httpd_close_callback(tf_http_request_t* request) static void _httpd_websocket_close_callback(tf_http_request_t* request)
{ {
JSContext* context = request->context; JSContext* context = request->context;
JSValue response_object = JS_MKPTR(JS_TAG_OBJECT, request->user_data); JSValue response_object = JS_MKPTR(JS_TAG_OBJECT, request->user_data);
@ -172,7 +172,9 @@ static void _httpd_close_callback(tf_http_request_t* request)
tf_util_report_error(context, response); tf_util_report_error(context, response);
JS_FreeValue(context, response); JS_FreeValue(context, response);
JS_FreeValue(context, on_close); JS_FreeValue(context, on_close);
tf_http_request_release(request); JS_SetPropertyStr(context, response_object, "onMessage", JS_UNDEFINED);
JS_SetPropertyStr(context, response_object, "onClose", JS_UNDEFINED);
JS_FreeValue(context, response_object);
} }
static void _httpd_message_callback(tf_http_request_t* request, int op_code, const void* data, size_t size) static void _httpd_message_callback(tf_http_request_t* request, int op_code, const void* data, size_t size)
@ -217,6 +219,7 @@ static void _httpd_callback_internal(tf_http_request_t* request, bool is_websock
JS_SetPropertyStr(context, request_object, "client", client); JS_SetPropertyStr(context, request_object, "client", client);
JSValue response_object = JS_NewObjectClass(context, _httpd_request_class_id); JSValue response_object = JS_NewObjectClass(context, _httpd_request_class_id);
/* The ref is owned by the JS object and will be released by the finalizer. */
tf_http_request_ref(request); tf_http_request_ref(request);
JS_SetOpaque(response_object, request); JS_SetOpaque(response_object, request);
JS_SetPropertyStr(context, response_object, "writeHead", JS_NewCFunction(context, _httpd_response_write_head, "writeHead", 2)); JS_SetPropertyStr(context, response_object, "writeHead", JS_NewCFunction(context, _httpd_response_write_head, "writeHead", 2));
@ -318,15 +321,15 @@ static JSValue _httpd_websocket_upgrade(JSContext* context, JSValueConst this_va
tf_http_respond(request, 101, headers, headers_count, NULL, 0); tf_http_respond(request, 101, headers, headers_count, NULL, 0);
request->on_message = _httpd_message_callback; request->on_message = _httpd_message_callback;
request->on_close = _httpd_close_callback; request->on_close = _httpd_websocket_close_callback;
request->context = context; request->context = context;
request->user_data = JS_VALUE_GET_PTR(JS_DupValue(context, this_val)); request->user_data = JS_VALUE_GET_PTR(JS_DupValue(context, this_val));
} }
else else
{ {
tf_http_respond(request, 400, NULL, 0, NULL, 0); tf_http_respond(request, 400, NULL, 0, NULL, 0);
tf_http_request_release(request);
} }
tf_http_request_unref(request);
return JS_UNDEFINED; return JS_UNDEFINED;
} }
@ -385,7 +388,7 @@ static void _httpd_finalizer(JSRuntime* runtime, JSValue value)
static void _httpd_request_finalizer(JSRuntime* runtime, JSValue value) static void _httpd_request_finalizer(JSRuntime* runtime, JSValue value)
{ {
tf_http_request_t* request = JS_GetOpaque(value, _httpd_request_class_id); tf_http_request_t* request = JS_GetOpaque(value, _httpd_request_class_id);
tf_http_request_release(request); tf_http_request_unref(request);
} }
static void _httpd_endpoint_trace(tf_http_request_t* request) static void _httpd_endpoint_trace(tf_http_request_t* request)

View File

@ -1623,7 +1623,7 @@ tf_task_t* tf_task_create()
uv_unref((uv_handle_t*)&task->trace_timer); uv_unref((uv_handle_t*)&task->trace_timer);
task->gc_timer.data = task; task->gc_timer.data = task;
uv_timer_init(&task->_loop, &task->gc_timer); uv_timer_init(&task->_loop, &task->gc_timer);
uv_timer_start(&task->gc_timer, _tf_task_gc_timer, 10000, 10000); uv_timer_start(&task->gc_timer, _tf_task_gc_timer, 1000, 1000);
uv_unref((uv_handle_t*)&task->gc_timer); uv_unref((uv_handle_t*)&task->gc_timer);
task->idle.data = task; task->idle.data = task;
uv_idle_init(&task->_loop, &task->idle); uv_idle_init(&task->_loop, &task->idle);

View File

@ -292,6 +292,7 @@ static JSValue _util_setTimeout(JSContext* context, JSValueConst this_val, int a
JS_ToInt64(context, &duration, argv[1]); JS_ToInt64(context, &duration, argv[1]);
if (uv_timer_start(&timeout->_timer, _util_timeoutCallback, duration, 0) != 0) if (uv_timer_start(&timeout->_timer, _util_timeoutCallback, duration, 0) != 0)
{ {
JS_FreeValue(context, timeout->_callback);
tf_free(timeout); tf_free(timeout);
} }
return JS_NULL; return JS_NULL;