@aerokit/sdk 12.44.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.
Files changed (399) hide show
  1. package/LICENSE +277 -0
  2. package/README.md +170 -0
  3. package/dist/cjs/bpm/deployer.js +57 -0
  4. package/dist/cjs/bpm/index.js +35 -0
  5. package/dist/cjs/bpm/process.js +636 -0
  6. package/dist/cjs/bpm/tasks.js +973 -0
  7. package/dist/cjs/bpm/values.js +82 -0
  8. package/dist/cjs/cache/cache.js +64 -0
  9. package/dist/cjs/cache/index.js +26 -0
  10. package/dist/cjs/cms/cmis.js +689 -0
  11. package/dist/cjs/cms/index.js +26 -0
  12. package/dist/cjs/component/decorators.js +126 -0
  13. package/dist/cjs/component/index.js +36 -0
  14. package/dist/cjs/core/configurations.js +110 -0
  15. package/dist/cjs/core/context.js +47 -0
  16. package/dist/cjs/core/env.js +45 -0
  17. package/dist/cjs/core/globals.js +54 -0
  18. package/dist/cjs/core/index.js +35 -0
  19. package/dist/cjs/db/dao.js +795 -0
  20. package/dist/cjs/db/database.js +904 -0
  21. package/dist/cjs/db/decorators.js +167 -0
  22. package/dist/cjs/db/index.js +72 -0
  23. package/dist/cjs/db/insert.js +51 -0
  24. package/dist/cjs/db/orm.js +245 -0
  25. package/dist/cjs/db/ormstatements.js +243 -0
  26. package/dist/cjs/db/procedure.js +112 -0
  27. package/dist/cjs/db/query.js +57 -0
  28. package/dist/cjs/db/repository.js +148 -0
  29. package/dist/cjs/db/sequence.js +59 -0
  30. package/dist/cjs/db/sql.js +516 -0
  31. package/dist/cjs/db/store.js +172 -0
  32. package/dist/cjs/db/translator.js +100 -0
  33. package/dist/cjs/db/update.js +43 -0
  34. package/dist/cjs/etcd/client.js +174 -0
  35. package/dist/cjs/etcd/index.js +26 -0
  36. package/dist/cjs/extensions/decorators.js +40 -0
  37. package/dist/cjs/extensions/extensions.js +108 -0
  38. package/dist/cjs/extensions/index.js +39 -0
  39. package/dist/cjs/git/client.js +277 -0
  40. package/dist/cjs/git/index.js +26 -0
  41. package/dist/cjs/http/client-async.js +224 -0
  42. package/dist/cjs/http/client.js +145 -0
  43. package/dist/cjs/http/decorators.js +76 -0
  44. package/dist/cjs/http/errors/ForbiddenError.js +41 -0
  45. package/dist/cjs/http/errors/ValidationError.js +41 -0
  46. package/dist/cjs/http/errors.js +26 -0
  47. package/dist/cjs/http/index.js +59 -0
  48. package/dist/cjs/http/request.js +281 -0
  49. package/dist/cjs/http/response.js +452 -0
  50. package/dist/cjs/http/rs/resource-common.js +32 -0
  51. package/dist/cjs/http/rs/resource-http-controller.js +306 -0
  52. package/dist/cjs/http/rs/resource-mappings.js +130 -0
  53. package/dist/cjs/http/rs/resource-method.js +218 -0
  54. package/dist/cjs/http/rs/resource.js +232 -0
  55. package/dist/cjs/http/rs.js +31 -0
  56. package/dist/cjs/http/session.js +124 -0
  57. package/dist/cjs/http/upload.js +144 -0
  58. package/dist/cjs/http/utils.js +106 -0
  59. package/dist/cjs/index.js +1 -0
  60. package/dist/cjs/indexing/index.js +29 -0
  61. package/dist/cjs/indexing/searcher.js +70 -0
  62. package/dist/cjs/indexing/writer.js +45 -0
  63. package/dist/cjs/integrations/index.js +26 -0
  64. package/dist/cjs/integrations/integrations.js +55 -0
  65. package/dist/cjs/io/bytes.js +101 -0
  66. package/dist/cjs/io/files.js +344 -0
  67. package/dist/cjs/io/image.js +43 -0
  68. package/dist/cjs/io/index.js +38 -0
  69. package/dist/cjs/io/streams.js +243 -0
  70. package/dist/cjs/io/zip.js +251 -0
  71. package/dist/cjs/job/decorators.js +40 -0
  72. package/dist/cjs/job/index.js +39 -0
  73. package/dist/cjs/job/scheduler.js +347 -0
  74. package/dist/cjs/junit/index.js +18 -0
  75. package/dist/cjs/junit/junit.js +67 -0
  76. package/dist/cjs/kafka/consumer.js +70 -0
  77. package/dist/cjs/kafka/index.js +29 -0
  78. package/dist/cjs/kafka/producer.js +70 -0
  79. package/dist/cjs/log/index.js +26 -0
  80. package/dist/cjs/log/logging.js +174 -0
  81. package/dist/cjs/mail/client.js +153 -0
  82. package/dist/cjs/mail/index.js +26 -0
  83. package/dist/cjs/messaging/consumer.js +83 -0
  84. package/dist/cjs/messaging/decorators.js +40 -0
  85. package/dist/cjs/messaging/index.js +42 -0
  86. package/dist/cjs/messaging/producer.js +81 -0
  87. package/dist/cjs/mongodb/client.js +627 -0
  88. package/dist/cjs/mongodb/dao.js +390 -0
  89. package/dist/cjs/mongodb/index.js +36 -0
  90. package/dist/cjs/net/decorators.js +40 -0
  91. package/dist/cjs/net/index.js +42 -0
  92. package/dist/cjs/net/soap.js +228 -0
  93. package/dist/cjs/net/websockets.js +151 -0
  94. package/dist/cjs/net/wrappers/onClose.js +2 -0
  95. package/dist/cjs/net/wrappers/onError.js +2 -0
  96. package/dist/cjs/net/wrappers/onMessage.js +2 -0
  97. package/dist/cjs/net/wrappers/onOpen.js +2 -0
  98. package/dist/cjs/pdf/index.js +26 -0
  99. package/dist/cjs/pdf/pdf.js +160 -0
  100. package/dist/cjs/platform/command.js +47 -0
  101. package/dist/cjs/platform/engines.js +70 -0
  102. package/dist/cjs/platform/index.js +47 -0
  103. package/dist/cjs/platform/lifecycle.js +49 -0
  104. package/dist/cjs/platform/os.js +51 -0
  105. package/dist/cjs/platform/problems.js +127 -0
  106. package/dist/cjs/platform/registry.js +319 -0
  107. package/dist/cjs/platform/repository.js +498 -0
  108. package/dist/cjs/platform/workspace.js +574 -0
  109. package/dist/cjs/qldb/index.js +26 -0
  110. package/dist/cjs/qldb/qldb.js +24 -0
  111. package/dist/cjs/rabbitmq/consumer.js +50 -0
  112. package/dist/cjs/rabbitmq/index.js +29 -0
  113. package/dist/cjs/rabbitmq/producer.js +38 -0
  114. package/dist/cjs/redis/client.js +190 -0
  115. package/dist/cjs/redis/index.js +26 -0
  116. package/dist/cjs/security/decorators.js +48 -0
  117. package/dist/cjs/security/index.js +40 -0
  118. package/dist/cjs/security/oauth.js +75 -0
  119. package/dist/cjs/security/user.js +88 -0
  120. package/dist/cjs/template/engines.js +139 -0
  121. package/dist/cjs/template/index.js +26 -0
  122. package/dist/cjs/utils/alphanumeric.js +107 -0
  123. package/dist/cjs/utils/base64.js +104 -0
  124. package/dist/cjs/utils/converter.js +78 -0
  125. package/dist/cjs/utils/digest.js +167 -0
  126. package/dist/cjs/utils/escape.js +160 -0
  127. package/dist/cjs/utils/hex.js +104 -0
  128. package/dist/cjs/utils/index.js +68 -0
  129. package/dist/cjs/utils/jsonpath.js +489 -0
  130. package/dist/cjs/utils/qrcode.js +41 -0
  131. package/dist/cjs/utils/url.js +82 -0
  132. package/dist/cjs/utils/utf8.js +61 -0
  133. package/dist/cjs/utils/uuid.js +48 -0
  134. package/dist/cjs/utils/xml.js +57 -0
  135. package/dist/dts/bpm/deployer.d.ts +29 -0
  136. package/dist/dts/bpm/index.d.ts +8 -0
  137. package/dist/dts/bpm/process.d.ts +433 -0
  138. package/dist/dts/bpm/tasks.d.ts +2022 -0
  139. package/dist/dts/bpm/values.d.ts +38 -0
  140. package/dist/dts/cache/cache.d.ts +30 -0
  141. package/dist/dts/cache/index.d.ts +2 -0
  142. package/dist/dts/cms/cmis.d.ts +413 -0
  143. package/dist/dts/cms/index.d.ts +2 -0
  144. package/dist/dts/component/decorators.d.ts +52 -0
  145. package/dist/dts/component/index.d.ts +2 -0
  146. package/dist/dts/core/configurations.d.ts +65 -0
  147. package/dist/dts/core/context.d.ts +19 -0
  148. package/dist/dts/core/env.d.ts +23 -0
  149. package/dist/dts/core/globals.d.ts +30 -0
  150. package/dist/dts/core/index.d.ts +8 -0
  151. package/dist/dts/db/dao.d.ts +8 -0
  152. package/dist/dts/db/database.d.ts +507 -0
  153. package/dist/dts/db/decorators.d.ts +89 -0
  154. package/dist/dts/db/index.d.ts +25 -0
  155. package/dist/dts/db/insert.d.ts +32 -0
  156. package/dist/dts/db/orm.d.ts +44 -0
  157. package/dist/dts/db/ormstatements.d.ts +4 -0
  158. package/dist/dts/db/procedure.d.ts +25 -0
  159. package/dist/dts/db/query.d.ts +48 -0
  160. package/dist/dts/db/repository.d.ts +64 -0
  161. package/dist/dts/db/sequence.d.ts +34 -0
  162. package/dist/dts/db/sql.d.ts +267 -0
  163. package/dist/dts/db/store.d.ts +138 -0
  164. package/dist/dts/db/translator.d.ts +26 -0
  165. package/dist/dts/db/update.d.ts +21 -0
  166. package/dist/dts/etcd/client.d.ts +92 -0
  167. package/dist/dts/etcd/index.d.ts +2 -0
  168. package/dist/dts/extensions/decorators.d.ts +11 -0
  169. package/dist/dts/extensions/extensions.d.ts +41 -0
  170. package/dist/dts/extensions/index.d.ts +4 -0
  171. package/dist/dts/git/client.d.ts +478 -0
  172. package/dist/dts/git/index.d.ts +2 -0
  173. package/dist/dts/http/client-async.d.ts +158 -0
  174. package/dist/dts/http/client.d.ts +180 -0
  175. package/dist/dts/http/decorators.d.ts +11 -0
  176. package/dist/dts/http/errors/ForbiddenError.d.ts +20 -0
  177. package/dist/dts/http/errors/ValidationError.d.ts +20 -0
  178. package/dist/dts/http/errors.d.ts +2 -0
  179. package/dist/dts/http/index.d.ts +16 -0
  180. package/dist/dts/http/request.d.ts +158 -0
  181. package/dist/dts/http/response.d.ts +281 -0
  182. package/dist/dts/http/rs/resource-common.d.ts +11 -0
  183. package/dist/dts/http/rs/resource-http-controller.d.ts +43 -0
  184. package/dist/dts/http/rs/resource-mappings.d.ts +70 -0
  185. package/dist/dts/http/rs/resource-method.d.ts +206 -0
  186. package/dist/dts/http/rs/resource.d.ts +126 -0
  187. package/dist/dts/http/rs.d.ts +4 -0
  188. package/dist/dts/http/session.d.ts +81 -0
  189. package/dist/dts/http/upload.d.ts +100 -0
  190. package/dist/dts/http/utils.d.ts +54 -0
  191. package/dist/dts/index.d.ts +0 -0
  192. package/dist/dts/indexing/index.d.ts +4 -0
  193. package/dist/dts/indexing/searcher.d.ts +47 -0
  194. package/dist/dts/indexing/writer.d.ts +22 -0
  195. package/dist/dts/integrations/index.d.ts +2 -0
  196. package/dist/dts/integrations/integrations.d.ts +118 -0
  197. package/dist/dts/io/bytes.d.ts +56 -0
  198. package/dist/dts/io/files.d.ts +261 -0
  199. package/dist/dts/io/image.d.ts +22 -0
  200. package/dist/dts/io/index.d.ts +10 -0
  201. package/dist/dts/io/streams.d.ts +172 -0
  202. package/dist/dts/io/zip.d.ts +178 -0
  203. package/dist/dts/job/decorators.d.ts +11 -0
  204. package/dist/dts/job/index.d.ts +4 -0
  205. package/dist/dts/job/scheduler.d.ts +250 -0
  206. package/dist/dts/junit/index.d.ts +1 -0
  207. package/dist/dts/junit/junit.d.ts +50 -0
  208. package/dist/dts/kafka/consumer.d.ts +48 -0
  209. package/dist/dts/kafka/index.d.ts +4 -0
  210. package/dist/dts/kafka/producer.d.ts +50 -0
  211. package/dist/dts/log/index.d.ts +2 -0
  212. package/dist/dts/log/logging.d.ts +102 -0
  213. package/dist/dts/mail/client.d.ts +90 -0
  214. package/dist/dts/mail/index.d.ts +2 -0
  215. package/dist/dts/messaging/consumer.d.ts +61 -0
  216. package/dist/dts/messaging/decorators.d.ts +11 -0
  217. package/dist/dts/messaging/index.d.ts +6 -0
  218. package/dist/dts/messaging/producer.d.ts +59 -0
  219. package/dist/dts/mongodb/client.d.ts +367 -0
  220. package/dist/dts/mongodb/dao.d.ts +24 -0
  221. package/dist/dts/mongodb/index.d.ts +2 -0
  222. package/dist/dts/net/decorators.d.ts +11 -0
  223. package/dist/dts/net/index.d.ts +6 -0
  224. package/dist/dts/net/soap.d.ts +115 -0
  225. package/dist/dts/net/websockets.d.ts +100 -0
  226. package/dist/dts/net/wrappers/onClose.d.ts +0 -0
  227. package/dist/dts/net/wrappers/onError.d.ts +0 -0
  228. package/dist/dts/net/wrappers/onMessage.d.ts +0 -0
  229. package/dist/dts/net/wrappers/onOpen.d.ts +0 -0
  230. package/dist/dts/pdf/index.d.ts +2 -0
  231. package/dist/dts/pdf/pdf.d.ts +72 -0
  232. package/dist/dts/platform/command.d.ts +41 -0
  233. package/dist/dts/platform/engines.d.ts +35 -0
  234. package/dist/dts/platform/index.d.ts +16 -0
  235. package/dist/dts/platform/lifecycle.d.ts +22 -0
  236. package/dist/dts/platform/os.d.ts +23 -0
  237. package/dist/dts/platform/problems.d.ts +114 -0
  238. package/dist/dts/platform/registry.d.ts +227 -0
  239. package/dist/dts/platform/repository.d.ts +354 -0
  240. package/dist/dts/platform/workspace.d.ts +421 -0
  241. package/dist/dts/qldb/index.d.ts +2 -0
  242. package/dist/dts/qldb/qldb.d.ts +1 -0
  243. package/dist/dts/rabbitmq/consumer.d.ts +25 -0
  244. package/dist/dts/rabbitmq/index.d.ts +4 -0
  245. package/dist/dts/rabbitmq/producer.d.ts +15 -0
  246. package/dist/dts/redis/client.d.ts +134 -0
  247. package/dist/dts/redis/index.d.ts +2 -0
  248. package/dist/dts/security/decorators.d.ts +4 -0
  249. package/dist/dts/security/index.d.ts +5 -0
  250. package/dist/dts/security/oauth.d.ts +39 -0
  251. package/dist/dts/security/user.d.ts +51 -0
  252. package/dist/dts/template/engines.d.ts +98 -0
  253. package/dist/dts/template/index.d.ts +2 -0
  254. package/dist/dts/utils/alphanumeric.d.ts +39 -0
  255. package/dist/dts/utils/base64.d.ts +48 -0
  256. package/dist/dts/utils/converter.d.ts +44 -0
  257. package/dist/dts/utils/digest.d.ts +50 -0
  258. package/dist/dts/utils/escape.d.ts +110 -0
  259. package/dist/dts/utils/hex.d.ts +48 -0
  260. package/dist/dts/utils/index.d.ts +23 -0
  261. package/dist/dts/utils/jsonpath.d.ts +22 -0
  262. package/dist/dts/utils/qrcode.d.ts +16 -0
  263. package/dist/dts/utils/url.d.ts +50 -0
  264. package/dist/dts/utils/utf8.d.ts +33 -0
  265. package/dist/dts/utils/uuid.d.ts +21 -0
  266. package/dist/dts/utils/xml.d.ts +22 -0
  267. package/dist/esm/bpm/deployer.mjs +38 -0
  268. package/dist/esm/bpm/index.mjs +15 -0
  269. package/dist/esm/bpm/process.mjs +617 -0
  270. package/dist/esm/bpm/tasks.mjs +954 -0
  271. package/dist/esm/bpm/values.mjs +63 -0
  272. package/dist/esm/cache/cache.mjs +45 -0
  273. package/dist/esm/cache/index.mjs +6 -0
  274. package/dist/esm/cms/cmis.mjs +660 -0
  275. package/dist/esm/cms/index.mjs +6 -0
  276. package/dist/esm/component/decorators.mjs +107 -0
  277. package/dist/esm/component/index.mjs +6 -0
  278. package/dist/esm/core/configurations.mjs +91 -0
  279. package/dist/esm/core/context.mjs +28 -0
  280. package/dist/esm/core/env.mjs +26 -0
  281. package/dist/esm/core/globals.mjs +35 -0
  282. package/dist/esm/core/index.mjs +15 -0
  283. package/dist/esm/db/dao.mjs +775 -0
  284. package/dist/esm/db/database.mjs +885 -0
  285. package/dist/esm/db/decorators.mjs +148 -0
  286. package/dist/esm/db/index.mjs +42 -0
  287. package/dist/esm/db/insert.mjs +32 -0
  288. package/dist/esm/db/orm.mjs +225 -0
  289. package/dist/esm/db/ormstatements.mjs +223 -0
  290. package/dist/esm/db/procedure.mjs +93 -0
  291. package/dist/esm/db/query.mjs +38 -0
  292. package/dist/esm/db/repository.mjs +129 -0
  293. package/dist/esm/db/sequence.mjs +40 -0
  294. package/dist/esm/db/sql.mjs +497 -0
  295. package/dist/esm/db/store.mjs +153 -0
  296. package/dist/esm/db/translator.mjs +81 -0
  297. package/dist/esm/db/update.mjs +24 -0
  298. package/dist/esm/etcd/client.mjs +155 -0
  299. package/dist/esm/etcd/index.mjs +6 -0
  300. package/dist/esm/extensions/decorators.mjs +21 -0
  301. package/dist/esm/extensions/extensions.mjs +89 -0
  302. package/dist/esm/extensions/index.mjs +9 -0
  303. package/dist/esm/git/client.mjs +258 -0
  304. package/dist/esm/git/index.mjs +6 -0
  305. package/dist/esm/http/client-async.mjs +205 -0
  306. package/dist/esm/http/client.mjs +126 -0
  307. package/dist/esm/http/decorators.mjs +47 -0
  308. package/dist/esm/http/errors/ForbiddenError.mjs +22 -0
  309. package/dist/esm/http/errors/ValidationError.mjs +22 -0
  310. package/dist/esm/http/errors.mjs +7 -0
  311. package/dist/esm/http/index.mjs +29 -0
  312. package/dist/esm/http/request.mjs +262 -0
  313. package/dist/esm/http/response.mjs +433 -0
  314. package/dist/esm/http/rs/resource-common.mjs +13 -0
  315. package/dist/esm/http/rs/resource-http-controller.mjs +287 -0
  316. package/dist/esm/http/rs/resource-mappings.mjs +111 -0
  317. package/dist/esm/http/rs/resource-method.mjs +199 -0
  318. package/dist/esm/http/rs/resource.mjs +213 -0
  319. package/dist/esm/http/rs.mjs +12 -0
  320. package/dist/esm/http/session.mjs +105 -0
  321. package/dist/esm/http/upload.mjs +125 -0
  322. package/dist/esm/http/utils.mjs +87 -0
  323. package/dist/esm/index.mjs +1 -0
  324. package/dist/esm/indexing/index.mjs +9 -0
  325. package/dist/esm/indexing/searcher.mjs +51 -0
  326. package/dist/esm/indexing/writer.mjs +26 -0
  327. package/dist/esm/integrations/index.mjs +6 -0
  328. package/dist/esm/integrations/integrations.mjs +36 -0
  329. package/dist/esm/io/bytes.mjs +82 -0
  330. package/dist/esm/io/files.mjs +325 -0
  331. package/dist/esm/io/image.mjs +24 -0
  332. package/dist/esm/io/index.mjs +18 -0
  333. package/dist/esm/io/streams.mjs +224 -0
  334. package/dist/esm/io/zip.mjs +232 -0
  335. package/dist/esm/job/decorators.mjs +21 -0
  336. package/dist/esm/job/index.mjs +9 -0
  337. package/dist/esm/job/scheduler.mjs +328 -0
  338. package/dist/esm/junit/index.mjs +2 -0
  339. package/dist/esm/junit/junit.mjs +48 -0
  340. package/dist/esm/kafka/consumer.mjs +51 -0
  341. package/dist/esm/kafka/index.mjs +9 -0
  342. package/dist/esm/kafka/producer.mjs +51 -0
  343. package/dist/esm/log/index.mjs +6 -0
  344. package/dist/esm/log/logging.mjs +155 -0
  345. package/dist/esm/mail/client.mjs +134 -0
  346. package/dist/esm/mail/index.mjs +6 -0
  347. package/dist/esm/messaging/consumer.mjs +64 -0
  348. package/dist/esm/messaging/decorators.mjs +21 -0
  349. package/dist/esm/messaging/index.mjs +12 -0
  350. package/dist/esm/messaging/producer.mjs +62 -0
  351. package/dist/esm/mongodb/client.mjs +608 -0
  352. package/dist/esm/mongodb/dao.mjs +360 -0
  353. package/dist/esm/mongodb/index.mjs +7 -0
  354. package/dist/esm/net/decorators.mjs +21 -0
  355. package/dist/esm/net/index.mjs +12 -0
  356. package/dist/esm/net/soap.mjs +209 -0
  357. package/dist/esm/net/websockets.mjs +132 -0
  358. package/dist/esm/net/wrappers/onClose.mjs +2 -0
  359. package/dist/esm/net/wrappers/onError.mjs +2 -0
  360. package/dist/esm/net/wrappers/onMessage.mjs +2 -0
  361. package/dist/esm/net/wrappers/onOpen.mjs +2 -0
  362. package/dist/esm/pdf/index.mjs +6 -0
  363. package/dist/esm/pdf/pdf.mjs +141 -0
  364. package/dist/esm/platform/command.mjs +28 -0
  365. package/dist/esm/platform/engines.mjs +51 -0
  366. package/dist/esm/platform/index.mjs +27 -0
  367. package/dist/esm/platform/lifecycle.mjs +30 -0
  368. package/dist/esm/platform/os.mjs +32 -0
  369. package/dist/esm/platform/problems.mjs +108 -0
  370. package/dist/esm/platform/registry.mjs +300 -0
  371. package/dist/esm/platform/repository.mjs +479 -0
  372. package/dist/esm/platform/workspace.mjs +555 -0
  373. package/dist/esm/qldb/index.mjs +6 -0
  374. package/dist/esm/qldb/qldb.mjs +5 -0
  375. package/dist/esm/rabbitmq/consumer.mjs +31 -0
  376. package/dist/esm/rabbitmq/index.mjs +9 -0
  377. package/dist/esm/rabbitmq/producer.mjs +19 -0
  378. package/dist/esm/redis/client.mjs +171 -0
  379. package/dist/esm/redis/index.mjs +6 -0
  380. package/dist/esm/security/decorators.mjs +29 -0
  381. package/dist/esm/security/index.mjs +10 -0
  382. package/dist/esm/security/oauth.mjs +56 -0
  383. package/dist/esm/security/user.mjs +69 -0
  384. package/dist/esm/template/engines.mjs +120 -0
  385. package/dist/esm/template/index.mjs +6 -0
  386. package/dist/esm/utils/alphanumeric.mjs +88 -0
  387. package/dist/esm/utils/base64.mjs +85 -0
  388. package/dist/esm/utils/converter.mjs +59 -0
  389. package/dist/esm/utils/digest.mjs +148 -0
  390. package/dist/esm/utils/escape.mjs +141 -0
  391. package/dist/esm/utils/hex.mjs +85 -0
  392. package/dist/esm/utils/index.mjs +38 -0
  393. package/dist/esm/utils/jsonpath.mjs +470 -0
  394. package/dist/esm/utils/qrcode.mjs +22 -0
  395. package/dist/esm/utils/url.mjs +63 -0
  396. package/dist/esm/utils/utf8.mjs +42 -0
  397. package/dist/esm/utils/uuid.mjs +29 -0
  398. package/dist/esm/utils/xml.mjs +38 -0
  399. package/package.json +58 -0
@@ -0,0 +1,973 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var tasks_exports = {};
19
+ __export(tasks_exports, {
20
+ DelegationState: () => DelegationState,
21
+ NullHandlingOnOrder: () => NullHandlingOnOrder,
22
+ TaskService: () => TaskService,
23
+ Tasks: () => Tasks
24
+ });
25
+ module.exports = __toCommonJS(tasks_exports);
26
+ var import_io = require("@aerokit/sdk/io");
27
+ var import_values = require("@aerokit/sdk/bpm/values");
28
+ const BpmFacade = Java.type("org.eclipse.dirigible.components.api.bpm.BpmFacade");
29
+ class Tasks {
30
+ static list() {
31
+ const tasks = JSON.parse(BpmFacade.getTasks());
32
+ return tasks.map((e) => new TaskData(e));
33
+ }
34
+ static getVariable(taskId, variableName) {
35
+ return import_values.Values.parseValue(BpmFacade.getTaskVariable(taskId, variableName));
36
+ }
37
+ /**
38
+ * Returns all variables. This will include all variables of parent scopes too.
39
+ */
40
+ static getVariables(taskId) {
41
+ return import_values.Values.parseValuesMap(BpmFacade.getTaskVariables(taskId));
42
+ }
43
+ static setVariable(taskId, variableName, value) {
44
+ BpmFacade.setTaskVariable(taskId, variableName, import_values.Values.stringifyValue(value));
45
+ }
46
+ static setVariables(taskId, variables) {
47
+ BpmFacade.setTaskVariables(taskId, import_values.Values.stringifyValuesMap(variables));
48
+ }
49
+ static complete(taskId, variables = {}) {
50
+ BpmFacade.completeTask(taskId, JSON.stringify(variables));
51
+ }
52
+ static getTaskService() {
53
+ return new TaskService(BpmFacade.getBpmProviderFlowable().getTaskService());
54
+ }
55
+ }
56
+ class TaskService {
57
+ constructor(taskService) {
58
+ this.taskService = taskService;
59
+ }
60
+ /**
61
+ * Creates a new task that is not related to any process instance.
62
+ *
63
+ * The returned task is transient and must be saved with {@link #saveTask(Task)} 'manually'.
64
+ */
65
+ newTask(taskId) {
66
+ if (this.isNotNull(taskId)) {
67
+ return this.taskService.newTask(taskId);
68
+ }
69
+ return this.taskService.newTask();
70
+ }
71
+ /**
72
+ * Create a builder for the task
73
+ *
74
+ * @return task builder
75
+ */
76
+ createTaskBuilder() {
77
+ return this.taskService.createTaskBuilder();
78
+ }
79
+ /**
80
+ * Saves the given task to the persistent data store. If the task is already present in the persistent store, it is updated. After a new task has been saved, the task instance passed into this
81
+ * method is updated with the id of the newly created task.
82
+ *
83
+ * @param task
84
+ * the task, cannot be null.
85
+ */
86
+ saveTask(task) {
87
+ this.taskService.saveTask(task);
88
+ }
89
+ /**
90
+ * Saves the given tasks to the persistent data store. If the tasks are already present in the persistent store, it is updated. After a new task has been saved, the task instance passed into this
91
+ * method is updated with the id of the newly created task.
92
+ *
93
+ * @param taskList the list of task instances, cannot be null.
94
+ */
95
+ bulkSaveTasks(taskList) {
96
+ this.taskService.bulkSaveTasks(taskList);
97
+ }
98
+ /**
99
+ * Deletes the given task, not deleting historic information that is related to this task.
100
+ *
101
+ * @param taskId
102
+ * The id of the task that will be deleted, cannot be null. If no task exists with the given taskId, the operation is ignored.
103
+ * @param cascade
104
+ * If cascade is true, also the historic information related to this task is deleted.
105
+ * @throws FlowableObjectNotFoundException
106
+ * when the task with given id does not exist.
107
+ * @throws FlowableException
108
+ * when an error occurs while deleting the task or in case the task is part of a running process.
109
+ */
110
+ deleteTask(taskId, cascade) {
111
+ if (this.isNotNull(cascade)) {
112
+ this.taskService.deleteTask(taskId, cascade);
113
+ } else {
114
+ this.taskService.deleteTask(taskId);
115
+ }
116
+ }
117
+ /**
118
+ * Deletes all tasks of the given collection, not deleting historic information that is related to these tasks.
119
+ *
120
+ * @param taskIds
121
+ * The id's of the tasks that will be deleted, cannot be null. All id's in the list that don't have an existing task will be ignored.
122
+ * @param cascade
123
+ * If cascade is true, also the historic information related to this task is deleted.
124
+ * @throws FlowableObjectNotFoundException
125
+ * when one of the task does not exist.
126
+ * @throws FlowableException
127
+ * when an error occurs while deleting the tasks or in case one of the tasks is part of a running process.
128
+ */
129
+ deleteTasks(taskIds, cascade) {
130
+ if (this.isNotNull(cascade)) {
131
+ this.taskService.deleteTasks(taskIds, cascade);
132
+ } else {
133
+ this.taskService.deleteTasks(taskIds);
134
+ }
135
+ }
136
+ /**
137
+ * Deletes the given task, not deleting historic information that is related to this task..
138
+ *
139
+ * @param taskId
140
+ * The id of the task that will be deleted, cannot be null. If no task exists with the given taskId, the operation is ignored.
141
+ * @param deleteReason
142
+ * reason the task is deleted. Is recorded in history, if enabled.
143
+ * @throws FlowableObjectNotFoundException
144
+ * when the task with given id does not exist.
145
+ * @throws FlowableException
146
+ * when an error occurs while deleting the task or in case the task is part of a running process
147
+ */
148
+ deleteTaskWithReason(taskId, deleteReason) {
149
+ this.taskService.deleteTask(taskId, deleteReason);
150
+ }
151
+ /**
152
+ * Deletes all tasks of the given collection, not deleting historic information that is related to these tasks.
153
+ *
154
+ * @param taskIds
155
+ * The id's of the tasks that will be deleted, cannot be null. All id's in the list that don't have an existing task will be ignored.
156
+ * @param deleteReason
157
+ * reason the task is deleted. Is recorded in history, if enabled.
158
+ * @throws FlowableObjectNotFoundException
159
+ * when one of the tasks does not exist.
160
+ * @throws FlowableException
161
+ * when an error occurs while deleting the tasks or in case one of the tasks is part of a running process.
162
+ */
163
+ deleteTasksWithReason(taskIds, deleteReason) {
164
+ this.taskService.deleteTasks(taskIds, deleteReason);
165
+ }
166
+ /**
167
+ * Claim responsibility for a task: the given user is made assignee for the task. The difference with {@link #setAssignee(String, String)} is that here a check is done if the task already has a
168
+ * user assigned to it. No check is done whether the user is known by the identity component.
169
+ *
170
+ * @param taskId
171
+ * task to claim, cannot be null.
172
+ * @param userId
173
+ * user that claims the task. When userId is null the task is unclaimed, assigned to no one.
174
+ * @throws FlowableObjectNotFoundException
175
+ * when the task doesn't exist.
176
+ * @throws org.flowable.common.engine.api.FlowableTaskAlreadyClaimedException
177
+ * when the task is already claimed by another user
178
+ */
179
+ claim(taskId, userId) {
180
+ this.taskService.claim(taskId, userId);
181
+ }
182
+ /**
183
+ * A shortcut to {@link #claim} with null user in order to unclaim the task
184
+ *
185
+ * @param taskId
186
+ * task to unclaim, cannot be null.
187
+ * @throws FlowableObjectNotFoundException
188
+ * when the task doesn't exist.
189
+ */
190
+ unclaim(taskId) {
191
+ this.taskService.unclaim(taskId);
192
+ }
193
+ /**
194
+ * Set the task state to in progress. No check is done whether the user is known by the identity component.
195
+ *
196
+ * @param taskId
197
+ * task to change the state, cannot be null.
198
+ * @param userId
199
+ * user that puts the task in progress.
200
+ * @throws FlowableObjectNotFoundException
201
+ * when the task doesn't exist.
202
+ */
203
+ startProgress(taskId, userId) {
204
+ this.taskService.startProgress(taskId, userId);
205
+ }
206
+ /**
207
+ * Suspends the task. No check is done whether the user is known by the identity component.
208
+ *
209
+ * @param taskId
210
+ * task to suspend, cannot be null.
211
+ * @param userId
212
+ * user that suspends the task.
213
+ * @throws FlowableObjectNotFoundException
214
+ * when the task doesn't exist.
215
+ */
216
+ suspendTask(taskId, userId) {
217
+ this.taskService.suspendTask(taskId, userId);
218
+ }
219
+ /**
220
+ * Activates the task. No check is done whether the user is known by the identity component.
221
+ *
222
+ * @param taskId
223
+ * task to activate, cannot be null.
224
+ * @param userId
225
+ * user that activates the task.
226
+ * @throws FlowableObjectNotFoundException
227
+ * when the task doesn't exist.
228
+ */
229
+ activateTask(taskId, userId) {
230
+ this.taskService.activateTask(taskId, userId);
231
+ }
232
+ /**
233
+ * Delegates the task to another user. This means that the assignee is set and the delegation state is set to {@link DelegationState#PENDING}. If no owner is set on the task, the owner is set to
234
+ * the current assignee of the task.
235
+ *
236
+ * @param taskId
237
+ * The id of the task that will be delegated.
238
+ * @param userId
239
+ * The id of the user that will be set as assignee.
240
+ * @throws FlowableObjectNotFoundException
241
+ * when no task exists with the given id.
242
+ */
243
+ delegateTask(taskId, userId) {
244
+ this.taskService.delegateTask(taskId, userId);
245
+ }
246
+ /**
247
+ * Marks that the assignee is done with this task and that it can be send back to the owner. Can only be called when this task is {@link DelegationState#PENDING} delegation. After this method
248
+ * returns, the {@link Task#getDelegationState() delegationState} is set to {@link DelegationState#RESOLVED}.
249
+ *
250
+ * @param taskId
251
+ * the id of the task to resolve, cannot be null.
252
+ * @param variables
253
+ * @param transientVariables
254
+ * @throws FlowableObjectNotFoundException
255
+ * when no task exists with the given id.
256
+ */
257
+ resolveTask(taskId, variables, transientVariables) {
258
+ if (this.isNotNull(variables) && this.isNotNull(transientVariables)) {
259
+ this.taskService.resolveTask(taskId, variables, transientVariables);
260
+ } else if (this.isNotNull(variables)) {
261
+ this.taskService.resolveTask(taskId, variables);
262
+ } else {
263
+ this.taskService.resolveTask(taskId);
264
+ }
265
+ }
266
+ /**
267
+ * Called when the task is successfully executed.
268
+ *
269
+ * @param taskId
270
+ * the id of the task to complete, cannot be null.
271
+ * @param userId
272
+ * user that completes the task.
273
+ * @param variables
274
+ * task parameters. May be null or empty.
275
+ * @param transientVariables
276
+ * task parameters. May be null or empty.
277
+ * @param localScope
278
+ * If true, the provided variables will be stored task-local, instead of process instance wide (which is the default behaviour).
279
+ * @throws FlowableObjectNotFoundException
280
+ * when no task exists with the given id.
281
+ * @throws FlowableException
282
+ * when this task is {@link DelegationState#PENDING} delegation.
283
+ */
284
+ complete(taskId, userId, variables, transientVariables, localScope) {
285
+ if (this.isNotNull(userId) && this.isNotNull(variables) && this.isNotNull(localScope)) {
286
+ this.taskService.complete(taskId, userId, variables, localScope);
287
+ } else if (this.isNotNull(variables) && this.isNotNull(localScope)) {
288
+ this.taskService.complete(taskId, variables, localScope);
289
+ } else if (this.isNotNull(userId) && this.isNotNull(variables) && this.isNotNull(transientVariables)) {
290
+ this.taskService.complete(taskId, userId, variables, transientVariables);
291
+ } else if (this.isNotNull(variables) && this.isNotNull(transientVariables)) {
292
+ this.taskService.complete(taskId, variables, transientVariables);
293
+ } else if (this.isNotNull(userId) && this.isNotNull(variables)) {
294
+ this.taskService.complete(taskId, userId, variables);
295
+ } else if (this.isNotNull(variables)) {
296
+ this.taskService.complete(taskId, variables);
297
+ } else if (this.isNotNull(userId)) {
298
+ this.taskService.complete(taskId, userId);
299
+ } else {
300
+ this.taskService.complete(taskId);
301
+ }
302
+ }
303
+ /**
304
+ * Called when the task is successfully executed, and the task form has been submitted.
305
+ *
306
+ * @param taskId
307
+ * the id of the task to complete, cannot be null.
308
+ * @param formDefinitionId
309
+ * the id of the form definition that is filled-in to complete the task, cannot be null.
310
+ * @param outcome
311
+ * the outcome of the completed form, can be null.
312
+ * @param variables
313
+ * values of the completed form. May be null or empty.
314
+ * @param userId
315
+ * user that completes the task.
316
+ * @param transientVariables
317
+ * additional transient values that need to added to the process instance transient variables. May be null or empty.
318
+ * @param localScope
319
+ * If true, the provided variables will be stored task-local, instead of process instance wide (which is the default for {@link #complete(String, Map)}).
320
+ * @throws FlowableObjectNotFoundException
321
+ * when no task exists with the given id.
322
+ */
323
+ completeTaskWithForm(taskId, formDefinitionId, outcome, variables, userId, transientVariables, localScope) {
324
+ if (this.isNotNull(userId) && this.isNotNull(localScope)) {
325
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables, localScope);
326
+ } else if (this.isNotNull(localScope)) {
327
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables, localScope);
328
+ } else if (this.isNotNull(userId) && this.isNotNull(transientVariables)) {
329
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables, transientVariables);
330
+ } else if (this.isNotNull(transientVariables)) {
331
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables, transientVariables);
332
+ } else if (this.isNotNull(userId)) {
333
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables);
334
+ } else {
335
+ this.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables);
336
+ }
337
+ }
338
+ /**
339
+ * Gets a Form model instance of the task form of a specific task
340
+ *
341
+ * @param taskId
342
+ * id of the task, cannot be null.
343
+ * @param ignoreVariables
344
+ * should the variables be ignored when fetching the form model?
345
+ * @throws FlowableObjectNotFoundException
346
+ * when the task or form definition doesn't exist.
347
+ */
348
+ getTaskFormModel(taskId, ignoreVariables) {
349
+ if (this.isNotNull(ignoreVariables)) {
350
+ return this.taskService.getTaskFormModel(taskId, ignoreVariables);
351
+ } else {
352
+ return this.taskService.getTaskFormModel(taskId);
353
+ }
354
+ }
355
+ /**
356
+ * Changes the assignee of the given task to the given userId. No check is done whether the user is known by the identity component.
357
+ *
358
+ * @param taskId
359
+ * id of the task, cannot be null.
360
+ * @param userId
361
+ * id of the user to use as assignee.
362
+ * @throws FlowableObjectNotFoundException
363
+ * when the task or user doesn't exist.
364
+ */
365
+ setAssignee(taskId, userId) {
366
+ this.taskService.setAssignee(taskId, userId);
367
+ }
368
+ /**
369
+ * Transfers ownership of this task to another user. No check is done whether the user is known by the identity component.
370
+ *
371
+ * @param taskId
372
+ * id of the task, cannot be null.
373
+ * @param userId
374
+ * of the person that is receiving ownership.
375
+ * @throws FlowableObjectNotFoundException
376
+ * when the task or user doesn't exist.
377
+ */
378
+ setOwner(taskId, userId) {
379
+ this.taskService.setOwner(taskId, userId);
380
+ }
381
+ /**
382
+ * Retrieves the {@link IdentityLink}s associated with the given task. Such an {@link IdentityLink} informs how a certain identity (eg. group or user) is associated with a certain task (eg. as
383
+ * candidate, assignee, etc.)
384
+ */
385
+ getIdentityLinksForTask(taskId) {
386
+ return this.taskService.getIdentityLinksForTask(taskId);
387
+ }
388
+ /**
389
+ * Convenience shorthand for {@link #addUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
390
+ *
391
+ * @param taskId
392
+ * id of the task, cannot be null.
393
+ * @param userId
394
+ * id of the user to use as candidate, cannot be null.
395
+ * @throws FlowableObjectNotFoundException
396
+ * when the task or user doesn't exist.
397
+ */
398
+ addCandidateUser(taskId, userId) {
399
+ this.taskService.addCandidateUser(taskId, userId);
400
+ }
401
+ /**
402
+ * Convenience shorthand for {@link #addGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
403
+ *
404
+ * @param taskId
405
+ * id of the task, cannot be null.
406
+ * @param groupId
407
+ * id of the group to use as candidate, cannot be null.
408
+ * @throws FlowableObjectNotFoundException
409
+ * when the task or group doesn't exist.
410
+ */
411
+ addCandidateGroup(taskId, groupId) {
412
+ this.taskService.addCandidateGroup(taskId, groupId);
413
+ }
414
+ /**
415
+ * Involves a user with a task. The type of identity link is defined by the given identityLinkType.
416
+ *
417
+ * @param taskId
418
+ * id of the task, cannot be null.
419
+ * @param userId
420
+ * id of the user involve, cannot be null.
421
+ * @param identityLinkType
422
+ * type of identityLink, cannot be null (@see {@link IdentityLinkType}).
423
+ * @throws FlowableObjectNotFoundException
424
+ * when the task or user doesn't exist.
425
+ */
426
+ addUserIdentityLink(taskId, userId, identityLinkType) {
427
+ this.taskService.addUserIdentityLink(taskId, userId, identityLinkType);
428
+ }
429
+ /**
430
+ * Involves a group with a task. The type of identityLink is defined by the given identityLink.
431
+ *
432
+ * @param taskId
433
+ * id of the task, cannot be null.
434
+ * @param groupId
435
+ * id of the group to involve, cannot be null.
436
+ * @param identityLinkType
437
+ * type of identity, cannot be null (@see {@link IdentityLinkType}).
438
+ * @throws FlowableObjectNotFoundException
439
+ * when the task or group doesn't exist.
440
+ */
441
+ addGroupIdentityLink(taskId, groupId, identityLinkType) {
442
+ this.taskService.addGroupIdentityLink(taskId, groupId, identityLinkType);
443
+ }
444
+ /**
445
+ * Convenience shorthand for {@link #deleteUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
446
+ *
447
+ * @param taskId
448
+ * id of the task, cannot be null.
449
+ * @param userId
450
+ * id of the user to use as candidate, cannot be null.
451
+ * @throws FlowableObjectNotFoundException
452
+ * when the task or user doesn't exist.
453
+ */
454
+ deleteCandidateUser(taskId, userId) {
455
+ this.taskService.deleteCandidateUser(taskId, userId);
456
+ }
457
+ /**
458
+ * Convenience shorthand for {@link #deleteGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
459
+ *
460
+ * @param taskId
461
+ * id of the task, cannot be null.
462
+ * @param groupId
463
+ * id of the group to use as candidate, cannot be null.
464
+ * @throws FlowableObjectNotFoundException
465
+ * when the task or group doesn't exist.
466
+ */
467
+ deleteCandidateGroup(taskId, groupId) {
468
+ this.taskService.deleteCandidateGroup(taskId, groupId);
469
+ }
470
+ /**
471
+ * Removes the association between a user and a task for the given identityLinkType.
472
+ *
473
+ * @param taskId
474
+ * id of the task, cannot be null.
475
+ * @param userId
476
+ * id of the user involve, cannot be null.
477
+ * @param identityLinkType
478
+ * type of identityLink, cannot be null (@see {@link IdentityLinkType}).
479
+ * @throws FlowableObjectNotFoundException
480
+ * when the task or user doesn't exist.
481
+ */
482
+ deleteUserIdentityLink(taskId, userId, identityLinkType) {
483
+ this.taskService.deleteUserIdentityLink(taskId, userId, identityLinkType);
484
+ }
485
+ /**
486
+ * Removes the association between a group and a task for the given identityLinkType.
487
+ *
488
+ * @param taskId
489
+ * id of the task, cannot be null.
490
+ * @param groupId
491
+ * id of the group to involve, cannot be null.
492
+ * @param identityLinkType
493
+ * type of identity, cannot be null (@see {@link IdentityLinkType}).
494
+ * @throws FlowableObjectNotFoundException
495
+ * when the task or group doesn't exist.
496
+ */
497
+ deleteGroupIdentityLink(taskId, groupId, identityLinkType) {
498
+ this.taskService.deleteGroupIdentityLink(taskId, groupId, identityLinkType);
499
+ }
500
+ /**
501
+ * Changes the priority of the task.
502
+ *
503
+ * Authorization: actual owner / business admin
504
+ *
505
+ * @param taskId
506
+ * id of the task, cannot be null.
507
+ * @param priority
508
+ * the new priority for the task.
509
+ * @throws FlowableObjectNotFoundException
510
+ * when the task doesn't exist.
511
+ */
512
+ setPriority(taskId, priority) {
513
+ this.taskService.setPriority(taskId, priority);
514
+ }
515
+ /**
516
+ * Changes the due date of the task
517
+ *
518
+ * @param taskId
519
+ * id of the task, cannot be null.
520
+ * @param dueDate
521
+ * the new due date for the task
522
+ * @throws FlowableException
523
+ * when the task doesn't exist.
524
+ */
525
+ setDueDate(taskId, dueDate) {
526
+ this.taskService.setDueDate(taskId, dueDate);
527
+ }
528
+ /**
529
+ * set variable on a task. If the variable is not already existing, it will be created in the most outer scope. This means the process instance in case this task is related to an execution.
530
+ */
531
+ setVariable(taskId, variableName, value) {
532
+ this.taskService.setVariable(taskId, variableName, import_values.Values.stringifyValue(value));
533
+ }
534
+ /**
535
+ * set variables on a task. If the variable is not already existing, it will be created in the most outer scope. This means the process instance in case this task is related to an execution.
536
+ */
537
+ setVariables(taskId, variables) {
538
+ this.taskService.setVariables(taskId, import_values.Values.stringifyValuesMap(variables));
539
+ }
540
+ /**
541
+ * set variable on a task. If the variable is not already existing, it will be created in the task.
542
+ */
543
+ setVariableLocal(taskId, variableName, value) {
544
+ this.taskService.setVariableLocal(taskId, variableName, import_values.Values.stringifyValue(value));
545
+ }
546
+ /**
547
+ * set variables on a task. If the variable is not already existing, it will be created in the task.
548
+ */
549
+ setVariablesLocal(taskId, variables) {
550
+ this.taskService.setVariablesLocal(taskId, import_values.Values.stringifyValuesMap(variables));
551
+ }
552
+ /**
553
+ * get a variables and search in the task scope and if available also the execution scopes.
554
+ */
555
+ getVariable(taskId, variableName) {
556
+ return import_values.Values.parseValue(this.taskService.getVariable(taskId, variableName));
557
+ }
558
+ /**
559
+ * The variable. Searching for the variable is done in all scopes that are visible to the given task (including parent scopes). Returns null when no variable value is found with the given name.
560
+ *
561
+ * @param taskId
562
+ * id of task, cannot be null.
563
+ * @param variableName
564
+ * name of variable, cannot be null.
565
+ * @return the variable or null if the variable is undefined.
566
+ * @throws FlowableObjectNotFoundException
567
+ * when no execution is found for the given taskId.
568
+ */
569
+ getVariableInstance(taskId, variableName) {
570
+ return this.taskService.getVariableInstance(taskId, variableName);
571
+ }
572
+ /**
573
+ * checks whether or not the task has a variable defined with the given name, in the task scope and if available also the execution scopes.
574
+ */
575
+ hasVariable(taskId, variableName) {
576
+ return this.taskService.hasVariable(taskId, variableName);
577
+ }
578
+ /**
579
+ * checks whether or not the task has a variable defined with the given name.
580
+ */
581
+ getVariableLocal(taskId, variableName) {
582
+ return import_values.Values.parseValue(this.taskService.getVariableLocal(taskId, variableName));
583
+ }
584
+ /**
585
+ * The variable for a task. Returns the variable when it is set for the task (and not searching parent scopes). Returns null when no variable is found with the given name.
586
+ *
587
+ * @param taskId
588
+ * id of task, cannot be null.
589
+ * @param variableName
590
+ * name of variable, cannot be null.
591
+ * @return the variable or null if the variable is undefined.
592
+ * @throws FlowableObjectNotFoundException
593
+ * when no task is found for the given taskId.
594
+ */
595
+ getVariableInstanceLocal(taskId, variableName) {
596
+ return this.taskService.getVariableInstanceLocal(taskId, variableName);
597
+ }
598
+ /**
599
+ * checks whether or not the task has a variable defined with the given name, local task scope only.
600
+ */
601
+ hasVariableLocal(taskId, variableName) {
602
+ return this.taskService.hasVariableLocal(taskId, variableName);
603
+ }
604
+ /**
605
+ * get all variables and search in the task scope and if available also the execution scopes. If you have many variables and you only need a few, consider using
606
+ * {@link #getVariables(String, Collection)} for better performance.
607
+ */
608
+ getVariables(taskId, variableNames) {
609
+ if (this.isNotNull(variableNames)) {
610
+ return import_values.Values.parseValuesMap(this.taskService.getVariables(taskId, variableNames));
611
+ } else {
612
+ return import_values.Values.parseValuesMap(this.taskService.getVariables(taskId));
613
+ }
614
+ }
615
+ /**
616
+ * All variables visible from the given task scope (including parent scopes).
617
+ *
618
+ * @param taskId
619
+ * id of task, cannot be null.
620
+ * @param variableNames
621
+ * the collection of variable names that should be retrieved.
622
+ * @return the variable instances or an empty map if no such variables are found.
623
+ * @throws FlowableObjectNotFoundException
624
+ * when no task is found for the given taskId.
625
+ */
626
+ getVariableInstances(taskId, variableNames) {
627
+ if (this.isNotNull(variableNames)) {
628
+ return this.taskService.getVariableInstances(taskId, variableNames);
629
+ } else {
630
+ return this.taskService.getVariableInstances(taskId);
631
+ }
632
+ }
633
+ /**
634
+ * get all variables and search only in the task scope. If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} for better
635
+ * performance.
636
+ */
637
+ getVariablesLocal(taskId, variableNames) {
638
+ if (this.isNotNull(variableNames)) {
639
+ return import_values.Values.parseValuesMap(this.taskService.getVariablesLocal(taskId, variableNames));
640
+ } else {
641
+ return import_values.Values.parseValuesMap(this.taskService.getVariablesLocal(taskId));
642
+ }
643
+ }
644
+ /** get all variables and search only in the task scope. */
645
+ getVariableInstancesLocalByTaskIds(taskIds) {
646
+ return this.taskService.getVariableInstancesLocalByTaskIds(taskIds);
647
+ }
648
+ /**
649
+ * All variable values that are defined in the task scope, without taking outer scopes into account. If you have many task local variables and you only need a few, consider using
650
+ * {@link #getVariableInstancesLocal(String, Collection)} for better performance.
651
+ *
652
+ * @param taskId
653
+ * id of task, cannot be null.
654
+ * @return the variables or an empty map if no such variables are found.
655
+ * @throws FlowableObjectNotFoundException
656
+ * when no task is found for the given taskId.
657
+ */
658
+ getVariableInstancesLocal(taskId, variableNames) {
659
+ if (this.isNotNull(variableNames)) {
660
+ return this.taskService.getVariableInstancesLocal(taskId, variableNames);
661
+ } else {
662
+ return this.taskService.getVariableInstancesLocal(taskId);
663
+ }
664
+ }
665
+ /**
666
+ * Removes the variable from the task. When the variable does not exist, nothing happens.
667
+ */
668
+ removeVariable(taskId, variableName) {
669
+ this.taskService.removeVariable(taskId, variableName);
670
+ }
671
+ /**
672
+ * Removes the variable from the task (not considering parent scopes). When the variable does not exist, nothing happens.
673
+ */
674
+ removeVariableLocal(taskId, variableName) {
675
+ this.taskService.removeVariableLocal(taskId, variableName);
676
+ }
677
+ /**
678
+ * Removes all variables in the given collection from the task. Non existing variable names are simply ignored.
679
+ */
680
+ removeVariables(taskId, variableNames) {
681
+ this.taskService.removeVariables(taskId, variableNames);
682
+ }
683
+ /**
684
+ * Removes all variables in the given collection from the task (not considering parent scopes). Non existing variable names are simply ignored.
685
+ */
686
+ removeVariablesLocal(taskId, variableNames) {
687
+ this.taskService.removeVariablesLocal(taskId, variableNames);
688
+ }
689
+ /**
690
+ * All DataObjects visible from the given execution scope (including parent scopes).
691
+ *
692
+ * @param taskId
693
+ * id of task, cannot be null.
694
+ * @param dataObjectNames
695
+ * the collection of DataObject names that should be retrieved.
696
+ * @param locale
697
+ * locale the DataObject name and description should be returned in (if available).
698
+ * @param withLocalizationFallback
699
+ * When true localization will fallback to more general locales if the specified locale is not found.
700
+ * @return the DataObjects or an empty map if no such variables are found.
701
+ * @throws FlowableObjectNotFoundException
702
+ * when no task is found for the given taskId.
703
+ */
704
+ getDataObjects(taskId, dataObjectNames, locale, withLocalizationFallback) {
705
+ if (this.isNotNull(dataObjectNames) && this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {
706
+ return this.taskService.getDataObjects(taskId, dataObjectNames, locale, withLocalizationFallback);
707
+ } else if (this.isNotNull(dataObjectNames)) {
708
+ return this.taskService.getDataObjects(taskId, dataObjectNames);
709
+ } else if (this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {
710
+ return this.taskService.getDataObjects(taskId, locale, withLocalizationFallback);
711
+ } else {
712
+ return this.taskService.getDataObjects(taskId);
713
+ }
714
+ }
715
+ /**
716
+ * The DataObject. Searching for the DataObject is done in all scopes that are visible to the given task (including parent scopes). Returns null when no DataObject value is found with the given
717
+ * name.
718
+ *
719
+ * @param taskId
720
+ * id of task, cannot be null.
721
+ * @param dataObject
722
+ * name of DataObject, cannot be null.
723
+ * @param locale
724
+ * locale the DataObject name and description should be returned in (if available).
725
+ * @param withLocalizationFallback
726
+ * When true localization will fallback to more general locales including the default locale of the JVM if the specified locale is not found.
727
+ * @return the DataObject or null if the variable is undefined.
728
+ * @throws FlowableObjectNotFoundException
729
+ * when no task is found for the given taskId.
730
+ */
731
+ getDataObject(taskId, dataObject, locale, withLocalizationFallback) {
732
+ if (this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {
733
+ return this.taskService.getDataObject(taskId, dataObject, locale, withLocalizationFallback);
734
+ } else {
735
+ return this.taskService.getDataObject(taskId, dataObject);
736
+ }
737
+ }
738
+ /** Add a comment to a task and/or process instance. */
739
+ addComment(taskId, processInstanceId, message, type) {
740
+ if (this.isNotNull(type)) {
741
+ return this.taskService.addComment(taskId, processInstanceId, type, message);
742
+ } else {
743
+ return this.taskService.addComment(taskId, processInstanceId, message);
744
+ }
745
+ }
746
+ /** Update a comment to a task and/or process instance. */
747
+ saveComment(comment) {
748
+ this.taskService.saveComment(comment);
749
+ }
750
+ /**
751
+ * Returns an individual comment with the given id. Returns null if no comment exists with the given id.
752
+ */
753
+ getComment(commentId) {
754
+ return this.taskService.getComment(commentId);
755
+ }
756
+ /** Removes all comments from the provided task and/or process instance */
757
+ deleteComments(taskId, processInstanceId) {
758
+ this.taskService.deleteComments(taskId, processInstanceId);
759
+ }
760
+ /**
761
+ * Removes an individual comment with the given id.
762
+ *
763
+ * @throws FlowableObjectNotFoundException
764
+ * when no comment exists with the given id.
765
+ */
766
+ deleteComment(commentId) {
767
+ this.taskService.deleteComment(commentId);
768
+ }
769
+ /** The comments related to the given task. */
770
+ getTaskComments(taskId, type) {
771
+ if (this.isNotNull(type)) {
772
+ return this.taskService.getTaskComments(taskId, type);
773
+ } else {
774
+ return this.taskService.getTaskComments(taskId);
775
+ }
776
+ }
777
+ /** All comments of a given type. */
778
+ getCommentsByType(type) {
779
+ return this.taskService.getCommentsByType(type);
780
+ }
781
+ /** The all events related to the given task. */
782
+ getTaskEvents(taskId) {
783
+ return this.taskService.getTaskEvents(taskId);
784
+ }
785
+ /**
786
+ * Returns an individual event with the given id. Returns null if no event exists with the given id.
787
+ */
788
+ getEvent(eventId) {
789
+ return this.taskService.getEvent(eventId);
790
+ }
791
+ /** The comments related to the given process instance. */
792
+ getProcessInstanceComments(processInstanceId, type) {
793
+ if (this.isNotNull(type)) {
794
+ return this.taskService.getProcessInstanceComments(processInstanceId, type);
795
+ } else {
796
+ return this.taskService.getProcessInstanceComments(processInstanceId);
797
+ }
798
+ }
799
+ /**
800
+ * Add a new attachment to a task and/or a process instance and use an input stream to provide the content
801
+ */
802
+ createAttachment(attachmentType, taskId, processInstanceId, attachmentName, attachmentDescription, content, url) {
803
+ if (this.isNotNull(url)) {
804
+ return this.taskService.createAttachment(attachmentType, taskId, processInstanceId, attachmentName, attachmentDescription, url);
805
+ } else {
806
+ return this.taskService.createAttachment(attachmentType, taskId, processInstanceId, attachmentName, attachmentDescription, import_io.Streams.createByteArrayInputStream(content));
807
+ }
808
+ }
809
+ /** Update the name and description of an attachment */
810
+ saveAttachment(attachment) {
811
+ this.taskService.saveAttachment(attachment);
812
+ }
813
+ /** Retrieve a particular attachment */
814
+ getAttachment(attachmentId) {
815
+ return this.taskService.getAttachment(attachmentId);
816
+ }
817
+ /** Retrieve stream content of a particular attachment */
818
+ getAttachmentContent(attachmentId) {
819
+ const content = this.taskService.getAttachmentContent(attachmentId);
820
+ const baos = import_io.Streams.createByteArrayOutputStream();
821
+ import_io.Streams.copyLarge(content, baos);
822
+ return baos.getBytes();
823
+ }
824
+ /** The list of attachments associated to a task */
825
+ getTaskAttachments(taskId) {
826
+ return this.taskService.getTaskAttachments(taskId);
827
+ }
828
+ /** The list of attachments associated to a process instance */
829
+ getProcessInstanceAttachments(processInstanceId) {
830
+ return this.taskService.getProcessInstanceAttachments(processInstanceId);
831
+ }
832
+ /** Delete an attachment */
833
+ deleteAttachment(attachmentId) {
834
+ this.taskService.deleteAttachment(attachmentId);
835
+ }
836
+ /** The list of subtasks for this parent task */
837
+ getSubTasks(parentTaskId) {
838
+ return this.taskService.getSubTasks(parentTaskId);
839
+ }
840
+ isNotNull(property) {
841
+ return property !== null && property !== void 0;
842
+ }
843
+ }
844
+ class TaskData {
845
+ constructor(data) {
846
+ this.data = data;
847
+ }
848
+ getId() {
849
+ return this.data.id ?? void 0;
850
+ }
851
+ getRevision() {
852
+ return this.data.revision;
853
+ }
854
+ getOwner() {
855
+ return this.data.owner ?? void 0;
856
+ }
857
+ getAssigneeUpdatedCount() {
858
+ return this.data.assigneeUpdatedCount;
859
+ }
860
+ getOriginalAssignee() {
861
+ return this.data.originalAssignee ?? void 0;
862
+ }
863
+ getAssignee() {
864
+ return this.data.assignee ?? void 0;
865
+ }
866
+ getDelegationState() {
867
+ return this.data.delegationState ?? void 0;
868
+ }
869
+ getParentTaskId() {
870
+ return this.data.parentTaskId ?? void 0;
871
+ }
872
+ getName() {
873
+ return this.data.name ?? void 0;
874
+ }
875
+ getLocalizedName() {
876
+ return this.data.localizedName ?? void 0;
877
+ }
878
+ getDescription() {
879
+ return this.data.description ?? void 0;
880
+ }
881
+ getLocalizedDescription() {
882
+ return this.data.localizedDescription ?? void 0;
883
+ }
884
+ getPriority() {
885
+ return this.data.priority;
886
+ }
887
+ getCreateTime() {
888
+ return this.data.createTime ?? void 0;
889
+ }
890
+ getDueDate() {
891
+ return this.data.dueDate ?? void 0;
892
+ }
893
+ getSuspensionState() {
894
+ return this.data.suspensionState ?? void 0;
895
+ }
896
+ getCategory() {
897
+ return this.data.category ?? void 0;
898
+ }
899
+ isIdentityLinksInitialized() {
900
+ return this.data.isIdentityLinksInitialized;
901
+ }
902
+ getExecutionId() {
903
+ return this.data.executionId ?? void 0;
904
+ }
905
+ getProcessInstanceId() {
906
+ return this.data.processInstanceId ?? void 0;
907
+ }
908
+ getProcessDefinitionId() {
909
+ return this.data.processDefinitionId ?? void 0;
910
+ }
911
+ getScopeId() {
912
+ return this.data.scopeId ?? void 0;
913
+ }
914
+ getSubScopeId() {
915
+ return this.data.subScopeId ?? void 0;
916
+ }
917
+ getScopeType() {
918
+ return this.data.scopeType ?? void 0;
919
+ }
920
+ getScopeDefinitionId() {
921
+ return this.data.scopeDefinitionId ?? void 0;
922
+ }
923
+ getTaskDefinitionKey() {
924
+ return this.data.taskDefinitionKey ?? void 0;
925
+ }
926
+ getFormKey() {
927
+ return this.data.formKey ?? void 0;
928
+ }
929
+ isDeleted() {
930
+ return this.data.isDeleted;
931
+ }
932
+ isCanceled() {
933
+ return this.data.isCanceled;
934
+ }
935
+ isCountEnabled() {
936
+ return this.data.isCountEnabled;
937
+ }
938
+ getVariableCount() {
939
+ return this.data.variableCount;
940
+ }
941
+ getIdentityLinkCount() {
942
+ return this.data.identityLinkCount;
943
+ }
944
+ getClaimTime() {
945
+ return this.data.claimTime ?? void 0;
946
+ }
947
+ getTenantId() {
948
+ return this.data.tenantId;
949
+ }
950
+ getEventName() {
951
+ return this.data.eventName ?? void 0;
952
+ }
953
+ getEventHandlerId() {
954
+ return this.data.eventHandlerId ?? void 0;
955
+ }
956
+ isForcedUpdate() {
957
+ return this.data.forcedUpdate;
958
+ }
959
+ }
960
+ var DelegationState = /* @__PURE__ */ ((DelegationState2) => {
961
+ DelegationState2[DelegationState2["PENDING"] = 0] = "PENDING";
962
+ DelegationState2[DelegationState2["RESOLVED"] = 1] = "RESOLVED";
963
+ return DelegationState2;
964
+ })(DelegationState || {});
965
+ var NullHandlingOnOrder = /* @__PURE__ */ ((NullHandlingOnOrder2) => {
966
+ NullHandlingOnOrder2[NullHandlingOnOrder2["NULLS_FIRST"] = 0] = "NULLS_FIRST";
967
+ NullHandlingOnOrder2[NullHandlingOnOrder2["NULLS_LAST"] = 1] = "NULLS_LAST";
968
+ return NullHandlingOnOrder2;
969
+ })(NullHandlingOnOrder || {});
970
+ if (typeof module !== "undefined") {
971
+ module.exports = Tasks;
972
+ }
973
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bpm/tasks.ts"],
  "sourcesContent": ["/**\n * API Tasks\n */\n\nimport { Streams } from \"@aerokit/sdk/io\";\nimport { Values } from \"@aerokit/sdk/bpm/values\";\n\nconst BpmFacade = Java.type(\"org.eclipse.dirigible.components.api.bpm.BpmFacade\");\n\nexport class Tasks {\n\n\tpublic static list(): TaskData[] {\n\t\tconst tasks: any[] = JSON.parse(BpmFacade.getTasks());\n\t\treturn tasks.map(e => new TaskData(e));\n\t}\n\n\tpublic static getVariable(taskId: string, variableName: string): any {\n\t\treturn Values.parseValue(BpmFacade.getTaskVariable(taskId, variableName));\n\t}\n\n\t/**\n\t * Returns all variables. This will include all variables of parent scopes too.\n\t */\n\tpublic static getVariables(taskId: string): Map<string, any> {\n\t\treturn Values.parseValuesMap(BpmFacade.getTaskVariables(taskId));\n\t}\n\n\tpublic static setVariable(taskId: string, variableName: string, value: any): void {\n\t\tBpmFacade.setTaskVariable(taskId, variableName, Values.stringifyValue(value));\n\t}\n\n\tpublic static setVariables(taskId: string, variables: Map<string, any>): void {\n\t\tBpmFacade.setTaskVariables(taskId, Values.stringifyValuesMap(variables));\n\t}\n\n\tpublic static complete(taskId: string, variables: { [key: string]: any } = {}): void {\n\t\tBpmFacade.completeTask(taskId, JSON.stringify(variables));\n\t}\n\n\tpublic static getTaskService(): TaskService {\n\t\treturn new TaskService(BpmFacade.getBpmProviderFlowable().getTaskService());\n\t}\n}\n\n/**\n * Service which provides access to {@link Task} and form related operations.\n *\n */\nexport class TaskService {\n\n\tprivate readonly taskService: any;\n\n\tconstructor(taskService: any) {\n\t\tthis.taskService = taskService;\n\t}\n\t/**\n\t * Creates a new task that is not related to any process instance.\n\t * \n\t * The returned task is transient and must be saved with {@link #saveTask(Task)} 'manually'.\n\t */\n\tpublic newTask(taskId?: string): Task {\n\t\tif (this.isNotNull(taskId)) {\n\t\t\treturn this.taskService.newTask(taskId);\n\t\t}\n\t\treturn this.taskService.newTask();\n\t}\n\n\t/**\n\t * Create a builder for the task\n\t * \n\t * @return task builder\n\t */\n\tpublic createTaskBuilder(): TaskBuilder {\n\t\treturn this.taskService.createTaskBuilder();\n\t}\n\n\t/**\n\t * Saves the given task to the persistent data store. If the task is already present in the persistent store, it is updated. After a new task has been saved, the task instance passed into this\n\t * method is updated with the id of the newly created task.\n\t * \n\t * @param task\n\t *            the task, cannot be null.\n\t */\n\tpublic saveTask(task: Task): void {\n\t\tthis.taskService.saveTask(task);\n\t}\n\n\t/**\n\t * Saves the given tasks to the persistent data store. If the tasks are already present in the persistent store, it is updated. After a new task has been saved, the task instance passed into this\n\t * method is updated with the id of the newly created task.\n\t *\n\t * @param taskList the list of task instances, cannot be null.\n\t */\n\tpublic bulkSaveTasks(taskList: Task[]): void {\n\t\tthis.taskService.bulkSaveTasks(taskList);\n\t}\n\n\t/**\n\t * Deletes the given task, not deleting historic information that is related to this task.\n\t * \n\t * @param taskId\n\t *            The id of the task that will be deleted, cannot be null. If no task exists with the given taskId, the operation is ignored.\n\t * @param cascade\n\t *            If cascade is true, also the historic information related to this task is deleted.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task with given id does not exist.\n\t * @throws FlowableException\n\t *             when an error occurs while deleting the task or in case the task is part of a running process.\n\t */\n\tpublic deleteTask(taskId: string, cascade?: boolean): void {\n\t\tif (this.isNotNull(cascade)) {\n\t\t\tthis.taskService.deleteTask(taskId, cascade);\n\t\t} else {\n\t\t\tthis.taskService.deleteTask(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * Deletes all tasks of the given collection, not deleting historic information that is related to these tasks.\n\t * \n\t * @param taskIds\n\t *            The id's of the tasks that will be deleted, cannot be null. All id's in the list that don't have an existing task will be ignored.\n\t * @param cascade\n\t *            If cascade is true, also the historic information related to this task is deleted.\n\t * @throws FlowableObjectNotFoundException\n\t *             when one of the task does not exist.\n\t * @throws FlowableException\n\t *             when an error occurs while deleting the tasks or in case one of the tasks is part of a running process.\n\t */\n\tpublic deleteTasks(taskIds: string[], cascade?: boolean): void {\n\t\tif (this.isNotNull(cascade)) {\n\t\t\tthis.taskService.deleteTasks(taskIds, cascade);\n\t\t} else {\n\t\t\tthis.taskService.deleteTasks(taskIds);\n\t\t}\n\t}\n\n\t/**\n\t * Deletes the given task, not deleting historic information that is related to this task..\n\t * \n\t * @param taskId\n\t *            The id of the task that will be deleted, cannot be null. If no task exists with the given taskId, the operation is ignored.\n\t * @param deleteReason\n\t *            reason the task is deleted. Is recorded in history, if enabled.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task with given id does not exist.\n\t * @throws FlowableException\n\t *             when an error occurs while deleting the task or in case the task is part of a running process\n\t */\n\tpublic deleteTaskWithReason(taskId: string, deleteReason: string): void {\n\t\tthis.taskService.deleteTask(taskId, deleteReason)\n\t}\n\n\t/**\n\t * Deletes all tasks of the given collection, not deleting historic information that is related to these tasks.\n\t * \n\t * @param taskIds\n\t *            The id's of the tasks that will be deleted, cannot be null. All id's in the list that don't have an existing task will be ignored.\n\t * @param deleteReason\n\t *            reason the task is deleted. Is recorded in history, if enabled.\n\t * @throws FlowableObjectNotFoundException\n\t *             when one of the tasks does not exist.\n\t * @throws FlowableException\n\t *             when an error occurs while deleting the tasks or in case one of the tasks is part of a running process.\n\t */\n\tpublic deleteTasksWithReason(taskIds: string[], deleteReason: string): void {\n\t\tthis.taskService.deleteTasks(taskIds, deleteReason);\n\t}\n\n\t/**\n\t * Claim responsibility for a task: the given user is made assignee for the task. The difference with {@link #setAssignee(String, String)} is that here a check is done if the task already has a\n\t * user assigned to it. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            task to claim, cannot be null.\n\t * @param userId\n\t *            user that claims the task. When userId is null the task is unclaimed, assigned to no one.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t * @throws org.flowable.common.engine.api.FlowableTaskAlreadyClaimedException\n\t *             when the task is already claimed by another user\n\t */\n\tpublic claim(taskId: string, userId: string): void {\n\t\tthis.taskService.claim(taskId, userId);\n\t}\n\n\t/**\n\t * A shortcut to {@link #claim} with null user in order to unclaim the task\n\t * \n\t * @param taskId\n\t *            task to unclaim, cannot be null.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t */\n\tpublic unclaim(taskId: string): void {\n\t\tthis.taskService.unclaim(taskId);\n\t}\n\n\t/**\n\t * Set the task state to in progress. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            task to change the state, cannot be null.\n\t * @param userId\n\t *            user that puts the task in progress.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t */\n\tpublic startProgress(taskId: string, userId: string): void {\n\t\tthis.taskService.startProgress(taskId, userId);\n\t}\n\n\t/**\n\t * Suspends the task. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            task to suspend, cannot be null.\n\t * @param userId\n\t *            user that suspends the task.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t */\n\tpublic suspendTask(taskId: string, userId: string): void {\n\t\tthis.taskService.suspendTask(taskId, userId);\n\t}\n\n\t/**\n\t * Activates the task. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            task to activate, cannot be null.\n\t * @param userId\n\t *            user that activates the task.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t */\n\tpublic activateTask(taskId: string, userId: string): void {\n\t\tthis.taskService.activateTask(taskId, userId);\n\t}\n\n\t/**\n\t * Delegates the task to another user. This means that the assignee is set and the delegation state is set to {@link DelegationState#PENDING}. If no owner is set on the task, the owner is set to\n\t * the current assignee of the task.\n\t * \n\t * @param taskId\n\t *            The id of the task that will be delegated.\n\t * @param userId\n\t *            The id of the user that will be set as assignee.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task exists with the given id.\n\t */\n\tpublic delegateTask(taskId: string, userId: string): void {\n\t\tthis.taskService.delegateTask(taskId, userId);\n\t}\n\n\t/**\n\t * Marks that the assignee is done with this task and that it can be send back to the owner. Can only be called when this task is {@link DelegationState#PENDING} delegation. After this method\n\t * returns, the {@link Task#getDelegationState() delegationState} is set to {@link DelegationState#RESOLVED}.\n\t * \n\t * @param taskId\n\t *            the id of the task to resolve, cannot be null.\n\t * @param variables\n\t * @param transientVariables\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task exists with the given id.\n\t */\n\tpublic resolveTask(taskId: string, variables?: Map<string, any>, transientVariables?: Map<string, any>): void {\n\t\tif (this.isNotNull(variables) && this.isNotNull(transientVariables)) {\n\t\t\tthis.taskService.resolveTask(taskId, variables, transientVariables);\n\t\t} else if (this.isNotNull(variables)) {\n\t\t\tthis.taskService.resolveTask(taskId, variables);\n\t\t} else {\n\t\t\tthis.taskService.resolveTask(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * Called when the task is successfully executed.\n\t * \n\t * @param taskId\n\t *            the id of the task to complete, cannot be null.\n\t * @param userId\n\t *            user that completes the task.\n\t * @param variables\n\t *            task parameters. May be null or empty.\n\t * @param transientVariables\n\t *            task parameters. May be null or empty.\n\t * @param localScope\n\t *            If true, the provided variables will be stored task-local, instead of process instance wide (which is the default behaviour).\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task exists with the given id.\n\t * @throws FlowableException\n\t *             when this task is {@link DelegationState#PENDING} delegation.\n\t */\n\tpublic complete(taskId: string, userId?: string, variables?: Map<string, any>, transientVariables?: Map<string, any>, localScope?: boolean): void {\n\t\tif (this.isNotNull(userId) && this.isNotNull(variables) && this.isNotNull(localScope)) {\n\t\t\tthis.taskService.complete(taskId, userId, variables, localScope);\n\t\t} else if (this.isNotNull(variables) && this.isNotNull(localScope)) {\n\t\t\tthis.taskService.complete(taskId, variables, localScope);\n\t\t} else if (this.isNotNull(userId) && this.isNotNull(variables) && this.isNotNull(transientVariables)) {\n\t\t\tthis.taskService.complete(taskId, userId, variables, transientVariables);\n\t\t} else if (this.isNotNull(variables) && this.isNotNull(transientVariables)) {\n\t\t\tthis.taskService.complete(taskId, variables, transientVariables);\n\t\t} else if (this.isNotNull(userId) && this.isNotNull(variables)) {\n\t\t\tthis.taskService.complete(taskId, userId, variables);\n\t\t} else if (this.isNotNull(variables)) {\n\t\t\tthis.taskService.complete(taskId, variables);\n\t\t} else if (this.isNotNull(userId)) {\n\t\t\tthis.taskService.complete(taskId, userId);\n\t\t} else {\n\t\t\tthis.taskService.complete(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * Called when the task is successfully executed, and the task form has been submitted.\n\t * \n\t * @param taskId\n\t *            the id of the task to complete, cannot be null.\n\t * @param formDefinitionId\n\t *            the id of the form definition that is filled-in to complete the task, cannot be null.\n\t * @param outcome\n\t *            the outcome of the completed form, can be null.\n\t * @param variables\n\t *            values of the completed form. May be null or empty.\n\t * @param userId\n\t *            user that completes the task.\n\t * @param transientVariables\n\t *            additional transient values that need to added to the process instance transient variables. May be null or empty.\n\t * @param localScope\n\t *            If true, the provided variables will be stored task-local, instead of process instance wide (which is the default for {@link #complete(String, Map)}).\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task exists with the given id.\n\t */\n\tpublic completeTaskWithForm(taskId: string, formDefinitionId: string, outcome: string, variables: Map<String, any>, userId?: string, transientVariables?: Map<String, any>, localScope?: boolean): void {\n\t\tif (this.isNotNull(userId) && this.isNotNull(localScope)) {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables, localScope);\n\t\t} else if (this.isNotNull(localScope)) {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables, localScope);\n\t\t} else if (this.isNotNull(userId) && this.isNotNull(transientVariables)) {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables, transientVariables);\n\t\t} else if (this.isNotNull(transientVariables)) {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables, transientVariables);\n\t\t} else if (this.isNotNull(userId)) {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, userId, variables);\n\t\t} else {\n\t\t\tthis.taskService.completeTaskWithForm(taskId, formDefinitionId, outcome, variables);\n\t\t}\n\t}\n\t/**\n\t * Gets a Form model instance of the task form of a specific task\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param ignoreVariables\n\t *            should the variables be ignored when fetching the form model?\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or form definition doesn't exist.\n\t */\n\tpublic getTaskFormModel(taskId: string, ignoreVariables?: boolean): FormInfo {\n\t\tif (this.isNotNull(ignoreVariables)) {\n\t\t\treturn this.taskService.getTaskFormModel(taskId, ignoreVariables);\n\t\t} else {\n\t\t\treturn this.taskService.getTaskFormModel(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * Changes the assignee of the given task to the given userId. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            id of the user to use as assignee.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic setAssignee(taskId: string, userId: string): void {\n\t\tthis.taskService.setAssignee(taskId, userId);\n\t}\n\n\t/**\n\t * Transfers ownership of this task to another user. No check is done whether the user is known by the identity component.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            of the person that is receiving ownership.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic setOwner(taskId: string, userId: string): void {\n\t\tthis.taskService.setOwner(taskId, userId);\n\t}\n\n\t/**\n\t * Retrieves the {@link IdentityLink}s associated with the given task. Such an {@link IdentityLink} informs how a certain identity (eg. group or user) is associated with a certain task (eg. as\n\t * candidate, assignee, etc.)\n\t */\n\tpublic getIdentityLinksForTask(taskId: string): IdentityLink[] {\n\t\treturn this.taskService.getIdentityLinksForTask(taskId);\n\t}\n\n\t/**\n\t * Convenience shorthand for {@link #addUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            id of the user to use as candidate, cannot be null.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic addCandidateUser(taskId: string, userId: string): void {\n\t\tthis.taskService.addCandidateUser(taskId, userId);\n\t}\n\n\t/**\n\t * Convenience shorthand for {@link #addGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param groupId\n\t *            id of the group to use as candidate, cannot be null.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or group doesn't exist.\n\t */\n\tpublic addCandidateGroup(taskId: string, groupId: string): void {\n\t\tthis.taskService.addCandidateGroup(taskId, groupId);\n\t}\n\n\t/**\n\t * Involves a user with a task. The type of identity link is defined by the given identityLinkType.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            id of the user involve, cannot be null.\n\t * @param identityLinkType\n\t *            type of identityLink, cannot be null (@see {@link IdentityLinkType}).\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic addUserIdentityLink(taskId: string, userId: string, identityLinkType: string): void {\n\t\tthis.taskService.addUserIdentityLink(taskId, userId, identityLinkType);\n\t}\n\n\t/**\n\t * Involves a group with a task. The type of identityLink is defined by the given identityLink.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param groupId\n\t *            id of the group to involve, cannot be null.\n\t * @param identityLinkType\n\t *            type of identity, cannot be null (@see {@link IdentityLinkType}).\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or group doesn't exist.\n\t */\n\tpublic addGroupIdentityLink(taskId: string, groupId: string, identityLinkType: string): void {\n\t\tthis.taskService.addGroupIdentityLink(taskId, groupId, identityLinkType);\n\t}\n\n\t/**\n\t * Convenience shorthand for {@link #deleteUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            id of the user to use as candidate, cannot be null.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic deleteCandidateUser(taskId: string, userId: string): void {\n\t\tthis.taskService.deleteCandidateUser(taskId, userId);\n\t}\n\n\t/**\n\t * Convenience shorthand for {@link #deleteGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param groupId\n\t *            id of the group to use as candidate, cannot be null.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or group doesn't exist.\n\t */\n\tpublic deleteCandidateGroup(taskId: string, groupId: string): void {\n\t\tthis.taskService.deleteCandidateGroup(taskId, groupId);\n\t}\n\n\t/**\n\t * Removes the association between a user and a task for the given identityLinkType.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param userId\n\t *            id of the user involve, cannot be null.\n\t * @param identityLinkType\n\t *            type of identityLink, cannot be null (@see {@link IdentityLinkType}).\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or user doesn't exist.\n\t */\n\tpublic deleteUserIdentityLink(taskId: string, userId: string, identityLinkType: string): void {\n\t\tthis.taskService.deleteUserIdentityLink(taskId, userId, identityLinkType);\n\t}\n\n\t/**\n\t * Removes the association between a group and a task for the given identityLinkType.\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param groupId\n\t *            id of the group to involve, cannot be null.\n\t * @param identityLinkType\n\t *            type of identity, cannot be null (@see {@link IdentityLinkType}).\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task or group doesn't exist.\n\t */\n\tpublic deleteGroupIdentityLink(taskId: string, groupId: string, identityLinkType: string): void {\n\t\tthis.taskService.deleteGroupIdentityLink(taskId, groupId, identityLinkType);\n\t}\n\n\t/**\n\t * Changes the priority of the task.\n\t * \n\t * Authorization: actual owner / business admin\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param priority\n\t *            the new priority for the task.\n\t * @throws FlowableObjectNotFoundException\n\t *             when the task doesn't exist.\n\t */\n\tpublic setPriority(taskId: string, priority: number): void {\n\t\tthis.taskService.setPriority(taskId, priority);\n\t}\n\n\t/**\n\t * Changes the due date of the task\n\t * \n\t * @param taskId\n\t *            id of the task, cannot be null.\n\t * @param dueDate\n\t *            the new due date for the task\n\t * @throws FlowableException\n\t *             when the task doesn't exist.\n\t */\n\tpublic setDueDate(taskId: string, dueDate: Date): void {\n\t\tthis.taskService.setDueDate(taskId, dueDate);\n\t}\n\n\t/**\n\t * set variable on a task. If the variable is not already existing, it will be created in the most outer scope. This means the process instance in case this task is related to an execution.\n\t */\n\tpublic setVariable(taskId: string, variableName: string, value: any): void {\n\t\tthis.taskService.setVariable(taskId, variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * set variables on a task. If the variable is not already existing, it will be created in the most outer scope. This means the process instance in case this task is related to an execution.\n\t */\n\tpublic setVariables(taskId: string, variables: Map<string, any>): void {\n\t\tthis.taskService.setVariables(taskId, Values.stringifyValuesMap(variables));\n\t}\n\n\t/**\n\t * set variable on a task. If the variable is not already existing, it will be created in the task.\n\t */\n\tpublic setVariableLocal(taskId: string, variableName: string, value: any): void {\n\t\tthis.taskService.setVariableLocal(taskId, variableName, Values.stringifyValue(value));\n\t}\n\n\t/**\n\t * set variables on a task. If the variable is not already existing, it will be created in the task.\n\t */\n\tpublic setVariablesLocal(taskId: string, variables: Map<string, any>): void {\n\t\tthis.taskService.setVariablesLocal(taskId, Values.stringifyValuesMap(variables));\n\t}\n\n\t/**\n\t * get a variables and search in the task scope and if available also the execution scopes.\n\t */\n\tpublic getVariable(taskId: string, variableName: string): any {\n\t\treturn Values.parseValue(this.taskService.getVariable(taskId, variableName));\n\t}\n\n\t/**\n\t * The variable. Searching for the variable is done in all scopes that are visible to the given task (including parent scopes). Returns null when no variable value is found with the given name.\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @param variableName\n\t *            name of variable, cannot be null.\n\t * @return the variable or null if the variable is undefined.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no execution is found for the given taskId.\n\t */\n\tpublic getVariableInstance(taskId: string, variableName: string): VariableInstance {\n\t\treturn this.taskService.getVariableInstance(taskId, variableName);\n\t}\n\n\t/**\n\t * checks whether or not the task has a variable defined with the given name, in the task scope and if available also the execution scopes.\n\t */\n\tpublic hasVariable(taskId: string, variableName: string): boolean {\n\t\treturn this.taskService.hasVariable(taskId, variableName);\n\t}\n\n\t/**\n\t * checks whether or not the task has a variable defined with the given name.\n\t */\n\tpublic getVariableLocal(taskId: string, variableName: string): any {\n\t\treturn Values.parseValue(this.taskService.getVariableLocal(taskId, variableName));\n\t}\n\n\t/**\n\t * The variable for a task. Returns the variable when it is set for the task (and not searching parent scopes). Returns null when no variable is found with the given name.\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @param variableName\n\t *            name of variable, cannot be null.\n\t * @return the variable or null if the variable is undefined.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task is found for the given taskId.\n\t */\n\tpublic getVariableInstanceLocal(taskId: string, variableName: string): VariableInstance {\n\t\treturn this.taskService.getVariableInstanceLocal(taskId, variableName);\n\t}\n\n\t/**\n\t * checks whether or not the task has a variable defined with the given name, local task scope only.\n\t */\n\tpublic hasVariableLocal(taskId: string, variableName: string): boolean {\n\t\treturn this.taskService.hasVariableLocal(taskId, variableName);\n\t}\n\n\t/**\n\t * get all variables and search in the task scope and if available also the execution scopes. If you have many variables and you only need a few, consider using\n\t * {@link #getVariables(String, Collection)} for better performance.\n\t */\n\tpublic getVariables(taskId: string, variableNames?: string[]): Map<string, any> {\n\t\tif (this.isNotNull(variableNames)) {\n\t\t\treturn Values.parseValuesMap(this.taskService.getVariables(taskId, variableNames));\n\t\t} else {\n\t\t\treturn Values.parseValuesMap(this.taskService.getVariables(taskId));\n\t\t}\n\t}\n\n\t/**\n\t * All variables visible from the given task scope (including parent scopes).\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @param variableNames\n\t *            the collection of variable names that should be retrieved.\n\t * @return the variable instances or an empty map if no such variables are found.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task is found for the given taskId.\n\t */\n\tpublic getVariableInstances(taskId: string, variableNames?: string[]): Map<string, VariableInstance> {\n\t\tif (this.isNotNull(variableNames)) {\n\t\t\treturn this.taskService.getVariableInstances(taskId, variableNames);\n\t\t} else {\n\t\t\treturn this.taskService.getVariableInstances(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * get all variables and search only in the task scope. If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} for better\n\t * performance.\n\t */\n\tpublic getVariablesLocal(taskId: string, variableNames?: string[]): Map<string, any> {\n\t\tif (this.isNotNull(variableNames)) {\n\t\t\treturn Values.parseValuesMap(this.taskService.getVariablesLocal(taskId, variableNames));\n\t\t} else {\n\t\t\treturn Values.parseValuesMap(this.taskService.getVariablesLocal(taskId));\n\t\t}\n\t}\n\n\t/** get all variables and search only in the task scope. */\n\tpublic getVariableInstancesLocalByTaskIds(taskIds: Set<string>): VariableInstance[] {\n\t\treturn this.taskService.getVariableInstancesLocalByTaskIds(taskIds);\n\t}\n\n\t/**\n\t * All variable values that are defined in the task scope, without taking outer scopes into account. If you have many task local variables and you only need a few, consider using\n\t * {@link #getVariableInstancesLocal(String, Collection)} for better performance.\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @return the variables or an empty map if no such variables are found.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task is found for the given taskId.\n\t */\n\tpublic getVariableInstancesLocal(taskId: string, variableNames?: string[]): Map<string, VariableInstance> {\n\t\tif (this.isNotNull(variableNames)) {\n\t\t\treturn this.taskService.getVariableInstancesLocal(taskId, variableNames);\n\t\t} else {\n\t\t\treturn this.taskService.getVariableInstancesLocal(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * Removes the variable from the task. When the variable does not exist, nothing happens.\n\t */\n\tpublic removeVariable(taskId: string, variableName: string): void {\n\t\tthis.taskService.removeVariable(taskId, variableName);\n\t}\n\n\t/**\n\t * Removes the variable from the task (not considering parent scopes). When the variable does not exist, nothing happens.\n\t */\n\tpublic removeVariableLocal(taskId: string, variableName: string): void {\n\t\tthis.taskService.removeVariableLocal(taskId, variableName);\n\t}\n\n\t/**\n\t * Removes all variables in the given collection from the task. Non existing variable names are simply ignored.\n\t */\n\tpublic removeVariables(taskId: string, variableNames: string[]): void {\n\t\tthis.taskService.removeVariables(taskId, variableNames);\n\t}\n\n\t/**\n\t * Removes all variables in the given collection from the task (not considering parent scopes). Non existing variable names are simply ignored.\n\t */\n\tpublic removeVariablesLocal(taskId: string, variableNames: string[]): void {\n\t\tthis.taskService.removeVariablesLocal(taskId, variableNames);\n\t}\n\n\t/**\n\t * All DataObjects visible from the given execution scope (including parent scopes).\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @param dataObjectNames\n\t *            the collection of DataObject names that should be retrieved.\n\t * @param locale\n\t *            locale the DataObject name and description should be returned in (if available).\n\t * @param withLocalizationFallback\n\t *            When true localization will fallback to more general locales if the specified locale is not found.\n\t * @return the DataObjects or an empty map if no such variables are found.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task is found for the given taskId.\n\t */\n\tpublic getDataObjects(taskId: string, dataObjectNames?: string[], locale?: string, withLocalizationFallback?: boolean): Map<string, DataObject> {\n\t\tif (this.isNotNull(dataObjectNames) && this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {\n\t\t\treturn this.taskService.getDataObjects(taskId, dataObjectNames, locale, withLocalizationFallback);\n\t\t} else if (this.isNotNull(dataObjectNames)) {\n\t\t\treturn this.taskService.getDataObjects(taskId, dataObjectNames);\n\t\t} else if (this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {\n\t\t\treturn this.taskService.getDataObjects(taskId, locale, withLocalizationFallback);\n\t\t} else {\n\t\t\treturn this.taskService.getDataObjects(taskId);\n\t\t}\n\t}\n\n\t/**\n\t * The DataObject. Searching for the DataObject is done in all scopes that are visible to the given task (including parent scopes). Returns null when no DataObject value is found with the given\n\t * name.\n\t *\n\t * @param taskId\n\t *            id of task, cannot be null.\n\t * @param dataObject\n\t *            name of DataObject, cannot be null.\n\t * @param locale\n\t *            locale the DataObject name and description should be returned in (if available).\n\t * @param withLocalizationFallback\n\t *            When true localization will fallback to more general locales including the default locale of the JVM if the specified locale is not found.\n\t * @return the DataObject or null if the variable is undefined.\n\t * @throws FlowableObjectNotFoundException\n\t *             when no task is found for the given taskId.\n\t */\n\tpublic getDataObject(taskId: string, dataObject: string, locale?: string, withLocalizationFallback?: boolean): DataObject {\n\t\tif (this.isNotNull(locale) && this.isNotNull(withLocalizationFallback)) {\n\t\t\treturn this.taskService.getDataObject(taskId, dataObject, locale, withLocalizationFallback);\n\t\t} else {\n\t\t\treturn this.taskService.getDataObject(taskId, dataObject);\n\t\t}\n\t}\n\n\t/** Add a comment to a task and/or process instance. */\n\tpublic addComment(taskId: string, processInstanceId: string, message: string, type?: string): Comment {\n\t\tif (this.isNotNull(type)) {\n\t\t\treturn this.taskService.addComment(taskId, processInstanceId, type, message);\n\t\t} else {\n\t\t\treturn this.taskService.addComment(taskId, processInstanceId, message);\n\t\t}\n\t}\n\n\t/** Update a comment to a task and/or process instance. */\n\tpublic saveComment(comment: Comment): void {\n\t\tthis.taskService.saveComment(comment);\n\t}\n\n\t/**\n\t * Returns an individual comment with the given id. Returns null if no comment exists with the given id.\n\t */\n\tpublic getComment(commentId: string): Comment {\n\t\treturn this.taskService.getComment(commentId);\n\t}\n\n\t/** Removes all comments from the provided task and/or process instance */\n\tpublic deleteComments(taskId: string, processInstanceId: string): void {\n\t\tthis.taskService.deleteComments(taskId, processInstanceId);\n\t}\n\n\t/**\n\t * Removes an individual comment with the given id.\n\t * \n\t * @throws FlowableObjectNotFoundException\n\t *             when no comment exists with the given id.\n\t */\n\tpublic deleteComment(commentId: string): void {\n\t\tthis.taskService.deleteComment(commentId);\n\t}\n\n\t/** The comments related to the given task. */\n\tpublic getTaskComments(taskId: string, type?: string): Comment[] {\n\t\tif (this.isNotNull(type)) {\n\t\t\treturn this.taskService.getTaskComments(taskId, type);\n\t\t} else {\n\t\t\treturn this.taskService.getTaskComments(taskId);\n\t\t}\n\t}\n\n\t/** All comments of a given type. */\n\tpublic getCommentsByType(type: string): Comment[] {\n\t\treturn this.taskService.getCommentsByType(type);\n\t}\n\n\t/** The all events related to the given task. */\n\tpublic getTaskEvents(taskId: string): TaskEvent[] {\n\t\treturn this.taskService.getTaskEvents(taskId);\n\t}\n\n\t/**\n\t * Returns an individual event with the given id. Returns null if no event exists with the given id.\n\t */\n\tpublic getEvent(eventId: string): TaskEvent {\n\t\treturn this.taskService.getEvent(eventId);\n\t}\n\n\t/** The comments related to the given process instance. */\n\tpublic getProcessInstanceComments(processInstanceId: string, type?: string): Comment[] {\n\t\tif (this.isNotNull(type)) {\n\t\t\treturn this.taskService.getProcessInstanceComments(processInstanceId, type);\n\t\t} else {\n\t\t\treturn this.taskService.getProcessInstanceComments(processInstanceId);\n\t\t}\n\t}\n\n\t/**\n\t * Add a new attachment to a task and/or a process instance and use an input stream to provide the content\n\t */\n\tpublic createAttachment(attachmentType: string, taskId: string, processInstanceId: string, attachmentName: string, attachmentDescription: string, content?: any[], url?: string): Attachment {\n\t\tif (this.isNotNull(url)) {\n\t\t\treturn this.taskService.createAttachment(attachmentType, taskId, processInstanceId, attachmentName, attachmentDescription, url);\n\t\t} else {\n\t\t\treturn this.taskService.createAttachment(attachmentType, taskId, processInstanceId, attachmentName, attachmentDescription, Streams.createByteArrayInputStream(content));\n\t\t}\n\t}\n\n\t/** Update the name and description of an attachment */\n\tpublic saveAttachment(attachment: Attachment): void {\n\t\tthis.taskService.saveAttachment(attachment);\n\t}\n\n\t/** Retrieve a particular attachment */\n\tpublic getAttachment(attachmentId: string): Attachment {\n\t\treturn this.taskService.getAttachment(attachmentId);\n\t}\n\n\t/** Retrieve stream content of a particular attachment */\n\tpublic getAttachmentContent(attachmentId: string): any[] {\n\t\tconst content = this.taskService.getAttachmentContent(attachmentId);\n\t\tconst baos = Streams.createByteArrayOutputStream();\n\t\tStreams.copyLarge(content, baos);\n\t\treturn baos.getBytes()\n\t};\n\n\t/** The list of attachments associated to a task */\n\tpublic getTaskAttachments(taskId: string): Attachment[] {\n\t\treturn this.taskService.getTaskAttachments(taskId);\n\t}\n\n\t/** The list of attachments associated to a process instance */\n\tpublic getProcessInstanceAttachments(processInstanceId: string): Attachment[] {\n\t\treturn this.taskService.getProcessInstanceAttachments(processInstanceId);\n\t}\n\n\t/** Delete an attachment */\n\tpublic deleteAttachment(attachmentId: string): void {\n\t\tthis.taskService.deleteAttachment(attachmentId);\n\t}\n\n\t/** The list of subtasks for this parent task */\n\tpublic getSubTasks(parentTaskId: string): Task[] {\n\t\treturn this.taskService.getSubTasks(parentTaskId);\n\t}\n\n\tprivate isNotNull(property: any): boolean {\n\t\treturn property !== null && property !== undefined;\n\t}\n}\n\nclass TaskData {\n\n\tprivate data: any;\n\n\tconstructor(data: any) {\n\t\tthis.data = data;\n\t}\n\n\tpublic getId(): string | undefined {\n\t\treturn this.data.id ?? undefined;\n\t}\n\n\tpublic getRevision(): number {\n\t\treturn this.data.revision;\n\t}\n\n\tpublic getOwner(): string | undefined {\n\t\treturn this.data.owner ?? undefined;\n\t}\n\n\tpublic getAssigneeUpdatedCount(): number {\n\t\treturn this.data.assigneeUpdatedCount;\n\t}\n\n\tpublic getOriginalAssignee(): string | undefined {\n\t\treturn this.data.originalAssignee ?? undefined;\n\t}\n\n\tpublic getAssignee(): string | undefined {\n\t\treturn this.data.assignee ?? undefined;\n\t}\n\n\tpublic getDelegationState(): string | undefined {\n\t\treturn this.data.delegationState ?? undefined;\n\t}\n\n\tpublic getParentTaskId(): string | undefined {\n\t\treturn this.data.parentTaskId ?? undefined;\n\t}\n\n\tpublic getName(): string | undefined {\n\t\treturn this.data.name ?? undefined;\n\t}\n\n\tpublic getLocalizedName(): string | undefined {\n\t\treturn this.data.localizedName ?? undefined;\n\t}\n\n\tpublic getDescription(): string | undefined {\n\t\treturn this.data.description ?? undefined;\n\t}\n\n\tpublic getLocalizedDescription(): string | undefined {\n\t\treturn this.data.localizedDescription ?? undefined;\n\t}\n\n\tpublic getPriority(): number {\n\t\treturn this.data.priority;\n\t}\n\n\tpublic getCreateTime(): Date | undefined {\n\t\treturn this.data.createTime ?? undefined;\n\t}\n\n\tpublic getDueDate(): Date | undefined {\n\t\treturn this.data.dueDate ?? undefined;\n\t}\n\n\tpublic getSuspensionState(): number {\n\t\treturn this.data.suspensionState ?? undefined;\n\t}\n\n\tpublic getCategory(): string | undefined {\n\t\treturn this.data.category ?? undefined;\n\t}\n\n\tpublic isIdentityLinksInitialized(): boolean {\n\t\treturn this.data.isIdentityLinksInitialized;\n\t}\n\n\tpublic getExecutionId(): string | undefined {\n\t\treturn this.data.executionId ?? undefined;\n\t}\n\n\tpublic getProcessInstanceId(): string | undefined {\n\t\treturn this.data.processInstanceId ?? undefined;\n\t}\n\n\tpublic getProcessDefinitionId(): string | undefined {\n\t\treturn this.data.processDefinitionId ?? undefined;\n\t}\n\n\tpublic getScopeId(): string | undefined {\n\t\treturn this.data.scopeId ?? undefined;\n\t}\n\n\tpublic getSubScopeId(): string | undefined {\n\t\treturn this.data.subScopeId ?? undefined;\n\t}\n\n\tpublic getScopeType(): string | undefined {\n\t\treturn this.data.scopeType ?? undefined;\n\t}\n\n\tpublic getScopeDefinitionId(): string | undefined {\n\t\treturn this.data.scopeDefinitionId ?? undefined;\n\t}\n\n\tpublic getTaskDefinitionKey(): string | undefined {\n\t\treturn this.data.taskDefinitionKey ?? undefined;\n\t}\n\n\tpublic getFormKey(): string | undefined {\n\t\treturn this.data.formKey ?? undefined;\n\t}\n\n\tpublic isDeleted(): boolean {\n\t\treturn this.data.isDeleted;\n\t}\n\n\tpublic isCanceled(): boolean {\n\t\treturn this.data.isCanceled;\n\t}\n\n\tpublic isCountEnabled(): boolean {\n\t\treturn this.data.isCountEnabled;\n\t}\n\n\tpublic getVariableCount(): number {\n\t\treturn this.data.variableCount;\n\t}\n\n\tpublic getIdentityLinkCount(): number {\n\t\treturn this.data.identityLinkCount;\n\t}\n\n\tpublic getClaimTime(): Date | undefined {\n\t\treturn this.data.claimTime ?? undefined;\n\t}\n\n\tpublic getTenantId(): string {\n\t\treturn this.data.tenantId;\n\t}\n\n\tpublic getEventName(): string | undefined {\n\t\treturn this.data.eventName ?? undefined;\n\t}\n\n\tpublic getEventHandlerId(): string | undefined {\n\t\treturn this.data.eventHandlerId ?? undefined;\n\t}\n\n\tpublic isForcedUpdate(): boolean {\n\t\treturn this.data.forcedUpdate;\n\t}\n}\n\n/**\n * Represents one task for a human user.\n */\nexport interface Task extends TaskInfo {\n\n\t/** Name or title of the task. */\n\tsetName(name: string): void;\n\n\t/** Sets an optional localized name for the task. */\n\tsetLocalizedName(name: string): void;\n\n\t/** Change the description of the task */\n\tsetDescription(description: string): void;\n\n\t/** Sets an optional localized description for the task. */\n\tsetLocalizedDescription(description: string): void;\n\n\t/** Sets the indication of how important/urgent this task is */\n\tsetPriority(priority: number): void;\n\n\t/**\n\t * The user id of the person that is responsible for this task.\n\t */\n\tsetOwner(owner: string): void;\n\n\t/**\n\t * The user id of the person to which this task is delegated.\n\t */\n\tsetAssignee(assignee: string): void;\n\n\t/** The current {@link DelegationState} for this task. */\n\tgetDelegationState(): DelegationState;\n\n\t/** The current {@link DelegationState} for this task. */\n\tsetDelegationState(delegationState: DelegationState): void;\n\n\t/** Change due date of the task. */\n\tsetDueDate(dueDate: Date): void;\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\tsetCategory(category: string): void;\n\n\t/** the parent task for which this task is a subtask */\n\tsetParentTaskId(parentTaskId: string): void;\n\n\t/** Change the tenantId of the task */\n\tsetTenantId(tenantId: string): void;\n\n\t/** Change the form key of the task */\n\tsetFormKey(formKey: string): void;\n\n\t/** Indicates whether this task is suspended or not. */\n\tisSuspended(): boolean;\n\n}\n\nexport interface TaskInfo {\n\n\t/** DB id of the task. */\n\tgetId(): string;\n\n\t/**\n\t * Name or title of the task.\n\t */\n\tgetName(): string;\n\n\t/**\n\t * Free text description of the task.\n\t */\n\tgetDescription(): string;\n\n\t/**\n\t * Indication of how important/urgent this task is\n\t */\n\tgetPriority(): number;\n\n\t/**\n\t * The user id of the person that is responsible for this task.\n\t */\n\tgetOwner(): string;\n\n\t/**\n\t * The user id of the person to which this task is delegated.\n\t */\n\tgetAssignee(): string;\n\n\t/**\n\t * Reference to the process instance or null if it is not related to a process instance.\n\t */\n\tgetProcessInstanceId(): string;\n\n\t/**\n\t * Reference to the path of execution or null if it is not related to a process instance.\n\t */\n\tgetExecutionId(): string;\n\n\t/**\n\t * Reference to the task definition or null if it is not related to any task definition.\n\t */\n\tgetTaskDefinitionId(): string;\n\n\t/**\n\t * Reference to the process definition or null if it is not related to a process.\n\t */\n\tgetProcessDefinitionId(): string;\n\n\t/**\n\t * Reference to a scope identifier or null if none is set (e.g. for bpmn process task it is null)\n\t */\n\tgetScopeId(): string;\n\n\t/**\n\t * Reference to a sub scope identifier or null if none is set (e.g. for bpmn process task it is null)\n\t */\n\tgetSubScopeId(): string;\n\n\t/**\n\t * Reference to a scope type or null if none is set (e.g. for bpmn process task it is null)\n\t */\n\tgetScopeType(): string;\n\n\t/**\n\t * Reference to a scope definition identifier or null if none is set (e.g. for bpmn process task it is null)\n\t */\n\tgetScopeDefinitionId(): string;\n\n\t/**\n\t * If this task 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). Even if the direct parent of the task is a process which itself might have been created out of a process task of a case, its stage instance\n\t * is reflected in the task.\n\t *\n\t * @return the stage instance id this task belongs to or null, if this task is not part of a case at all or is not a child element of a stage\n\t */\n\tgetPropagatedStageInstanceId(): string;\n\n\t/**\n\t * The state of this task\n\t */\n\tgetState(): string;\n\n\t/** The date/time when this task was created */\n\tgetCreateTime(): Date;\n\n\t/** The date/time when this task was put in progress */\n\tgetInProgressStartTime(): Date;\n\n\t/**\n\t * The user reference that put this task in progress\n\t */\n\tgetInProgressStartedBy(): string;\n\n\t/**\n\t * The claim time of this task\n\t */\n\tgetClaimTime(): Date;\n\n\t/**\n\t * The user reference that claimed this task\n\t */\n\tgetClaimedBy(): String;\n\n\t/**\n\t * The suspended time of this task\n\t */\n\tgetSuspendedTime(): Date;\n\n\t/**\n\t * The user reference that suspended this task\n\t */\n\tgetSuspendedBy(): string;\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\tgetTaskDefinitionKey(): string;\n\n\t/**\n\t * In progress start due date of the task.\n\t */\n\tgetInProgressStartDueDate(): Date;\n\n\t/**\n\t * Due date of the task.\n\t */\n\tgetDueDate(): Date;\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\tgetCategory(); string;\n\n\t/**\n\t * The parent task for which this task is a subtask\n\t */\n\tgetParentTaskId(): string;\n\n\t/**\n\t * The tenant identifier of this task\n\t */\n\tgetTenantId(): string;\n\n\t/**\n\t * The form key for the user task\n\t */\n\tgetFormKey(): string;\n\n\t/**\n\t * Returns the local task variables if requested in the task query\n\t */\n\tgetTaskLocalVariables(): Map<string, Object>;\n\n\t/**\n\t * Returns the process variables if requested in the task query\n\t */\n\tgetProcessVariables(): Map<string, Object>;\n\n\t/**\n\t * Returns the case variables if requested in the task query\n\t */\n\tgetCaseVariables(): Map<string, Object>;\n\n\t/**\n\t * Returns the identity links.\n\t */\n\tgetIdentityLinks(): IdentityLinkInfo[];\n}\n\nexport interface IdentityLinkInfo {\n\tgetType(): string;\n\n\tgetUserId(): string;\n\n\tgetGroupId(): string;\n\n\tgetTaskId(): string;\n\n\tgetProcessInstanceId(): string;\n\n\tgetScopeId(): string;\n\n\tgetSubScopeId(): string;\n\n\tgetScopeType(): string;\n\n\tgetScopeDefinitionId(): string;\n}\n\nexport interface IdentityLink extends IdentityLinkInfo {\n\n\t/**\n\t * The process definition id associated with this identity link.\n\t */\n\tgetProcessDefinitionId(): string;\n\n}\n\nexport enum 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\n/**\n * Wraps {@link TaskInfo} to the builder.\n * \n */\nexport interface TaskBuilder {\n\n\t/**\n\t * Creates task instance according values set in the builder\n\t * \n\t * @return task instance\n\t */\n\tcreate(): Task;\n\n\t/**\n\t * DB id of the task.\n\t */\n\tid(id: string): TaskBuilder;\n\tgetId(): string;\n\n\t/**\n\t * Name or title of the task.\n\t */\n\tname(name: string): TaskBuilder;\n\tgetName(): string;\n\n\t/**\n\t * Free text description of the task.\n\t */\n\tdescription(description: string): TaskBuilder;\n\tgetDescription(): string;\n\n\t/**\n\t * Indication of how important/urgent this task is\n\t */\n\tpriority(priority: number): TaskBuilder;\n\tgetPriority(): number;\n\n\t/**\n\t * The userId of the person that is responsible for this task.\n\t */\n\towner(ownerId: string): TaskBuilder;\n\tgetOwner(): string;\n\n\t/**\n\t * The userId of the person to which this task is delegated.\n\t */\n\tassignee(assigneId: string): TaskBuilder;\n\tgetAssignee(): string;\n\n\t/**\n\t * Change due date of the task.\n\t */\n\tdueDate(dueDate: Date): TaskBuilder;\n\tgetDueDate(): Date;\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\tcategory(category: string): TaskBuilder;\n\tgetCategory(): string;\n\n\t/**\n\t * the parent task for which this task is a subtask\n\t */\n\tparentTaskId(parentTaskId: string): TaskBuilder;\n\tgetParentTaskId(): string;\n\n\t/**\n\t * Change the tenantId of the task\n\t */\n\ttenantId(tenantId: string): TaskBuilder;\n\tgetTenantId(): string;\n\n\t/**\n\t * Change the form key of the task\n\t */\n\tformKey(formKey: string): TaskBuilder;\n\tgetFormKey(): string;\n\n\t/**\n\t * task definition id to create task from\n\t */\n\ttaskDefinitionId(taskDefinitionId: string): TaskBuilder;\n\tgetTaskDefinitionId(): string;\n\n\t/**\n\t * task definition key to create task from\n\t */\n\ttaskDefinitionKey(taskDefinitionKey: string): TaskBuilder;\n\tgetTaskDefinitionKey(): string;\n\n\t/**\n\t * add identity links to the task\n\t */\n\tidentityLinks(identityLinks: Set<IdentityLinkInfo>): TaskBuilder;\n\tgetIdentityLinks(): Set<IdentityLinkInfo>;\n\n\t/**\n\t * add task scopeId\n\t */\n\tscopeId(scopeId: string): TaskBuilder;\n\tgetScopeId(): string;\n\n\t/**\n\t * Add scope type\n\t */\n\tscopeType(scopeType: string): TaskBuilder;\n\tgetScopeType(): string;\n}\n\nexport interface FormInfo {\n\n\tgetId(): string;\n\n\tsetId(id: string): void;\n\n\tgetName(): string;\n\n\tsetName(name: string): void;\n\n\tgetDescription(): string;\n\n\tsetDescription(description: string): void;\n\n\tgetKey(): string;\n\n\tsetKey(key: string): void;\n\n\tgetVersion(): number;\n\n\tsetVersion(version: number): void;\n\n\tgetFormModel(): any;\n\n\tsetFormModel(formModel: any): void;\n}\n\nexport interface ValueFields {\n\n\t/**\n\t * @return the name of the variable\n\t */\n\tgetName(): string;\n\n\t/**\n\t * @return the process instance id of the variable\n\t */\n\tgetProcessInstanceId(): string;\n\n\t/**\n\t * @return the execution id of the variable\n\t */\n\tgetExecutionId(): string;\n\n\t/**\n\t * @return the scope id of the variable\n\t */\n\tgetScopeId(): string;\n\n\t/**\n\t * @return the sub scope id of the variable\n\t */\n\tgetSubScopeId(): string;\n\n\t/**\n\t * @return the scope type of the variable\n\t */\n\tgetScopeType(): string;\n\n\t/**\n\t * @return the task id of the variable\n\t */\n\tgetTaskId(): string;\n\n\t/**\n\t * @return the first text value, if any, or null.\n\t */\n\tgetTextValue(): string;\n\n\t/**\n\t * Sets the first text value. A value of null is allowed.\n\t */\n\tsetTextValue(textValue: string): void;\n\n\t/**\n\t * @return the second text value, if any, or null.\n\t */\n\tgetTextValue2(): string;\n\n\t/**\n\t * Sets second text value. A value of null is allowed.\n\t */\n\tsetTextValue2(textValue2: string): void;\n\n\t/**\n\t * @return the long value, if any, or null.\n\t */\n\tgetLongValue(): number;\n\n\t/**\n\t * Sets the long value. A value of null is allowed.\n\t */\n\tsetLongValue(longValue: number): void;\n\n\t/**\n\t * @return the double value, if any, or null.\n\t */\n\tgetDoubleValue(): number;\n\n\t/**\n\t * Sets the double value. A value of null is allowed.\n\t */\n\tsetDoubleValue(doubleValue: number): void;\n\n\t/**\n\t * @return the byte array value, if any, or null.\n\t */\n\tgetBytes(): any[];\n\n\t/**\n\t * Sets the byte array value. A value of null is allowed.\n\t */\n\tsetBytes(bytes: any[]): void;\n\n\tgetCachedValue(): any;\n\n\tsetCachedValue(cachedValue: any): void;\n\n}\n\nexport interface VariableInstance extends ValueFields {\n\n\tgetId(): string;\n\n\tsetId(id: string): void;\n\n\tsetName(name: string): void;\n\n\tsetExecutionId(executionId: string): void;\n\n\tsetProcessInstanceId(processInstanceId: string): void;\n\n\tsetProcessDefinitionId(processDefinitionId: string): void;\n\n\tgetProcessDefinitionId(): string;\n\n\tgetValue(): any;\n\n\tsetValue(value: any): void;\n\n\tgetTypeName(): string;\n\n\tsetTypeName(typeName: string): void;\n\n\tisReadOnly(): boolean;\n\n\tsetTaskId(taskId: string): void;\n\n\tsetScopeId(scopeId: string): void;\n\n\tsetSubScopeId(subScopeId: string): void;\n\n\tsetScopeType(scopeType: string): void;\n\n\tsetScopeDefinitionId(scopeDefinitionId: string): void;\n\n\tgetScopeDefinitionId(): string;\n\n\tgetMetaInfo(): string;\n\n\tsetMetaInfo(metaInfo: string): void;\n\n}\n\nexport interface DataObject {\n\n\t/**\n\t * The unique id of this Data Object.\n\t */\n\tgetId(): string;\n\n\t/**\n\t /**\n\t * The id of the process instance that this Data Object is associated with.\n\t */\n\tgetProcessInstanceId(): string;\n\n\t/**\n\t * The id of the execution in which this Data Object resides. A DataObject only resides on a process instance\n\t * execution or a subprocess execution.\n\t */\n\tgetExecutionId(): string;\n\n\t/**\n\t * Name of the DataObject.\n\t */\n\tgetName(): string;\n\n\t/**\n\t * Localized Name of the DataObject.\n\t */\n\tgetLocalizedName(): string;\n\n\t/**\n\t * Description of the DataObject.\n\t */\n\tgetDescription(): string;\n\n\t/**\n\t * Value of the DataObject.\n\t */\n\tgetValue(): any;\n\n\t/**\n\t * Type of the DataObject.\n\t */\n\tgetType(): string;\n\n\t/**\n\t * The id of the flow element in the process defining this data object.\n\t */\n\tgetDataObjectDefinitionKey(): string;\n}\n\nexport interface Comment {\n\n\t/** unique identifier for this comment */\n\tgetId(): string;\n\n\t/** reference to the user that made the comment */\n\tgetUserId(): string;\n\n\tsetUserId(userId: string): void;\n\n\tgetTime(): Date;\n\n\tsetTime(time: Date);\n\n\t/** reference to the task on which this comment was made */\n\tgetTaskId(): string;\n\n\tsetTaskId(taskId: string): void;\n\n\t/** reference to the process instance on which this comment was made */\n\tgetProcessInstanceId(): string;\n\n\tsetProcessInstanceId(processInstanceId: string): void;\n\n\t/** reference to the type given to the comment */\n\tgetType(): string;\n\n\tsetType(type: string): void;\n\n\t/**\n\t * the full comment message the user had related to the task and/or process instance\n\t * \n\t * @see TaskService#getTaskComments(String)\n\t */\n\tgetFullMessage(): string;\n\n\tsetFullMessage(fullMessage: string): void;\n}\n\nexport interface TaskEvent {\n\n\t/** Unique identifier for this event */\n\tgetId(): string;\n\n\t/**\n\t * Indicates the type of of action and also indicates the meaning of the parts as exposed in {@link #getMessageParts()}\n\t */\n\tgetAction(): string;\n\n\t/**\n\t * The meaning of the message parts is defined by the action as you can find in {@link #getAction()}\n\t */\n\tgetMessageParts(): string[];\n\n\t/**\n\t * The message that can be used in case this action only has a single message part.\n\t */\n\tgetMessage(): string;\n\n\t/** reference to the user that made the comment */\n\tgetUserId(): string;\n\n\t/** time and date when the user made the comment */\n\tgetTime(): Date;\n\n\t/** reference to the task on which this comment was made */\n\tgetTaskId(): string;\n\n\t/** reference to the process instance on which this comment was made */\n\tgetProcessInstanceId(): string;\n\n}\n\nexport interface Attachment {\n\n\t/** unique id for this attachment */\n\tgetId(): string;\n\n\t/** free user defined short (max 255 chars) name for this attachment */\n\tgetName(): string;\n\n\t/** free user defined short (max 255 chars) name for this attachment */\n\tsetName(name: string): void;\n\n\t/**\n\t * long (max 255 chars) explanation what this attachment is about in context of the task and/or process instance it's linked to.\n\t */\n\tgetDescription(): string;\n\n\t/**\n\t * long (max 255 chars) explanation what this attachment is about in context of the task and/or process instance it's linked to.\n\t */\n\tsetDescription(description: string): void;\n\n\t/**\n\t * indication of the type of content that this attachment refers to. Can be mime type or any other indication.\n\t */\n\tgetType(): string;\n\n\t/** reference to the task to which this attachment is associated. */\n\n\tgetTaskId(): string;\n\t/**\n\t * reference to the process instance to which this attachment is associated.\n\t */\n\tgetProcessInstanceId(): string;\n\n\t/**\n\t * the remote URL in case this is remote content. If the attachment content was {@link TaskService#createAttachment(String, String, String, String, String, java.io.InputStream) uploaded with an\n\t * input stream}, then this method returns null and the content can be fetched with {@link TaskService#getAttachmentContent(String)}.\n\t */\n\tgetUrl(): string;\n\n\t/** reference to the user who created this attachment. */\n\tgetUserId(): string;\n\n\t/** timestamp when this attachment was created */\n\tgetTime(): Date;\n\n\t/** timestamp when this attachment was created */\n\tsetTime(time: Date): void;\n\n\t/** the id of the byte array entity storing the content */\n\tgetContentId(): string;\n\n}\n\nexport enum NullHandlingOnOrder {\n\tNULLS_FIRST, NULLS_LAST\n}\n\nexport interface QueryProperty {\n\n\tgetName(): string;\n}\n\nexport interface Query<T, U> {\n\n\t/**\n\t * Order the results ascending on the given property as defined in this class (needs to come after a call to one of the orderByXxxx methods).\n\t */\n\tasc(): T;\n\n\t/**\n\t * Order the results descending on the given property as defined in this class (needs to come after a call to one of the orderByXxxx methods).\n\t */\n\tdesc(): T;\n\n\torderBy(property: QueryProperty): T;\n\n\torderBy(property: QueryProperty, nullHandlingOnOrder: NullHandlingOnOrder): T;\n\n\t/**\n\t * Executes the query and returns the number of results\n\t */\n\tcount(): number;\n\n\t/**\n\t * Executes the query and returns the resulting entity or null if no entity matches the query criteria.\n\t *\n\t * @throws org.flowable.common.engine.api.FlowableException when the query results in more than one entities.\n\t */\n\tsingleResult(): U;\n\n\t/**\n\t * Executes the query and get a list of entities as the result.\n\t */\n\tlist(): U[];\n\n\t/**\n\t * Executes the query and get a list of entities as the result.\n\t */\n\tlistPage(firstResult: number, maxResults: number): U[];\n}\n\n\nexport interface TaskInfoQuery<T, V extends TaskInfo> extends Query<T, V> {\n\n\t/**\n\t * Only select tasks with the given task id (in practice, there will be maximum one of this kind)\n\t */\n\ttaskId(taskId: string): T;\n\n\t/**\n\t * Only select tasks with an id that is in the given list\n\t *\n\t * @throws FlowableIllegalArgumentException\n\t *             When passed id list is empty or <code>null</code> or contains <code>null String</code>.\n\t */\n\ttaskIds(taskIds: string[]): T;\n\n\t/** Only select tasks with the given name */\n\ttaskName(name: string): T;\n\n\t/**\n\t * Only select tasks with a name that is in the given list\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When passed name list is empty or <code>null</code> or contains <code>null String</code>.\n\t */\n\ttaskNameIn(nameList: string[]): T;\n\n\t/**\n\t * Only select tasks with a name that is in the given list\n\t * \n\t * This method, unlike the {@link #taskNameIn(Collection)} method will not take in account the upper/lower case: both the input parameters as the column value are lowercased when the query is executed.\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When passed name list is empty or <code>null</code> or contains <code>null String</code>.\n\t */\n\ttaskNameInIgnoreCase(nameList: string[]): T;\n\n\t/**\n\t * Only select tasks with a name matching the parameter. The syntax is that of SQL: for example usage: nameLike(%test%)\n\t */\n\ttaskNameLike(nameLike: string): T;\n\n\t/**\n\t * Only select tasks with a name matching the parameter. The syntax is that of SQL: for example usage: nameLike(%test%)\n\t * \n\t * This method, unlike the {@link #taskNameLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the query is\n\t * executed.\n\t */\n\ttaskNameLikeIgnoreCase(nameLike: string): T;\n\n\t/** Only select tasks with the given description. */\n\ttaskDescription(description: string): T;\n\n\t/**\n\t * Only select tasks with a description matching the parameter . The syntax is that of SQL: for example usage: descriptionLike(%test%)\n\t */\n\ttaskDescriptionLike(descriptionLike: string): T;\n\n\t/**\n\t * Only select tasks with a description matching the parameter . The syntax is that of SQL: for example usage: descriptionLike(%test%)\n\t * \n\t * This method, unlike the {@link #taskDescriptionLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the query is\n\t * executed.\n\t */\n\ttaskDescriptionLikeIgnoreCase(descriptionLike: string): T;\n\n\t/** Only select tasks with the given priority. */\n\ttaskPriority(priority: number): T;\n\n\t/** Only select tasks with the given priority or higher. */\n\ttaskMinPriority(minPriority: number): T;\n\n\t/** Only select tasks with the given priority or lower. */\n\ttaskMaxPriority(maxPriority: number): T;\n\n\t/** Only select tasks which are assigned to the given user. */\n\ttaskAssignee(assignee: string): T;\n\n\t/**\n\t * Only select tasks which were last assigned to an assignee like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t */\n\ttaskAssigneeLike(assigneeLike: string): T;\n\n\t/**\n\t * Only select tasks which were last assigned to an assignee like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t * \n\t * This method, unlike the {@link #taskAssigneeLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the query is\n\t * executed.\n\t */\n\ttaskAssigneeLikeIgnoreCase(assigneeLikeIgnoreCase: string): T;\n\n\t/** Only select tasks which don't have an assignee. */\n\ttaskUnassigned(): T;\n\n\t/** Only select tasks which are assigned to any user */\n\ttaskAssigned(): T;\n\n\t/**\n\t * Only select tasks with an assignee that is in the given list\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When passed name list is empty or <code>null</code> or contains <code>null String</code>.\n\t */\n\ttaskAssigneeIds(assigneeListIds: string[]): T;\n\n\t/** Only select tasks for which the given user is the owner. */\n\ttaskOwner(owner: string): T;\n\n\t/**\n\t * Only select tasks which were last assigned to an owner like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t */\n\ttaskOwnerLike(ownerLike: string): T;\n\n\t/**\n\t * Only select tasks which were last assigned to an owner like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t * \n\t * This method, unlike the {@link #taskOwnerLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the query is\n\t * executed.\n\t */\n\ttaskOwnerLikeIgnoreCase(ownerLikeIgnoreCase: string): T;\n\n\t/** Only select tasks for which the given user is a candidate. */\n\ttaskCandidateUser(candidateUser: string): T;\n\n\t/**\n\t * Only select tasks for which there exist an {@link IdentityLink} with the given user, including tasks which have been assigned to the given user (assignee) or owned by the given user (owner).\n\t */\n\ttaskInvolvedUser(involvedUser: string): T;\n\n\t/**\n\t * Only select tasks for which there exist an {@link IdentityLink} with the given Groups.\n\t */\n\ttaskInvolvedGroups(involvedGroup: string[]): T;\n\n\t/**\n\t * Allows to select a task using {@link #taskCandidateGroup(String)} {@link #taskCandidateGroupIn(Collection)} or {@link #taskCandidateUser(String)} but ignore the assignee value instead of querying for an empty assignee.\n\t */\n\tignoreAssigneeValue(): T;\n\n\t/** Only select tasks for which users in the given group are candidates. */\n\ttaskCandidateGroup(candidateGroup: string): T;\n\n\t/**\n\t * Only select tasks for which the 'candidateGroup' is one of the given groups.\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When query is executed and {@link #taskCandidateGroup(String)} or {@link #taskCandidateUser(String)} has been executed on the query instance. When passed group list is empty or\n\t *             <code>null</code>.\n\t */\n\ttaskCandidateGroupIn(candidateGroups: string[]): T\n\n\t/**\n\t * Only select tasks that have the given tenant id.\n\t */\n\ttaskTenantId(tenantId: string): T;\n\n\t/**\n\t * Only select tasks with a tenant id like the given one.\n\t */\n\ttaskTenantIdLike(tenantIdLike: string): T;\n\n\t/**\n\t * Only select tasks that do not have a tenant id.\n\t */\n\ttaskWithoutTenantId(): T;\n\n\t/**\n\t * Only select tasks for the given process instance id.\n\t */\n\tprocessInstanceId(processInstanceId: string): T;\n\n\t/**\n\t * Only select tasks for the given process ids.\n\t */\n\tprocessInstanceIdIn(processInstanceIds: string[]): T;\n\n\t/**\n\t * Only select tasks without a process instance id.\n\t */\n\twithoutProcessInstanceId(): T;\n\n\t/**\n\t * Only select tasks for the given business key\n\t */\n\tprocessInstanceBusinessKey(processInstanceBusinessKey: string): T;\n\n\t/**\n\t * Only select tasks with a business key like the given value The syntax is that of SQL: for example usage: processInstanceBusinessKeyLike(\"%test%\").\n\t */\n\tprocessInstanceBusinessKeyLike(processInstanceBusinessKeyLike: string): T;\n\n\t/**\n\t * Only select tasks with a business key like the given value The syntax is that of SQL: for example usage: processInstanceBusinessKeyLike(\"%test%\").\n\t * \n\t * This method, unlike the {@link #processInstanceBusinessKeyLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when\n\t * the query is executed.\n\t */\n\tprocessInstanceBusinessKeyLikeIgnoreCase(processInstanceBusinessKeyLikeIgnoreCase: string): T;\n\n\t/**\n\t * Only select tasks for the given execution.\n\t */\n\texecutionId(executionId: string): T;\n\n\t/**\n\t * Only select tasks for the given case instance.\n\t */\n\tcaseInstanceId(caseInstanceId: string): T;\n\n\t/**\n\t * Only select tasks for the given case definition.\n\t */\n\tcaseDefinitionId(caseDefinitionId: string): T;\n\n\t/**\n\t * Only select tasks which are part of a case instance which has the given case definition key.\n\t */\n\tcaseDefinitionKey(caseDefinitionKey: string): T;\n\n\t/**\n\t * Only select tasks which are part of a case instance which has a case definition key like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t */\n\tcaseDefinitionKeyLike(caseDefinitionKeyLike: string): T;\n\n\t/**\n\t * Only select tasks which are part of a case instance which has a case definition key like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t *\n\t * This method, unlike the {@link #caseDefinitionKeyLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the\n\t * query is executed.\n\t */\n\tcaseDefinitionKeyLikeIgnoreCase(caseDefinitionKeyLikeIgnoreCase: string): T;\n\n\t/** Only select tasks that have a case definition for which the key is present in the given list **/\n\tcaseDefinitionKeyIn(caseDefinitionKeys: string[]): T;\n\n\t/**\n\t * Only select tasks for the given plan item instance. \n\t */\n\tplanItemInstanceId(planItemInstanceId: string): T;\n\n\t/**\n\t * Only select tasks for the given scope identifier. \n\t */\n\tscopeId(scopeId: string): T;\n\n\t/**\n\t * Only select tasks for the given sub scope identifier. \n\t */\n\tsubScopeId(subScopeId: string): T;\n\n\t/**\n\t * Only select tasks for the given scope type. \n\t */\n\tscopeType(scopeType: string): T;\n\n\t/**\n\t * Only select tasks for the given scope definition identifier. \n\t */\n\tscopeDefinitionId(scopeDefinitionId: string): T;\n\n\t/**\n\t * Only select tasks for the given stage, defined through its stage instance id.\n\t */\n\tpropagatedStageInstanceId(propagatedStageInstanceId: string): T;\n\n\t/**\n\t * Select all tasks for the given process instance id and its children.\n\t */\n\tprocessInstanceIdWithChildren(processInstanceId: string): T;\n\n\t/**\n\t * Select all tasks for the given case instance id and its children.\n\t */\n\tcaseInstanceIdWithChildren(caseInstanceId: string): T;\n\n\t/**\n\t * Only select tasks that are created on the given date.\n\t */\n\ttaskCreatedOn(createTime: Date): T;\n\n\t/**\n\t * Only select tasks that are created before the given date.\n\t */\n\ttaskCreatedBefore(before: Date): T;\n\n\t/**\n\t * Only select tasks that are created after the given date.\n\t */\n\ttaskCreatedAfter(after: Date): T;\n\n\t/**\n\t * Only select tasks that are started in progress on the given date.\n\t */\n\ttaskInProgressStartTimeOn(claimedTime: Date): T;\n\n\t/**\n\t * Only select tasks that are started in progress before the given date.\n\t */\n\ttaskInProgressStartTimeBefore(before: Date): T;\n\n\t/**\n\t * Only select tasks that are started in progress after the given date.\n\t */\n\ttaskInProgressStartTimeAfter(after: Date): T;\n\n\t/**\n\t * Select all tasks that have an in progress started user reference for the given value.\n\t */\n\ttaskInProgressStartedBy(startedBy: string): T;\n\n\t/**\n\t * Only select tasks that are claimed on the given date.\n\t */\n\ttaskClaimedOn(claimedTime: Date): T;\n\n\t/**\n\t * Only select tasks that are claimed before the given date.\n\t */\n\ttaskClaimedBefore(before: Date): T;\n\n\t/**\n\t * Only select tasks that are claimed after the given date.\n\t */\n\ttaskClaimedAfter(after: Date): T;\n\n\t/**\n\t * Select all tasks that have a claimed by user reference for the given value.\n\t */\n\ttaskClaimedBy(claimedBy: string): T;\n\n\t/**\n\t * Only select tasks that are suspended on the given date.\n\t */\n\ttaskSuspendedOn(suspendedTime: Date): T;\n\n\t/**\n\t * Only select tasks that are suspended before the given date.\n\t */\n\ttaskSuspendedBefore(before: Date): T;\n\n\t/**\n\t * Only select tasks that are suspended after the given date.\n\t */\n\ttaskSuspendedAfter(after: Date): T;\n\n\t/**\n\t * Select all tasks that have a suspended by user reference for the given value.\n\t */\n\ttaskSuspendedBy(suspendedBy: string): T;\n\n\t/**\n\t * Only select tasks with the given category.\n\t */\n\ttaskCategory(category: string): T;\n\n\t/**\n\t * Only select tasks belonging to one of the categories in the given list.\n\t *\n\t * @param taskCategoryInList\n\t * @throws FlowableIllegalArgumentException When passed category list is empty or <code>null</code> or contains <code>null</code> String.\n\t */\n\ttaskCategoryIn(taskCategoryInList: string[]): T;\n\n\t/**\n\t * Only select tasks with a defined category which do not belong to a category present in the given list.\n\t * <p>\n\t * NOTE: This method does <b>not</b> return tasks <b>without</b> category e.g. tasks having a <code>null</code> category.\n\t * To include <code>null</code> categories, use <code>query.or().taskCategoryNotIn(...).taskWithoutCategory().endOr()</code>\n\t * </p>\n\t *\n\t * @param taskCategoryNotInList\n\t * @throws FlowableIllegalArgumentException When passed category list is empty or <code>null</code> or contains <code>null String</code>.\n\t * @see #taskWithoutCategory\n\t */\n\ttaskCategoryNotIn(taskCategoryNotInList: string[]): T;\n\n\t/**\n\t * Selects tasks without category.\n\t * <p>\n\t * Can also be used in conjunction with other filter criteria to include tasks without category e.g. in <code>or</code> queries.\n\t * </p>\n\t * @see #taskCategoryNotIn(Collection)\n\t */\n\ttaskWithoutCategory(): T;\n\n\t/**\n\t * Only select tasks with form key.\n\t */\n\ttaskWithFormKey(): T;\n\n\t/**\n\t * Only select tasks with the given formKey.\n\t */\n\ttaskFormKey(formKey: string): T;\n\n\t/**\n\t * Only select tasks with the given taskDefinitionKey. The task definition key is the id of the userTask: &lt;userTask id=\"xxx\" .../&gt;\n\t **/\n\ttaskDefinitionKey(key: string): T;\n\n\t/**\n\t * Only select tasks with a taskDefinitionKey that match the given parameter. The syntax is that of SQL: for example usage: taskDefinitionKeyLike(\"%test%\"). The task definition key is the id of\n\t * the userTask: &lt;userTask id=\"xxx\" .../&gt;\n\t **/\n\ttaskDefinitionKeyLike(keyLike: string): T;\n\n\t/**\n\t * Only select tasks with the given taskDefinitionKeys. The task definition key is the id of the userTask: &lt;userTask id=\"xxx\" .../&gt;\n\t **/\n\ttaskDefinitionKeys(keys: string[]): T;\n\n\t/**\n\t * Only select tasks with the given state.\n\t **/\n\ttaskState(state: string): T;\n\n\t/**\n\t * Only select tasks with the given in progress start due date.\n\t */\n\ttaskInProgressStartDueDate(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks which have an in progress start due date before the given date.\n\t */\n\ttaskInProgressStartDueBefore(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks which have an in progress start due date after the given date.\n\t */\n\ttaskInProgressStartDueAfter(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks with no in progress start due date.\n\t */\n\twithoutTaskInProgressStartDueDate(): T;\n\n\t/**\n\t * Only select tasks with the given due date.\n\t */\n\ttaskDueDate(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks which have a due date before the given date.\n\t */\n\ttaskDueBefore(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks which have a due date after the given date.\n\t */\n\ttaskDueAfter(dueDate: Date): T;\n\n\t/**\n\t * Only select tasks with no due date.\n\t */\n\twithoutTaskDueDate(): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has the given process definition key.\n\t */\n\tprocessDefinitionKey(processDefinitionKey: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has a process definition key like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t */\n\tprocessDefinitionKeyLike(processDefinitionKeyLike: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has a process definition key like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t * \n\t * This method, unlike the {@link #processDefinitionKeyLike(String)} method will not take in account the upper/lower case: both the input parameter as the column value are lowercased when the\n\t * query is executed.\n\t */\n\tprocessDefinitionKeyLikeIgnoreCase(processDefinitionKeyLikeIgnoreCase: string): T;\n\n\t/** Only select tasks that have a process definition for which the key is present in the given list **/\n\tprocessDefinitionKeyIn(processDefinitionKeys: string[]): T;\n\n\t/**\n\t * Only select tasks which created from the given task definition referenced by id.\n\t */\n\ttaskDefinitionId(taskDefinitionId: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has the given process definition id.\n\t */\n\tprocessDefinitionId(processDefinitionId: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has the given process definition name.\n\t */\n\tprocessDefinitionName(processDefinitionName: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has a process definition name like the given value. The syntax that should be used is the same as in SQL, eg. %test%.\n\t */\n\tprocessDefinitionNameLike(processDefinitionNameLike: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance whose definition belongs to the category which is present in the given list.\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When passed category list is empty or <code>null</code> or contains <code>null String</code>.\n\t * @param processCategoryInList\n\t */\n\tprocessCategoryIn(processCategoryInList: string[]): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance whose definition does not belong to the category which is present in the given list.\n\t * \n\t * @throws FlowableIllegalArgumentException\n\t *             When passed category list is empty or <code>null</code> or contains <code>null String</code>.\n\t * @param processCategoryNotInList\n\t */\n\tprocessCategoryNotIn(processCategoryNotInList: string[]): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has the given deployment id.\n\t */\n\tdeploymentId(deploymentId: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process instance which has the given deployment id.\n\t */\n\tdeploymentIdIn(deploymentIds: string[]): T;\n\n\t/**\n\t * Only select tasks which are related to a case instance for to the given deployment id.\n\t */\n\tcmmnDeploymentId(cmmnDeploymentId: string): T;\n\n\t/**\n\t * Only select tasks which are related to a case instances for the given deployment id.\n\t */\n\tcmmnDeploymentIdIn(cmmnDeploymentIds: string[]): T;\n\n\t/**\n\t * Only select tasks which don't have a scope id set.\n\t */\n\twithoutScopeId(): T;\n\n\t/**\n\t * Only select tasks which have a local task variable with the given name set to the given value.\n\t */\n\ttaskVariableValueEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which have at least one local task variable with the given value.\n\t */\n\ttaskVariableValueEquals(variableValue: any): T;\n\n\t/**\n\t * Only select tasks which have a local string variable with the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\ttaskVariableValueEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a local task variable with the given name, but with a different value than the passed value. Byte-arrays and {@link Serializable} objects (which are not primitive\n\t * type wrappers) are not supported.\n\t */\n\ttaskVariableValueNotEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which have a local string variable with is not the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\ttaskVariableValueNotEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a local variable value greater than the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)\n\t * are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\ttaskVariableValueGreaterThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a local variable value greater than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive\n\t * type wrappers) are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\ttaskVariableValueGreaterThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a local variable value less than the passed value when the ended.Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers) are\n\t * not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\ttaskVariableValueLessThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a local variable value less than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\ttaskVariableValueLessThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a local variable value like the given value when they ended. This can be used on string variables only.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\ttaskVariableValueLike(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a local variable value like the given value (case insensitive) when they ended. This can be used on string variables only.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\ttaskVariableValueLikeIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a local variable with the given name.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t */\n\ttaskVariableExists(name: string): T;\n\n\t/**\n\t * Only select tasks which does not have a local variable with the given name.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t */\n\ttaskVariableNotExists(name: string): T;\n\n\t/**\n\t * Only select tasks which are part of a process that has a variable with the given name set to the given value.\n\t */\n\tprocessVariableValueEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a process that has at least one variable with the given value.\n\t */\n\tprocessVariableValueEquals(variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a process that has a local string variable which is not the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\tprocessVariableValueEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a variable with the given name, but with a different value than the passed value. Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t */\n\tprocessVariableValueNotEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a process that has a string variable with the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\tprocessVariableValueNotEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable value greater than the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\tprocessVariableValueGreaterThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value greater than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive\n\t * type wrappers) are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\tprocessVariableValueGreaterThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value less than the passed value when the ended.Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers) are\n\t * not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\tprocessVariableValueLessThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value less than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null.\n\t */\n\tprocessVariableValueLessThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value like the given value when they ended. This can be used on string variables only.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\tprocessVariableValueLike(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable value like the given value (case insensitive) when they ended. This can be used on string variables only.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t * @param value\n\t *            cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\tprocessVariableValueLikeIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable with the given name.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t */\n\tprocessVariableExists(name: string): T;\n\n\t/**\n\t * Only select tasks which does not have a global variable with the given name.\n\t * \n\t * @param name\n\t *            cannot be null.\n\t */\n\tprocessVariableNotExists(name: string): T;\n\n\t/**\n\t * Only select tasks which are part of a case that has a variable with the given name set to the given value.\n\t */\n\tcaseVariableValueEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a case that has at least one variable with the given value.\n\t */\n\tcaseVariableValueEquals(variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a case that has a local string variable which is not the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\tcaseVariableValueEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a variable with the given name, but with a different value than the passed value. Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t */\n\tcaseVariableValueNotEquals(variableName: string, variableValue: any): T;\n\n\t/**\n\t * Only select tasks which are part of a case that has a string variable with the given value, case insensitive.\n\t * <p>\n\t * This method only works if your database has encoding/collation that supports case-sensitive queries. For example, use \"collate UTF-8\" on MySQL and for MSSQL, select one of the case-sensitive\n\t * Collations available (<a href=\"http://msdn.microsoft.com/en-us/library/ms144250(v=sql.105).aspx\" >MSDN Server Collation Reference</a>).\n\t * </p>\n\t */\n\tcaseVariableValueNotEqualsIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable value greater than the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null.\n\t */\n\tcaseVariableValueGreaterThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value greater than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive\n\t * type wrappers) are not supported.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null.\n\t */\n\tcaseVariableValueGreaterThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value less than the passed value when the ended.Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers) are\n\t * not supported.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null.\n\t */\n\tcaseVariableValueLessThan(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value less than or equal to the passed value when they ended. Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type\n\t * wrappers) are not supported.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null.\n\t */\n\tcaseVariableValueLessThanOrEqual(name: string, value: any): T;\n\n\t/**\n\t * Only select tasks which have a global variable value like the given value when they ended. This can be used on string variables only.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\tcaseVariableValueLike(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable value like the given value (case insensitive) when they ended. This can be used on string variables only.\n\t *\n\t * @param name cannot be null.\n\t * @param value cannot be null. The string can include the wildcard character '%' to express like-strategy: starts with (string%), ends with (%string) or contains (%string%).\n\t */\n\tcaseVariableValueLikeIgnoreCase(name: string, value: string): T;\n\n\t/**\n\t * Only select tasks which have a global variable with the given name.\n\t *\n\t * @param name cannot be null.\n\t */\n\tcaseVariableExists(name: string): T;\n\n\t/**\n\t * Only select tasks which does not have a global variable with the given name.\n\t *\n\t * @param name cannot be null.\n\t */\n\tcaseVariableNotExists(name: string): T;\n\n\t/**\n\t * Only selects tasks which with the given root scope id\n\t */\n\ttaskRootScopeId(parentScopeId: string): T;\n\n\t/**\n\t * Only selects tasks which with the given parent scope id\n\t */\n\ttaskParentScopeId(parentScopeId: string): T;\n\n\t/**\n\t * Include local task variables in the task query result\n\t */\n\tincludeTaskLocalVariables(): T;\n\n\t/**\n\t * Include global process variables in the task query result\n\t */\n\tincludeProcessVariables(): T;\n\n\t/**\n\t * Include global case variables in the task query result\n\t */\n\tincludeCaseVariables(): T;\n\n\t/**\n\t * Include identity links in the task query result\n\t */\n\tincludeIdentityLinks(): T;\n\n\t/**\n\t * Localize task name and description to specified locale.\n\t */\n\tlocale(locale: string): T;\n\n\t/**\n\t * Instruct localization to fallback to more general locales including the default locale of the JVM if the specified locale is not found.\n\t */\n\twithLocalizationFallback(): T;\n\n\t/**\n\t * All query clauses called will be added to a single or-statement. This or-statement will be included with the other already existing clauses in the query, joined by an 'and'.\n\t * <p>\n\t * Calling endOr() will add all clauses to the regular query again. Calling or() after or() has been called or calling endOr() after endOr() has been called will result in an exception.\n\t * It is possible to call or() endOr() several times if each or() has a matching endOr(), e.g.:\n\t * </p>\n\t * {@code query.<ConditionA>}\n\t * {@code  .or().<conditionB>.<conditionC>.endOr()}\n\t * {@code  .<conditionD>.<conditionE>}\n\t * {@code  .or().<conditionF>.<conditionG>.endOr()}\n\t * <p>\n\t * will result in: conditionA &amp; (conditionB | conditionC) &amp; conditionD &amp; conditionE &amp; (conditionF | conditionG)\n\t */\n\tor(): T;\n\n\tendOr(): T;\n\n\t// ORDERING\n\n\t/**\n\t * Order by task id (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskId(): T;\n\n\t/**\n\t * Order by task name (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskName(): T;\n\n\t/**\n\t * Order by description (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskDescription(): T;\n\n\t/**\n\t * Order by priority (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskPriority(): T;\n\n\t/**\n\t * Order by assignee (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskAssignee(): T;\n\n\t/**\n\t * Order by the time on which the tasks were created (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskCreateTime(): T;\n\n\t/**\n\t * Order by process instance id (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByProcessInstanceId(): T;\n\n\t/**\n\t * Order by execution id (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByExecutionId(): T;\n\n\t/**\n\t * Order by process definition id (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByProcessDefinitionId(): T;\n\n\t/**\n\t * Order by task due date (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskDueDate(): T;\n\n\t/**\n\t * Order by task owner (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskOwner(): T;\n\n\t/**\n\t * Order by task definition key (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTaskDefinitionKey(): T;\n\n\t/**\n\t * Order by tenant id (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByTenantId(): T;\n\n\t/**\n\t * Order by due date (needs to be followed by {@link #asc()} or {@link #desc()}). If any of the tasks have null for the due date, these will be first in the result.\n\t */\n\torderByDueDateNullsFirst(): T;\n\n\t/**\n\t * Order by due date (needs to be followed by {@link #asc()} or {@link #desc()}). If any of the tasks have null for the due date, these will be last in the result.\n\t */\n\torderByDueDateNullsLast(): T;\n\n\t/**\n\t * Order by category (needs to be followed by {@link #asc()} or {@link #desc()}).\n\t */\n\torderByCategory(): T;\n\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Tasks;\n}\n"],
  "mappings": "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",
  "names": ["DelegationState", "NullHandlingOnOrder"]
}
