Add missing gitlab trigger event types (#2591)

See issue #2590
This commit is contained in:
Manuel 2021-12-24 11:37:24 +01:00 committed by GitHub
parent 185bc04436
commit 231c760ef5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -16,6 +16,69 @@ import {
gitlabApiRequest, gitlabApiRequest,
} from './GenericFunctions'; } from './GenericFunctions';
const GITLAB_EVENTS = [
{
name: 'Comment',
value: 'note',
description: 'Triggered when a new comment is made on commits, merge requests, issues, and code snippets.',
},
{
name: 'Confidential Issues',
value: 'confidential_issues',
description: 'Triggered on confidential issues\' events.',
},
{
name: 'Confidential Comments',
value: 'confidential_note',
description: 'Triggered when a confidential comment is made.',
},
{
name: 'Deployments',
value: 'deployment',
description: 'Triggered when a deployment starts/succeeds/fails/is cancelled.',
},
{
name: 'Issue',
value: 'issues',
description: 'Triggered when a new issue is created or an existing issue was updated/closed/reopened.',
},
{
name: 'Job',
value: 'job',
description: 'Triggered on status change of a job.',
},
{
name: 'Merge Request',
value: 'merge_requests',
description: 'Triggered when a new merge request is created, an existing merge request was updated/merged/closed or a commit is added in the source branch.',
},
{
name: 'Pipeline',
value: 'pipeline',
description: 'Triggered on status change of Pipeline.',
},
{
name: 'Push',
value: 'push',
description: 'Triggered when you push to the repository except when pushing tags.',
},
{
name: 'Release',
value: 'releases',
description: 'Release events are triggered when a release is created or updated.',
},
{
name: 'Tag',
value: 'tag_push',
description: 'Triggered when you create (or delete) tags to the repository.',
},
{
name: 'Wiki Page',
value: 'wiki_page',
description: 'Triggered when a wiki page is created, updated or deleted.',
},
];
export class GitlabTrigger implements INodeType { export class GitlabTrigger implements INodeType {
description: INodeTypeDescription = { description: INodeTypeDescription = {
displayName: 'GitLab Trigger', displayName: 'GitLab Trigger',
@ -103,51 +166,12 @@ export class GitlabTrigger implements INodeType {
name: 'events', name: 'events',
type: 'multiOptions', type: 'multiOptions',
options: [ options: [
...GITLAB_EVENTS,
{ {
name: '*', name: '*',
value: '*', value: '*',
description: 'Any time any event is triggered (Wildcard Event).', description: 'Any time any event is triggered (Wildcard Event).',
}, },
{
name: 'Comment',
value: 'note',
description: 'Triggered when a new comment is made on commits, merge requests, issues, and code snippets.',
},
{
name: 'Issue',
value: 'issues',
description: 'Triggered when a new issue is created or an existing issue was updated/closed/reopened.',
},
{
name: 'Job',
value: 'job',
description: 'Triggered on status change of a job.',
},
{
name: 'Merge Request',
value: 'merge_requests',
description: 'Triggered when a new merge request is created, an existing merge request was updated/merged/closed or a commit is added in the source branch.',
},
{
name: 'Pipeline',
value: 'pipeline',
description: 'Triggered on status change of Pipeline.',
},
{
name: 'Push',
value: 'push',
description: 'Triggered when you push to the repository except when pushing tags.',
},
{
name: 'Tag',
value: 'tag_push',
description: 'Triggered when you create (or delete) tags to the repository.',
},
{
name: 'Wiki Page',
value: 'wiki_page',
description: 'Triggered when a wiki page is created, updated or deleted.',
},
], ],
required: true, required: true,
default: [], default: [],
@ -205,7 +229,7 @@ export class GitlabTrigger implements INodeType {
let eventsArray = this.getNodeParameter('events', []) as string[]; let eventsArray = this.getNodeParameter('events', []) as string[];
if (eventsArray.includes('*')) { if (eventsArray.includes('*')) {
eventsArray = ['note', 'issues', 'job', 'merge_requests', 'pipeline', 'push', 'tag_push', 'wiki_page']; eventsArray = GITLAB_EVENTS.map(e => e.value);
} }
const events: { [key: string]: boolean } = {}; const events: { [key: string]: boolean } = {};