n-api: fix use-after-free with napi_remove_async_cleanup_hook
Fixes: https://github.com/nodejs/node/issues/34657 Refs: https://github.com/nodejs/node/pull/34572 PR-URL: https://github.com/nodejs/node/pull/34662 Reviewed-By: Gabriel Schulhof <gabriel.schulhof@intel.com> Reviewed-By: James M Snell <jasnell@gmail.com>
This commit is contained in:
parent
09c5942bfd
commit
262d0d0482
@ -533,6 +533,7 @@ napi_status napi_add_async_cleanup_hook(
|
||||
auto handle = node::AddEnvironmentCleanupHook(env->isolate, fun, arg);
|
||||
if (remove_handle != nullptr) {
|
||||
*remove_handle = new napi_async_cleanup_hook_handle__ { std::move(handle) };
|
||||
env->Ref();
|
||||
}
|
||||
|
||||
return napi_clear_last_error(env);
|
||||
@ -547,6 +548,11 @@ napi_status napi_remove_async_cleanup_hook(
|
||||
node::RemoveEnvironmentCleanupHook(std::move(remove_handle->handle));
|
||||
delete remove_handle;
|
||||
|
||||
// Release the `env` handle asynchronously since it would be surprising if
|
||||
// a call to a N-API function would destroy `env` synchronously.
|
||||
static_cast<node_napi_env>(env)->node_env()
|
||||
->SetImmediate([env](node::Environment*) { env->Unref(); });
|
||||
|
||||
return napi_clear_last_error(env);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user