From 50ecb8d0a9033f664d289bd4815406bde6f44376 Mon Sep 17 00:00:00 2001 From: Ricardo Espinoza Date: Fri, 28 Feb 2020 10:06:05 -0500 Subject: [PATCH 1/2] :zap: Reuse webhooks. --- .../nodes/Typeform/TypeformTrigger.node.ts | 26 +++++++++---------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts b/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts index 94683c5322..0d29a7ac3a 100644 --- a/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts +++ b/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts @@ -17,6 +17,7 @@ import { ITypeformAnswerField, ITypeformDefinition, } from './GenericFunctions'; +import { Webhook } from '../Webhook.node'; export class TypeformTrigger implements INodeType { @@ -89,24 +90,23 @@ export class TypeformTrigger implements INodeType { default: { async checkExists(this: IHookFunctions): Promise { const webhookData = this.getWorkflowStaticData('node'); - - if (webhookData.webhookId === undefined) { - // No webhook id is set so no webhook can exist - return false; - } + const webhookUrl = this.getNodeWebhookUrl('default'); const formId = this.getNodeParameter('formId') as string; - const endpoint = `forms/${formId}/webhooks/${webhookData.webhookId}`; + const endpoint = `forms/${formId}/webhooks`; - try { - const body = {}; - await apiRequest.call(this, 'POST', endpoint, body); - } catch (e) { - return false; + const { items } = await apiRequest.call(this, 'GET', endpoint, {}); + + for (const item of items) { + if (item.form_id === formId + && item.url === webhookUrl) { + webhookData.webhookId = item.tag; + return true; + } } - return true; + return false; }, async create(this: IHookFunctions): Promise { const webhookUrl = this.getNodeWebhookUrl('default'); @@ -138,14 +138,12 @@ export class TypeformTrigger implements INodeType { if (webhookData.webhookId !== undefined) { const endpoint = `forms/${formId}/webhooks/${webhookData.webhookId}`; - try { const body = {}; await apiRequest.call(this, 'DELETE', endpoint, body); } catch (e) { return false; } - // Remove from the static workflow data so that it is clear // that no webhooks are registred anymore delete webhookData.webhookId; From e52b1d66e5d9179a651ad13f21fcdce6e0efacee Mon Sep 17 00:00:00 2001 From: Ricardo Espinoza Date: Fri, 28 Feb 2020 10:06:58 -0500 Subject: [PATCH 2/2] :zap: small fix --- packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts b/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts index 0d29a7ac3a..b127a1f594 100644 --- a/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts +++ b/packages/nodes-base/nodes/Typeform/TypeformTrigger.node.ts @@ -17,8 +17,6 @@ import { ITypeformAnswerField, ITypeformDefinition, } from './GenericFunctions'; -import { Webhook } from '../Webhook.node'; - export class TypeformTrigger implements INodeType { description: INodeTypeDescription = {