feat: Add run method to webhook triggers

This commit is contained in:
Faruk AYDIN
2023-10-07 18:34:53 +02:00
parent f79fc29203
commit 27a3edeb93
18 changed files with 89 additions and 0 deletions

View File

@@ -1,3 +1,4 @@
import Crypto from 'crypto';
import isEmpty from 'lodash/isEmpty'; import isEmpty from 'lodash/isEmpty';
import defineTrigger from '../../../../helpers/define-trigger'; import defineTrigger from '../../../../helpers/define-trigger';
import webhookFilters from '../../common/webhook-filters'; import webhookFilters from '../../common/webhook-filters';
@@ -19,6 +20,17 @@ export default defineTrigger({
}, },
], ],
async run($) {
const dataItem = {
raw: $.request.body,
meta: {
internalId: Crypto.randomUUID(),
},
};
$.pushTriggerItem(dataItem);
},
async testRun($) { async testRun($) {
const lastExecutionStep = await $.getLastExecutionStep(); const lastExecutionStep = await $.getLastExecutionStep();

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -19,6 +20,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.confidential_issues_events, key: GITLAB_EVENT_TYPE.confidential_issues_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.confidential_issues_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.confidential_issues_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -19,6 +20,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.confidential_note_events, key: GITLAB_EVENT_TYPE.confidential_note_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.confidential_note_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.confidential_note_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.deployment_events, key: GITLAB_EVENT_TYPE.deployment_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.deployment_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.deployment_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.feature_flag_events, key: GITLAB_EVENT_TYPE.feature_flag_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.feature_flag_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.feature_flag_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.issues_events, key: GITLAB_EVENT_TYPE.issues_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.issues_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.issues_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -17,6 +18,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.job_events, key: GITLAB_EVENT_TYPE.job_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.job_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.job_events),
unregisterHook, unregisterHook,

View File

@@ -22,6 +22,17 @@ export const projectArgumentDescriptor = {
}, },
}; };
export const getRunFn = async ($: IGlobalVariable) => {
const dataItem = {
raw: $.request.body,
meta: {
internalId: Crypto.randomUUID(),
},
};
$.pushTriggerItem(dataItem);
};
export const getTestRunFn = export const getTestRunFn =
(eventData: IJSONObject) => ($: IGlobalVariable) => { (eventData: IJSONObject) => ($: IGlobalVariable) => {
/* /*

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.merge_requests_events, key: GITLAB_EVENT_TYPE.merge_requests_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.merge_requests_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.merge_requests_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.note_events, key: GITLAB_EVENT_TYPE.note_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.note_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.note_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.pipeline_events, key: GITLAB_EVENT_TYPE.pipeline_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.pipeline_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.pipeline_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -54,6 +55,7 @@ export const triggerDescriptor: IRawTrigger = {
branchFilterStrategyArgumentDescriptor, branchFilterStrategyArgumentDescriptor,
pushEventsBranchFilterArgumentDescriptor, pushEventsBranchFilterArgumentDescriptor,
], ],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.push_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.push_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -17,6 +18,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.releases_events, key: GITLAB_EVENT_TYPE.releases_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.releases_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.releases_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.tag_push_events, key: GITLAB_EVENT_TYPE.tag_push_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.tag_push_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.tag_push_events),
unregisterHook, unregisterHook,

View File

@@ -3,6 +3,7 @@ import defineTrigger from '../../../../helpers/define-trigger';
import { GITLAB_EVENT_TYPE } from '../types'; import { GITLAB_EVENT_TYPE } from '../types';
import { import {
getRegisterHookFn, getRegisterHookFn,
getRunFn,
getTestRunFn, getTestRunFn,
projectArgumentDescriptor, projectArgumentDescriptor,
unregisterHook, unregisterHook,
@@ -18,6 +19,7 @@ export const triggerDescriptor: IRawTrigger = {
key: GITLAB_EVENT_TYPE.wiki_page_events, key: GITLAB_EVENT_TYPE.wiki_page_events,
type: 'webhook', type: 'webhook',
arguments: [projectArgumentDescriptor], arguments: [projectArgumentDescriptor],
run: ($) => getRunFn($),
testRun: getTestRunFn(data), testRun: getTestRunFn(data),
registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.wiki_page_events), registerHook: getRegisterHookFn(GITLAB_EVENT_TYPE.wiki_page_events),
unregisterHook, unregisterHook,

View File

@@ -1,4 +1,5 @@
import { URLSearchParams } from 'node:url'; import { URLSearchParams } from 'node:url';
import Crypto from 'crypto';
import isEmpty from 'lodash/isEmpty'; import isEmpty from 'lodash/isEmpty';
import defineTrigger from '../../../../helpers/define-trigger'; import defineTrigger from '../../../../helpers/define-trigger';
import fetchMessages from './fetch-messages'; import fetchMessages from './fetch-messages';
@@ -37,6 +38,17 @@ export default defineTrigger({
useSingletonWebhook: true, useSingletonWebhook: true,
singletonWebhookRefValueParameter: 'phoneNumberSid', singletonWebhookRefValueParameter: 'phoneNumberSid',
async run($) {
const dataItem = {
raw: $.request.body,
meta: {
internalId: Crypto.randomUUID(),
},
};
$.pushTriggerItem(dataItem);
},
async testRun($) { async testRun($) {
await fetchMessages($); await fetchMessages($);

View File

@@ -1,3 +1,4 @@
import Crypto from 'crypto';
import appConfig from '../../../../config/app'; import appConfig from '../../../../config/app';
import defineTrigger from '../../../../helpers/define-trigger'; import defineTrigger from '../../../../helpers/define-trigger';
@@ -27,6 +28,17 @@ export default defineTrigger({
}, },
], ],
async run($) {
const dataItem = {
raw: $.request.body,
meta: {
internalId: Crypto.randomUUID(),
},
};
$.pushTriggerItem(dataItem);
},
async testRun($) { async testRun($) {
const { data: form } = await $.http.get( const { data: form } = await $.http.get(
`/forms/${$.step.parameters.formId}` `/forms/${$.step.parameters.formId}`

View File

@@ -1,3 +1,4 @@
import Crypto from 'crypto';
import isEmpty from 'lodash/isEmpty'; import isEmpty from 'lodash/isEmpty';
import defineTrigger from '../../../../helpers/define-trigger'; import defineTrigger from '../../../../helpers/define-trigger';
@@ -8,6 +9,21 @@ export default defineTrigger({
showWebhookUrl: true, showWebhookUrl: true,
description: 'Triggers when the webhook receives a request.', description: 'Triggers when the webhook receives a request.',
async run($) {
const dataItem = {
raw: {
headers: $.request.headers,
body: $.request.body,
query: $.request.query,
},
meta: {
internalId: Crypto.randomUUID(),
},
};
$.pushTriggerItem(dataItem);
},
async testRun($) { async testRun($) {
const lastExecutionStep = await $.getLastExecutionStep(); const lastExecutionStep = await $.getLastExecutionStep();