From 62f993c84f6ecf2f4d0431d505ba18a0253bd244 Mon Sep 17 00:00:00 2001 From: Jan Oberhauser Date: Wed, 19 Apr 2023 13:44:41 +0200 Subject: [PATCH] feat(core): Add support for digestAuth to httpRequest and declarative style (#5676) feat(core): Add support to digestAuth to httpRequest and declarative style --- packages/cli/src/CredentialsHelper.ts | 2 +- packages/core/src/NodeExecuteFunctions.ts | 21 +++++++++++++++++++-- packages/workflow/src/Interfaces.ts | 3 +++ 3 files changed, 23 insertions(+), 3 deletions(-) diff --git a/packages/cli/src/CredentialsHelper.ts b/packages/cli/src/CredentialsHelper.ts index 4fd8295ce1..2851638360 100644 --- a/packages/cli/src/CredentialsHelper.ts +++ b/packages/cli/src/CredentialsHelper.ts @@ -224,7 +224,7 @@ export class CredentialsHelper extends ICredentialsHelper { node: INode, defaultTimezone: string, ): string { - if (parameterValue.charAt(0) !== '=') { + if (typeof parameterValue !== 'string' || parameterValue.charAt(0) !== '=') { return parameterValue; } diff --git a/packages/core/src/NodeExecuteFunctions.ts b/packages/core/src/NodeExecuteFunctions.ts index f9a32fe78f..ec78d8a1dc 100644 --- a/packages/core/src/NodeExecuteFunctions.ts +++ b/packages/core/src/NodeExecuteFunctions.ts @@ -825,15 +825,31 @@ function convertN8nRequestToAxios(n8nRequest: IHttpRequestOptions): AxiosRequest async function httpRequest( requestOptions: IHttpRequestOptions, ): Promise { - const axiosRequest = convertN8nRequestToAxios(requestOptions); + let axiosRequest = convertN8nRequestToAxios(requestOptions); if ( axiosRequest.data === undefined || (axiosRequest.method !== undefined && axiosRequest.method.toUpperCase() === 'GET') ) { delete axiosRequest.data; } + let result: AxiosResponse; + try { + result = await axios(axiosRequest); + } catch (error) { + if (requestOptions.auth?.sendImmediately === false) { + const { response } = error; + if (response?.status !== 401 || !response.headers['www-authenticate']?.includes('nonce')) { + throw error; + } + + const { auth } = axiosRequest; + delete axiosRequest.auth; + axiosRequest = digestAuthAxiosConfig(axiosRequest, response, auth); + result = await axios(axiosRequest); + } + throw error; + } - const result = await axios(axiosRequest); if (requestOptions.returnFullResponse) { return { body: result.data, @@ -842,6 +858,7 @@ async function httpRequest( statusMessage: result.statusText, }; } + return result.data; } diff --git a/packages/workflow/src/Interfaces.ts b/packages/workflow/src/Interfaces.ts index e18299e79f..6c1b687b3f 100644 --- a/packages/workflow/src/Interfaces.ts +++ b/packages/workflow/src/Interfaces.ts @@ -172,6 +172,7 @@ export interface IRequestOptionsSimplified { auth?: { username: string; password: string; + sendImmediately?: boolean; }; body: IDataObject; headers: IDataObject; @@ -182,6 +183,7 @@ export interface IRequestOptionsSimplifiedAuth { auth?: { username: string; password: string; + sendImmediately?: boolean; }; body?: IDataObject; headers?: IDataObject; @@ -501,6 +503,7 @@ export interface IHttpRequestOptions { auth?: { username: string; password: string; + sendImmediately?: boolean; }; disableFollowRedirect?: boolean; encoding?: 'arraybuffer' | 'blob' | 'document' | 'json' | 'text' | 'stream';