@aerokit/sdk 12.72.0 → 12.74.0

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.
@@ -1,5 +1,11 @@
1
1
  import { Values } from "@aerokit/sdk/bpm/values";
2
+ const JBpmnError = Java.type("org.flowable.engine.delegate.BpmnError");
2
3
  const BpmFacade = Java.type("org.eclipse.dirigible.components.api.bpm.BpmFacade");
4
+ class BpmnError {
5
+ constructor(code, message) {
6
+ return new JBpmnError(code, message);
7
+ }
8
+ }
3
9
  class Process {
4
10
  /**
5
11
  * Starts a new process instance for a given process definition key.
@@ -95,9 +101,308 @@ class Process {
95
101
  static getExecutionContext() {
96
102
  return new ExecutionContext();
97
103
  }
104
+ /**
105
+ * Retrieves the current task context object, typically used within a task listener or service task.
106
+ *
107
+ * @returns A new instance of the `TaskContext` containing details about the current task.
108
+ */
109
+ static getTaskContext() {
110
+ return new TaskContext();
111
+ }
112
+ }
113
+ class VariableScope {
114
+ constructor(variableScope) {
115
+ this.variableScope = variableScope;
116
+ }
117
+ /**
118
+ * Returns all variables. This will include all variables of parent scopes too.
119
+ * @returns A Map of variable names (`string`) to variable values (`any`).
120
+ */
121
+ getVariables() {
122
+ const variables = this.variableScope.getVariables();
123
+ for (const [key, value] of variables) {
124
+ variables.set(key, Values.parseValue(value));
125
+ }
126
+ return variables;
127
+ }
128
+ /**
129
+ * Returns all variables, as instances of the {@link VariableInstance} interface, which gives more information than only the value (type, execution id, etc.)
130
+ * @returns A Map of variable names (`string`) to {@link VariableInstance} objects (Java type).
131
+ */
132
+ getVariableInstances() {
133
+ return this.variableScope.getVariableInstances();
134
+ }
135
+ /**
136
+ * Returns the variable local to this scope only. So, in contrary to {@link #getVariables()}, the variables from the parent scope won't be returned.
137
+ * @returns A Map of variable names (`string`) to local variable values (`any`).
138
+ */
139
+ getVariablesLocal() {
140
+ const variablesLocal = this.variableScope.getVariablesLocal();
141
+ for (const [key, value] of variablesLocal) {
142
+ variablesLocal.set(key, Values.parseValue(value));
143
+ }
144
+ return variablesLocal;
145
+ }
146
+ /**
147
+ * Returns the variables local to this scope as instances of the {@link VariableInstance} interface, which provided additional information about the variable.
148
+ * @returns A Map of variable names (`string`) to local {@link VariableInstance} objects (Java type).
149
+ */
150
+ getVariableInstancesLocal() {
151
+ return this.variableScope.getVariableInstancesLocal();
152
+ }
153
+ /**
154
+ * Returns the variable value for one specific variable. Will look in parent scopes when the variable does not exist on this particular scope.
155
+ * @param variableName The name of the variable to retrieve.
156
+ * @returns The value of the variable (`any`), or `null` if not found.
157
+ */
158
+ getVariable(variableName) {
159
+ return Values.parseValue(this.variableScope.getVariable(variableName));
160
+ }
161
+ /**
162
+ * Similar to {@link #getVariable(String)}, but returns a {@link VariableInstance} instance, which contains more information than just the value.
163
+ * @param variableName The name of the variable to retrieve.
164
+ * @returns The {@link VariableInstance} object (Java type), or `null`.
165
+ */
166
+ getVariableInstance(variableName) {
167
+ return this.variableScope.getVariableInstance(variableName);
168
+ }
169
+ /**
170
+ * Returns the value for the specific variable and only checks this scope and not any parent scope.
171
+ * @param variableName The name of the local variable to retrieve.
172
+ * @returns The value of the local variable (`any`), or `null` if not found locally.
173
+ */
174
+ getVariableLocal(variableName) {
175
+ return Values.parseValue(this.variableScope.getVariableLocal(variableName));
176
+ }
177
+ /**
178
+ * Similar to {@link #getVariableLocal(String)}, but returns an instance of {@link VariableInstance}, which has some additional information beyond the value.
179
+ * @param variableName The name of the local variable to retrieve.
180
+ * @returns The local {@link VariableInstance} object (Java type), or `null`.
181
+ */
182
+ getVariableInstanceLocal(variableName) {
183
+ return this.variableScope.getVariableInstanceLocal(variableName);
184
+ }
185
+ /**
186
+ * Returns all the names of the variables for this scope and all parent scopes.
187
+ * @returns A Set of all variable names (`string`).
188
+ */
189
+ getVariableNames() {
190
+ const variableNames = /* @__PURE__ */ new Set();
191
+ for (const next of this.variableScope.getVariableNames().toArray()) {
192
+ variableNames.add(next);
193
+ }
194
+ return variableNames;
195
+ }
196
+ /**
197
+ * Returns all the names of the variables for this scope (no parent scopes).
198
+ * @returns A Set of local variable names (`string`).
199
+ */
200
+ getVariableNamesLocal() {
201
+ const variableNamesLocal = /* @__PURE__ */ new Set();
202
+ for (const next of this.variableScope.getVariableNamesLocal().toArray()) {
203
+ variableNamesLocal.add(next);
204
+ }
205
+ return variableNamesLocal;
206
+ }
207
+ /**
208
+ * Sets the variable with the provided name to the provided value. It checks parent scopes for an existing variable before setting on the current scope.
209
+ * @param variableName The name of the variable to be set.
210
+ * @param value The value of the variable to be set (`any`).
211
+ */
212
+ setVariable(variableName, value) {
213
+ this.variableScope.setVariable(variableName, Values.stringifyValue(value));
214
+ }
215
+ /**
216
+ * Similar to {@link #setVariable(String, Object)}, but the variable is set to this scope specifically (local variable).
217
+ * @param variableName The name of the variable to be set locally.
218
+ * @param value The value of the variable to be set (`any`).
219
+ * @returns The old value of the local variable (Java type), or `null`.
220
+ */
221
+ setVariableLocal(variableName, value) {
222
+ return this.variableScope.setVariableLocal(variableName, Values.stringifyValue(value));
223
+ }
224
+ /**
225
+ * Sets the provided variables to the variable scope, using the default scoping algorithm.
226
+ * @param variables A map of keys (`string`) and values (`any`) for the variables to be set.
227
+ */
228
+ setVariables(variables) {
229
+ for (const [key, value] of variables) {
230
+ variables.set(key, Values.stringifyValue(value));
231
+ }
232
+ this.variableScope.setVariables(variables);
233
+ }
234
+ /**
235
+ * Similar to {@link #setVariables(Map)}, but the variables are set on this scope specifically (local variables).
236
+ * @param variables A map of keys (`string`) and values (`any`) for the local variables to be set.
237
+ */
238
+ setVariablesLocal(variables) {
239
+ for (const [key, value] of variables) {
240
+ variables.set(key, Values.stringifyValue(value));
241
+ }
242
+ this.variableScope.setVariablesLocal(variables);
243
+ }
244
+ /**
245
+ * Returns whether this scope or any parent scope has variables.
246
+ * @returns `true` if variables exist in scope hierarchy, `false` otherwise.
247
+ */
248
+ hasVariables() {
249
+ return this.variableScope.hasVariables();
250
+ }
251
+ /**
252
+ * Returns whether this scope has variables.
253
+ * @returns `true` if local variables exist, `false` otherwise.
254
+ */
255
+ hasVariablesLocal() {
256
+ return this.variableScope.hasVariablesLocal();
257
+ }
258
+ /**
259
+ * Returns whether this scope or any parent scope has a specific variable.
260
+ * @param variableName The name of the variable to check.
261
+ * @returns `true` if the variable is found in the scope hierarchy, `false` otherwise.
262
+ */
263
+ hasVariable(variableName) {
264
+ return this.variableScope.hasVariable(variableName);
265
+ }
266
+ /**
267
+ * Returns whether this scope has a specific variable.
268
+ * @param variableName The name of the local variable to check.
269
+ * @returns `true` if the variable is found locally, `false` otherwise.
270
+ */
271
+ hasVariableLocal(variableName) {
272
+ return this.variableScope.hasVariableLocal(variableName);
273
+ }
274
+ /**
275
+ * Removes the variable from the process instance and creates a new HistoricVariableUpdate. Searches up the scope hierarchy.
276
+ * @param variableName The name of the variable to remove.
277
+ */
278
+ removeVariable(variableName) {
279
+ this.variableScope.removeVariable(variableName);
280
+ }
281
+ /**
282
+ * Removes the local variable and creates a new HistoricVariableUpdate.
283
+ * @param variableName The name of the local variable to remove.
284
+ */
285
+ removeVariableLocal(variableName) {
286
+ this.variableScope.removeVariableLocal(variableName);
287
+ }
288
+ /**
289
+ * Removes the variables and creates a new HistoricVariableUpdate for each of them. Searches up the scope hierarchy.
290
+ * @param variableNames An array of variable names (`string[]`) to remove.
291
+ */
292
+ removeVariables(variableNames) {
293
+ this.variableScope.removeVariables(variableNames);
294
+ }
295
+ /**
296
+ * Removes the local variables and creates a new HistoricVariableUpdate for each of them.
297
+ * @param variableNames An array of local variable names (`string[]`) to remove.
298
+ */
299
+ removeVariablesLocal(variableNames) {
300
+ this.variableScope.removeVariablesLocal(variableNames);
301
+ }
302
+ /**
303
+ * Sets a transient variable using the default scoping mechanism (up the hierarchy). Transient variables have no history and are cleared at wait states.
304
+ * @param variableName The name of the transient variable.
305
+ * @param variableValue The value of the transient variable (`any`).
306
+ */
307
+ setTransientVariable(variableName, variableValue) {
308
+ this.variableScope.setTransientVariable(variableName, Values.stringifyValue(variableValue));
309
+ }
310
+ /**
311
+ * Sets a local transient variable. Transient variables have no history and are cleared at wait states.
312
+ * @param variableName The name of the local transient variable.
313
+ * @param variableValue The value of the local transient variable (`any`).
314
+ */
315
+ setTransientVariableLocal(variableName, variableValue) {
316
+ this.variableScope.setTransientVariableLocal(variableName, Values.stringifyValue(variableValue));
317
+ }
318
+ /**
319
+ * Sets multiple transient variables using the default scoping mechanism (up the hierarchy).
320
+ * @param transientVariables A map of keys (`string`) and values (`any`) for the transient variables to be set.
321
+ */
322
+ setTransientVariables(transientVariables) {
323
+ for (const [key, value] of transientVariables) {
324
+ transientVariables.set(key, Values.stringifyValue(value));
325
+ }
326
+ this.variableScope.setTransientVariables(transientVariables);
327
+ }
328
+ /**
329
+ * Retrieves the value of a transient variable, searching up the parent scopes.
330
+ * @param variableName The name of the transient variable to retrieve.
331
+ * @returns The value of the transient variable (`any`), or `null` if not found.
332
+ */
333
+ getTransientVariable(variableName) {
334
+ return Values.parseValue(this.variableScope.getTransientVariable(variableName));
335
+ }
336
+ /**
337
+ * Retrieves all transient variables in the current scope hierarchy.
338
+ * @returns A Map of transient variable names (`string`) to values (`any`).
339
+ */
340
+ getTransientVariables() {
341
+ const transientVariables = this.variableScope.getTransientVariables();
342
+ for (const [key, value] of transientVariables) {
343
+ transientVariables.set(key, Values.parseValue(value));
344
+ }
345
+ return transientVariables;
346
+ }
347
+ /**
348
+ * Sets multiple local transient variables.
349
+ * @param transientVariables A map of keys (`string`) and values (`any`) for the local transient variables to be set.
350
+ */
351
+ setTransientVariablesLocal(transientVariables) {
352
+ for (const [key, value] of transientVariables) {
353
+ transientVariables.set(key, Values.stringifyValue(value));
354
+ }
355
+ this.variableScope.setTransientVariablesLocal(transientVariables);
356
+ }
357
+ /**
358
+ * Retrieves the value of a local transient variable.
359
+ * @param variableName The name of the local transient variable to retrieve.
360
+ * @returns The value of the local transient variable (`any`), or `null` if not found.
361
+ */
362
+ getTransientVariableLocal(variableName) {
363
+ return Values.parseValue(this.variableScope.getTransientVariableLocal(variableName));
364
+ }
365
+ /**
366
+ * Retrieves all local transient variables.
367
+ * @returns A Map of local transient variable names (`string`) to values (`any`).
368
+ */
369
+ getTransientVariablesLocal() {
370
+ const transientVariablesLocal = this.variableScope.getTransientVariablesLocal();
371
+ for (const [key, value] of transientVariablesLocal) {
372
+ transientVariablesLocal.set(key, Values.parseValue(value));
373
+ }
374
+ return transientVariablesLocal;
375
+ }
376
+ /**
377
+ * Removes a specific local transient variable.
378
+ * @param variableName The name of the local transient variable to remove.
379
+ */
380
+ removeTransientVariableLocal(variableName) {
381
+ this.variableScope.removeTransientVariableLocal(variableName);
382
+ }
383
+ /**
384
+ * Removes a specific transient variable, searching up the scope hierarchy.
385
+ * @param variableName The name of the transient variable to remove.
386
+ */
387
+ removeTransientVariable(variableName) {
388
+ this.variableScope.removeTransientVariable(variableName);
389
+ }
390
+ /**
391
+ * Remove all transient variables of this scope and its parent scopes.
392
+ */
393
+ removeTransientVariables() {
394
+ this.variableScope.removeTransientVariables();
395
+ }
396
+ /**
397
+ * Removes all local transient variables.
398
+ */
399
+ removeTransientVariablesLocal() {
400
+ this.variableScope.removeTransientVariablesLocal();
401
+ }
98
402
  }
99
- class ExecutionContext {
403
+ class ExecutionContext extends VariableScope {
100
404
  constructor() {
405
+ super(__context.get("execution"));
101
406
  this.execution = __context.get("execution");
102
407
  }
103
408
  /**
@@ -322,296 +627,426 @@ class ExecutionContext {
322
627
  setMultiInstanceRoot(isMultiInstanceRoot) {
323
628
  this.execution.setMultiInstanceRoot(isMultiInstanceRoot);
324
629
  }
630
+ }
631
+ var DelegationState = /* @__PURE__ */ ((DelegationState2) => {
632
+ DelegationState2[DelegationState2["PENDING"] = 0] = "PENDING";
633
+ DelegationState2[DelegationState2["RESOLVED"] = 1] = "RESOLVED";
634
+ return DelegationState2;
635
+ })(DelegationState || {});
636
+ class TaskContext extends VariableScope {
637
+ constructor() {
638
+ super(__context.get("task"));
639
+ this.task = __context.get("task");
640
+ }
325
641
  /**
326
- * Returns all variables. This will include all variables of parent scopes too.
327
- * @returns A Map of variable names (`string`) to variable values (`any`).
642
+ * DB id of the task.
643
+ *
644
+ * @returns the unique ID of the current task.
328
645
  */
329
- getVariables() {
330
- const variables = this.execution.getVariables();
331
- for (const [key, value] of variables) {
332
- variables.set(key, Values.parseValue(value));
333
- }
334
- return variables;
646
+ getId() {
647
+ return this.task.getId();
335
648
  }
336
649
  /**
337
- * Returns all variables, as instances of the {@link VariableInstance} interface, which gives more information than only the value (type, execution id, etc.)
338
- * @returns A Map of variable names (`string`) to {@link VariableInstance} objects (Java type).
650
+ * Name or title of the task.
651
+ *
652
+ * @returns the name of the current task.
339
653
  */
340
- getVariableInstances() {
341
- return this.execution.getVariableInstances();
654
+ getName() {
655
+ return this.task.getName();
342
656
  }
343
657
  /**
344
- * Returns the variable local to this scope only. So, in contrary to {@link #getVariables()}, the variables from the parent scope won't be returned.
345
- * @returns A Map of variable names (`string`) to local variable values (`any`).
658
+ * Change the name of the task.
659
+ *
660
+ * @param name the new name for the task.
346
661
  */
347
- getVariablesLocal() {
348
- const variablesLocal = this.execution.getVariablesLocal();
349
- for (const [key, value] of variablesLocal) {
350
- variablesLocal.set(key, Values.parseValue(value));
351
- }
352
- return variablesLocal;
662
+ setName(name) {
663
+ this.task.setName(name);
353
664
  }
354
665
  /**
355
- * Returns the variables local to this scope as instances of the {@link VariableInstance} interface, which provided additional information about the variable.
356
- * @returns A Map of variable names (`string`) to local {@link VariableInstance} objects (Java type).
666
+ * Get the free text description of the task.
667
+ *
668
+ * @returns the description of the current task.
357
669
  */
358
- getVariableInstancesLocal() {
359
- return this.execution.getVariableInstancesLocal();
670
+ getDescription() {
671
+ return this.task.getDescription();
360
672
  }
361
673
  /**
362
- * Returns the variable value for one specific variable. Will look in parent scopes when the variable does not exist on this particular scope.
363
- * @param variableName The name of the variable to retrieve.
364
- * @returns The value of the variable (`any`), or `null` if not found.
674
+ * Free text description of the task.
675
+ *
676
+ * @param description the new description for the task.
365
677
  */
366
- getVariable(variableName) {
367
- return Values.parseValue(this.execution.getVariable(variableName));
678
+ setDescription(description) {
679
+ this.task.setDescription(description);
368
680
  }
369
681
  /**
370
- * Similar to {@link #getVariable(String)}, but returns a {@link VariableInstance} instance, which contains more information than just the value.
371
- * @param variableName The name of the variable to retrieve.
372
- * @returns The {@link VariableInstance} object (Java type), or `null`.
682
+ * Indication of how important/urgent this task is with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low,
683
+ * [40..59] normal, [60..79] high [80..100] highest
684
+ *
685
+ * @returns the priority of the current task.
373
686
  */
374
- getVariableInstance(variableName) {
375
- return this.execution.getVariableInstance(variableName);
687
+ getPriority() {
688
+ return this.task.getPriority();
376
689
  }
377
690
  /**
378
- * Returns the value for the specific variable and only checks this scope and not any parent scope.
379
- * @param variableName The name of the local variable to retrieve.
380
- * @returns The value of the local variable (`any`), or `null` if not found locally.
691
+ * Indication of how important/urgent this task is with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low,
692
+ * [40..59] normal, [60..79] high [80..100] highest
693
+ *
694
+ * @param priority the new priority for the task, with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low, [40..59] normal,
381
695
  */
382
- getVariableLocal(variableName) {
383
- return Values.parseValue(this.execution.getVariableLocal(variableName));
696
+ setPriority(priority) {
697
+ this.task.setPriority(priority);
384
698
  }
385
699
  /**
386
- * Similar to {@link #getVariableLocal(String)}, but returns an instance of {@link VariableInstance}, which has some additional information beyond the value.
387
- * @param variableName The name of the local variable to retrieve.
388
- * @returns The local {@link VariableInstance} object (Java type), or `null`.
700
+ * Refrence to the process instance this task is associated with, or `null` if the task is not related to a process instance.
701
+ *
702
+ * @returns the ID of the process instance this task is associated with, or `null`.
389
703
  */
390
- getVariableInstanceLocal(variableName) {
391
- return this.execution.getVariableInstanceLocal(variableName);
704
+ getProcessInstanceId() {
705
+ return this.task.getProcessInstanceId();
392
706
  }
393
707
  /**
394
- * Returns all the names of the variables for this scope and all parent scopes.
395
- * @returns A Set of all variable names (`string`).
708
+ * Reference to the path of execution this task is associated with, or `null` if the task is not related to a process instance.
709
+ *
710
+ * @returns the ID of the execution this task is associated with, or `null`.
396
711
  */
397
- getVariableNames() {
398
- const variableNames = /* @__PURE__ */ new Set();
399
- for (const next of this.execution.getVariableNames().toArray()) {
400
- variableNames.add(next);
401
- }
402
- return variableNames;
712
+ getExecutionId() {
713
+ return this.task.getExecutionId();
403
714
  }
404
715
  /**
405
- * Returns all the names of the variables for this scope (no parent scopes).
406
- * @returns A Set of local variable names (`string`).
716
+ * Reference to the process definition this task is associated with, or `null` if the task is not related to a process instance.
717
+ *
718
+ * @returns the ID of the process definition this task is associated with, or `null`.
407
719
  */
408
- getVariableNamesLocal() {
409
- const variableNamesLocal = /* @__PURE__ */ new Set();
410
- for (const next of this.execution.getVariableNamesLocal().toArray()) {
411
- variableNamesLocal.add(next);
412
- }
413
- return variableNamesLocal;
720
+ getProcessDefinitionId() {
721
+ return this.task.getProcessDefinitionId();
414
722
  }
415
723
  /**
416
- * Sets the variable with the provided name to the provided value. It checks parent scopes for an existing variable before setting on the current scope.
417
- * @param variableName The name of the variable to be set.
418
- * @param value The value of the variable to be set (`any`).
724
+ * The current state of the task.
725
+ *
726
+ * @returns the state of the current task.
419
727
  */
420
- setVariable(variableName, value) {
421
- this.execution.setVariable(variableName, Values.stringifyValue(value));
728
+ getState() {
729
+ return this.task.getState();
422
730
  }
423
731
  /**
424
- * Similar to {@link #setVariable(String, Object)}, but the variable is set to this scope specifically (local variable).
425
- * @param variableName The name of the variable to be set locally.
426
- * @param value The value of the variable to be set (`any`).
427
- * @returns The old value of the local variable (Java type), or `null`.
732
+ * The date/time when this task was created.
733
+ *
734
+ * @returns the creation time of the current task.
428
735
  */
429
- setVariableLocal(variableName, value) {
430
- return this.execution.setVariableLocal(variableName, Values.stringifyValue(value));
736
+ getCreateTime() {
737
+ return this.task.getCreateTime();
431
738
  }
432
739
  /**
433
- * Sets the provided variables to the variable scope, using the default scoping algorithm.
434
- * @param variables A map of keys (`string`) and values (`any`) for the variables to be set.
740
+ * The date/time when this task was put in progress.
741
+ *
742
+ * @returns the in progress start time of the current task.
435
743
  */
436
- setVariables(variables) {
437
- for (const [key, value] of variables) {
438
- variables.set(key, Values.stringifyValue(value));
439
- }
440
- this.execution.setVariables(variables);
744
+ getInProgressStartTime() {
745
+ return this.task.getInProgressStartTime();
441
746
  }
442
747
  /**
443
- * Similar to {@link #setVariables(Map)}, but the variables are set on this scope specifically (local variables).
444
- * @param variables A map of keys (`string`) and values (`any`) for the local variables to be set.
748
+ * The user reference that started the task.
749
+ *
750
+ * @returns the user reference that started the task.
445
751
  */
446
- setVariablesLocal(variables) {
447
- for (const [key, value] of variables) {
448
- variables.set(key, Values.stringifyValue(value));
449
- }
450
- this.execution.setVariablesLocal(variables);
752
+ getInProgressStartedBy() {
753
+ return this.task.getInProgressStartedBy();
451
754
  }
452
755
  /**
453
- * Returns whether this scope or any parent scope has variables.
454
- * @returns `true` if variables exist in scope hierarchy, `false` otherwise.
756
+ * The date/time when this task was claimed.
757
+ *
758
+ * @returns the claim time of the current task.
455
759
  */
456
- hasVariables() {
457
- return this.execution.hasVariables();
760
+ getClaimTime() {
761
+ return this.task.getClaimTime();
458
762
  }
459
763
  /**
460
- * Returns whether this scope has variables.
461
- * @returns `true` if local variables exist, `false` otherwise.
764
+ * The user reference that claimed the task.
765
+ *
766
+ * @returns the user reference that claimed the task.
462
767
  */
463
- hasVariablesLocal() {
464
- return this.execution.hasVariablesLocal();
768
+ getClaimedBy() {
769
+ return this.task.getClaimedBy();
465
770
  }
466
771
  /**
467
- * Returns whether this scope or any parent scope has a specific variable.
468
- * @param variableName The name of the variable to check.
469
- * @returns `true` if the variable is found in the scope hierarchy, `false` otherwise.
772
+ * The date/time when this task was suspended.
773
+ *
774
+ * @returns the date/time when this task was suspended.
470
775
  */
471
- hasVariable(variableName) {
472
- return this.execution.hasVariable(variableName);
776
+ getSuspendedTime() {
777
+ return this.task.getSuspendedTime();
473
778
  }
474
779
  /**
475
- * Returns whether this scope has a specific variable.
476
- * @param variableName The name of the local variable to check.
477
- * @returns `true` if the variable is found locally, `false` otherwise.
780
+ * The user reference that suspended the task.
781
+ *
782
+ * @returns the user reference that suspended the task.
478
783
  */
479
- hasVariableLocal(variableName) {
480
- return this.execution.hasVariableLocal(variableName);
784
+ getSuspendedBy() {
785
+ return this.task.getSuspendedBy();
481
786
  }
482
787
  /**
483
- * Removes the variable from the process instance and creates a new HistoricVariableUpdate. Searches up the scope hierarchy.
484
- * @param variableName The name of the variable to remove.
788
+ * The id of the activity in the process defining this task or null if this is not related to a process.
789
+ *
790
+ * @returns the task definition key.
485
791
  */
486
- removeVariable(variableName) {
487
- this.execution.removeVariable(variableName);
792
+ getTaskDefinitionKey() {
793
+ return this.task.getTaskDefinitionKey();
488
794
  }
489
795
  /**
490
- * Removes the local variable and creates a new HistoricVariableUpdate.
491
- * @param variableName The name of the local variable to remove.
796
+ * Indicated whether this task is suspended or not.
797
+ *
798
+ * @returns `true` if the task is suspended, `false` otherwise.
492
799
  */
493
- removeVariableLocal(variableName) {
494
- this.execution.removeVariableLocal(variableName);
800
+ isSuspended() {
801
+ return this.task.isSuspended();
495
802
  }
496
803
  /**
497
- * Removes the variables and creates a new HistoricVariableUpdate for each of them. Searches up the scope hierarchy.
498
- * @param variableNames An array of variable names (`string[]`) to remove.
804
+ * The tenant identifier of this task, which is the same as the tenant identifier of the process definition and process instance this task is associated with (if any).
805
+ *
806
+ * @returns the tenant ID of this task, or `null`/empty string if no tenant is associated.
499
807
  */
500
- removeVariables(variableNames) {
501
- this.execution.removeVariables(variableNames);
808
+ getTenantId() {
809
+ return this.task.getTenantId();
502
810
  }
503
811
  /**
504
- * Removes the local variables and creates a new HistoricVariableUpdate for each of them.
505
- * @param variableNames An array of local variable names (`string[]`) to remove.
812
+ * The form key for the user task, which is the same as the form key defined on the user task in the process definition. Will return `null` if this task is not a user task or if no form key is defined.
813
+ *
814
+ * @returns the form key for the user task, or `null` if no form key is defined.
506
815
  */
507
- removeVariablesLocal(variableNames) {
508
- this.execution.removeVariablesLocal(variableNames);
816
+ getFormKey() {
817
+ return this.task.getFormKey();
509
818
  }
510
819
  /**
511
- * Sets a transient variable using the default scoping mechanism (up the hierarchy). Transient variables have no history and are cleared at wait states.
512
- * @param variableName The name of the transient variable.
513
- * @param variableValue The value of the transient variable (`any`).
820
+ * Change the form key of the task.
821
+ *
822
+ * @param formKey the new form key for the user task, or `null` to remove the form key
514
823
  */
515
- setTransientVariable(variableName, variableValue) {
516
- this.execution.setTransientVariable(variableName, Values.stringifyValue(variableValue));
824
+ setFormKey(formKey) {
825
+ this.task.setFormKey(formKey);
517
826
  }
518
827
  /**
519
- * Sets a local transient variable. Transient variables have no history and are cleared at wait states.
520
- * @param variableName The name of the local transient variable.
521
- * @param variableValue The value of the local transient variable (`any`).
828
+ * The event name which triggered the task listener to fire for this task. Will return `null`/empty string if not executing a task listener.
829
+ *
830
+ * @returns the event name which triggered the task listener to fire for this task, or `null`/empty string if not executing a task listener.
522
831
  */
523
- setTransientVariableLocal(variableName, variableValue) {
524
- this.execution.setTransientVariableLocal(variableName, Values.stringifyValue(variableValue));
832
+ getEventName() {
833
+ return this.task.getEventName();
525
834
  }
526
835
  /**
527
- * Sets multiple transient variables using the default scoping mechanism (up the hierarchy).
528
- * @param transientVariables A map of keys (`string`) and values (`any`) for the transient variables to be set.
836
+ * The event handler identifier which triggered the task listener to fire for this task. Will return `null`/empty string if not executing a task listener or if the event handler does not have an identifier.
837
+ *
838
+ * @returns the event handler identifier, or `null`/empty string if not executing a task listener or if the event handler does not have an identifier.
529
839
  */
530
- setTransientVariables(transientVariables) {
531
- for (const [key, value] of transientVariables) {
532
- transientVariables.set(key, Values.stringifyValue(value));
533
- }
534
- this.execution.setTransientVariables(transientVariables);
840
+ getEventHandlerId() {
841
+ return this.task.getEventHandlerId();
535
842
  }
536
843
  /**
537
- * Retrieves the value of a transient variable, searching up the parent scopes.
538
- * @param variableName The name of the transient variable to retrieve.
539
- * @returns The value of the transient variable (`any`), or `null` if not found.
844
+ * The current delegation state of the task, which is `null` if the task is not delegated, `PENDING` if the task is delegated and waiting for resolution by the assignee, and `RESOLVED` if the task is delegated and has been resolved by the assignee but not yet completed by the owner.
845
+ *
846
+ * @returns the delegation state of the task, which is `null` if the task is not delegated, `PENDING` if the task is delegated and waiting for resolution by the assignee, and `RESOLVED` if the task is delegated and has been resolved by the assignee but not yet completed by the owner.
540
847
  */
541
- getTransientVariable(variableName) {
542
- return Values.parseValue(this.execution.getTransientVariable(variableName));
848
+ getDelegationState() {
849
+ return this.task.getDelegationState();
543
850
  }
544
851
  /**
545
- * Retrieves all transient variables in the current scope hierarchy.
546
- * @returns A Map of transient variable names (`string`) to values (`any`).
852
+ * Adds a candidate user to this task, which means that the user is allowed to claim and work on this task. This does not mean that the user is the assignee of the task, but it means that the user is a candidate to become an assignee. The user will be able to see this task in their task list and claim it to become the assignee.
853
+ *
854
+ * @param userId the user ID of the candidate user to add to this task.
547
855
  */
548
- getTransientVariables() {
549
- const transientVariables = this.execution.getTransientVariables();
550
- for (const [key, value] of transientVariables) {
551
- transientVariables.set(key, Values.parseValue(value));
552
- }
553
- return transientVariables;
856
+ addCandidateUser(userId) {
857
+ this.task.addCandidateUser(userId);
554
858
  }
555
859
  /**
556
- * Sets multiple local transient variables.
557
- * @param transientVariables A map of keys (`string`) and values (`any`) for the local transient variables to be set.
860
+ * Adds multiple users as candidate user to this task.
861
+ *
862
+ * @param candidateUsers the collection of candidate user IDs to add to this task.
558
863
  */
559
- setTransientVariablesLocal(transientVariables) {
560
- for (const [key, value] of transientVariables) {
561
- transientVariables.set(key, Values.stringifyValue(value));
562
- }
563
- this.execution.setTransientVariablesLocal(transientVariables);
864
+ addCandidateUsers(candidateUsers) {
865
+ this.task.addCandidateUsers(candidateUsers);
564
866
  }
565
867
  /**
566
- * Retrieves the value of a local transient variable.
567
- * @param variableName The name of the local transient variable to retrieve.
568
- * @returns The value of the local transient variable (`any`), or `null` if not found.
868
+ * Adds a candidate group to this task, which means that all users that are members of this group are allowed to claim and work on this task. This does not mean that the group is the assignee of the task, but it means that all users that are members of the group are candidates to become assignees. The users that are members of the group will be able to see this task in their task list and claim it to become the assignee.
869
+ *
870
+ * @param groupId the group ID of the candidate group to add to this task.
569
871
  */
570
- getTransientVariableLocal(variableName) {
571
- return Values.parseValue(this.execution.getTransientVariableLocal(variableName));
872
+ addCandidateGroup(groupId) {
873
+ this.task.addCandidateGroup(groupId);
572
874
  }
573
875
  /**
574
- * Retrieves all local transient variables.
575
- * @returns A Map of local transient variable names (`string`) to values (`any`).
876
+ * Adds multiple groups as candidate group to this task.
877
+ *
878
+ * @param candidateGroups the collection of candidate group IDs to add to this task.
576
879
  */
577
- getTransientVariablesLocal() {
578
- const transientVariablesLocal = this.execution.getTransientVariablesLocal();
579
- for (const [key, value] of transientVariablesLocal) {
580
- transientVariablesLocal.set(key, Values.parseValue(value));
581
- }
582
- return transientVariablesLocal;
880
+ addCandidateGroups(candidateGroups) {
881
+ this.task.addCandidateGroups(candidateGroups);
583
882
  }
584
883
  /**
585
- * Removes a specific local transient variable.
586
- * @param variableName The name of the local transient variable to remove.
884
+ * The user id of the person responsible for this task. This is the user that has to work on this task and complete it. When a task is assigned to a user, that user becomes the assignee of the task. The assignee is the only one that can complete the task (unless the task is delegated
885
+ *
886
+ * @returns the user ID of the assignee of this task
587
887
  */
588
- removeTransientVariableLocal(variableName) {
589
- this.execution.removeTransientVariableLocal(variableName);
888
+ getOwner() {
889
+ return this.task.getOwner();
590
890
  }
591
891
  /**
592
- * Removes a specific transient variable, searching up the scope hierarchy.
593
- * @param variableName The name of the transient variable to remove.
892
+ * The user id of the person responsible for this task. This is the user that has to work on this task and complete it. When a task is assigned to a user, that user becomes the assignee of the task. The assignee is the only one that can complete the task (unless the task is delegated
893
+ *
894
+ * @param owner the user ID of the assignee of this task
594
895
  */
595
- removeTransientVariable(variableName) {
596
- this.execution.removeTransientVariable(variableName);
896
+ setOwner(owner) {
897
+ this.task.setOwner(owner);
597
898
  }
598
899
  /**
599
- * Remove all transient variables of this scope and its parent scopes.
900
+ * The user id of the person to which this task is delegated.
901
+ *
902
+ * @returns the user ID of the assignee of this task
600
903
  */
601
- removeTransientVariables() {
602
- this.execution.removeTransientVariables();
904
+ getAssignee() {
905
+ return this.task.getAssignee();
603
906
  }
604
907
  /**
605
- * Removes all local transient variables.
908
+ * The user id of the person to which this task is delegated.
909
+ * @param assignee the user ID of the assignee of this task
606
910
  */
607
- removeTransientVariablesLocal() {
608
- this.execution.removeTransientVariablesLocal();
911
+ setAssignee(assignee) {
912
+ this.task.setAssignee(assignee);
913
+ }
914
+ /**
915
+ * Due date of the in progress start of the task.
916
+ *
917
+ * @returns the due date of the in progress start of the task.
918
+ */
919
+ getInProgressStartDueDate() {
920
+ return this.task.getInProgressStartDueDate();
921
+ }
922
+ /**
923
+ * Change the in progress start due date of the task.
924
+ *
925
+ * @param inProgressStartDueDate the new due date of the in progress start of the task.
926
+ */
927
+ setInProgressStartDueDate(inProgressStartDueDate) {
928
+ this.task.setInProgressStartDueDate(inProgressStartDueDate);
929
+ }
930
+ /**
931
+ * Due date of the task.
932
+ *
933
+ * @returns the due date of the task.
934
+ */
935
+ getDueDate() {
936
+ return this.task.getDueDate();
937
+ }
938
+ /**
939
+ * Change the due date of the task.
940
+ *
941
+ * @param dueDate the new due date of the task.
942
+ */
943
+ setDueDate(dueDate) {
944
+ this.task.setDueDate(dueDate);
945
+ }
946
+ /**
947
+ * The category of the task. This is an optional field and allows to 'tag' tasks as belonging to a certain category.
948
+ *
949
+ * @returns the category of the task
950
+ */
951
+ getCategory() {
952
+ return this.task.getCategory();
953
+ }
954
+ /**
955
+ * Change the category of the task. This is an optional field and allows to 'tag' tasks as belonging to a certain category.
956
+ *
957
+ * @param category the new category of the task
958
+ */
959
+ setCategory(category) {
960
+ this.task.setCategory(category);
961
+ }
962
+ /**
963
+ * Involves a user with a task. The type of identity link is defined by the given identityLinkType.
964
+ *
965
+ * @param userId
966
+ * id of the user involve, cannot be null.
967
+ * @param identityLinkType
968
+ * type of identityLink, cannot be null (@see {@link IdentityLinkType}).
969
+ * @throws FlowableObjectNotFoundException
970
+ * when the task or user doesn't exist.
971
+ */
972
+ addUserIdentityLink(userId, identityLinkType) {
973
+ this.task.addUserIdentityLink(userId, identityLinkType);
974
+ }
975
+ /**
976
+ * Involves a group with group task. The type of identityLink is defined by the given identityLink.
977
+ *
978
+ * @param groupId
979
+ * id of the group to involve, cannot be null.
980
+ * @param identityLinkType
981
+ * type of identity, cannot be null (@see {@link IdentityLinkType}).
982
+ * @throws FlowableObjectNotFoundException
983
+ * when the task or group doesn't exist.
984
+ */
985
+ addGroupIdentityLink(groupId, identityLinkType) {
986
+ this.task.addGroupIdentityLink(groupId, identityLinkType);
987
+ }
988
+ /**
989
+ * Convenience shorthand for {@link #deleteUserIdentityLink(String, String)} ; with type {@link IdentityLinkType#CANDIDATE}
990
+ *
991
+ * @param userId
992
+ * id of the user to use as candidate, cannot be null.
993
+ * @throws FlowableObjectNotFoundException
994
+ * when the task or user doesn't exist.
995
+ */
996
+ deleteCandidateUser(userId) {
997
+ this.task.deleteCandidateUser(userId);
998
+ }
999
+ /**
1000
+ * Convenience shorthand for {@link #deleteGroupIdentityLink(String, String)}; with type {@link IdentityLinkType#CANDIDATE}
1001
+ *
1002
+ * @param groupId
1003
+ * id of the group to use as candidate, cannot be null.
1004
+ * @throws FlowableObjectNotFoundException
1005
+ * when the task or group doesn't exist.
1006
+ */
1007
+ deleteCandidateGroup(groupId) {
1008
+ this.task.deleteCandidateGroup(groupId);
1009
+ }
1010
+ /**
1011
+ * Removes the association between a user and a task for the given identityLinkType.
1012
+ *
1013
+ * @param userId
1014
+ * id of the user involve, cannot be null.
1015
+ * @param identityLinkType
1016
+ * type of identityLink, cannot be null (@see {@link IdentityLinkType}).
1017
+ * @throws FlowableObjectNotFoundException
1018
+ * when the task or user doesn't exist.
1019
+ */
1020
+ deleteUserIdentityLink(userId, identityLinkType) {
1021
+ this.task.deleteUserIdentityLink(userId, identityLinkType);
1022
+ }
1023
+ /**
1024
+ * Removes the association between a group and a task for the given identityLinkType.
1025
+ *
1026
+ * @param groupId
1027
+ * id of the group to involve, cannot be null.
1028
+ * @param identityLinkType
1029
+ * type of identity, cannot be null (@see {@link IdentityLinkType}).
1030
+ * @throws FlowableObjectNotFoundException
1031
+ * when the task or group doesn't exist.
1032
+ */
1033
+ deleteGroupIdentityLink(groupId, identityLinkType) {
1034
+ this.task.deleteGroupIdentityLink(groupId, identityLinkType);
1035
+ }
1036
+ /**
1037
+ * Retrieves the candidate users and groups associated with the task.
1038
+ *
1039
+ * @return set of {@link IdentityLink}s of type {@link IdentityLinkType#CANDIDATE}.
1040
+ */
1041
+ getCandidates() {
1042
+ return this.task.getCandidates();
609
1043
  }
610
1044
  }
611
1045
  if (typeof module !== "undefined") {
612
1046
  module.exports = Process;
613
1047
  }
614
1048
  export {
1049
+ BpmnError,
615
1050
  Process
616
1051
  };
617
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bpm/process.ts"],
  "sourcesContent": ["/**\n * API Process\n * * Provides methods for interacting with process instances,\n * including starting, updating metadata, and managing variables.\n */\n\nimport { Values } from \"@aerokit/sdk/bpm/values\";\n\nconst BpmFacade = Java.type(\"org.eclipse.dirigible.components.api.bpm.BpmFacade\");\n\nexport class Process {\n\n\t/**\n\t * Starts a new process instance for a given process definition key.\n\t *\n\t * @param key The process definition key (ID) of the process to start.\n\t * @param businessKey An optional business key to associate with the process instance. Defaults to an empty string.\n\t * @param parameters An optional map of process variables to pass to the process instance upon starting. Defaults to an empty object.\n\t * @returns The unique ID of the newly started process instance.\n\t */\n\tpublic static start(key: string, businessKey: string = '', parameters: { [key: string]: any } = {}): string {\n\t\treturn BpmFacade.startProcess(key, businessKey, JSON.stringify(parameters));\n\t}\n\n\t/**\n\t * Sets a human-readable name for an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param name The new name for the process instance.\n\t */\n\tpublic static setProcessInstanceName(processInstanceId: string, name: string): void {\n\t\tBpmFacade.setProcessInstanceName(processInstanceId, name);\n\t}\n\n\t/**\n\t * Updates the business key of an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param businessKey The new business key.\n\t */\n\tpublic static updateBusinessKey(processInstanceId: string, businessKey: string): void {\n\t\tBpmFacade.updateBusinessKey(processInstanceId, businessKey);\n\t}\n\n\t/**\n\t * Updates the business status of an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param businessStatus The new business status.\n\t */\n\tpublic static updateBusinessStatus(processInstanceId: string, businessStatus: string): void {\n\t\tBpmFacade.updateBusinessStatus(processInstanceId, businessStatus);\n\t}\n\n\t/**\n\t * Retrieves the value of a specific variable from a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The value of the variable, or `null` if the variable does not exist. The type is `any` as it depends on the stored value.\n\t */\n\tpublic static getVariable(processInstanceId: string, variableName: string): any {\n\t\treturn BpmFacade.getVariable(processInstanceId, variableName);\n\t}\n\n\t/**\n\t * Retrieves all variables associated with a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @returns An object containing all variables for the process instance, where keys are variable names and values are the variable values.\n\t */\n\tpublic static getVariables(processInstanceId: string): any {\n\t\treturn BpmFacade.getVariables(processInstanceId);\n\t}\n\n\t/**\n\t * Sets or updates the value of a variable in a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to set.\n\t * @param value The new value for the variable. The type is `any` to accommodate different data types.\n\t */\n\tpublic static setVariable(processInstanceId: string, variableName: string, value: any): void {\n\t\tBpmFacade.setVariable(processInstanceId, variableName, value);\n\t}\n\n\t/**\n\t * Removes a variable from a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to remove.\n\t */\n\tpublic static removeVariable(processInstanceId: string, variableName: string): void {\n\t\tBpmFacade.removeVariable(processInstanceId, variableName);\n\t}\n\n\t/**\n\t * Correlates a message event with a running process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to correlate the message to.\n\t * @param messageName The name of the message event defined in the BPMN process.\n\t * @param variables A map of variables (`Map<string, any>`) to pass along with the message event.\n\t */\n\tpublic static correlateMessageEvent(processInstanceId: string, messageName: string, variables: Map<string, any>): void {\n\t\tBpmFacade.correlateMessageEvent(processInstanceId, messageName, Values.stringifyValuesMap(variables));\n\t}\n\n\t/**\n\t * Retrieves the current execution context object, typically used within an execution listener or service task.\n\t *\n\t * @returns A new instance of the `ExecutionContext` containing details about the current process execution path.\n\t */\n\tpublic static getExecutionContext() {\n\t\treturn new ExecutionContext();\n\t}\n}\n\n/**\n * ExecutionContext object\n * * Provides detailed information and control over the current process execution path.\n */\nclass ExecutionContext {\n\n\tprivate execution: any;\n\n\tconstructor() {\n\t\tthis.execution = __context.get('execution');\n\t}\n\n\t/**\n\t * Unique id of this path of execution that can be used as a handle to provide external signals back into the engine after wait states.\n\t *\n\t * @returns The unique ID of the current execution.\n\t */\n\tpublic getId(): string {\n\t\treturn this.execution.getId();\n\t}\n\n\t/**\n\t * Reference to the overall process instance.\n\t * @returns The ID of the process instance.\n\t */\n\tpublic getProcessInstanceId(): string {\n\t\treturn this.execution.getProcessInstanceId();\n\t}\n\n\t/**\n\t * The 'root' process instance. When using call activity for example, the processInstance set will not always be the root. This method returns the topmost process instance.\n\t *\n\t * @returns The ID of the root process instance.\n\t */\n\tpublic getRootProcessInstanceId(): string {\n\t\treturn this.execution.getRootProcessInstanceId();\n\t}\n\n\t/**\n\t * Will contain the event name in case this execution is passed in for an {@link ExecutionListener}.\n\t * @returns The current event name, or `null`/empty string if not executing an event listener.\n\t */\n\tpublic getEventName(): string {\n\t\treturn this.execution.getEventName();\n\t}\n\n\t/**\n\t * Sets the current event (typically when execution an {@link ExecutionListener}).\n\t *\n\t * @param eventName The name of the event.\n\t */\n\tpublic setEventName(eventName: string): void {\n\t\tthis.execution.setEventName(eventName);\n\t}\n\n\t/**\n\t * The business key for the process instance this execution is associated with.\n\t * @returns The business key.\n\t */\n\tpublic getProcessInstanceBusinessKey(): string {\n\t\treturn this.execution.getProcessInstanceBusinessKey();\n\t}\n\n\t/**\n\t * The business status for the process instance this execution is associated with.\n\t * @returns The business status.\n\t */\n\tpublic getProcessInstanceBusinessStatus(): string {\n\t\treturn this.execution.getProcessInstanceBusinessStatus();\n\t}\n\n\t/**\n\t * The process definition key for the process instance this execution is associated with.\n\t * @returns The process definition ID.\n\t */\n\tpublic getProcessDefinitionId(): string {\n\t\treturn this.execution.getProcessDefinitionId();\n\t}\n\n\t/**\n\t * If this execution runs in the context of a case and stage, this method returns it's closest parent stage instance id (the stage plan item instance id to be\n\t * precise).\n\t *\n\t * @returns The stage instance id this execution belongs to or `null`, if this execution is not part of a case at all or is not a child element of a stage.\n\t */\n\tpublic getPropagatedStageInstanceId(): string {\n\t\treturn this.execution.getPropagatedStageInstanceId();\n\t}\n\n\t/**\n\t * Gets the id of the parent of this execution. If null, the execution represents a process-instance.\n\t * @returns The parent execution ID, or `null`.\n\t */\n\tpublic getParentId(): string {\n\t\treturn this.execution.getParentId();\n\t}\n\n\t/**\n\t * Gets the id of the calling execution. If not null, the execution is part of a subprocess.\n\t * @returns The super execution ID, or `null`.\n\t */\n\tpublic getSuperExecutionId(): string {\n\t\treturn this.execution.getSuperExecutionId();\n\t}\n\n\t/**\n\t * Gets the id of the current activity.\n\t * @returns The current activity ID.\n\t */\n\tpublic getCurrentActivityId(): string {\n\t\treturn this.execution.getCurrentActivityId();\n\t}\n\n\t/**\n\t * Returns the tenant id, if any is set before on the process definition or process instance.\n\t * @returns The tenant ID, or `null`/empty string.\n\t */\n\tpublic getTenantId(): string {\n\t\treturn this.execution.getTenantId();\n\t}\n\n\t/**\n\t * The BPMN element where the execution currently is at.\n\t * @returns The current flow element object (type is Java object).\n\t */\n\tpublic getCurrentFlowElement(): any {\n\t\treturn this.execution.getCurrentFlowElement();\n\t}\n\n\t/**\n\t * Change the current BPMN element the execution is at.\n\t * @param flowElement The new flow element object (Java type).\n\t */\n\tpublic setCurrentFlowElement(flowElement: any): void {\n\t\tthis.execution.setCurrentFlowElement(flowElement);\n\t}\n\n\t/**\n\t * Returns the {@link FlowableListener} instance matching an {@link ExecutionListener} if currently an execution listener is being execution. Returns null otherwise.\n\t * @returns The current Flowable Listener object (Java type), or `null`.\n\t */\n\tpublic getCurrentFlowableListener(): any {\n\t\treturn this.execution.getCurrentFlowableListener();\n\t}\n\n\t/**\n\t * Called when an {@link ExecutionListener} is being executed.\n\t * @param currentListener The current listener object (Java type).\n\t */\n\tpublic setCurrentFlowableListener(currentListener: any): void {\n\t\tthis.execution.setCurrentFlowableListener(currentListener);\n\t}\n\n\t/**\n\t * Create a snapshot read only delegate execution of this delegate execution.\n\t *\n\t * @returns A {@link ReadOnlyDelegateExecution} object (Java type).\n\t */\n\tpublic snapshotReadOnly(): any {\n\t\treturn this.execution.snapshotReadOnly();\n\t}\n\n\t/**\n\t * returns the parent of this execution, or null if there no parent.\n\t * @returns The parent execution object (Java type), or `null`.\n\t */\n\tpublic getParent(): any {\n\t\treturn this.execution.getParent();\n\t}\n\n\t/**\n\t * returns the list of execution of which this execution the parent of.\n\t * @returns An array of child execution objects (Java type).\n\t */\n\tpublic getExecutions(): any[] {\n\t\treturn this.execution.getExecutions();\n\t}\n\n\t/**\n\t * makes this execution active or inactive.\n\t * @param isActive A boolean indicating whether the execution should be active.\n\t */\n\tpublic setActive(isActive: boolean): void {\n\t\tthis.execution.setActive(isActive);\n\t}\n\n\t/**\n\t * returns whether this execution is currently active.\n\t * @returns `true` if active, `false` otherwise.\n\t */\n\tpublic isActive(): boolean {\n\t\treturn this.execution.isActive();\n\t}\n\n\t/**\n\t * returns whether this execution has ended or not.\n\t * @returns `true` if ended, `false` otherwise.\n\t */\n\tpublic isEnded(): boolean {\n\t\treturn this.execution.isEnded();\n\t}\n\n\t/**\n\t * changes the concurrent indicator on this execution.\n\t * @param isConcurrent A boolean indicating whether the execution should be concurrent.\n\t */\n\tpublic setConcurrent(isConcurrent: boolean): void {\n\t\tthis.execution.setConcurrent(isConcurrent);\n\t}\n\n\t/**\n\t * returns whether this execution is concurrent or not.\n\t * @returns `true` if concurrent, `false` otherwise.\n\t */\n\tpublic isConcurrent(): boolean {\n\t\treturn this.execution.isConcurrent();\n\t}\n\n\t/**\n\t * returns whether this execution is a process instance or not.\n\t * @returns `true` if it's a process instance, `false` otherwise.\n\t */\n\tpublic isProcessInstanceType(): boolean {\n\t\treturn this.execution.isProcessInstanceType();\n\t}\n\n\t/**\n\t * Inactivates this execution. This is useful for example in a join: the execution still exists, but it is not longer active.\n\t */\n\tpublic inactivate(): void {\n\t\tthis.execution.inactivate();\n\t}\n\n\t/**\n\t * Returns whether this execution is a scope.\n\t * @returns `true` if it is a scope, `false` otherwise.\n\t */\n\tpublic isScope(): boolean {\n\t\treturn this.execution.isScope();\n\t}\n\n\t/**\n\t * Changes whether this execution is a scope or not.\n\t * @param isScope A boolean indicating whether the execution should be a scope.\n\t */\n\tpublic setScope(isScope: boolean): void {\n\t\tthis.execution.setScope(isScope);\n\t}\n\n\t/**\n\t * Returns whether this execution is the root of a multi instance execution.\n\t * @returns `true` if it's a multi instance root, `false` otherwise.\n\t */\n\tpublic isMultiInstanceRoot(): boolean {\n\t\treturn this.execution.isMultiInstanceRoot();\n\t}\n\n\t/**\n\t * Changes whether this execution is a multi instance root or not.\n\t * @param isMultiInstanceRoot A boolean indicating whether the execution is the root of a multi-instance execution.\n\t */\n\tpublic setMultiInstanceRoot(isMultiInstanceRoot: boolean): void {\n\t\tthis.execution.setMultiInstanceRoot(isMultiInstanceRoot);\n\t}\n\n\t/**\n\t * Returns all variables. This will include all variables of parent scopes too.\n\t * @returns A Map of variable names (`string`) to variable values (`any`).\n\t */\n\tpublic getVariables(): Map<string, any> {\n\t\tconst variables = this.execution.getVariables();\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn variables;\n\t}\n\n\t/**\n\t * Returns all variables, as instances of the {@link VariableInstance} interface, which gives more information than only the value (type, execution id, etc.)\n\t * @returns A Map of variable names (`string`) to {@link VariableInstance} objects (Java type).\n\t */\n\tpublic getVariableInstances(): Map<string, any> {\n\t\treturn this.execution.getVariableInstances();\n\t}\n\n\t/**\n\t * Returns the variable local to this scope only. So, in contrary to {@link #getVariables()}, the variables from the parent scope won't be returned.\n\t * @returns A Map of variable names (`string`) to local variable values (`any`).\n\t */\n\tpublic getVariablesLocal(): Map<string, any> {\n\t\tconst variablesLocal = this.execution.getVariablesLocal();\n\t\tfor (const [key, value] of variablesLocal) {\n\t\t\tvariablesLocal.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn variablesLocal;\n\t}\n\n\t/**\n\t * Returns the variables local to this scope as instances of the {@link VariableInstance} interface, which provided additional information about the variable.\n\t * @returns A Map of variable names (`string`) to local {@link VariableInstance} objects (Java type).\n\t */\n\tpublic getVariableInstancesLocal(): Map<string, any> {\n\t\treturn this.execution.getVariableInstancesLocal();\n\t}\n\n\t/**\n\t * Returns the variable value for one specific variable. Will look in parent scopes when the variable does not exist on this particular scope.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The value of the variable (`any`), or `null` if not found.\n\t */\n\tpublic getVariable(variableName: string): any {\n\t\treturn Values.parseValue(this.execution.getVariable(variableName));\n\t}\n\n\t/**\n\t * Similar to {@link #getVariable(String)}, but returns a {@link VariableInstance} instance, which contains more information than just the value.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The {@link VariableInstance} object (Java type), or `null`.\n\t */\n\tpublic getVariableInstance(variableName: string): any {\n\t\treturn this.execution.getVariableInstance(variableName);\n\t}\n\n\t/**\n\t * Returns the value for the specific variable and only checks this scope and not any parent scope.\n\t * @param variableName The name of the local variable to retrieve.\n\t * @returns The value of the local variable (`any`), or `null` if not found locally.\n\t */\n\tpublic getVariableLocal(variableName: string): any {\n\t\treturn Values.parseValue(this.execution.getVariableLocal(variableName));\n\t}\n\n\t/**\n\t * Similar to {@link #getVariableLocal(String)}, but returns an instance of {@link VariableInstance}, which has some additional information beyond the value.\n\t * @param variableName The name of the local variable to retrieve.\n\t * @returns The local {@link VariableInstance} object (Java type), or `null`.\n\t */\n\tpublic getVariableInstanceLocal(variableName: string): any {\n\t\treturn this.execution.getVariableInstanceLocal(variableName);\n\t}\n\n\t/**\n\t * Returns all the names of the variables for this scope and all parent scopes.\n\t * @returns A Set of all variable names (`string`).\n\t */\n\tpublic getVariableNames(): Set<string> {\n\t\tconst variableNames = new Set<string>();\n\t\tfor (const next of this.execution.getVariableNames().toArray()) {\n\t\t\tvariableNames.add(next);\n\t\t}\n\t\treturn variableNames;\n\t}\n\n\t/**\n\t * Returns all the names of the variables for this scope (no parent scopes).\n\t * @returns A Set of local variable names (`string`).\n\t */\n\tpublic getVariableNamesLocal(): Set<string> {\n\t\tconst variableNamesLocal = new Set<string>();\n\t\tfor (const next of this.execution.getVariableNamesLocal().toArray()) {\n\t\t\tvariableNamesLocal.add(next);\n\t\t}\n\t\treturn variableNamesLocal;\n\t}\n\n\t/**\n\t * Sets the variable with the provided name to the provided value. It checks parent scopes for an existing variable before setting on the current scope.\n\t * @param variableName The name of the variable to be set.\n\t * @param value The value of the variable to be set (`any`).\n\t */\n\tpublic setVariable(variableName: string, value: any): void {\n\t\tthis.execution.setVariable(variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * Similar to {@link #setVariable(String, Object)}, but the variable is set to this scope specifically (local variable).\n\t * @param variableName The name of the variable to be set locally.\n\t * @param value The value of the variable to be set (`any`).\n\t * @returns The old value of the local variable (Java type), or `null`.\n\t */\n\tpublic setVariableLocal(variableName: string, value: any): any {\n\t\treturn this.execution.setVariableLocal(variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * Sets the provided variables to the variable scope, using the default scoping algorithm.\n\t * @param variables A map of keys (`string`) and values (`any`) for the variables to be set.\n\t */\n\tpublic setVariables(variables: Map<string, any>): void {\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.execution.setVariables(variables);\n\t}\n\n\t/**\n\t * Similar to {@link #setVariables(Map)}, but the variables are set on this scope specifically (local variables).\n\t * @param variables A map of keys (`string`) and values (`any`) for the local variables to be set.\n\t */\n\tpublic setVariablesLocal(variables: Map<string, any>): void {\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.execution.setVariablesLocal(variables);\n\t}\n\n\t/**\n\t * Returns whether this scope or any parent scope has variables.\n\t * @returns `true` if variables exist in scope hierarchy, `false` otherwise.\n\t */\n\tpublic hasVariables(): boolean {\n\t\treturn this.execution.hasVariables();\n\t}\n\n\t/**\n\t * Returns whether this scope has variables.\n\t * @returns `true` if local variables exist, `false` otherwise.\n\t */\n\tpublic hasVariablesLocal(): boolean {\n\t\treturn this.execution.hasVariablesLocal();\n\t}\n\n\t/**\n\t * Returns whether this scope or any parent scope has a specific variable.\n\t * @param variableName The name of the variable to check.\n\t * @returns `true` if the variable is found in the scope hierarchy, `false` otherwise.\n\t */\n\tpublic hasVariable(variableName: string): boolean {\n\t\treturn this.execution.hasVariable(variableName);\n\t}\n\n\t/**\n\t * Returns whether this scope has a specific variable.\n\t * @param variableName The name of the local variable to check.\n\t * @returns `true` if the variable is found locally, `false` otherwise.\n\t */\n\tpublic hasVariableLocal(variableName: string): boolean {\n\t\treturn this.execution.hasVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes the variable from the process instance and creates a new HistoricVariableUpdate. Searches up the scope hierarchy.\n\t * @param variableName The name of the variable to remove.\n\t */\n\tpublic removeVariable(variableName: string): void {\n\t\tthis.execution.removeVariable(variableName);\n\t}\n\n\t/**\n\t * Removes the local variable and creates a new HistoricVariableUpdate.\n\t * @param variableName The name of the local variable to remove.\n\t */\n\tpublic removeVariableLocal(variableName: string): void {\n\t\tthis.execution.removeVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes the variables and creates a new HistoricVariableUpdate for each of them. Searches up the scope hierarchy.\n\t * @param variableNames An array of variable names (`string[]`) to remove.\n\t */\n\tpublic removeVariables(variableNames: string[]): void {\n\t\tthis.execution.removeVariables(variableNames);\n\t}\n\n\t/**\n\t * Removes the local variables and creates a new HistoricVariableUpdate for each of them.\n\t * @param variableNames An array of local variable names (`string[]`) to remove.\n\t */\n\tpublic removeVariablesLocal(variableNames: string[]): void {\n\t\tthis.execution.removeVariablesLocal(variableNames);\n\t}\n\n\t/**\n\t * Sets a transient variable using the default scoping mechanism (up the hierarchy). Transient variables have no history and are cleared at wait states.\n\t * @param variableName The name of the transient variable.\n\t * @param variableValue The value of the transient variable (`any`).\n\t */\n\tpublic setTransientVariable(variableName: string, variableValue: any): void {\n\t\tthis.execution.setTransientVariable(variableName, Values.stringifyValue(variableValue));\n\t}\n\n\t/**\n\t * Sets a local transient variable. Transient variables have no history and are cleared at wait states.\n\t * @param variableName The name of the local transient variable.\n\t * @param variableValue The value of the local transient variable (`any`).\n\t */\n\tpublic setTransientVariableLocal(variableName: string, variableValue: any): void {\n\t\tthis.execution.setTransientVariableLocal(variableName, Values.stringifyValue(variableValue));\n\t}\n\n\t/**\n\t * Sets multiple transient variables using the default scoping mechanism (up the hierarchy).\n\t * @param transientVariables A map of keys (`string`) and values (`any`) for the transient variables to be set.\n\t */\n\tpublic setTransientVariables(transientVariables: Map<string, any>): void {\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.execution.setTransientVariables(transientVariables);\n\t}\n\n\t/**\n\t * Retrieves the value of a transient variable, searching up the parent scopes.\n\t * @param variableName The name of the transient variable to retrieve.\n\t * @returns The value of the transient variable (`any`), or `null` if not found.\n\t */\n\tpublic getTransientVariable(variableName: string): any {\n\t\treturn Values.parseValue(this.execution.getTransientVariable(variableName));\n\t}\n\n\t/**\n\t * Retrieves all transient variables in the current scope hierarchy.\n\t * @returns A Map of transient variable names (`string`) to values (`any`).\n\t */\n\tpublic getTransientVariables(): Map<string, any> {\n\t\tconst transientVariables = this.execution.getTransientVariables();\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn transientVariables;\n\t}\n\n\t/**\n\t * Sets multiple local transient variables.\n\t * @param transientVariables A map of keys (`string`) and values (`any`) for the local transient variables to be set.\n\t */\n\tpublic setTransientVariablesLocal(transientVariables: Map<string, any>): void {\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.execution.setTransientVariablesLocal(transientVariables);\n\t}\n\n\t/**\n\t * Retrieves the value of a local transient variable.\n\t * @param variableName The name of the local transient variable to retrieve.\n\t * @returns The value of the local transient variable (`any`), or `null` if not found.\n\t */\n\tpublic getTransientVariableLocal(variableName: string): any {\n\t\treturn Values.parseValue(this.execution.getTransientVariableLocal(variableName));\n\t}\n\n\t/**\n\t * Retrieves all local transient variables.\n\t * @returns A Map of local transient variable names (`string`) to values (`any`).\n\t */\n\tpublic getTransientVariablesLocal(): Map<string, any> {\n\t\tconst transientVariablesLocal = this.execution.getTransientVariablesLocal();\n\t\tfor (const [key, value] of transientVariablesLocal) {\n\t\t\ttransientVariablesLocal.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn transientVariablesLocal;\n\t}\n\n\t/**\n\t * Removes a specific local transient variable.\n\t * @param variableName The name of the local transient variable to remove.\n\t */\n\tpublic removeTransientVariableLocal(variableName: string): void {\n\t\tthis.execution.removeTransientVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes a specific transient variable, searching up the scope hierarchy.\n\t * @param variableName The name of the transient variable to remove.\n\t */\n\tpublic removeTransientVariable(variableName: string): void {\n\t\tthis.execution.removeTransientVariable(variableName);\n\t}\n\n\t/**\n\t * Remove all transient variables of this scope and its parent scopes.\n\t */\n\tpublic removeTransientVariables(): void {\n\t\tthis.execution.removeTransientVariables();\n\t}\n\n\t/**\n\t * Removes all local transient variables.\n\t */\n\tpublic removeTransientVariablesLocal(): void {\n\t\tthis.execution.removeTransientVariablesLocal();\n\t}\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Process;\n}\n"],
  "mappings": "AAMA,SAAS,cAAc;AAEvB,MAAM,YAAY,KAAK,KAAK,oDAAoD;AAEzE,MAAM,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUpB,OAAc,MAAM,KAAa,cAAsB,IAAI,aAAqC,CAAC,GAAW;AAC3G,WAAO,UAAU,aAAa,KAAK,aAAa,KAAK,UAAU,UAAU,CAAC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,uBAAuB,mBAA2B,MAAoB;AACnF,cAAU,uBAAuB,mBAAmB,IAAI;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,kBAAkB,mBAA2B,aAA2B;AACrF,cAAU,kBAAkB,mBAAmB,WAAW;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,qBAAqB,mBAA2B,gBAA8B;AAC3F,cAAU,qBAAqB,mBAAmB,cAAc;AAAA,EACjE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,YAAY,mBAA2B,cAA2B;AAC/E,WAAO,UAAU,YAAY,mBAAmB,YAAY;AAAA,EAC7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,mBAAgC;AAC1D,WAAO,UAAU,aAAa,iBAAiB;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,YAAY,mBAA2B,cAAsB,OAAkB;AAC5F,cAAU,YAAY,mBAAmB,cAAc,KAAK;AAAA,EAC7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,eAAe,mBAA2B,cAA4B;AACnF,cAAU,eAAe,mBAAmB,YAAY;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,sBAAsB,mBAA2B,aAAqB,WAAmC;AACtH,cAAU,sBAAsB,mBAAmB,aAAa,OAAO,mBAAmB,SAAS,CAAC;AAAA,EACrG;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,sBAAsB;AACnC,WAAO,IAAI,iBAAiB;AAAA,EAC7B;AACD;AAMA,MAAM,iBAAiB;AAAA,EAItB,cAAc;AACb,SAAK,YAAY,UAAU,IAAI,WAAW;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,QAAgB;AACtB,WAAO,KAAK,UAAU,MAAM;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,uBAA+B;AACrC,WAAO,KAAK,UAAU,qBAAqB;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,2BAAmC;AACzC,WAAO,KAAK,UAAU,yBAAyB;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,eAAuB;AAC7B,WAAO,KAAK,UAAU,aAAa;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,aAAa,WAAyB;AAC5C,SAAK,UAAU,aAAa,SAAS;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,gCAAwC;AAC9C,WAAO,KAAK,UAAU,8BAA8B;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,mCAA2C;AACjD,WAAO,KAAK,UAAU,iCAAiC;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,yBAAiC;AACvC,WAAO,KAAK,UAAU,uBAAuB;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,+BAAuC;AAC7C,WAAO,KAAK,UAAU,6BAA6B;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,cAAsB;AAC5B,WAAO,KAAK,UAAU,YAAY;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,sBAA8B;AACpC,WAAO,KAAK,UAAU,oBAAoB;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,uBAA+B;AACrC,WAAO,KAAK,UAAU,qBAAqB;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,cAAsB;AAC5B,WAAO,KAAK,UAAU,YAAY;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,wBAA6B;AACnC,WAAO,KAAK,UAAU,sBAAsB;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,sBAAsB,aAAwB;AACpD,SAAK,UAAU,sBAAsB,WAAW;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,6BAAkC;AACxC,WAAO,KAAK,UAAU,2BAA2B;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,2BAA2B,iBAA4B;AAC7D,SAAK,UAAU,2BAA2B,eAAe;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,mBAAwB;AAC9B,WAAO,KAAK,UAAU,iBAAiB;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,YAAiB;AACvB,WAAO,KAAK,UAAU,UAAU;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,gBAAuB;AAC7B,WAAO,KAAK,UAAU,cAAc;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAU,UAAyB;AACzC,SAAK,UAAU,UAAU,QAAQ;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,WAAoB;AAC1B,WAAO,KAAK,UAAU,SAAS;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACzB,WAAO,KAAK,UAAU,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,cAAc,cAA6B;AACjD,SAAK,UAAU,cAAc,YAAY;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,eAAwB;AAC9B,WAAO,KAAK,UAAU,aAAa;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,wBAAiC;AACvC,WAAO,KAAK,UAAU,sBAAsB;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA,EAKO,aAAmB;AACzB,SAAK,UAAU,WAAW;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACzB,WAAO,KAAK,UAAU,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,SAAS,SAAwB;AACvC,SAAK,UAAU,SAAS,OAAO;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,sBAA+B;AACrC,WAAO,KAAK,UAAU,oBAAoB;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,qBAAqB,qBAAoC;AAC/D,SAAK,UAAU,qBAAqB,mBAAmB;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,eAAiC;AACvC,UAAM,YAAY,KAAK,UAAU,aAAa;AAC9C,eAAW,CAAC,KAAK,KAAK,KAAK,WAAW;AACrC,gBAAU,IAAI,KAAK,OAAO,WAAW,KAAK,CAAC;AAAA,IAC5C;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,uBAAyC;AAC/C,WAAO,KAAK,UAAU,qBAAqB;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,oBAAsC;AAC5C,UAAM,iBAAiB,KAAK,UAAU,kBAAkB;AACxD,eAAW,CAAC,KAAK,KAAK,KAAK,gBAAgB;AAC1C,qBAAe,IAAI,KAAK,OAAO,WAAW,KAAK,CAAC;AAAA,IACjD;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,4BAA8C;AACpD,WAAO,KAAK,UAAU,0BAA0B;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,YAAY,cAA2B;AAC7C,WAAO,OAAO,WAAW,KAAK,UAAU,YAAY,YAAY,CAAC;AAAA,EAClE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,oBAAoB,cAA2B;AACrD,WAAO,KAAK,UAAU,oBAAoB,YAAY;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,iBAAiB,cAA2B;AAClD,WAAO,OAAO,WAAW,KAAK,UAAU,iBAAiB,YAAY,CAAC;AAAA,EACvE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,yBAAyB,cAA2B;AAC1D,WAAO,KAAK,UAAU,yBAAyB,YAAY;AAAA,EAC5D;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,mBAAgC;AACtC,UAAM,gBAAgB,oBAAI,IAAY;AACtC,eAAW,QAAQ,KAAK,UAAU,iBAAiB,EAAE,QAAQ,GAAG;AAC/D,oBAAc,IAAI,IAAI;AAAA,IACvB;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,wBAAqC;AAC3C,UAAM,qBAAqB,oBAAI,IAAY;AAC3C,eAAW,QAAQ,KAAK,UAAU,sBAAsB,EAAE,QAAQ,GAAG;AACpE,yBAAmB,IAAI,IAAI;AAAA,IAC5B;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,YAAY,cAAsB,OAAkB;AAC1D,SAAK,UAAU,YAAY,cAAc,OAAO,eAAe,KAAK,CAAC;AAAA,EACtE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,iBAAiB,cAAsB,OAAiB;AAC9D,WAAO,KAAK,UAAU,iBAAiB,cAAc,OAAO,eAAe,KAAK,CAAC;AAAA,EAClF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,aAAa,WAAmC;AACtD,eAAW,CAAC,KAAK,KAAK,KAAK,WAAW;AACrC,gBAAU,IAAI,KAAK,OAAO,eAAe,KAAK,CAAC;AAAA,IAChD;AACA,SAAK,UAAU,aAAa,SAAS;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,kBAAkB,WAAmC;AAC3D,eAAW,CAAC,KAAK,KAAK,KAAK,WAAW;AACrC,gBAAU,IAAI,KAAK,OAAO,eAAe,KAAK,CAAC;AAAA,IAChD;AACA,SAAK,UAAU,kBAAkB,SAAS;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,eAAwB;AAC9B,WAAO,KAAK,UAAU,aAAa;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,oBAA6B;AACnC,WAAO,KAAK,UAAU,kBAAkB;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,YAAY,cAA+B;AACjD,WAAO,KAAK,UAAU,YAAY,YAAY;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,iBAAiB,cAA+B;AACtD,WAAO,KAAK,UAAU,iBAAiB,YAAY;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,eAAe,cAA4B;AACjD,SAAK,UAAU,eAAe,YAAY;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,oBAAoB,cAA4B;AACtD,SAAK,UAAU,oBAAoB,YAAY;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,gBAAgB,eAA+B;AACrD,SAAK,UAAU,gBAAgB,aAAa;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,qBAAqB,eAA+B;AAC1D,SAAK,UAAU,qBAAqB,aAAa;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,qBAAqB,cAAsB,eAA0B;AAC3E,SAAK,UAAU,qBAAqB,cAAc,OAAO,eAAe,aAAa,CAAC;AAAA,EACvF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,0BAA0B,cAAsB,eAA0B;AAChF,SAAK,UAAU,0BAA0B,cAAc,OAAO,eAAe,aAAa,CAAC;AAAA,EAC5F;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,sBAAsB,oBAA4C;AACxE,eAAW,CAAC,KAAK,KAAK,KAAK,oBAAoB;AAC9C,yBAAmB,IAAI,KAAK,OAAO,eAAe,KAAK,CAAC;AAAA,IACzD;AACA,SAAK,UAAU,sBAAsB,kBAAkB;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,qBAAqB,cAA2B;AACtD,WAAO,OAAO,WAAW,KAAK,UAAU,qBAAqB,YAAY,CAAC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,wBAA0C;AAChD,UAAM,qBAAqB,KAAK,UAAU,sBAAsB;AAChE,eAAW,CAAC,KAAK,KAAK,KAAK,oBAAoB;AAC9C,yBAAmB,IAAI,KAAK,OAAO,WAAW,KAAK,CAAC;AAAA,IACrD;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,2BAA2B,oBAA4C;AAC7E,eAAW,CAAC,KAAK,KAAK,KAAK,oBAAoB;AAC9C,yBAAmB,IAAI,KAAK,OAAO,eAAe,KAAK,CAAC;AAAA,IACzD;AACA,SAAK,UAAU,2BAA2B,kBAAkB;AAAA,EAC7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,0BAA0B,cAA2B;AAC3D,WAAO,OAAO,WAAW,KAAK,UAAU,0BAA0B,YAAY,CAAC;AAAA,EAChF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,6BAA+C;AACrD,UAAM,0BAA0B,KAAK,UAAU,2BAA2B;AAC1E,eAAW,CAAC,KAAK,KAAK,KAAK,yBAAyB;AACnD,8BAAwB,IAAI,KAAK,OAAO,WAAW,KAAK,CAAC;AAAA,IAC1D;AACA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,6BAA6B,cAA4B;AAC/D,SAAK,UAAU,6BAA6B,YAAY;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,wBAAwB,cAA4B;AAC1D,SAAK,UAAU,wBAAwB,YAAY;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKO,2BAAiC;AACvC,SAAK,UAAU,yBAAyB;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA,EAKO,gCAAsC;AAC5C,SAAK,UAAU,8BAA8B;AAAA,EAC9C;AAED;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

1052
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bpm/process.ts"],
  "sourcesContent": ["/**\n * API Process\n * * Provides methods for interacting with process instances,\n * including starting, updating metadata, and managing variables.\n */\n\nimport { Values } from \"@aerokit/sdk/bpm/values\";\nimport { IdentityLink } from \"./tasks\";\n\nconst JBpmnError = Java.type('org.flowable.engine.delegate.BpmnError');\nconst BpmFacade = Java.type(\"org.eclipse.dirigible.components.api.bpm.BpmFacade\");\n\nexport class BpmnError {\n\tconstructor(code: string, message?: string) {\n\t\treturn new JBpmnError(code, message);\n\t}\n}\n\nexport class Process {\n\n\t/**\n\t * Starts a new process instance for a given process definition key.\n\t *\n\t * @param key The process definition key (ID) of the process to start.\n\t * @param businessKey An optional business key to associate with the process instance. Defaults to an empty string.\n\t * @param parameters An optional map of process variables to pass to the process instance upon starting. Defaults to an empty object.\n\t * @returns The unique ID of the newly started process instance.\n\t */\n\tpublic static start(key: string, businessKey: string = '', parameters: { [key: string]: any } = {}): string {\n\t\treturn BpmFacade.startProcess(key, businessKey, JSON.stringify(parameters));\n\t}\n\n\t/**\n\t * Sets a human-readable name for an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param name The new name for the process instance.\n\t */\n\tpublic static setProcessInstanceName(processInstanceId: string, name: string): void {\n\t\tBpmFacade.setProcessInstanceName(processInstanceId, name);\n\t}\n\n\t/**\n\t * Updates the business key of an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param businessKey The new business key.\n\t */\n\tpublic static updateBusinessKey(processInstanceId: string, businessKey: string): void {\n\t\tBpmFacade.updateBusinessKey(processInstanceId, businessKey);\n\t}\n\n\t/**\n\t * Updates the business status of an existing process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to update.\n\t * @param businessStatus The new business status.\n\t */\n\tpublic static updateBusinessStatus(processInstanceId: string, businessStatus: string): void {\n\t\tBpmFacade.updateBusinessStatus(processInstanceId, businessStatus);\n\t}\n\n\t/**\n\t * Retrieves the value of a specific variable from a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The value of the variable, or `null` if the variable does not exist. The type is `any` as it depends on the stored value.\n\t */\n\tpublic static getVariable(processInstanceId: string, variableName: string): any {\n\t\treturn BpmFacade.getVariable(processInstanceId, variableName);\n\t}\n\n\t/**\n\t * Retrieves all variables associated with a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @returns An object containing all variables for the process instance, where keys are variable names and values are the variable values.\n\t */\n\tpublic static getVariables(processInstanceId: string): any {\n\t\treturn BpmFacade.getVariables(processInstanceId);\n\t}\n\n\t/**\n\t * Sets or updates the value of a variable in a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to set.\n\t * @param value The new value for the variable. The type is `any` to accommodate different data types.\n\t */\n\tpublic static setVariable(processInstanceId: string, variableName: string, value: any): void {\n\t\tBpmFacade.setVariable(processInstanceId, variableName, value);\n\t}\n\n\t/**\n\t * Removes a variable from a process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance.\n\t * @param variableName The name of the variable to remove.\n\t */\n\tpublic static removeVariable(processInstanceId: string, variableName: string): void {\n\t\tBpmFacade.removeVariable(processInstanceId, variableName);\n\t}\n\n\t/**\n\t * Correlates a message event with a running process instance.\n\t *\n\t * @param processInstanceId The ID of the process instance to correlate the message to.\n\t * @param messageName The name of the message event defined in the BPMN process.\n\t * @param variables A map of variables (`Map<string, any>`) to pass along with the message event.\n\t */\n\tpublic static correlateMessageEvent(processInstanceId: string, messageName: string, variables: Map<string, any>): void {\n\t\tBpmFacade.correlateMessageEvent(processInstanceId, messageName, Values.stringifyValuesMap(variables));\n\t}\n\n\t/**\n\t * Retrieves the current execution context object, typically used within an execution listener or service task.\n\t *\n\t * @returns A new instance of the `ExecutionContext` containing details about the current process execution path.\n\t */\n\tpublic static getExecutionContext() {\n\t\treturn new ExecutionContext();\n\t}\n\n\t/**\n\t * Retrieves the current task context object, typically used within a task listener or service task.\n\t *\n\t * @returns A new instance of the `TaskContext` containing details about the current task.\n\t */\n\tpublic static getTaskContext() {\n\t\treturn new TaskContext();\n\t}\n}\n\nclass VariableScope {\n\n\tprivate variableScope: any;\n\n\tconstructor(variableScope: any) {\n\t\tthis.variableScope = variableScope;\n\t}\n\n\t/**\n\t * Returns all variables. This will include all variables of parent scopes too.\n\t * @returns A Map of variable names (`string`) to variable values (`any`).\n\t */\n\tpublic getVariables(): Map<string, any> {\n\t\tconst variables = this.variableScope.getVariables();\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn variables;\n\t}\n\n\t/**\n\t * Returns all variables, as instances of the {@link VariableInstance} interface, which gives more information than only the value (type, execution id, etc.)\n\t * @returns A Map of variable names (`string`) to {@link VariableInstance} objects (Java type).\n\t */\n\tpublic getVariableInstances(): Map<string, any> {\n\t\treturn this.variableScope.getVariableInstances();\n\t}\n\n\t/**\n\t * Returns the variable local to this scope only. So, in contrary to {@link #getVariables()}, the variables from the parent scope won't be returned.\n\t * @returns A Map of variable names (`string`) to local variable values (`any`).\n\t */\n\tpublic getVariablesLocal(): Map<string, any> {\n\t\tconst variablesLocal = this.variableScope.getVariablesLocal();\n\t\tfor (const [key, value] of variablesLocal) {\n\t\t\tvariablesLocal.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn variablesLocal;\n\t}\n\n\t/**\n\t * Returns the variables local to this scope as instances of the {@link VariableInstance} interface, which provided additional information about the variable.\n\t * @returns A Map of variable names (`string`) to local {@link VariableInstance} objects (Java type).\n\t */\n\tpublic getVariableInstancesLocal(): Map<string, any> {\n\t\treturn this.variableScope.getVariableInstancesLocal();\n\t}\n\n\t/**\n\t * Returns the variable value for one specific variable. Will look in parent scopes when the variable does not exist on this particular scope.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The value of the variable (`any`), or `null` if not found.\n\t */\n\tpublic getVariable(variableName: string): any {\n\t\treturn Values.parseValue(this.variableScope.getVariable(variableName));\n\t}\n\n\t/**\n\t * Similar to {@link #getVariable(String)}, but returns a {@link VariableInstance} instance, which contains more information than just the value.\n\t * @param variableName The name of the variable to retrieve.\n\t * @returns The {@link VariableInstance} object (Java type), or `null`.\n\t */\n\tpublic getVariableInstance(variableName: string): any {\n\t\treturn this.variableScope.getVariableInstance(variableName);\n\t}\n\n\t/**\n\t * Returns the value for the specific variable and only checks this scope and not any parent scope.\n\t * @param variableName The name of the local variable to retrieve.\n\t * @returns The value of the local variable (`any`), or `null` if not found locally.\n\t */\n\tpublic getVariableLocal(variableName: string): any {\n\t\treturn Values.parseValue(this.variableScope.getVariableLocal(variableName));\n\t}\n\n\t/**\n\t * Similar to {@link #getVariableLocal(String)}, but returns an instance of {@link VariableInstance}, which has some additional information beyond the value.\n\t * @param variableName The name of the local variable to retrieve.\n\t * @returns The local {@link VariableInstance} object (Java type), or `null`.\n\t */\n\tpublic getVariableInstanceLocal(variableName: string): any {\n\t\treturn this.variableScope.getVariableInstanceLocal(variableName);\n\t}\n\n\t/**\n\t * Returns all the names of the variables for this scope and all parent scopes.\n\t * @returns A Set of all variable names (`string`).\n\t */\n\tpublic getVariableNames(): Set<string> {\n\t\tconst variableNames = new Set<string>();\n\t\tfor (const next of this.variableScope.getVariableNames().toArray()) {\n\t\t\tvariableNames.add(next);\n\t\t}\n\t\treturn variableNames;\n\t}\n\n\t/**\n\t * Returns all the names of the variables for this scope (no parent scopes).\n\t * @returns A Set of local variable names (`string`).\n\t */\n\tpublic getVariableNamesLocal(): Set<string> {\n\t\tconst variableNamesLocal = new Set<string>();\n\t\tfor (const next of this.variableScope.getVariableNamesLocal().toArray()) {\n\t\t\tvariableNamesLocal.add(next);\n\t\t}\n\t\treturn variableNamesLocal;\n\t}\n\n\t/**\n\t * Sets the variable with the provided name to the provided value. It checks parent scopes for an existing variable before setting on the current scope.\n\t * @param variableName The name of the variable to be set.\n\t * @param value The value of the variable to be set (`any`).\n\t */\n\tpublic setVariable(variableName: string, value: any): void {\n\t\tthis.variableScope.setVariable(variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * Similar to {@link #setVariable(String, Object)}, but the variable is set to this scope specifically (local variable).\n\t * @param variableName The name of the variable to be set locally.\n\t * @param value The value of the variable to be set (`any`).\n\t * @returns The old value of the local variable (Java type), or `null`.\n\t */\n\tpublic setVariableLocal(variableName: string, value: any): any {\n\t\treturn this.variableScope.setVariableLocal(variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * Sets the provided variables to the variable scope, using the default scoping algorithm.\n\t * @param variables A map of keys (`string`) and values (`any`) for the variables to be set.\n\t */\n\tpublic setVariables(variables: Map<string, any>): void {\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.variableScope.setVariables(variables);\n\t}\n\n\t/**\n\t * Similar to {@link #setVariables(Map)}, but the variables are set on this scope specifically (local variables).\n\t * @param variables A map of keys (`string`) and values (`any`) for the local variables to be set.\n\t */\n\tpublic setVariablesLocal(variables: Map<string, any>): void {\n\t\tfor (const [key, value] of variables) {\n\t\t\tvariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.variableScope.setVariablesLocal(variables);\n\t}\n\n\t/**\n\t * Returns whether this scope or any parent scope has variables.\n\t * @returns `true` if variables exist in scope hierarchy, `false` otherwise.\n\t */\n\tpublic hasVariables(): boolean {\n\t\treturn this.variableScope.hasVariables();\n\t}\n\n\t/**\n\t * Returns whether this scope has variables.\n\t * @returns `true` if local variables exist, `false` otherwise.\n\t */\n\tpublic hasVariablesLocal(): boolean {\n\t\treturn this.variableScope.hasVariablesLocal();\n\t}\n\n\t/**\n\t * Returns whether this scope or any parent scope has a specific variable.\n\t * @param variableName The name of the variable to check.\n\t * @returns `true` if the variable is found in the scope hierarchy, `false` otherwise.\n\t */\n\tpublic hasVariable(variableName: string): boolean {\n\t\treturn this.variableScope.hasVariable(variableName);\n\t}\n\n\t/**\n\t * Returns whether this scope has a specific variable.\n\t * @param variableName The name of the local variable to check.\n\t * @returns `true` if the variable is found locally, `false` otherwise.\n\t */\n\tpublic hasVariableLocal(variableName: string): boolean {\n\t\treturn this.variableScope.hasVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes the variable from the process instance and creates a new HistoricVariableUpdate. Searches up the scope hierarchy.\n\t * @param variableName The name of the variable to remove.\n\t */\n\tpublic removeVariable(variableName: string): void {\n\t\tthis.variableScope.removeVariable(variableName);\n\t}\n\n\t/**\n\t * Removes the local variable and creates a new HistoricVariableUpdate.\n\t * @param variableName The name of the local variable to remove.\n\t */\n\tpublic removeVariableLocal(variableName: string): void {\n\t\tthis.variableScope.removeVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes the variables and creates a new HistoricVariableUpdate for each of them. Searches up the scope hierarchy.\n\t * @param variableNames An array of variable names (`string[]`) to remove.\n\t */\n\tpublic removeVariables(variableNames: string[]): void {\n\t\tthis.variableScope.removeVariables(variableNames);\n\t}\n\n\t/**\n\t * Removes the local variables and creates a new HistoricVariableUpdate for each of them.\n\t * @param variableNames An array of local variable names (`string[]`) to remove.\n\t */\n\tpublic removeVariablesLocal(variableNames: string[]): void {\n\t\tthis.variableScope.removeVariablesLocal(variableNames);\n\t}\n\n\t/**\n\t * Sets a transient variable using the default scoping mechanism (up the hierarchy). Transient variables have no history and are cleared at wait states.\n\t * @param variableName The name of the transient variable.\n\t * @param variableValue The value of the transient variable (`any`).\n\t */\n\tpublic setTransientVariable(variableName: string, variableValue: any): void {\n\t\tthis.variableScope.setTransientVariable(variableName, Values.stringifyValue(variableValue));\n\t}\n\n\t/**\n\t * Sets a local transient variable. Transient variables have no history and are cleared at wait states.\n\t * @param variableName The name of the local transient variable.\n\t * @param variableValue The value of the local transient variable (`any`).\n\t */\n\tpublic setTransientVariableLocal(variableName: string, variableValue: any): void {\n\t\tthis.variableScope.setTransientVariableLocal(variableName, Values.stringifyValue(variableValue));\n\t}\n\n\t/**\n\t * Sets multiple transient variables using the default scoping mechanism (up the hierarchy).\n\t * @param transientVariables A map of keys (`string`) and values (`any`) for the transient variables to be set.\n\t */\n\tpublic setTransientVariables(transientVariables: Map<string, any>): void {\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.variableScope.setTransientVariables(transientVariables);\n\t}\n\n\t/**\n\t * Retrieves the value of a transient variable, searching up the parent scopes.\n\t * @param variableName The name of the transient variable to retrieve.\n\t * @returns The value of the transient variable (`any`), or `null` if not found.\n\t */\n\tpublic getTransientVariable(variableName: string): any {\n\t\treturn Values.parseValue(this.variableScope.getTransientVariable(variableName));\n\t}\n\n\t/**\n\t * Retrieves all transient variables in the current scope hierarchy.\n\t * @returns A Map of transient variable names (`string`) to values (`any`).\n\t */\n\tpublic getTransientVariables(): Map<string, any> {\n\t\tconst transientVariables = this.variableScope.getTransientVariables();\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn transientVariables;\n\t}\n\n\t/**\n\t * Sets multiple local transient variables.\n\t * @param transientVariables A map of keys (`string`) and values (`any`) for the local transient variables to be set.\n\t */\n\tpublic setTransientVariablesLocal(transientVariables: Map<string, any>): void {\n\t\tfor (const [key, value] of transientVariables) {\n\t\t\ttransientVariables.set(key, Values.stringifyValue(value));\n\t\t}\n\t\tthis.variableScope.setTransientVariablesLocal(transientVariables);\n\t}\n\n\t/**\n\t * Retrieves the value of a local transient variable.\n\t * @param variableName The name of the local transient variable to retrieve.\n\t * @returns The value of the local transient variable (`any`), or `null` if not found.\n\t */\n\tpublic getTransientVariableLocal(variableName: string): any {\n\t\treturn Values.parseValue(this.variableScope.getTransientVariableLocal(variableName));\n\t}\n\n\t/**\n\t * Retrieves all local transient variables.\n\t * @returns A Map of local transient variable names (`string`) to values (`any`).\n\t */\n\tpublic getTransientVariablesLocal(): Map<string, any> {\n\t\tconst transientVariablesLocal = this.variableScope.getTransientVariablesLocal();\n\t\tfor (const [key, value] of transientVariablesLocal) {\n\t\t\ttransientVariablesLocal.set(key, Values.parseValue(value));\n\t\t}\n\t\treturn transientVariablesLocal;\n\t}\n\n\t/**\n\t * Removes a specific local transient variable.\n\t * @param variableName The name of the local transient variable to remove.\n\t */\n\tpublic removeTransientVariableLocal(variableName: string): void {\n\t\tthis.variableScope.removeTransientVariableLocal(variableName);\n\t}\n\n\t/**\n\t * Removes a specific transient variable, searching up the scope hierarchy.\n\t * @param variableName The name of the transient variable to remove.\n\t */\n\tpublic removeTransientVariable(variableName: string): void {\n\t\tthis.variableScope.removeTransientVariable(variableName);\n\t}\n\n\t/**\n\t * Remove all transient variables of this scope and its parent scopes.\n\t */\n\tpublic removeTransientVariables(): void {\n\t\tthis.variableScope.removeTransientVariables();\n\t}\n\n\t/**\n\t * Removes all local transient variables.\n\t */\n\tpublic removeTransientVariablesLocal(): void {\n\t\tthis.variableScope.removeTransientVariablesLocal();\n\t}\n}\n\n/**\n * ExecutionContext object\n * * Provides detailed information and control over the current process execution path.\n */\nclass ExecutionContext extends VariableScope {\n\n\tprivate execution: any;\n\n\tconstructor() {\n\t\tsuper(__context.get('execution'));\n\t\tthis.execution = __context.get('execution');\n\t}\n\n\t/**\n\t * Unique id of this path of execution that can be used as a handle to provide external signals back into the engine after wait states.\n\t *\n\t * @returns The unique ID of the current execution.\n\t */\n\tpublic getId(): string {\n\t\treturn this.execution.getId();\n\t}\n\n\t/**\n\t * Reference to the overall process instance.\n\t * @returns The ID of the process instance.\n\t */\n\tpublic getProcessInstanceId(): string {\n\t\treturn this.execution.getProcessInstanceId();\n\t}\n\n\t/**\n\t * The 'root' process instance. When using call activity for example, the processInstance set will not always be the root. This method returns the topmost process instance.\n\t *\n\t * @returns The ID of the root process instance.\n\t */\n\tpublic getRootProcessInstanceId(): string {\n\t\treturn this.execution.getRootProcessInstanceId();\n\t}\n\n\t/**\n\t * Will contain the event name in case this execution is passed in for an {@link ExecutionListener}.\n\t * @returns The current event name, or `null`/empty string if not executing an event listener.\n\t */\n\tpublic getEventName(): string {\n\t\treturn this.execution.getEventName();\n\t}\n\n\t/**\n\t * Sets the current event (typically when execution an {@link ExecutionListener}).\n\t *\n\t * @param eventName The name of the event.\n\t */\n\tpublic setEventName(eventName: string): void {\n\t\tthis.execution.setEventName(eventName);\n\t}\n\n\t/**\n\t * The business key for the process instance this execution is associated with.\n\t * @returns The business key.\n\t */\n\tpublic getProcessInstanceBusinessKey(): string {\n\t\treturn this.execution.getProcessInstanceBusinessKey();\n\t}\n\n\t/**\n\t * The business status for the process instance this execution is associated with.\n\t * @returns The business status.\n\t */\n\tpublic getProcessInstanceBusinessStatus(): string {\n\t\treturn this.execution.getProcessInstanceBusinessStatus();\n\t}\n\n\t/**\n\t * The process definition key for the process instance this execution is associated with.\n\t * @returns The process definition ID.\n\t */\n\tpublic getProcessDefinitionId(): string {\n\t\treturn this.execution.getProcessDefinitionId();\n\t}\n\n\t/**\n\t * If this execution runs in the context of a case and stage, this method returns it's closest parent stage instance id (the stage plan item instance id to be\n\t * precise).\n\t *\n\t * @returns The stage instance id this execution belongs to or `null`, if this execution is not part of a case at all or is not a child element of a stage.\n\t */\n\tpublic getPropagatedStageInstanceId(): string {\n\t\treturn this.execution.getPropagatedStageInstanceId();\n\t}\n\n\t/**\n\t * Gets the id of the parent of this execution. If null, the execution represents a process-instance.\n\t * @returns The parent execution ID, or `null`.\n\t */\n\tpublic getParentId(): string {\n\t\treturn this.execution.getParentId();\n\t}\n\n\t/**\n\t * Gets the id of the calling execution. If not null, the execution is part of a subprocess.\n\t * @returns The super execution ID, or `null`.\n\t */\n\tpublic getSuperExecutionId(): string {\n\t\treturn this.execution.getSuperExecutionId();\n\t}\n\n\t/**\n\t * Gets the id of the current activity.\n\t * @returns The current activity ID.\n\t */\n\tpublic getCurrentActivityId(): string {\n\t\treturn this.execution.getCurrentActivityId();\n\t}\n\n\t/**\n\t * Returns the tenant id, if any is set before on the process definition or process instance.\n\t * @returns The tenant ID, or `null`/empty string.\n\t */\n\tpublic getTenantId(): string {\n\t\treturn this.execution.getTenantId();\n\t}\n\n\t/**\n\t * The BPMN element where the execution currently is at.\n\t * @returns The current flow element object (type is Java object).\n\t */\n\tpublic getCurrentFlowElement(): any {\n\t\treturn this.execution.getCurrentFlowElement();\n\t}\n\n\t/**\n\t * Change the current BPMN element the execution is at.\n\t * @param flowElement The new flow element object (Java type).\n\t */\n\tpublic setCurrentFlowElement(flowElement: any): void {\n\t\tthis.execution.setCurrentFlowElement(flowElement);\n\t}\n\n\t/**\n\t * Returns the {@link FlowableListener} instance matching an {@link ExecutionListener} if currently an execution listener is being execution. Returns null otherwise.\n\t * @returns The current Flowable Listener object (Java type), or `null`.\n\t */\n\tpublic getCurrentFlowableListener(): any {\n\t\treturn this.execution.getCurrentFlowableListener();\n\t}\n\n\t/**\n\t * Called when an {@link ExecutionListener} is being executed.\n\t * @param currentListener The current listener object (Java type).\n\t */\n\tpublic setCurrentFlowableListener(currentListener: any): void {\n\t\tthis.execution.setCurrentFlowableListener(currentListener);\n\t}\n\n\t/**\n\t * Create a snapshot read only delegate execution of this delegate execution.\n\t *\n\t * @returns A {@link ReadOnlyDelegateExecution} object (Java type).\n\t */\n\tpublic snapshotReadOnly(): any {\n\t\treturn this.execution.snapshotReadOnly();\n\t}\n\n\t/**\n\t * returns the parent of this execution, or null if there no parent.\n\t * @returns The parent execution object (Java type), or `null`.\n\t */\n\tpublic getParent(): any {\n\t\treturn this.execution.getParent();\n\t}\n\n\t/**\n\t * returns the list of execution of which this execution the parent of.\n\t * @returns An array of child execution objects (Java type).\n\t */\n\tpublic getExecutions(): any[] {\n\t\treturn this.execution.getExecutions();\n\t}\n\n\t/**\n\t * makes this execution active or inactive.\n\t * @param isActive A boolean indicating whether the execution should be active.\n\t */\n\tpublic setActive(isActive: boolean): void {\n\t\tthis.execution.setActive(isActive);\n\t}\n\n\t/**\n\t * returns whether this execution is currently active.\n\t * @returns `true` if active, `false` otherwise.\n\t */\n\tpublic isActive(): boolean {\n\t\treturn this.execution.isActive();\n\t}\n\n\t/**\n\t * returns whether this execution has ended or not.\n\t * @returns `true` if ended, `false` otherwise.\n\t */\n\tpublic isEnded(): boolean {\n\t\treturn this.execution.isEnded();\n\t}\n\n\t/**\n\t * changes the concurrent indicator on this execution.\n\t * @param isConcurrent A boolean indicating whether the execution should be concurrent.\n\t */\n\tpublic setConcurrent(isConcurrent: boolean): void {\n\t\tthis.execution.setConcurrent(isConcurrent);\n\t}\n\n\t/**\n\t * returns whether this execution is concurrent or not.\n\t * @returns `true` if concurrent, `false` otherwise.\n\t */\n\tpublic isConcurrent(): boolean {\n\t\treturn this.execution.isConcurrent();\n\t}\n\n\t/**\n\t * returns whether this execution is a process instance or not.\n\t * @returns `true` if it's a process instance, `false` otherwise.\n\t */\n\tpublic isProcessInstanceType(): boolean {\n\t\treturn this.execution.isProcessInstanceType();\n\t}\n\n\t/**\n\t * Inactivates this execution. This is useful for example in a join: the execution still exists, but it is not longer active.\n\t */\n\tpublic inactivate(): void {\n\t\tthis.execution.inactivate();\n\t}\n\n\t/**\n\t * Returns whether this execution is a scope.\n\t * @returns `true` if it is a scope, `false` otherwise.\n\t */\n\tpublic isScope(): boolean {\n\t\treturn this.execution.isScope();\n\t}\n\n\t/**\n\t * Changes whether this execution is a scope or not.\n\t * @param isScope A boolean indicating whether the execution should be a scope.\n\t */\n\tpublic setScope(isScope: boolean): void {\n\t\tthis.execution.setScope(isScope);\n\t}\n\n\t/**\n\t * Returns whether this execution is the root of a multi instance execution.\n\t * @returns `true` if it's a multi instance root, `false` otherwise.\n\t */\n\tpublic isMultiInstanceRoot(): boolean {\n\t\treturn this.execution.isMultiInstanceRoot();\n\t}\n\n\t/**\n\t * Changes whether this execution is a multi instance root or not.\n\t * @param isMultiInstanceRoot A boolean indicating whether the execution is the root of a multi-instance execution.\n\t */\n\tpublic setMultiInstanceRoot(isMultiInstanceRoot: boolean): void {\n\t\tthis.execution.setMultiInstanceRoot(isMultiInstanceRoot);\n\t}\n\n}\n\nenum DelegationState {\n\n\t/**\n\t * The owner delegated the task and wants to review the result after the assignee has resolved the task. When the assignee completes the task, the task is marked as {@link #RESOLVED} and sent back\n\t * to the owner. When that happens, the owner is set as the assignee so that the owner gets this task back in the ToDo.\n\t */\n\tPENDING,\n\n\t/**\n\t * The assignee has resolved the task, the assignee was set to the owner again and the owner now finds this task back in the ToDo list for review. The owner now is able to complete the task.\n\t */\n\tRESOLVED\n}\n\nclass TaskContext extends VariableScope {\n\n\tprivate task: any;\n\n\tconstructor() {\n\t\tsuper(__context.get('task'));\n\t\tthis.task = __context.get('task');\n\t}\n\n\t/**\n\t * DB id of the task.\n\t * \n\t * @returns the unique ID of the current task.\n\t */\n\tpublic getId(): string {\n\t\treturn this.task.getId();\n\t}\n\n\t/**\n\t * Name or title of the task.\n\t * \n\t * @returns the name of the current task.\n\t */\n\tpublic getName(): string {\n\t\treturn this.task.getName();\n\t}\n\n\t/**\n\t * Change the name of the task.\n\t * \n\t * @param name the new name for the task.\n\t */\n\tpublic setName(name: string): void {\n\t\tthis.task.setName(name);\n\t}\n\n\t/**\n\t * Get the free text description of the task.\n\t * \n\t * @returns the description of the current task.\n\t */\n\tpublic getDescription(): string {\n\t\treturn this.task.getDescription();\n\t}\n\n\t/**\n\t * Free text description of the task.\n\t * \n\t * @param description the new description for the task.\n\t */\n\tpublic setDescription(description: string): void {\n\t\tthis.task.setDescription(description);\n\t}\n\n\t/**\n\t * Indication of how important/urgent this task is with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low,\n\t * [40..59] normal, [60..79] high [80..100] highest\n\t * \n\t * @returns the priority of the current task.\n\t */\n\tpublic getPriority(): number {\n\t\treturn this.task.getPriority();\n\t}\n\n\t/**\n\t * Indication of how important/urgent this task is with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low,\n\t * [40..59] normal, [60..79] high [80..100] highest\n\t * \n\t * @param priority the new priority for the task, with a number between 0 and 100 where higher values mean a higher priority and lower values mean lower priority: [0..19] lowest, [20..39] low, [40..59] normal, \n\t */\n\tpublic setPriority(priority: number): void {\n\t\tthis.task.setPriority(priority);\n\t}\n\n\t/**\n\t * Refrence to the process instance this task is associated with, or `null` if the task is not related to a process instance.\n\t * \n\t * @returns the ID of the process instance this task is associated with, or `null`.\n\t */\n\tpublic getProcessInstanceId(): string {\n\t\treturn this.task.getProcessInstanceId();\n\t}\n\n\t/**\n\t * Reference to the path of execution this task is associated with, or `null` if the task is not related to a process instance.\n\t * \n\t * @returns the ID of the execution this task is associated with, or `null`.\n\t */\n\tpublic getExecutionId(): string {\n\t\treturn this.task.getExecutionId();\n\t}\n\n\t/**\n\t * Reference to the process definition this task is associated with, or `null` if the task is not related to a process instance.\n\t * \n\t * @returns the ID of the process definition this task is associated with, or `null`.\n\t */\n\tpublic getProcessDefinitionId(): string {\n\t\treturn this.task.getProcessDefinitionId();\n\t}\n\n\t/**\n\t * The current state of the task.\n\t * \n\t * @returns the state of the current task.\n\t */\n\tpublic getState(): string {\n\t\treturn this.task.getState();\n\t}\n\n\t/**\n\t * The date/time when this task was created.\n\t * \n\t * @returns the creation time of the current task.\n\t */\n\tpublic getCreateTime(): Date {\n\t\treturn this.task.getCreateTime();\n\t}\n\n\t/**\n\t * The date/time when this task was put in progress.\n\t * \n\t * @returns the in progress start time of the current task.\n\t */\n\tpublic getInProgressStartTime(): Date {\n\t\treturn this.task.getInProgressStartTime();\n\t}\n\n\t/**\n\t * The user reference that started the task.\n\t * \n\t * @returns the user reference that started the task.\n\t */\n\tpublic getInProgressStartedBy(): string {\n\t\treturn this.task.getInProgressStartedBy();\n\t}\n\n\t/**\n\t * The date/time when this task was claimed.\n\t * \n\t * @returns the claim time of the current task.\n\t */\n\tpublic getClaimTime(): Date {\n\t\treturn this.task.getClaimTime();\n\t}\n\n\t/**\n\t * The user reference that claimed the task.\n\t * \n\t * @returns the user reference that claimed the task.\n\t */\n\tpublic getClaimedBy(): string {\n\t\treturn this.task.getClaimedBy();\n\t}\n\n\t/**\n\t * The date/time when this task was suspended.\n\t * \n\t * @returns the date/time when this task was suspended.\n\t */\n\tpublic getSuspendedTime(): Date {\n\t\treturn this.task.getSuspendedTime();\n\t}\n\n\t/**\n\t * The user reference that suspended the task.\n\t * \n\t * @returns the user reference that suspended the task.\n\t */\n\tpublic getSuspendedBy(): string {\n\t\treturn this.task.getSuspendedBy();\n\t}\n\n\t/**\n\t * The id of the activity in the process defining this task or null if this is not related to a process.\n\t * \n\t * @returns the task definition key.\n\t */\n\tpublic getTaskDefinitionKey(): string {\n\t\treturn this.task.getTaskDefinitionKey();\n\t}\n\n\t/**\n\t * Indicated whether this task is suspended or not.\n\t * \n\t * @returns `true` if the task is suspended, `false` otherwise.\n\t */\n\tpublic isSuspended(): boolean {\n\t\treturn this.task.isSuspended();\n\t}\n\n\t/**\n\t * The tenant identifier of this task, which is the same as the tenant identifier of the process definition and process instance this task is associated with (if any).\n\t * \n\t * @returns the tenant ID of this task, or `null`/empty string if no tenant is associated.\n\t */\n\tpublic getTenantId(): string {\n\t\treturn this.task.getTenantId();\n\t}\n\n\t/**\n\t * The form key for the user task, which is the same as the form key defined on the user task in the process definition. Will return `null` if this task is not a user task or if no form key is defined.\n\t * \n\t * @returns the form key for the user task, or `null` if no form key is defined.\n\t */\n\tpublic getFormKey(): string {\n\t\treturn this.task.getFormKey();\n\t}\n\n\t/**\n\t * Change the form key of the task.\n\t * \n\t * @param formKey the new form key for the user task, or `null` to remove the form key\n\t */\n\tpublic setFormKey(formKey: string): void {\n\t\tthis.task.setFormKey(formKey);\n\t}\n\n\t/**\n\t * The event name which triggered the task listener to fire for this task. Will return `null`/empty string if not executing a task listener.\n\t * \n\t * @returns the event name which triggered the task listener to fire for this task, or `null`/empty string if not executing a task listener.\n\t */\n\tpublic getEventName(): string {\n\t\treturn this.task.getEventName();\n\t}\n\n\t/**\n\t * The event handler identifier which triggered the task listener to fire for this task. Will return `null`/empty string if not executing a task listener or if the event handler does not have an identifier.\n\t * \n\t * @returns the event handler identifier, or `null`/empty string if not executing a task listener or if the event handler does not have an identifier.\n\t */\n\tpublic getEventHandlerId(): string {\n\t\treturn this.task.getEventHandlerId();\n\t}\n\n\t/**\n\t * The current delegation state of the task, which is `null` if the task is not delegated, `PENDING` if the task is delegated and waiting for resolution by the assignee, and `RESOLVED` if the task is delegated and has been resolved by the assignee but not yet completed by the owner.\n\t * \n\t * @returns the delegation state of the task, which is `null` if the task is not delegated, `PENDING` if the task is delegated and waiting for resolution by the assignee, and `RESOLVED` if the task is delegated and has been resolved by the assignee but not yet completed by the owner.\n\t */\n\tpublic getDelegationState(): DelegationState {\n\t\treturn this.task.getDelegationState();\n\t}\n\n\t/**\n\t * Adds a candidate user to this task, which means that the user is allowed to claim and work on this task. This does not mean that the user is the assignee of the task, but it means that the user is a candidate to become an assignee. The user will be able to see this task in their task list and claim it to become the assignee.\n\t * \n\t * @param userId the user ID of the candidate user to add to this task.\n\t */\n\tpublic addCandidateUser(userId: string): void {\n\t\tthis.task.addCandidateUser(userId);\n\t}\n\n\t/**\n\t * Adds multiple users as candidate user to this task.\n\t * \n\t * @param candidateUsers the collection of candidate user IDs to add to this task.\n\t */\n\tpublic addCandidateUsers(candidateUsers: string[]): void {\n\t\tthis.task.addCandidateUsers(candidateUsers);\n\t}\n\n\t/**\n\t * Adds a candidate group to this task, which means that all users that are members of this group are allowed to claim and work on this task. This does not mean that the group is the assignee of the task, but it means that all users that are members of the group are candidates to become assignees. The users that are members of the group will be able to see this task in their task list and claim it to become the assignee.\n\t * \n\t * @param groupId the group ID of the candidate group to add to this task.\n\t */\n\tpublic addCandidateGroup(groupId: string): void {\n\t\tthis.task.addCandidateGroup(groupId);\n\t}\n\n\t/**\n\t * Adds multiple groups as candidate group to this task.\n\t * \n\t * @param candidateGroups the collection of candidate group IDs to add to this task.\n\t */\n\tpublic addCandidateGroups(candidateGroups: string[]): void {\n\t\tthis.task.addCandidateGroups(candidateGroups);\n\t}\n\n\t/**\n\t * The user id of the person responsible for this task. This is the user that has to work on this task and complete it. When a task is assigned to a user, that user becomes the assignee of the task. The assignee is the only one that can complete the task (unless the task is delegated\n\t * \n\t * @returns the user ID of the assignee of this task\n\t */\n\tpublic getOwner(): string {\n\t\treturn this.task.getOwner();\n\t}\n\n\t/**\n\t * The user id of the person responsible for this task. This is the user that has to work on this task and complete it. When a task is assigned to a user, that user becomes the assignee of the task. The assignee is the only one that can complete the task (unless the task is delegated\n\t * \n\t * @param owner the user ID of the assignee of this task\n\t */\n\tpublic setOwner(owner: string): void {\n\t\tthis.task.setOwner(owner);\n\t}\n\n\t/**\n\t * The user id of the person to which this task is delegated.\n\t * \n\t * @returns the user ID of the assignee of this task\n\t */\n\tpublic getAssignee(): string {\n\t\treturn this.task.getAssignee();\n\t}\n\n\t/**\n\t * The user id of the person to which this task is delegated.\n\t * @param assignee the user ID of the assignee of this task\n\t */\n    public setAssignee(assignee: string): void {\n        this.task.setAssignee(assignee);\n    }\n\n\t/**\n\t * Due date of the in progress start of the task.\n\t * \n\t * @returns the due date of the in progress start of the task.\n\t */\n\tpublic getInProgressStartDueDate(): Date {\n\t\treturn this.task.getInProgressStartDueDate();\n\t}\n\n\t/**\n\t * Change the in progress start due date of the task.\n\t * \n\t * @param inProgressStartDueDate the new due date of the in progress start of the task.\n\t */\n\tpublic setInProgressStartDueDate(inProgressStartDueDate: Date): void {\n\t\tthis.task.setInProgressStartDueDate(inProgressStartDueDate);\n\t}\n\n\t/**\n\t * Due date of the task.\n\t * \n\t * @returns the due date of the task.\n\t */\n\tpublic getDueDate(): Date {\n\t\treturn this.task.getDueDate();\n\t}\n\n\t/**\n\t * Change the due date of the task.\n\t * \n\t * @param dueDate the new due date of the task.\n\t */\n\tpublic setDueDate(dueDate: Date): void {\n\t\tthis.task.setDueDate(dueDate);\n\t}\n\n\t/**\n\t * The category of the task. This is an optional field and allows to 'tag' tasks as belonging to a certain category.\n\t * \n\t * @returns the category of the task\n\t */\n\tpublic getCategory(): string {\n\t\treturn this.task.getCategory();\n\t}\n\n\t/**\n\t * Change the category of the task. This is an optional field and allows to 'tag' tasks as belonging to a certain category.\n\t * \n\t * @param category the new category of the task\n\t */\n\tpublic setCategory(category: string): void {\n\t\tthis.task.setCategory(category);\n\t}\n\n\n    /**\n     * Involves a user with a task. The type of identity link is defined by the given identityLinkType.\n     *\n     * @param userId\n     *            id of the user involve, cannot be null.\n     * @param identityLinkType\n     *            type of identityLink, cannot be null (@see {@link IdentityLinkType}).\n     * @throws FlowableObjectNotFoundException\n     *             when the task or user doesn't exist.\n     */\n\tpublic addUserIdentityLink(userId: string, identityLinkType: string): void {\n\t\tthis.task.addUserIdentityLink(userId, identityLinkType);\n\t}\n\n    /**\n     * Involves a group with group task. The type of identityLink is defined by the given identityLink.\n     *\n     * @param groupId\n     *            id of the group to involve, cannot be null.\n     * @param identityLinkType\n     *            type of identity, cannot be null (@see {@link IdentityLinkType}).\n     * @throws FlowableObjectNotFoundException\n     *             when the task or group doesn't exist.\n     */\n    public addGroupIdentityLink(groupId: string, identityLinkType: string): void {\n        this.task.addGroupIdentityLink(groupId, identityLinkType);\n    }\n\n    /**\n     * Convenience shorthand for {@link #deleteUserIdentityLink(String, String)} ; with type {@link IdentityLinkType#CANDIDATE}\n     *\n     * @param userId\n     *            id of the user to use as candidate, cannot be null.\n     * @throws FlowableObjectNotFoundException\n     *             when the task or user doesn't exist.\n     */\n    public deleteCandidateUser(userId: string): void {\n        this.task.deleteCandidateUser(userId);\n    }\n\n    /**\n     * Convenience shorthand for {@link #deleteGroupIdentityLink(String, String)}; with type {@link IdentityLinkType#CANDIDATE}\n     *\n     * @param groupId\n     *            id of the group to use as candidate, cannot be null.\n     * @throws FlowableObjectNotFoundException\n     *             when the task or group doesn't exist.\n     */\n\tpublic deleteCandidateGroup(groupId: string): void {\n\t\tthis.task.deleteCandidateGroup(groupId);\n\t}\n\n\t/**\n     * Removes the association between a user and a task for the given identityLinkType.\n     *\n     * @param userId\n     *            id of the user involve, cannot be null.\n     * @param identityLinkType\n     *            type of identityLink, cannot be null (@see {@link IdentityLinkType}).\n     * @throws FlowableObjectNotFoundException\n     *             when the task or user doesn't exist.\n     */\n\tpublic deleteUserIdentityLink(userId: string, identityLinkType: string): void {\n\t\tthis.task.deleteUserIdentityLink(userId, identityLinkType);\n\t}\n\n    /**\n     * Removes the association between a group and a task for the given identityLinkType.\n     *\n     * @param groupId\n     *            id of the group to involve, cannot be null.\n     * @param identityLinkType\n     *            type of identity, cannot be null (@see {@link IdentityLinkType}).\n     * @throws FlowableObjectNotFoundException\n     *             when the task or group doesn't exist.\n     */\n    public deleteGroupIdentityLink(groupId: string, identityLinkType: string): void {\n        this.task.deleteGroupIdentityLink(groupId, identityLinkType);\n    }\n\n\n    /**\n     * Retrieves the candidate users and groups associated with the task.\n     *\n     * @return set of {@link IdentityLink}s of type {@link IdentityLinkType#CANDIDATE}.\n     */\n\tpublic getCandidates(): IdentityLink[] {\n\t\treturn this.task.getCandidates();\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Process;\n}\n"],
  "mappings": "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",
  "names": ["DelegationState"]
}
