From ebf45157e610d1e2527e6180de99105b8aeb0fb8 Mon Sep 17 00:00:00 2001 From: Yann Jouanique Date: Wed, 12 Oct 2022 21:56:49 +0200 Subject: [PATCH] fix(KoboToolbox Node): fix hook logs not working correctly (#4286) --- .../nodes/KoBoToolbox/HookDescription.ts | 72 +++++++++++++++++-- .../nodes/KoBoToolbox/KoBoToolbox.node.ts | 11 ++- 2 files changed, 74 insertions(+), 9 deletions(-) diff --git a/packages/nodes-base/nodes/KoBoToolbox/HookDescription.ts b/packages/nodes-base/nodes/KoBoToolbox/HookDescription.ts index ea190d3c16..9e35470bd5 100644 --- a/packages/nodes-base/nodes/KoBoToolbox/HookDescription.ts +++ b/packages/nodes-base/nodes/KoBoToolbox/HookDescription.ts @@ -22,25 +22,25 @@ export const hookOperations: INodeProperties[] = [ name: 'Get Many', value: 'getAll', description: 'List many hooks on a form', - action: 'Get many hooks', + action: 'Get Many hooks', }, { name: 'Logs', value: 'getLogs', description: 'Get hook logs', - action: 'Logs a hook', + action: 'Get Logs for a hook', }, { name: 'Retry All', value: 'retryAll', description: 'Retry all failed attempts for a given hook', - action: 'Retry all hooks', + action: 'Retry All hooks', }, { name: 'Retry One', value: 'retryOne', description: 'Retry a specific hook', - action: 'Retry one hook', + action: 'Retry One hook', }, ], default: 'getAll', @@ -127,7 +127,7 @@ export const hookFields: INodeProperties[] = [ displayOptions: { show: { resource: ['hook'], - operation: ['getAll', 'getLogs'], + operation: ['getAll'], }, }, description: 'Whether to return all results or only up to a given limit', @@ -142,11 +142,71 @@ export const hookFields: INodeProperties[] = [ displayOptions: { show: { resource: ['hook'], - operation: ['getAll', 'getLogs'], + operation: ['getAll'], returnAll: [false], }, }, default: 1000, description: 'Max number of results to return', }, + /* -------------------------------------------------------------------------- */ + /* hook:getLogs */ + /* -------------------------------------------------------------------------- */ + { + displayName: 'Log Status', + name: 'status', + type: 'options', + displayOptions: { + show: { + resource: ['hook'], + operation: ['getLogs'], + }, + }, + default: '', + description: 'Only retrieve logs with a specific status', + options: [ + { + name: 'All', + value: '', + }, + { + name: 'Failed', + value: '0', + }, + { + name: 'Pending', + value: '1', + }, + { + name: 'Success', + value: '2', + }, + ], + }, + { + displayName: 'Start Date', + name: 'startDate', + type: 'dateTime', + displayOptions: { + show: { + resource: ['hook'], + operation: ['getLogs'], + }, + }, + default: '', + description: 'Minimum date for the hook log to retrieve', + }, + { + displayName: 'End Date', + name: 'endDate', + type: 'dateTime', + displayOptions: { + show: { + resource: ['hook'], + operation: ['getLogs'], + }, + }, + default: '', + description: 'Maximum date for the hook log to retrieve', + }, ]; diff --git a/packages/nodes-base/nodes/KoBoToolbox/KoBoToolbox.node.ts b/packages/nodes-base/nodes/KoBoToolbox/KoBoToolbox.node.ts index e7dcbea461..9f468ae784 100644 --- a/packages/nodes-base/nodes/KoBoToolbox/KoBoToolbox.node.ts +++ b/packages/nodes-base/nodes/KoBoToolbox/KoBoToolbox.node.ts @@ -323,13 +323,17 @@ export class KoBoToolbox implements INodeType { // Hook: getLogs // ---------------------------------- const hookId = this.getNodeParameter('hookId', i) as string; + const startDate = this.getNodeParameter('startDate', i, null); + const endDate = this.getNodeParameter('endDate', i, null); + const status = this.getNodeParameter('status', i, null); + responseData = await koBoToolboxApiRequest.call(this, { url: `/api/v2/assets/${formId}/hooks/${hookId}/logs/`, qs: { - start: this.getNodeParameter('start', i, 0) as number, - limit: this.getNodeParameter('limit', i, 1000) as number, + ...(startDate && { start: startDate }), + ...(endDate && { end: endDate }), + ...(status && { status }), }, - scroll: this.getNodeParameter('returnAll', i) as boolean, }); } @@ -342,6 +346,7 @@ export class KoBoToolbox implements INodeType { responseData = [ await koBoToolboxApiRequest.call(this, { + method: 'PATCH', url: `/api/v2/assets/${formId}/hooks/${hookId}/logs/${logId}/retry/`, }), ];