bpmnlint-plugin-camunda-compat 2.27.0 → 2.28.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.js CHANGED
@@ -19,6 +19,7 @@ const camundaCloud10Rules = withConfig({
19
19
  'no-multiple-none-start-events': 'error',
20
20
  'no-priority-definition': 'error',
21
21
  'no-propagate-all-parent-variables': 'error',
22
+ 'no-task-listeners': 'error',
22
23
  'no-task-schedule': 'error',
23
24
  'no-template': 'error',
24
25
  'no-version-tag': 'error',
@@ -94,8 +95,8 @@ const camundaCloud86Rules = withConfig({
94
95
  }, { version: '8.6' });
95
96
 
96
97
  const camundaCloud87Rules = withConfig({
97
- ...camundaCloud86Rules,
98
- 'zeebe-user-task': 'error'
98
+ ...omit(camundaCloud86Rules, [ 'no-task-listeners' ]),
99
+ 'task-listener': 'error'
99
100
  }, { version: '8.7' });
100
101
 
101
102
  const camundaPlatform719Rules = withConfig({
@@ -155,6 +156,7 @@ const rules = {
155
156
  'no-propagate-all-parent-variables': './rules/camunda-cloud/no-propagate-all-parent-variables',
156
157
  'no-signal-event-sub-process': './rules/camunda-cloud/no-signal-event-sub-process',
157
158
  'no-task-schedule': './rules/camunda-cloud/no-task-schedule',
159
+ 'no-task-listeners': './rules/camunda-cloud/no-task-listeners',
158
160
  'no-template': './rules/camunda-cloud/no-template',
159
161
  'no-version-tag': './rules/camunda-cloud/no-version-tag',
160
162
  'no-zeebe-properties': './rules/camunda-cloud/no-zeebe-properties',
@@ -165,13 +167,13 @@ const rules = {
165
167
  'signal-reference': './rules/camunda-cloud/signal-reference',
166
168
  'start-event-form': './rules/camunda-cloud/start-event-form',
167
169
  'subscription': './rules/camunda-cloud/subscription',
170
+ 'task-listener': './rules/camunda-cloud/task-listener',
168
171
  'task-schedule': './rules/camunda-cloud/task-schedule',
169
172
  'timer': './rules/camunda-cloud/timer',
170
173
  'user-task-definition': './rules/camunda-cloud/user-task-definition',
171
174
  'user-task-form': './rules/camunda-cloud/user-task-form',
172
175
  'version-tag': './rules/camunda-cloud/version-tag',
173
- 'wait-for-completion': './rules/camunda-cloud/wait-for-completion',
174
- 'zeebe-user-task': './rules/camunda-cloud/zeebe-user-task'
176
+ 'wait-for-completion': './rules/camunda-cloud/wait-for-completion'
175
177
  };
176
178
 
177
179
  const configs = {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bpmnlint-plugin-camunda-compat",
3
- "version": "2.27.0",
3
+ "version": "2.28.1",
4
4
  "description": "A bpmnlint plug-in for Camunda compatibility",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -34,7 +34,7 @@
34
34
  "modeler-moddle": "^0.2.0",
35
35
  "sinon": "^17.0.1",
36
36
  "sinon-chai": "^3.7.0",
37
- "zeebe-bpmn-moddle": "^1.6.0"
37
+ "zeebe-bpmn-moddle": "^1.7.0"
38
38
  },
39
39
  "dependencies": {
40
40
  "@bpmn-io/feel-lint": "^1.2.0",
@@ -1,18 +1,14 @@
1
- const { is } = require('bpmnlint-utils');
2
-
3
1
  const { reportErrors } = require('../utils/reporter');
4
2
 
5
3
  const { skipInNonExecutableProcess } = require('../utils/rule');
6
4
 
7
- const { hasExtensionElement } = require('../utils/element');
5
+ const { hasNoExtensionElement } = require('../utils/element');
6
+
7
+ const ALLOWED_VERSION = '8.7';
8
8
 
9
9
  module.exports = skipInNonExecutableProcess(function() {
10
10
  function check(node, reporter) {
11
- if (!is(node, 'bpmn:UserTask')) {
12
- return;
13
- }
14
-
15
- const errors = hasExtensionElement(node, 'zeebe:UserTask', node);
11
+ const errors = hasNoExtensionElement(node, 'zeebe:TaskListeners', node, ALLOWED_VERSION);
16
12
 
17
13
  if (errors && errors.length) {
18
14
  reportErrors(node, reporter, errors);
@@ -0,0 +1,40 @@
1
+ const { is } = require('bpmnlint-utils');
2
+
3
+ const {
4
+ findExtensionElement,
5
+ hasProperties
6
+ } = require('../utils/element');
7
+
8
+ const { reportErrors } = require('../utils/reporter');
9
+
10
+ const { skipInNonExecutableProcess } = require('../utils/rule');
11
+
12
+
13
+ module.exports = skipInNonExecutableProcess(function() {
14
+ function check(node, reporter) {
15
+ if (!is(node, 'bpmn:UserTask')) {
16
+ return;
17
+ }
18
+
19
+ const taskListeners = findExtensionElement(node, 'zeebe:TaskListeners');
20
+
21
+ if (!taskListeners) {
22
+ return;
23
+ }
24
+
25
+ const listeners = taskListeners.get('listeners');
26
+ const errors = listeners.flatMap(listener => hasProperties(listener, {
27
+ type: {
28
+ required: true
29
+ }
30
+ }, node));
31
+
32
+ if (errors.length) {
33
+ reportErrors(node, reporter, errors);
34
+ }
35
+ }
36
+
37
+ return {
38
+ check
39
+ };
40
+ });