From e25246743fabd8a10e0572edacdb49ca21d30d89 Mon Sep 17 00:00:00 2001 From: Marcus Date: Thu, 23 Nov 2023 14:50:23 +0100 Subject: [PATCH] improve error statusCode and message parsing --- .../nodes/Aws/DynamoDB/GenericFunctions.ts | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/packages/nodes-base/nodes/Aws/DynamoDB/GenericFunctions.ts b/packages/nodes-base/nodes/Aws/DynamoDB/GenericFunctions.ts index a44214133ca72..ded5215174162 100644 --- a/packages/nodes-base/nodes/Aws/DynamoDB/GenericFunctions.ts +++ b/packages/nodes-base/nodes/Aws/DynamoDB/GenericFunctions.ts @@ -37,9 +37,11 @@ export async function awsApiRequest( (await this.helpers.requestWithAuthentication.call(this, 'aws', requestOptions)) as string, ); } catch (error) { - const errorMessage = + const statusCode = (error.statusCode || error.cause?.statusCode) as number; + let errorMessage = error.response?.body?.message || error.response?.body?.Message || error.message; - if (error.statusCode === 403) { + + if (statusCode === 403) { if (errorMessage === 'The security token included in the request is invalid.') { throw new Error('The AWS credentials are not valid!'); } else if ( @@ -51,7 +53,13 @@ export async function awsApiRequest( } } - throw new Error(`AWS error response [${error.statusCode}]: ${errorMessage}`); + if (error.cause?.error) { + try { + errorMessage = JSON.parse(error.cause?.error).message; + } catch (ex) {} + } + + throw new Error(`AWS error response [${statusCode}]: ${errorMessage}`); } }