feat: Add run method to webhook triggers
This commit is contained in:
@@ -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();
|
||||||
|
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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) => {
|
||||||
/*
|
/*
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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,
|
||||||
|
@@ -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($);
|
||||||
|
|
||||||
|
@@ -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}`
|
||||||
|
@@ -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();
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user