@webiny/api-headless-cms-bulk-actions 5.41.0-beta.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 (120) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +15 -0
  3. package/abstractions/IListEntries.d.ts +7 -0
  4. package/abstractions/IListEntries.js +7 -0
  5. package/abstractions/IListEntries.js.map +1 -0
  6. package/abstractions/IProcessEntry.d.ts +4 -0
  7. package/abstractions/IProcessEntry.js +7 -0
  8. package/abstractions/IProcessEntry.js.map +1 -0
  9. package/abstractions/IUseCase.d.ts +3 -0
  10. package/abstractions/IUseCase.js +7 -0
  11. package/abstractions/IUseCase.js.map +1 -0
  12. package/abstractions/index.d.ts +3 -0
  13. package/abstractions/index.js +40 -0
  14. package/abstractions/index.js.map +1 -0
  15. package/handlers/eventBridgeEventHandler.d.ts +1 -0
  16. package/handlers/eventBridgeEventHandler.js +49 -0
  17. package/handlers/eventBridgeEventHandler.js.map +1 -0
  18. package/handlers/index.d.ts +1 -0
  19. package/handlers/index.js +14 -0
  20. package/handlers/index.js.map +1 -0
  21. package/handlers/setupEventsTenant.d.ts +1 -0
  22. package/handlers/setupEventsTenant.js +19 -0
  23. package/handlers/setupEventsTenant.js.map +1 -0
  24. package/index.d.ts +6 -0
  25. package/index.js +73 -0
  26. package/index.js.map +1 -0
  27. package/package.json +52 -0
  28. package/plugins/createBulkAction.d.ts +10 -0
  29. package/plugins/createBulkAction.js +36 -0
  30. package/plugins/createBulkAction.js.map +1 -0
  31. package/plugins/createBulkActionGraphQL.d.ts +7 -0
  32. package/plugins/createBulkActionGraphQL.js +56 -0
  33. package/plugins/createBulkActionGraphQL.js.map +1 -0
  34. package/plugins/createBulkActionTasks.d.ts +9 -0
  35. package/plugins/createBulkActionTasks.js +135 -0
  36. package/plugins/createBulkActionTasks.js.map +1 -0
  37. package/plugins/createDefaultGraphQL.d.ts +3 -0
  38. package/plugins/createDefaultGraphQL.js +57 -0
  39. package/plugins/createDefaultGraphQL.js.map +1 -0
  40. package/plugins/index.d.ts +2 -0
  41. package/plugins/index.js +29 -0
  42. package/plugins/index.js.map +1 -0
  43. package/tasks/createBulkActionEntriesTasks.d.ts +1 -0
  44. package/tasks/createBulkActionEntriesTasks.js +38 -0
  45. package/tasks/createBulkActionEntriesTasks.js.map +1 -0
  46. package/tasks/createEmptyTrashBinsTask.d.ts +2 -0
  47. package/tasks/createEmptyTrashBinsTask.js +85 -0
  48. package/tasks/createEmptyTrashBinsTask.js.map +1 -0
  49. package/tasks/index.d.ts +2 -0
  50. package/tasks/index.js +29 -0
  51. package/tasks/index.js.map +1 -0
  52. package/types.d.ts +45 -0
  53. package/types.js +21 -0
  54. package/types.js.map +1 -0
  55. package/useCases/DeleteEntry.d.ts +10 -0
  56. package/useCases/DeleteEntry.js +26 -0
  57. package/useCases/DeleteEntry.js.map +1 -0
  58. package/useCases/ListDeletedEntries.d.ts +13 -0
  59. package/useCases/ListDeletedEntries.js +28 -0
  60. package/useCases/ListDeletedEntries.js.map +1 -0
  61. package/useCases/ListLatestEntries.d.ts +13 -0
  62. package/useCases/ListLatestEntries.js +28 -0
  63. package/useCases/ListLatestEntries.js.map +1 -0
  64. package/useCases/ListNotPublishedEntries.d.ts +13 -0
  65. package/useCases/ListNotPublishedEntries.js +34 -0
  66. package/useCases/ListNotPublishedEntries.js.map +1 -0
  67. package/useCases/ListPublishedEntries.d.ts +13 -0
  68. package/useCases/ListPublishedEntries.js +28 -0
  69. package/useCases/ListPublishedEntries.js.map +1 -0
  70. package/useCases/MoveEntryToFolder.d.ts +13 -0
  71. package/useCases/MoveEntryToFolder.js +23 -0
  72. package/useCases/MoveEntryToFolder.js.map +1 -0
  73. package/useCases/MoveEntryToTrash.d.ts +10 -0
  74. package/useCases/MoveEntryToTrash.js +26 -0
  75. package/useCases/MoveEntryToTrash.js.map +1 -0
  76. package/useCases/PublishEntry.d.ts +10 -0
  77. package/useCases/PublishEntry.js +20 -0
  78. package/useCases/PublishEntry.js.map +1 -0
  79. package/useCases/RestoreEntryFromTrash.d.ts +10 -0
  80. package/useCases/RestoreEntryFromTrash.js +24 -0
  81. package/useCases/RestoreEntryFromTrash.js.map +1 -0
  82. package/useCases/UnpublishEntry.d.ts +10 -0
  83. package/useCases/UnpublishEntry.js +20 -0
  84. package/useCases/UnpublishEntry.js.map +1 -0
  85. package/useCases/index.d.ts +10 -0
  86. package/useCases/index.js +117 -0
  87. package/useCases/index.js.map +1 -0
  88. package/useCases/internals/ChildTaskCleanup/ChildTasksCleanup.d.ts +17 -0
  89. package/useCases/internals/ChildTaskCleanup/ChildTasksCleanup.js +77 -0
  90. package/useCases/internals/ChildTaskCleanup/ChildTasksCleanup.js.map +1 -0
  91. package/useCases/internals/ChildTaskCleanup/index.d.ts +1 -0
  92. package/useCases/internals/ChildTaskCleanup/index.js +18 -0
  93. package/useCases/internals/ChildTaskCleanup/index.js.map +1 -0
  94. package/useCases/internals/CreateTasksByModel/CreateTasksByModel.d.ts +13 -0
  95. package/useCases/internals/CreateTasksByModel/CreateTasksByModel.js +111 -0
  96. package/useCases/internals/CreateTasksByModel/CreateTasksByModel.js.map +1 -0
  97. package/useCases/internals/CreateTasksByModel/TaskCache.d.ts +36 -0
  98. package/useCases/internals/CreateTasksByModel/TaskCache.js +76 -0
  99. package/useCases/internals/CreateTasksByModel/TaskCache.js.map +1 -0
  100. package/useCases/internals/CreateTasksByModel/index.d.ts +1 -0
  101. package/useCases/internals/CreateTasksByModel/index.js +18 -0
  102. package/useCases/internals/CreateTasksByModel/index.js.map +1 -0
  103. package/useCases/internals/ProcessTask/ProcessTask.d.ts +14 -0
  104. package/useCases/internals/ProcessTask/ProcessTask.js +81 -0
  105. package/useCases/internals/ProcessTask/ProcessTask.js.map +1 -0
  106. package/useCases/internals/ProcessTask/Result.d.ts +9 -0
  107. package/useCases/internals/ProcessTask/Result.js +29 -0
  108. package/useCases/internals/ProcessTask/Result.js.map +1 -0
  109. package/useCases/internals/ProcessTask/index.d.ts +1 -0
  110. package/useCases/internals/ProcessTask/index.js +18 -0
  111. package/useCases/internals/ProcessTask/index.js.map +1 -0
  112. package/useCases/internals/ProcessTasksByModel/ProcessTasksByModel.d.ts +11 -0
  113. package/useCases/internals/ProcessTasksByModel/ProcessTasksByModel.js +67 -0
  114. package/useCases/internals/ProcessTasksByModel/ProcessTasksByModel.js.map +1 -0
  115. package/useCases/internals/ProcessTasksByModel/index.d.ts +1 -0
  116. package/useCases/internals/ProcessTasksByModel/index.js +18 -0
  117. package/useCases/internals/ProcessTasksByModel/index.js.map +1 -0
  118. package/useCases/internals/index.d.ts +4 -0
  119. package/useCases/internals/index.js +51 -0
  120. package/useCases/internals/index.js.map +1 -0
@@ -0,0 +1,13 @@
1
+ import { ITaskResponseResult } from "@webiny/tasks";
2
+ import { IListEntries } from "../../../abstractions";
3
+ import { IBulkActionOperationByModelTaskParams } from "../../../types";
4
+ /**
5
+ * The `CreateTasksByModel` class handles the execution of a task to process entries in batches.
6
+ */
7
+ export declare class CreateTasksByModel {
8
+ private readonly taskCache;
9
+ private listEntriesGateway;
10
+ private readonly batchSize;
11
+ constructor(taskDefinition: string, listEntriesGateway: IListEntries, batchSize: number);
12
+ execute(params: IBulkActionOperationByModelTaskParams): Promise<ITaskResponseResult>;
13
+ }
@@ -0,0 +1,111 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.CreateTasksByModel = void 0;
7
+ var _TaskCache = require("./TaskCache");
8
+ var _types = require("../../../types");
9
+ const MAX_TASK_LIST_LENGTH = 10;
10
+
11
+ /**
12
+ * The `CreateTasksByModel` class handles the execution of a task to process entries in batches.
13
+ */
14
+ class CreateTasksByModel {
15
+ constructor(taskDefinition, listEntriesGateway, batchSize) {
16
+ this.taskCache = new _TaskCache.TaskCache(taskDefinition);
17
+ this.listEntriesGateway = listEntriesGateway;
18
+ this.batchSize = batchSize;
19
+ }
20
+ async execute(params) {
21
+ const {
22
+ response,
23
+ input,
24
+ isAborted,
25
+ isCloseToTimeout,
26
+ context,
27
+ store
28
+ } = params;
29
+ try {
30
+ const listEntriesParams = {
31
+ where: input.where,
32
+ search: input.search,
33
+ after: input.after,
34
+ limit: this.batchSize
35
+ };
36
+ while (true) {
37
+ if (isAborted()) {
38
+ return response.aborted();
39
+ } else if (isCloseToTimeout()) {
40
+ await this.taskCache.triggerTask(context, store.getTask());
41
+ return response.continue({
42
+ ...input,
43
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
44
+ });
45
+ }
46
+
47
+ // List entries from the HCMS based on the provided query
48
+ const {
49
+ entries,
50
+ meta
51
+ } = await this.listEntriesGateway.execute(input.modelId, listEntriesParams);
52
+
53
+ // End the task if no entries match the query
54
+ if (meta.totalCount === 0) {
55
+ return response.continue({
56
+ ...input,
57
+ action: _types.BulkActionOperationByModelAction.END_TASK
58
+ });
59
+ }
60
+
61
+ // Continue processing if we are reached the task list length limit
62
+ if (this.taskCache.getTasksLength() === MAX_TASK_LIST_LENGTH) {
63
+ await this.taskCache.triggerTask(context, store.getTask());
64
+ return response.continue({
65
+ ...input,
66
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
67
+ });
68
+ }
69
+
70
+ // Continue processing if no entries are returned in the current batch
71
+ if (entries.length === 0) {
72
+ await this.taskCache.triggerTask(context, store.getTask());
73
+ return response.continue({
74
+ ...input,
75
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
76
+ });
77
+ }
78
+
79
+ // Extract entry IDs
80
+ const ids = [];
81
+ for (let i = 0; i < entries.length; i++) {
82
+ ids.push(entries[i].id);
83
+ }
84
+ if (ids.length > 0) {
85
+ // Cache the task with the entry IDs
86
+ this.taskCache.cacheTask({
87
+ modelId: input.modelId,
88
+ identity: input.identity,
89
+ data: input.data,
90
+ ids
91
+ });
92
+ }
93
+
94
+ // Continue processing if there are no more entries or pagination is complete
95
+ if (!meta.hasMoreItems || !meta.cursor) {
96
+ await this.taskCache.triggerTask(context, store.getTask());
97
+ return response.continue({
98
+ ...input,
99
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
100
+ });
101
+ }
102
+ listEntriesParams.after = meta.cursor;
103
+ }
104
+ } catch (ex) {
105
+ return response.error(ex.message ?? `Error while creating task.`);
106
+ }
107
+ }
108
+ }
109
+ exports.CreateTasksByModel = CreateTasksByModel;
110
+
111
+ //# sourceMappingURL=CreateTasksByModel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_TaskCache","require","_types","MAX_TASK_LIST_LENGTH","CreateTasksByModel","constructor","taskDefinition","listEntriesGateway","batchSize","taskCache","TaskCache","execute","params","response","input","isAborted","isCloseToTimeout","context","store","listEntriesParams","where","search","after","limit","aborted","triggerTask","getTask","continue","action","BulkActionOperationByModelAction","PROCESS_SUBTASKS","entries","meta","modelId","totalCount","END_TASK","getTasksLength","length","ids","i","push","id","cacheTask","identity","data","hasMoreItems","cursor","ex","error","message","exports"],"sources":["CreateTasksByModel.ts"],"sourcesContent":["import { ITaskResponseResult } from \"@webiny/tasks\";\nimport { TaskCache } from \"./TaskCache\";\nimport { CmsEntryListParams } from \"@webiny/api-headless-cms/types\";\nimport { IListEntries } from \"~/abstractions\";\nimport { BulkActionOperationByModelAction, IBulkActionOperationByModelTaskParams } from \"~/types\";\n\nconst MAX_TASK_LIST_LENGTH = 10;\n\n/**\n * The `CreateTasksByModel` class handles the execution of a task to process entries in batches.\n */\nexport class CreateTasksByModel {\n private readonly taskCache: TaskCache;\n private listEntriesGateway: IListEntries;\n private readonly batchSize: number;\n\n constructor(taskDefinition: string, listEntriesGateway: IListEntries, batchSize: number) {\n this.taskCache = new TaskCache(taskDefinition);\n this.listEntriesGateway = listEntriesGateway;\n this.batchSize = batchSize;\n }\n\n async execute(params: IBulkActionOperationByModelTaskParams): Promise<ITaskResponseResult> {\n const { response, input, isAborted, isCloseToTimeout, context, store } = params;\n\n try {\n const listEntriesParams: CmsEntryListParams = {\n where: input.where,\n search: input.search,\n after: input.after,\n limit: this.batchSize\n };\n\n while (true) {\n if (isAborted()) {\n return response.aborted();\n } else if (isCloseToTimeout()) {\n await this.taskCache.triggerTask(context, store.getTask());\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n });\n }\n\n // List entries from the HCMS based on the provided query\n const { entries, meta } = await this.listEntriesGateway.execute(\n input.modelId,\n listEntriesParams\n );\n\n // End the task if no entries match the query\n if (meta.totalCount === 0) {\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.END_TASK\n });\n }\n\n // Continue processing if we are reached the task list length limit\n if (this.taskCache.getTasksLength() === MAX_TASK_LIST_LENGTH) {\n await this.taskCache.triggerTask(context, store.getTask());\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n });\n }\n\n // Continue processing if no entries are returned in the current batch\n if (entries.length === 0) {\n await this.taskCache.triggerTask(context, store.getTask());\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n });\n }\n\n // Extract entry IDs\n const ids: string[] = [];\n for (let i = 0; i < entries.length; i++) {\n ids.push(entries[i].id);\n }\n\n if (ids.length > 0) {\n // Cache the task with the entry IDs\n this.taskCache.cacheTask({\n modelId: input.modelId,\n identity: input.identity,\n data: input.data,\n ids\n });\n }\n\n // Continue processing if there are no more entries or pagination is complete\n if (!meta.hasMoreItems || !meta.cursor) {\n await this.taskCache.triggerTask(context, store.getTask());\n\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n });\n }\n\n listEntriesParams.after = meta.cursor;\n }\n } catch (ex) {\n return response.error(ex.message ?? `Error while creating task.`);\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,36 @@
1
+ import { HcmsBulkActionsContext } from "../../../types";
2
+ import { ITask, ITaskDataInput } from "@webiny/tasks";
3
+ /**
4
+ * TaskCache class for managing and triggering cached tasks.
5
+ * @template TTask - Task input data.
6
+ */
7
+ export declare class TaskCache<TTask = ITaskDataInput> {
8
+ private readonly taskDefinition;
9
+ private taskCache;
10
+ constructor(taskDefinition: string);
11
+ /**
12
+ * Adds a task to the cache.
13
+ * @param {TTask} item - The task input data to be cached.
14
+ */
15
+ cacheTask(item: TTask): void;
16
+ /**
17
+ * Triggers all cached tasks using the provided context and parent task.
18
+ * @param {HcmsBulkActionsContext} context - The context used to trigger the tasks.
19
+ * @param {ITask} parent - The parent task to associate with the triggered tasks.
20
+ */
21
+ triggerTask(context: HcmsBulkActionsContext, parent: ITask): Promise<void>;
22
+ /**
23
+ * Retrieves the cached tasks length.
24
+ * @returns number
25
+ */
26
+ getTasksLength(): number;
27
+ /**
28
+ * Retrieves the cached tasks.
29
+ * @returns {TTask[]} The list of cached tasks.
30
+ */
31
+ private getTasks;
32
+ /**
33
+ * Clears all cached tasks.
34
+ */
35
+ private clearTasks;
36
+ }
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.TaskCache = void 0;
7
+ /**
8
+ * TaskCache class for managing and triggering cached tasks.
9
+ * @template TTask - Task input data.
10
+ */
11
+ class TaskCache {
12
+ taskCache = [];
13
+ constructor(taskDefinition) {
14
+ this.taskDefinition = taskDefinition;
15
+ }
16
+
17
+ /**
18
+ * Adds a task to the cache.
19
+ * @param {TTask} item - The task input data to be cached.
20
+ */
21
+ cacheTask(item) {
22
+ this.taskCache.push(item);
23
+ }
24
+
25
+ /**
26
+ * Triggers all cached tasks using the provided context and parent task.
27
+ * @param {HcmsBulkActionsContext} context - The context used to trigger the tasks.
28
+ * @param {ITask} parent - The parent task to associate with the triggered tasks.
29
+ */
30
+ async triggerTask(context, parent) {
31
+ const tasks = this.getTasks();
32
+ if (tasks.length === 0) {
33
+ return;
34
+ }
35
+ for (const task of tasks) {
36
+ try {
37
+ await context.tasks.trigger({
38
+ definition: this.taskDefinition,
39
+ parent,
40
+ input: task
41
+ });
42
+ } catch (error) {
43
+ console.error(`Error triggering task.`, error);
44
+ }
45
+ }
46
+
47
+ // Clear the cache after processing
48
+ this.clearTasks();
49
+ }
50
+
51
+ /**
52
+ * Retrieves the cached tasks length.
53
+ * @returns number
54
+ */
55
+ getTasksLength() {
56
+ return this.getTasks().length;
57
+ }
58
+
59
+ /**
60
+ * Retrieves the cached tasks.
61
+ * @returns {TTask[]} The list of cached tasks.
62
+ */
63
+ getTasks() {
64
+ return this.taskCache;
65
+ }
66
+
67
+ /**
68
+ * Clears all cached tasks.
69
+ */
70
+ clearTasks() {
71
+ this.taskCache = [];
72
+ }
73
+ }
74
+ exports.TaskCache = TaskCache;
75
+
76
+ //# sourceMappingURL=TaskCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["TaskCache","taskCache","constructor","taskDefinition","cacheTask","item","push","triggerTask","context","parent","tasks","getTasks","length","task","trigger","definition","input","error","console","clearTasks","getTasksLength","exports"],"sources":["TaskCache.ts"],"sourcesContent":["import { HcmsBulkActionsContext } from \"~/types\";\nimport { ITask, ITaskDataInput } from \"@webiny/tasks\";\n\n/**\n * TaskCache class for managing and triggering cached tasks.\n * @template TTask - Task input data.\n */\nexport class TaskCache<TTask = ITaskDataInput> {\n private readonly taskDefinition: string;\n private taskCache: TTask[] = [];\n\n constructor(taskDefinition: string) {\n this.taskDefinition = taskDefinition;\n }\n\n /**\n * Adds a task to the cache.\n * @param {TTask} item - The task input data to be cached.\n */\n cacheTask(item: TTask) {\n this.taskCache.push(item);\n }\n\n /**\n * Triggers all cached tasks using the provided context and parent task.\n * @param {HcmsBulkActionsContext} context - The context used to trigger the tasks.\n * @param {ITask} parent - The parent task to associate with the triggered tasks.\n */\n async triggerTask(context: HcmsBulkActionsContext, parent: ITask) {\n const tasks = this.getTasks();\n\n if (tasks.length === 0) {\n return;\n }\n\n for (const task of tasks) {\n try {\n await context.tasks.trigger<TTask>({\n definition: this.taskDefinition,\n parent,\n input: task\n });\n } catch (error) {\n console.error(`Error triggering task.`, error);\n }\n }\n\n // Clear the cache after processing\n this.clearTasks();\n }\n\n /**\n * Retrieves the cached tasks length.\n * @returns number\n */\n getTasksLength() {\n return this.getTasks().length;\n }\n\n /**\n * Retrieves the cached tasks.\n * @returns {TTask[]} The list of cached tasks.\n */\n private getTasks() {\n return this.taskCache;\n }\n\n /**\n * Clears all cached tasks.\n */\n private clearTasks() {\n this.taskCache = [];\n }\n}\n"],"mappings":";;;;;;AAGA;AACA;AACA;AACA;AACO,MAAMA,SAAS,CAAyB;EAEnCC,SAAS,GAAY,EAAE;EAE/BC,WAAWA,CAACC,cAAsB,EAAE;IAChC,IAAI,CAACA,cAAc,GAAGA,cAAc;EACxC;;EAEA;AACJ;AACA;AACA;EACIC,SAASA,CAACC,IAAW,EAAE;IACnB,IAAI,CAACJ,SAAS,CAACK,IAAI,CAACD,IAAI,CAAC;EAC7B;;EAEA;AACJ;AACA;AACA;AACA;EACI,MAAME,WAAWA,CAACC,OAA+B,EAAEC,MAAa,EAAE;IAC9D,MAAMC,KAAK,GAAG,IAAI,CAACC,QAAQ,CAAC,CAAC;IAE7B,IAAID,KAAK,CAACE,MAAM,KAAK,CAAC,EAAE;MACpB;IACJ;IAEA,KAAK,MAAMC,IAAI,IAAIH,KAAK,EAAE;MACtB,IAAI;QACA,MAAMF,OAAO,CAACE,KAAK,CAACI,OAAO,CAAQ;UAC/BC,UAAU,EAAE,IAAI,CAACZ,cAAc;UAC/BM,MAAM;UACNO,KAAK,EAAEH;QACX,CAAC,CAAC;MACN,CAAC,CAAC,OAAOI,KAAK,EAAE;QACZC,OAAO,CAACD,KAAK,CAAE,wBAAuB,EAAEA,KAAK,CAAC;MAClD;IACJ;;IAEA;IACA,IAAI,CAACE,UAAU,CAAC,CAAC;EACrB;;EAEA;AACJ;AACA;AACA;EACIC,cAAcA,CAAA,EAAG;IACb,OAAO,IAAI,CAACT,QAAQ,CAAC,CAAC,CAACC,MAAM;EACjC;;EAEA;AACJ;AACA;AACA;EACYD,QAAQA,CAAA,EAAG;IACf,OAAO,IAAI,CAACV,SAAS;EACzB;;EAEA;AACJ;AACA;EACYkB,UAAUA,CAAA,EAAG;IACjB,IAAI,CAAClB,SAAS,GAAG,EAAE;EACvB;AACJ;AAACoB,OAAA,CAAArB,SAAA,GAAAA,SAAA","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export * from "./CreateTasksByModel";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _CreateTasksByModel = require("./CreateTasksByModel");
7
+ Object.keys(_CreateTasksByModel).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _CreateTasksByModel[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _CreateTasksByModel[key];
14
+ }
15
+ });
16
+ });
17
+
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_CreateTasksByModel","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["index.ts"],"sourcesContent":["export * from \"./CreateTasksByModel\";\n"],"mappings":";;;;;AAAA,IAAAA,mBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,mBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,mBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,mBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
@@ -0,0 +1,14 @@
1
+ import { IBulkActionOperationTaskParams } from "../../../types";
2
+ import { IProcessEntry } from "../../../abstractions";
3
+ /**
4
+ * The `ProcessTask` class is responsible for processing a batch of entries
5
+ * based on the provided parameters. It uses a gateway to perform the actual
6
+ * processing and maintains the results of the operations, including successfully
7
+ * processed and failed entries.
8
+ */
9
+ export declare class ProcessTask {
10
+ private readonly result;
11
+ private gateway;
12
+ constructor(gateway: IProcessEntry);
13
+ execute(params: IBulkActionOperationTaskParams): Promise<import("@webiny/tasks").ITaskResponseErrorResult | import("@webiny/tasks").ITaskResponseAbortedResult | import("@webiny/tasks").ITaskResponseContinueResult<import("../../../types").IBulkActionOperationInput> | import("@webiny/tasks").ITaskResponseDoneResult<import("../../../types").IBulkActionOperationOutput>>;
14
+ }
@@ -0,0 +1,81 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ProcessTask = void 0;
7
+ var _Result = require("./Result");
8
+ /**
9
+ * The `ProcessTask` class is responsible for processing a batch of entries
10
+ * based on the provided parameters. It uses a gateway to perform the actual
11
+ * processing and maintains the results of the operations, including successfully
12
+ * processed and failed entries.
13
+ */
14
+ class ProcessTask {
15
+ constructor(gateway) {
16
+ this.result = new _Result.Result();
17
+ this.gateway = gateway;
18
+ }
19
+ async execute(params) {
20
+ const {
21
+ input,
22
+ response,
23
+ isAborted,
24
+ isCloseToTimeout,
25
+ context
26
+ } = params;
27
+ try {
28
+ if (isAborted()) {
29
+ return response.aborted();
30
+ } else if (isCloseToTimeout()) {
31
+ return response.continue({
32
+ ...input
33
+ });
34
+ }
35
+
36
+ // Check if the input contains a model ID.
37
+ if (!input.modelId) {
38
+ return response.error(`Missing "modelId" in the input.`);
39
+ }
40
+
41
+ // Check if the model exists.
42
+ const model = await context.cms.getModel(input.modelId);
43
+ if (!model) {
44
+ return response.error(`Model with ${input.modelId} not found!`);
45
+ }
46
+
47
+ // Check if there are any IDs to process.
48
+ if (!input.ids || input.ids.length === 0) {
49
+ return response.done(`Task done: no entries to process for "${input.modelId}" model.`);
50
+ }
51
+
52
+ // Set the security identity in the context.
53
+ context.security.setIdentity(input.identity);
54
+
55
+ // Process each ID in the input.
56
+ for (const id of input.ids) {
57
+ try {
58
+ // Execute the gateway operation for the current ID.
59
+ await this.gateway.execute(model, id, input.data);
60
+ // Add the ID to the list of successfully processed entries.
61
+ this.result.addDone(id);
62
+ } catch (ex) {
63
+ console.error(ex.message || `Failed to process entry with id "${id}".`);
64
+ // Add the ID to the list of failed entries.
65
+ this.result.addFailed(id);
66
+ }
67
+ }
68
+
69
+ // Return a done response with the results of the processing.
70
+ return response.done(`Task done: all entries processed for "${model.name}" model.`, {
71
+ done: this.result.getDone(),
72
+ failed: this.result.getFailed()
73
+ });
74
+ } catch (ex) {
75
+ return response.error(ex.message ?? `Error while processing task.`);
76
+ }
77
+ }
78
+ }
79
+ exports.ProcessTask = ProcessTask;
80
+
81
+ //# sourceMappingURL=ProcessTask.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_Result","require","ProcessTask","constructor","gateway","result","Result","execute","params","input","response","isAborted","isCloseToTimeout","context","aborted","continue","modelId","error","model","cms","getModel","ids","length","done","security","setIdentity","identity","id","data","addDone","ex","console","message","addFailed","name","getDone","failed","getFailed","exports"],"sources":["ProcessTask.ts"],"sourcesContent":["import { Result } from \"./Result\";\nimport { IBulkActionOperationTaskParams } from \"~/types\";\nimport { IProcessEntry } from \"~/abstractions\";\n\n/**\n * The `ProcessTask` class is responsible for processing a batch of entries\n * based on the provided parameters. It uses a gateway to perform the actual\n * processing and maintains the results of the operations, including successfully\n * processed and failed entries.\n */\nexport class ProcessTask {\n private readonly result: Result;\n private gateway: IProcessEntry;\n\n constructor(gateway: IProcessEntry) {\n this.result = new Result();\n this.gateway = gateway;\n }\n\n async execute(params: IBulkActionOperationTaskParams) {\n const { input, response, isAborted, isCloseToTimeout, context } = params;\n\n try {\n if (isAborted()) {\n return response.aborted();\n } else if (isCloseToTimeout()) {\n return response.continue({\n ...input\n });\n }\n\n // Check if the input contains a model ID.\n if (!input.modelId) {\n return response.error(`Missing \"modelId\" in the input.`);\n }\n\n // Check if the model exists.\n const model = await context.cms.getModel(input.modelId);\n\n if (!model) {\n return response.error(`Model with ${input.modelId} not found!`);\n }\n\n // Check if there are any IDs to process.\n if (!input.ids || input.ids.length === 0) {\n return response.done(\n `Task done: no entries to process for \"${input.modelId}\" model.`\n );\n }\n\n // Set the security identity in the context.\n context.security.setIdentity(input.identity);\n\n // Process each ID in the input.\n for (const id of input.ids) {\n try {\n // Execute the gateway operation for the current ID.\n await this.gateway.execute(model, id, input.data);\n // Add the ID to the list of successfully processed entries.\n this.result.addDone(id);\n } catch (ex) {\n console.error(ex.message || `Failed to process entry with id \"${id}\".`);\n // Add the ID to the list of failed entries.\n this.result.addFailed(id);\n }\n }\n\n // Return a done response with the results of the processing.\n return response.done(`Task done: all entries processed for \"${model.name}\" model.`, {\n done: this.result.getDone(),\n failed: this.result.getFailed()\n });\n } catch (ex) {\n return response.error(ex.message ?? `Error while processing task.`);\n }\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAIA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,WAAW,CAAC;EAIrBC,WAAWA,CAACC,OAAsB,EAAE;IAChC,IAAI,CAACC,MAAM,GAAG,IAAIC,cAAM,CAAC,CAAC;IAC1B,IAAI,CAACF,OAAO,GAAGA,OAAO;EAC1B;EAEA,MAAMG,OAAOA,CAACC,MAAsC,EAAE;IAClD,MAAM;MAAEC,KAAK;MAAEC,QAAQ;MAAEC,SAAS;MAAEC,gBAAgB;MAAEC;IAAQ,CAAC,GAAGL,MAAM;IAExE,IAAI;MACA,IAAIG,SAAS,CAAC,CAAC,EAAE;QACb,OAAOD,QAAQ,CAACI,OAAO,CAAC,CAAC;MAC7B,CAAC,MAAM,IAAIF,gBAAgB,CAAC,CAAC,EAAE;QAC3B,OAAOF,QAAQ,CAACK,QAAQ,CAAC;UACrB,GAAGN;QACP,CAAC,CAAC;MACN;;MAEA;MACA,IAAI,CAACA,KAAK,CAACO,OAAO,EAAE;QAChB,OAAON,QAAQ,CAACO,KAAK,CAAE,iCAAgC,CAAC;MAC5D;;MAEA;MACA,MAAMC,KAAK,GAAG,MAAML,OAAO,CAACM,GAAG,CAACC,QAAQ,CAACX,KAAK,CAACO,OAAO,CAAC;MAEvD,IAAI,CAACE,KAAK,EAAE;QACR,OAAOR,QAAQ,CAACO,KAAK,CAAE,cAAaR,KAAK,CAACO,OAAQ,aAAY,CAAC;MACnE;;MAEA;MACA,IAAI,CAACP,KAAK,CAACY,GAAG,IAAIZ,KAAK,CAACY,GAAG,CAACC,MAAM,KAAK,CAAC,EAAE;QACtC,OAAOZ,QAAQ,CAACa,IAAI,CACf,yCAAwCd,KAAK,CAACO,OAAQ,UAC3D,CAAC;MACL;;MAEA;MACAH,OAAO,CAACW,QAAQ,CAACC,WAAW,CAAChB,KAAK,CAACiB,QAAQ,CAAC;;MAE5C;MACA,KAAK,MAAMC,EAAE,IAAIlB,KAAK,CAACY,GAAG,EAAE;QACxB,IAAI;UACA;UACA,MAAM,IAAI,CAACjB,OAAO,CAACG,OAAO,CAACW,KAAK,EAAES,EAAE,EAAElB,KAAK,CAACmB,IAAI,CAAC;UACjD;UACA,IAAI,CAACvB,MAAM,CAACwB,OAAO,CAACF,EAAE,CAAC;QAC3B,CAAC,CAAC,OAAOG,EAAE,EAAE;UACTC,OAAO,CAACd,KAAK,CAACa,EAAE,CAACE,OAAO,IAAK,oCAAmCL,EAAG,IAAG,CAAC;UACvE;UACA,IAAI,CAACtB,MAAM,CAAC4B,SAAS,CAACN,EAAE,CAAC;QAC7B;MACJ;;MAEA;MACA,OAAOjB,QAAQ,CAACa,IAAI,CAAE,yCAAwCL,KAAK,CAACgB,IAAK,UAAS,EAAE;QAChFX,IAAI,EAAE,IAAI,CAAClB,MAAM,CAAC8B,OAAO,CAAC,CAAC;QAC3BC,MAAM,EAAE,IAAI,CAAC/B,MAAM,CAACgC,SAAS,CAAC;MAClC,CAAC,CAAC;IACN,CAAC,CAAC,OAAOP,EAAE,EAAE;MACT,OAAOpB,QAAQ,CAACO,KAAK,CAACa,EAAE,CAACE,OAAO,IAAK,8BAA6B,CAAC;IACvE;EACJ;AACJ;AAACM,OAAA,CAAApC,WAAA,GAAAA,WAAA","ignoreList":[]}
@@ -0,0 +1,9 @@
1
+ export declare class Result {
2
+ private readonly done;
3
+ private readonly failed;
4
+ constructor();
5
+ addDone(entryId: string): void;
6
+ addFailed(entryId: string): void;
7
+ getFailed(): string[];
8
+ getDone(): string[];
9
+ }
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Result = void 0;
7
+ class Result {
8
+ constructor() {
9
+ this.done = new Set();
10
+ this.failed = new Set();
11
+ }
12
+ addDone(entryId) {
13
+ this.failed.delete(entryId);
14
+ this.done.add(entryId);
15
+ }
16
+ addFailed(entryId) {
17
+ this.failed.add(entryId);
18
+ this.done.delete(entryId);
19
+ }
20
+ getFailed() {
21
+ return Array.from(this.failed);
22
+ }
23
+ getDone() {
24
+ return Array.from(this.done);
25
+ }
26
+ }
27
+ exports.Result = Result;
28
+
29
+ //# sourceMappingURL=Result.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Result","constructor","done","Set","failed","addDone","entryId","delete","add","addFailed","getFailed","Array","from","getDone","exports"],"sources":["Result.ts"],"sourcesContent":["export class Result {\n private readonly done: Set<string>;\n private readonly failed: Set<string>;\n\n public constructor() {\n this.done = new Set();\n this.failed = new Set();\n }\n\n public addDone(entryId: string): void {\n this.failed.delete(entryId);\n this.done.add(entryId);\n }\n\n public addFailed(entryId: string): void {\n this.failed.add(entryId);\n this.done.delete(entryId);\n }\n\n public getFailed() {\n return Array.from(this.failed);\n }\n\n public getDone() {\n return Array.from(this.done);\n }\n}\n"],"mappings":";;;;;;AAAO,MAAMA,MAAM,CAAC;EAITC,WAAWA,CAAA,EAAG;IACjB,IAAI,CAACC,IAAI,GAAG,IAAIC,GAAG,CAAC,CAAC;IACrB,IAAI,CAACC,MAAM,GAAG,IAAID,GAAG,CAAC,CAAC;EAC3B;EAEOE,OAAOA,CAACC,OAAe,EAAQ;IAClC,IAAI,CAACF,MAAM,CAACG,MAAM,CAACD,OAAO,CAAC;IAC3B,IAAI,CAACJ,IAAI,CAACM,GAAG,CAACF,OAAO,CAAC;EAC1B;EAEOG,SAASA,CAACH,OAAe,EAAQ;IACpC,IAAI,CAACF,MAAM,CAACI,GAAG,CAACF,OAAO,CAAC;IACxB,IAAI,CAACJ,IAAI,CAACK,MAAM,CAACD,OAAO,CAAC;EAC7B;EAEOI,SAASA,CAAA,EAAG;IACf,OAAOC,KAAK,CAACC,IAAI,CAAC,IAAI,CAACR,MAAM,CAAC;EAClC;EAEOS,OAAOA,CAAA,EAAG;IACb,OAAOF,KAAK,CAACC,IAAI,CAAC,IAAI,CAACV,IAAI,CAAC;EAChC;AACJ;AAACY,OAAA,CAAAd,MAAA,GAAAA,MAAA","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export * from "./ProcessTask";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _ProcessTask = require("./ProcessTask");
7
+ Object.keys(_ProcessTask).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _ProcessTask[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _ProcessTask[key];
14
+ }
15
+ });
16
+ });
17
+
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_ProcessTask","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["index.ts"],"sourcesContent":["export * from \"./ProcessTask\";\n"],"mappings":";;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,YAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,YAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,YAAA,CAAAK,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
@@ -0,0 +1,11 @@
1
+ import { IBulkActionOperationByModelTaskParams } from "../../../types";
2
+ /**
3
+ * The `ProcessTasksByModel` class is responsible for processing tasks for a specific model.
4
+ * It checks for any running or pending tasks from the parent task and continues or completes
5
+ * the task based on the status.
6
+ */
7
+ export declare class ProcessTasksByModel {
8
+ private taskDefinition;
9
+ constructor(taskDefinition: string);
10
+ execute(params: IBulkActionOperationByModelTaskParams): Promise<import("@webiny/tasks").ITaskResponseErrorResult | import("@webiny/tasks").ITaskResponseAbortedResult | import("@webiny/tasks").ITaskResponseContinueResult<import("../../../types").IBulkActionOperationByModelInput>>;
11
+ }
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ProcessTasksByModel = void 0;
7
+ var _tasks = require("@webiny/tasks");
8
+ var _types = require("../../../types");
9
+ /**
10
+ * The `ProcessTasksByModel` class is responsible for processing tasks for a specific model.
11
+ * It checks for any running or pending tasks from the parent task and continues or completes
12
+ * the task based on the status.
13
+ */
14
+ class ProcessTasksByModel {
15
+ constructor(taskDefinition) {
16
+ this.taskDefinition = taskDefinition;
17
+ }
18
+ async execute(params) {
19
+ const {
20
+ response,
21
+ input,
22
+ isAborted,
23
+ isCloseToTimeout,
24
+ context,
25
+ store
26
+ } = params;
27
+ try {
28
+ if (isAborted()) {
29
+ return response.aborted();
30
+ } else if (isCloseToTimeout()) {
31
+ return response.continue({
32
+ ...input,
33
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
34
+ });
35
+ }
36
+ const {
37
+ items
38
+ } = await context.tasks.listTasks({
39
+ where: {
40
+ parentId: store.getTask().id,
41
+ definitionId: this.taskDefinition,
42
+ taskStatus_in: [_tasks.TaskDataStatus.RUNNING, _tasks.TaskDataStatus.PENDING]
43
+ },
44
+ limit: 1
45
+ });
46
+
47
+ // If there are running or pending tasks, continue with a wait.
48
+ if (items.length > 0) {
49
+ return response.continue({
50
+ ...input,
51
+ action: _types.BulkActionOperationByModelAction.PROCESS_SUBTASKS
52
+ }, {
53
+ seconds: 120
54
+ });
55
+ }
56
+ return response.continue({
57
+ ...input,
58
+ action: _types.BulkActionOperationByModelAction.CHECK_MORE_SUBTASKS
59
+ });
60
+ } catch (ex) {
61
+ return response.error(ex.message ?? `Error while processing task "${this.taskDefinition}"`);
62
+ }
63
+ }
64
+ }
65
+ exports.ProcessTasksByModel = ProcessTasksByModel;
66
+
67
+ //# sourceMappingURL=ProcessTasksByModel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_tasks","require","_types","ProcessTasksByModel","constructor","taskDefinition","execute","params","response","input","isAborted","isCloseToTimeout","context","store","aborted","continue","action","BulkActionOperationByModelAction","PROCESS_SUBTASKS","items","tasks","listTasks","where","parentId","getTask","id","definitionId","taskStatus_in","TaskDataStatus","RUNNING","PENDING","limit","length","seconds","CHECK_MORE_SUBTASKS","ex","error","message","exports"],"sources":["ProcessTasksByModel.ts"],"sourcesContent":["import { TaskDataStatus } from \"@webiny/tasks\";\nimport { BulkActionOperationByModelAction, IBulkActionOperationByModelTaskParams } from \"~/types\";\n\n/**\n * The `ProcessTasksByModel` class is responsible for processing tasks for a specific model.\n * It checks for any running or pending tasks from the parent task and continues or completes\n * the task based on the status.\n */\nexport class ProcessTasksByModel {\n private taskDefinition: string;\n\n constructor(taskDefinition: string) {\n this.taskDefinition = taskDefinition;\n }\n\n async execute(params: IBulkActionOperationByModelTaskParams) {\n const { response, input, isAborted, isCloseToTimeout, context, store } = params;\n\n try {\n if (isAborted()) {\n return response.aborted();\n } else if (isCloseToTimeout()) {\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n });\n }\n\n const { items } = await context.tasks.listTasks({\n where: {\n parentId: store.getTask().id,\n definitionId: this.taskDefinition,\n taskStatus_in: [TaskDataStatus.RUNNING, TaskDataStatus.PENDING]\n },\n limit: 1\n });\n\n // If there are running or pending tasks, continue with a wait.\n if (items.length > 0) {\n return response.continue(\n {\n ...input,\n action: BulkActionOperationByModelAction.PROCESS_SUBTASKS\n },\n {\n seconds: 120\n }\n );\n }\n\n return response.continue({\n ...input,\n action: BulkActionOperationByModelAction.CHECK_MORE_SUBTASKS\n });\n } catch (ex) {\n return response.error(\n ex.message ?? `Error while processing task \"${this.taskDefinition}\"`\n );\n }\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAEA;AACA;AACA;AACA;AACA;AACO,MAAME,mBAAmB,CAAC;EAG7BC,WAAWA,CAACC,cAAsB,EAAE;IAChC,IAAI,CAACA,cAAc,GAAGA,cAAc;EACxC;EAEA,MAAMC,OAAOA,CAACC,MAA6C,EAAE;IACzD,MAAM;MAAEC,QAAQ;MAAEC,KAAK;MAAEC,SAAS;MAAEC,gBAAgB;MAAEC,OAAO;MAAEC;IAAM,CAAC,GAAGN,MAAM;IAE/E,IAAI;MACA,IAAIG,SAAS,CAAC,CAAC,EAAE;QACb,OAAOF,QAAQ,CAACM,OAAO,CAAC,CAAC;MAC7B,CAAC,MAAM,IAAIH,gBAAgB,CAAC,CAAC,EAAE;QAC3B,OAAOH,QAAQ,CAACO,QAAQ,CAAC;UACrB,GAAGN,KAAK;UACRO,MAAM,EAAEC,uCAAgC,CAACC;QAC7C,CAAC,CAAC;MACN;MAEA,MAAM;QAAEC;MAAM,CAAC,GAAG,MAAMP,OAAO,CAACQ,KAAK,CAACC,SAAS,CAAC;QAC5CC,KAAK,EAAE;UACHC,QAAQ,EAAEV,KAAK,CAACW,OAAO,CAAC,CAAC,CAACC,EAAE;UAC5BC,YAAY,EAAE,IAAI,CAACrB,cAAc;UACjCsB,aAAa,EAAE,CAACC,qBAAc,CAACC,OAAO,EAAED,qBAAc,CAACE,OAAO;QAClE,CAAC;QACDC,KAAK,EAAE;MACX,CAAC,CAAC;;MAEF;MACA,IAAIZ,KAAK,CAACa,MAAM,GAAG,CAAC,EAAE;QAClB,OAAOxB,QAAQ,CAACO,QAAQ,CACpB;UACI,GAAGN,KAAK;UACRO,MAAM,EAAEC,uCAAgC,CAACC;QAC7C,CAAC,EACD;UACIe,OAAO,EAAE;QACb,CACJ,CAAC;MACL;MAEA,OAAOzB,QAAQ,CAACO,QAAQ,CAAC;QACrB,GAAGN,KAAK;QACRO,MAAM,EAAEC,uCAAgC,CAACiB;MAC7C,CAAC,CAAC;IACN,CAAC,CAAC,OAAOC,EAAE,EAAE;MACT,OAAO3B,QAAQ,CAAC4B,KAAK,CACjBD,EAAE,CAACE,OAAO,IAAK,gCAA+B,IAAI,CAAChC,cAAe,GACtE,CAAC;IACL;EACJ;AACJ;AAACiC,OAAA,CAAAnC,mBAAA,GAAAA,mBAAA","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export * from "./ProcessTasksByModel";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _ProcessTasksByModel = require("./ProcessTasksByModel");
7
+ Object.keys(_ProcessTasksByModel).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _ProcessTasksByModel[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _ProcessTasksByModel[key];
14
+ }
15
+ });
16
+ });
17
+
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_ProcessTasksByModel","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["index.ts"],"sourcesContent":["export * from \"./ProcessTasksByModel\";\n"],"mappings":";;;;;AAAA,IAAAA,oBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,oBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,oBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,oBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ export * from "./ChildTaskCleanup";
2
+ export * from "./CreateTasksByModel";
3
+ export * from "./ProcessTask";
4
+ export * from "./ProcessTasksByModel";
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _ChildTaskCleanup = require("./ChildTaskCleanup");
7
+ Object.keys(_ChildTaskCleanup).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _ChildTaskCleanup[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _ChildTaskCleanup[key];
14
+ }
15
+ });
16
+ });
17
+ var _CreateTasksByModel = require("./CreateTasksByModel");
18
+ Object.keys(_CreateTasksByModel).forEach(function (key) {
19
+ if (key === "default" || key === "__esModule") return;
20
+ if (key in exports && exports[key] === _CreateTasksByModel[key]) return;
21
+ Object.defineProperty(exports, key, {
22
+ enumerable: true,
23
+ get: function () {
24
+ return _CreateTasksByModel[key];
25
+ }
26
+ });
27
+ });
28
+ var _ProcessTask = require("./ProcessTask");
29
+ Object.keys(_ProcessTask).forEach(function (key) {
30
+ if (key === "default" || key === "__esModule") return;
31
+ if (key in exports && exports[key] === _ProcessTask[key]) return;
32
+ Object.defineProperty(exports, key, {
33
+ enumerable: true,
34
+ get: function () {
35
+ return _ProcessTask[key];
36
+ }
37
+ });
38
+ });
39
+ var _ProcessTasksByModel = require("./ProcessTasksByModel");
40
+ Object.keys(_ProcessTasksByModel).forEach(function (key) {
41
+ if (key === "default" || key === "__esModule") return;
42
+ if (key in exports && exports[key] === _ProcessTasksByModel[key]) return;
43
+ Object.defineProperty(exports, key, {
44
+ enumerable: true,
45
+ get: function () {
46
+ return _ProcessTasksByModel[key];
47
+ }
48
+ });
49
+ });
50
+
51
+ //# sourceMappingURL=index.js.map