From e8ce4ba8bb17359e87980f234184806e22d7f593 Mon Sep 17 00:00:00 2001 From: Kevin Pearson Date: Wed, 1 Nov 2023 08:22:31 -0700 Subject: [PATCH] fix: Errors thrown in async provider methods do not send the JSONRPC error response --- .../src/shared/ProvideManager/index.mjs | 25 +++++++++++-------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/languages/javascript/src/shared/ProvideManager/index.mjs b/languages/javascript/src/shared/ProvideManager/index.mjs index dde64557..68ce6e9c 100644 --- a/languages/javascript/src/shared/ProvideManager/index.mjs +++ b/languages/javascript/src/shared/ProvideManager/index.mjs @@ -93,6 +93,18 @@ const provide = function(capability, provider) { const response = { correlationId: request.correlationId } + let handleError = error => { + response.error = { + code: error.code || 1000, // todo: should be some reserved code for "Unknown" + message: error.message || `An error occured while calling provided ${method} method.` + } + + if (error.data) { + response.error.data = JSON.parse(JSON.stringify(error.data)) + } + + Transport.send(module, `${method}Error`, response) + } try { const result = provider[method].apply(provider, providerCallArgs) @@ -107,19 +119,10 @@ const provide = function(capability, provider) { } Transport.send(module, `${method}Response`, response) - }) + }).catch(err => handleError(err)) } catch(error) { - response.error = { - code: error.code || 1000, // todo: should be some reserved code for "Unknown" - message: error.message || `An error occured while calling provided ${method} method.` - } - - if (error.data) { - response.error.data = JSON.parse(JSON.stringify(error.data)) - } - - Transport.send(module, `${method}Error`, response) + handleError(error) } }) })