@nocobase/plugin-workflow 0.7.0-alpha.9 → 0.7.1-alpha.6

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 (159) hide show
  1. package/lib/Plugin.d.ts +18 -0
  2. package/lib/Plugin.js +285 -0
  3. package/lib/Processor.d.ts +40 -0
  4. package/lib/Processor.js +440 -0
  5. package/lib/actions/index.d.ts +3 -1
  6. package/lib/actions/index.js +33 -26
  7. package/{esm/actions/flow_nodes.d.ts → lib/actions/nodes.d.ts} +1 -0
  8. package/lib/actions/nodes.js +321 -0
  9. package/lib/actions/workflows.d.ts +2 -0
  10. package/lib/actions/workflows.js +197 -0
  11. package/lib/calculators/index.d.ts +2 -2
  12. package/lib/calculators/index.js +144 -92
  13. package/lib/collections/executions.js +32 -38
  14. package/lib/collections/flow_nodes.js +60 -72
  15. package/lib/collections/jobs.js +26 -47
  16. package/lib/collections/workflows.d.ts +1 -2
  17. package/lib/collections/workflows.js +70 -63
  18. package/lib/constants.js +22 -17
  19. package/lib/index.d.ts +4 -3
  20. package/lib/index.js +85 -22
  21. package/lib/instructions/calculation.d.ts +1 -1
  22. package/lib/instructions/calculation.js +32 -29
  23. package/lib/instructions/condition.d.ts +2 -2
  24. package/lib/instructions/condition.js +91 -88
  25. package/lib/instructions/create.d.ts +2 -2
  26. package/lib/instructions/create.js +39 -25
  27. package/lib/instructions/delay.d.ts +14 -0
  28. package/lib/instructions/delay.js +138 -0
  29. package/lib/instructions/destroy.d.ts +1 -1
  30. package/lib/instructions/destroy.js +38 -25
  31. package/lib/instructions/index.d.ts +11 -8
  32. package/lib/instructions/index.js +76 -25
  33. package/lib/instructions/parallel.d.ts +3 -3
  34. package/lib/instructions/parallel.js +95 -84
  35. package/lib/instructions/prompt.d.ts +2 -2
  36. package/lib/instructions/prompt.js +21 -13
  37. package/lib/instructions/query.d.ts +2 -1
  38. package/lib/instructions/query.js +42 -25
  39. package/lib/instructions/update.d.ts +2 -1
  40. package/lib/instructions/update.js +40 -25
  41. package/lib/models/Execution.d.ts +3 -33
  42. package/lib/models/Execution.js +18 -254
  43. package/lib/models/FlowNode.js +18 -5
  44. package/lib/models/Job.js +18 -5
  45. package/lib/models/Workflow.d.ts +5 -6
  46. package/lib/models/Workflow.js +18 -76
  47. package/lib/triggers/collection.d.ts +12 -0
  48. package/lib/triggers/collection.js +184 -0
  49. package/lib/triggers/index.d.ts +11 -7
  50. package/lib/triggers/index.js +64 -11
  51. package/lib/triggers/schedule.d.ts +38 -0
  52. package/lib/triggers/schedule.js +672 -0
  53. package/package.json +8 -12
  54. package/esm/actions/flow_nodes.js +0 -139
  55. package/esm/actions/flow_nodes.js.map +0 -1
  56. package/esm/actions/index.d.ts +0 -1
  57. package/esm/actions/index.js +0 -8
  58. package/esm/actions/index.js.map +0 -1
  59. package/esm/calculators/index.d.ts +0 -38
  60. package/esm/calculators/index.js +0 -128
  61. package/esm/calculators/index.js.map +0 -1
  62. package/esm/collections/executions.d.ts +0 -3
  63. package/esm/collections/executions.js +0 -38
  64. package/esm/collections/executions.js.map +0 -1
  65. package/esm/collections/flow_nodes.d.ts +0 -3
  66. package/esm/collections/flow_nodes.js +0 -72
  67. package/esm/collections/flow_nodes.js.map +0 -1
  68. package/esm/collections/jobs.d.ts +0 -3
  69. package/esm/collections/jobs.js +0 -47
  70. package/esm/collections/jobs.js.map +0 -1
  71. package/esm/collections/workflows.d.ts +0 -3
  72. package/esm/collections/workflows.js +0 -63
  73. package/esm/collections/workflows.js.map +0 -1
  74. package/esm/constants.d.ts +0 -17
  75. package/esm/constants.js +0 -18
  76. package/esm/constants.js.map +0 -1
  77. package/esm/index.d.ts +0 -5
  78. package/esm/index.js +0 -6
  79. package/esm/index.js.map +0 -1
  80. package/esm/instructions/calculation.d.ts +0 -8
  81. package/esm/instructions/calculation.js +0 -55
  82. package/esm/instructions/calculation.js.map +0 -1
  83. package/esm/instructions/condition.d.ts +0 -5
  84. package/esm/instructions/condition.js +0 -99
  85. package/esm/instructions/condition.js.map +0 -1
  86. package/esm/instructions/create.d.ts +0 -8
  87. package/esm/instructions/create.js +0 -25
  88. package/esm/instructions/create.js.map +0 -1
  89. package/esm/instructions/destroy.d.ts +0 -8
  90. package/esm/instructions/destroy.js +0 -25
  91. package/esm/instructions/destroy.js.map +0 -1
  92. package/esm/instructions/index.d.ts +0 -15
  93. package/esm/instructions/index.js +0 -20
  94. package/esm/instructions/index.js.map +0 -1
  95. package/esm/instructions/parallel.d.ts +0 -13
  96. package/esm/instructions/parallel.js +0 -88
  97. package/esm/instructions/parallel.js.map +0 -1
  98. package/esm/instructions/prompt.d.ts +0 -7
  99. package/esm/instructions/prompt.js +0 -13
  100. package/esm/instructions/prompt.js.map +0 -1
  101. package/esm/instructions/query.d.ts +0 -8
  102. package/esm/instructions/query.js +0 -25
  103. package/esm/instructions/query.js.map +0 -1
  104. package/esm/instructions/update.d.ts +0 -8
  105. package/esm/instructions/update.js +0 -25
  106. package/esm/instructions/update.js.map +0 -1
  107. package/esm/models/Execution.d.ts +0 -50
  108. package/esm/models/Execution.js +0 -250
  109. package/esm/models/Execution.js.map +0 -1
  110. package/esm/models/FlowNode.d.ts +0 -17
  111. package/esm/models/FlowNode.js +0 -4
  112. package/esm/models/FlowNode.js.map +0 -1
  113. package/esm/models/Job.d.ts +0 -15
  114. package/esm/models/Job.js +0 -4
  115. package/esm/models/Job.js.map +0 -1
  116. package/esm/models/Workflow.d.ts +0 -27
  117. package/esm/models/Workflow.js +0 -72
  118. package/esm/models/Workflow.js.map +0 -1
  119. package/esm/server.d.ts +0 -5
  120. package/esm/server.js +0 -62
  121. package/esm/server.js.map +0 -1
  122. package/esm/triggers/index.d.ts +0 -9
  123. package/esm/triggers/index.js +0 -6
  124. package/esm/triggers/index.js.map +0 -1
  125. package/esm/triggers/model.d.ts +0 -12
  126. package/esm/triggers/model.js +0 -47
  127. package/esm/triggers/model.js.map +0 -1
  128. package/lib/actions/flow_nodes.d.ts +0 -3
  129. package/lib/actions/flow_nodes.js +0 -163
  130. package/lib/actions/flow_nodes.js.map +0 -1
  131. package/lib/actions/index.js.map +0 -1
  132. package/lib/calculators/index.js.map +0 -1
  133. package/lib/collections/executions.js.map +0 -1
  134. package/lib/collections/flow_nodes.js.map +0 -1
  135. package/lib/collections/jobs.js.map +0 -1
  136. package/lib/collections/workflows.js.map +0 -1
  137. package/lib/constants.js.map +0 -1
  138. package/lib/index.js.map +0 -1
  139. package/lib/instructions/calculation.js.map +0 -1
  140. package/lib/instructions/condition.js.map +0 -1
  141. package/lib/instructions/create.js.map +0 -1
  142. package/lib/instructions/destroy.js.map +0 -1
  143. package/lib/instructions/index.js.map +0 -1
  144. package/lib/instructions/parallel.js.map +0 -1
  145. package/lib/instructions/prompt.js.map +0 -1
  146. package/lib/instructions/query.js.map +0 -1
  147. package/lib/instructions/update.js.map +0 -1
  148. package/lib/models/Execution.js.map +0 -1
  149. package/lib/models/FlowNode.js.map +0 -1
  150. package/lib/models/Job.js.map +0 -1
  151. package/lib/models/Workflow.js.map +0 -1
  152. package/lib/server.d.ts +0 -5
  153. package/lib/server.js +0 -68
  154. package/lib/server.js.map +0 -1
  155. package/lib/triggers/index.js.map +0 -1
  156. package/lib/triggers/model.d.ts +0 -12
  157. package/lib/triggers/model.js +0 -49
  158. package/lib/triggers/model.js.map +0 -1
  159. package/tsconfig.build.json +0 -9
@@ -0,0 +1,321 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.create = create;
7
+ exports.destroy = destroy;
8
+ exports.update = update;
9
+
10
+ function _sequelize() {
11
+ const data = require("sequelize");
12
+
13
+ _sequelize = function _sequelize() {
14
+ return data;
15
+ };
16
+
17
+ return data;
18
+ }
19
+
20
+ function _actions() {
21
+ const data = require("@nocobase/actions");
22
+
23
+ _actions = function _actions() {
24
+ return data;
25
+ };
26
+
27
+ return data;
28
+ }
29
+
30
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
31
+
32
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
33
+
34
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
35
+
36
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
37
+
38
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
39
+
40
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
41
+
42
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
43
+
44
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
45
+
46
+ function create(_x, _x2) {
47
+ return _create.apply(this, arguments);
48
+ }
49
+
50
+ function _create() {
51
+ _create = _asyncToGenerator(function* (context, next) {
52
+ const db = context.db;
53
+
54
+ const repository = _actions().utils.getRepositoryFromParams(context);
55
+
56
+ const _context$action$param = context.action.params,
57
+ whitelist = _context$action$param.whitelist,
58
+ blacklist = _context$action$param.blacklist,
59
+ updateAssociationValues = _context$action$param.updateAssociationValues,
60
+ values = _context$action$param.values,
61
+ workflowId = _context$action$param.associatedIndex;
62
+ context.body = yield db.sequelize.transaction( /*#__PURE__*/function () {
63
+ var _ref = _asyncToGenerator(function* (transaction) {
64
+ const workflow = yield repository.getSourceModel(transaction);
65
+
66
+ if (workflow.executed) {
67
+ context.throw(400, 'Node could not be created in executed workflow');
68
+ }
69
+
70
+ const instance = yield repository.create({
71
+ values,
72
+ whitelist,
73
+ blacklist,
74
+ updateAssociationValues,
75
+ context,
76
+ transaction
77
+ });
78
+
79
+ if (!instance.upstreamId) {
80
+ const previousHead = yield repository.findOne({
81
+ filter: {
82
+ id: {
83
+ $ne: instance.id
84
+ },
85
+ upstreamId: null
86
+ },
87
+ transaction
88
+ });
89
+
90
+ if (previousHead) {
91
+ yield previousHead.setUpstream(instance, {
92
+ transaction
93
+ });
94
+ yield instance.setDownstream(previousHead, {
95
+ transaction
96
+ });
97
+ instance.set('downstream', previousHead);
98
+ }
99
+
100
+ return instance;
101
+ }
102
+
103
+ const upstream = yield instance.getUpstream({
104
+ transaction
105
+ });
106
+
107
+ if (instance.branchIndex == null) {
108
+ const downstream = yield upstream.getDownstream({
109
+ transaction
110
+ });
111
+
112
+ if (downstream) {
113
+ yield downstream.setUpstream(instance, {
114
+ transaction
115
+ });
116
+ yield instance.setDownstream(downstream, {
117
+ transaction
118
+ });
119
+ instance.set('downstream', downstream);
120
+ }
121
+
122
+ yield upstream.update({
123
+ downstreamId: instance.id
124
+ }, {
125
+ transaction
126
+ });
127
+ upstream.set('downstream', instance);
128
+ } else {
129
+ const _yield$upstream$getBr = yield upstream.getBranches({
130
+ where: {
131
+ id: {
132
+ [_sequelize().Op.ne]: instance.id
133
+ },
134
+ branchIndex: instance.branchIndex
135
+ },
136
+ transaction
137
+ }),
138
+ _yield$upstream$getBr2 = _slicedToArray(_yield$upstream$getBr, 1),
139
+ downstream = _yield$upstream$getBr2[0];
140
+
141
+ if (downstream) {
142
+ yield downstream.update({
143
+ upstreamId: instance.id,
144
+ branchIndex: null
145
+ }, {
146
+ transaction
147
+ });
148
+ yield instance.setDownstream(downstream, {
149
+ transaction
150
+ });
151
+ instance.set('downstream', downstream);
152
+ }
153
+ }
154
+
155
+ instance.set('upstream', upstream);
156
+ });
157
+
158
+ return function (_x7) {
159
+ return _ref.apply(this, arguments);
160
+ };
161
+ }());
162
+ yield next();
163
+ });
164
+ return _create.apply(this, arguments);
165
+ }
166
+
167
+ function searchBranchNodes(nodes, from) {
168
+ const branchHeads = nodes.filter(item => item.upstreamId === from.id && item.branchIndex != null);
169
+ return branchHeads.reduce((flatten, head) => flatten.concat(searchBranchDownstreams(nodes, head)), []);
170
+ }
171
+
172
+ function searchBranchDownstreams(nodes, from) {
173
+ let result = [];
174
+
175
+ for (let search = from; search; search = search.downstream) {
176
+ result = [...result, search, ...searchBranchNodes(nodes, search)];
177
+ }
178
+
179
+ return result;
180
+ }
181
+
182
+ function destroy(_x3, _x4) {
183
+ return _destroy.apply(this, arguments);
184
+ }
185
+
186
+ function _destroy() {
187
+ _destroy = _asyncToGenerator(function* (context, next) {
188
+ const db = context.db;
189
+
190
+ const repository = _actions().utils.getRepositoryFromParams(context);
191
+
192
+ const filterByTk = context.action.params.filterByTk;
193
+ context.body = yield db.sequelize.transaction( /*#__PURE__*/function () {
194
+ var _ref2 = _asyncToGenerator(function* (transaction) {
195
+ const workflow = yield repository.getSourceModel(transaction);
196
+
197
+ if (workflow.executed) {
198
+ context.throw(400, 'Nodes in executed workflow could not be deleted');
199
+ }
200
+
201
+ const fields = ['id', 'upstreamId', 'downstreamId', 'branchIndex'];
202
+ const instance = yield repository.findOne({
203
+ filterByTk,
204
+ fields: [...fields, 'workflowId'],
205
+ appends: ['upstream', 'downstream'],
206
+ transaction
207
+ });
208
+
209
+ const _instance$get = instance.get(),
210
+ upstream = _instance$get.upstream,
211
+ downstream = _instance$get.downstream;
212
+
213
+ if (upstream && upstream.downstreamId === instance.id) {
214
+ yield upstream.update({
215
+ downstreamId: instance.downstreamId
216
+ }, {
217
+ transaction
218
+ });
219
+ }
220
+
221
+ if (downstream) {
222
+ yield downstream.update({
223
+ upstreamId: instance.upstreamId,
224
+ branchIndex: instance.branchIndex
225
+ }, {
226
+ transaction
227
+ });
228
+ }
229
+
230
+ const nodes = yield repository.find({
231
+ filter: {
232
+ workflowId: instance.workflowId
233
+ },
234
+ fields,
235
+ transaction
236
+ });
237
+ const nodesMap = new Map(); // make map
238
+
239
+ nodes.forEach(item => {
240
+ nodesMap.set(item.id, item);
241
+ }); // overwrite
242
+
243
+ nodesMap.set(instance.id, instance); // make linked list
244
+
245
+ nodes.forEach(item => {
246
+ if (item.upstreamId) {
247
+ item.upstream = nodesMap.get(item.upstreamId);
248
+ }
249
+
250
+ if (item.downstreamId) {
251
+ item.downstream = nodesMap.get(item.downstreamId);
252
+ }
253
+ });
254
+ const branchNodes = searchBranchNodes(nodes, instance);
255
+ yield repository.destroy({
256
+ filterByTk: [instance.id, ...branchNodes.map(item => item.id)],
257
+ transaction
258
+ });
259
+ return instance;
260
+ });
261
+
262
+ return function (_x8) {
263
+ return _ref2.apply(this, arguments);
264
+ };
265
+ }());
266
+ yield next();
267
+ });
268
+ return _destroy.apply(this, arguments);
269
+ }
270
+
271
+ function update(_x5, _x6) {
272
+ return _update.apply(this, arguments);
273
+ }
274
+
275
+ function _update() {
276
+ _update = _asyncToGenerator(function* (context, next) {
277
+ const db = context.db;
278
+
279
+ const repository = _actions().utils.getRepositoryFromParams(context);
280
+
281
+ const _context$action$param2 = context.action.params,
282
+ filterByTk = _context$action$param2.filterByTk,
283
+ values = _context$action$param2.values,
284
+ whitelist = _context$action$param2.whitelist,
285
+ blacklist = _context$action$param2.blacklist,
286
+ filter = _context$action$param2.filter,
287
+ updateAssociationValues = _context$action$param2.updateAssociationValues;
288
+ context.body = yield db.sequelize.transaction( /*#__PURE__*/function () {
289
+ var _ref3 = _asyncToGenerator(function* (transaction) {
290
+ // TODO(optimize): duplicated instance query
291
+ const _yield$repository$fin = yield repository.findOne({
292
+ filterByTk,
293
+ appends: ['workflow.executed'],
294
+ transaction
295
+ }),
296
+ workflow = _yield$repository$fin.workflow;
297
+
298
+ if (workflow.executed) {
299
+ context.throw(400, 'Nodes in executed workflow could not be reconfigured');
300
+ }
301
+
302
+ return repository.update({
303
+ filterByTk,
304
+ values,
305
+ whitelist,
306
+ blacklist,
307
+ filter,
308
+ updateAssociationValues,
309
+ context,
310
+ transaction
311
+ });
312
+ });
313
+
314
+ return function (_x9) {
315
+ return _ref3.apply(this, arguments);
316
+ };
317
+ }());
318
+ yield next();
319
+ });
320
+ return _update.apply(this, arguments);
321
+ }
@@ -0,0 +1,2 @@
1
+ import { Context } from '@nocobase/actions';
2
+ export declare function revision(context: Context, next: any): Promise<void>;
@@ -0,0 +1,197 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.revision = revision;
7
+
8
+ function _actions() {
9
+ const data = require("@nocobase/actions");
10
+
11
+ _actions = function _actions() {
12
+ return data;
13
+ };
14
+
15
+ return data;
16
+ }
17
+
18
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
19
+
20
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
21
+
22
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
23
+
24
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
25
+
26
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
27
+
28
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
29
+
30
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
31
+
32
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
33
+
34
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
35
+
36
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
37
+
38
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
39
+
40
+ function _asyncIterator(iterable) { var method, async, sync, retry = 2; for ("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = "@@asyncIterator", sync = "@@iterator"; } throw new TypeError("Object is not async iterable"); }
41
+
42
+ function AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, return: function _return(value) { var ret = this.s.return; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, throw: function _throw(value) { var thr = this.s.return; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); }
43
+
44
+ function typeOf(value) {
45
+ if (Array.isArray(value)) {
46
+ return 'array';
47
+ } else if (value instanceof Date) {
48
+ return 'date';
49
+ } else if (value === null) {
50
+ return 'null';
51
+ }
52
+
53
+ return typeof value;
54
+ }
55
+
56
+ function migrateConfig(config, oldToNew) {
57
+ function migrate(value) {
58
+ switch (typeOf(value)) {
59
+ case 'object':
60
+ return Object.keys(value).reduce((result, key) => _objectSpread(_objectSpread({}, result), {}, {
61
+ [key]: migrate(value[key])
62
+ }), {});
63
+
64
+ case 'array':
65
+ return value.map(item => migrate(item));
66
+
67
+ case 'string':
68
+ return value.replace(/(\{\{\$jobsMapByNodeId\.)(\d+)/, (_, prefix, id) => `${prefix}${oldToNew.get(Number.parseInt(id, 10)).id}`);
69
+
70
+ default:
71
+ return value;
72
+ }
73
+ }
74
+
75
+ return migrate(config);
76
+ }
77
+
78
+ function revision(_x, _x2) {
79
+ return _revision.apply(this, arguments);
80
+ }
81
+
82
+ function _revision() {
83
+ _revision = _asyncToGenerator(function* (context, next) {
84
+ const db = context.db;
85
+
86
+ const repository = _actions().utils.getRepositoryFromParams(context);
87
+
88
+ const filterByTk = context.action.params.filterByTk;
89
+ context.body = yield db.sequelize.transaction( /*#__PURE__*/function () {
90
+ var _ref = _asyncToGenerator(function* (transaction) {
91
+ const origin = yield repository.findOne({
92
+ filterByTk,
93
+ appends: ['nodes'],
94
+ context,
95
+ transaction
96
+ });
97
+ const instance = yield repository.create({
98
+ values: {
99
+ key: origin.key,
100
+ title: origin.title,
101
+ description: origin.description,
102
+ type: origin.type,
103
+ config: origin.config
104
+ },
105
+ transaction
106
+ });
107
+ const originalNodesMap = new Map();
108
+ origin.nodes.forEach(node => {
109
+ originalNodesMap.set(node.id, node);
110
+ });
111
+ const oldToNew = new Map();
112
+ const newToOld = new Map();
113
+ var _iteratorAbruptCompletion = false;
114
+ var _didIteratorError = false;
115
+
116
+ var _iteratorError;
117
+
118
+ try {
119
+ for (var _iterator = _asyncIterator(origin.nodes), _step; _iteratorAbruptCompletion = !(_step = yield _iterator.next()).done; _iteratorAbruptCompletion = false) {
120
+ const node = _step.value;
121
+ const newNode = yield instance.createNode({
122
+ type: node.type,
123
+ config: node.config,
124
+ title: node.title,
125
+ branchIndex: node.branchIndex
126
+ }, {
127
+ transaction
128
+ }); // NOTE: keep original node references for later replacement
129
+
130
+ oldToNew.set(node.id, newNode);
131
+ newToOld.set(newNode.id, node);
132
+ }
133
+ } catch (err) {
134
+ _didIteratorError = true;
135
+ _iteratorError = err;
136
+ } finally {
137
+ try {
138
+ if (_iteratorAbruptCompletion && _iterator.return != null) {
139
+ yield _iterator.return();
140
+ }
141
+ } finally {
142
+ if (_didIteratorError) {
143
+ throw _iteratorError;
144
+ }
145
+ }
146
+ }
147
+
148
+ var _iteratorAbruptCompletion2 = false;
149
+ var _didIteratorError2 = false;
150
+
151
+ var _iteratorError2;
152
+
153
+ try {
154
+ for (var _iterator2 = _asyncIterator(oldToNew.entries()), _step2; _iteratorAbruptCompletion2 = !(_step2 = yield _iterator2.next()).done; _iteratorAbruptCompletion2 = false) {
155
+ var _newUpstream$id, _newDownstream$id;
156
+
157
+ const _step2$value = _slicedToArray(_step2.value, 2),
158
+ oldId = _step2$value[0],
159
+ newNode = _step2$value[1];
160
+
161
+ const oldNode = originalNodesMap.get(oldId);
162
+ const newUpstream = oldNode.upstreamId ? oldToNew.get(oldNode.upstreamId) : null;
163
+ const newDownstream = oldNode.downstreamId ? oldToNew.get(oldNode.downstreamId) : null;
164
+ yield newNode.update({
165
+ upstreamId: (_newUpstream$id = newUpstream === null || newUpstream === void 0 ? void 0 : newUpstream.id) !== null && _newUpstream$id !== void 0 ? _newUpstream$id : null,
166
+ downstreamId: (_newDownstream$id = newDownstream === null || newDownstream === void 0 ? void 0 : newDownstream.id) !== null && _newDownstream$id !== void 0 ? _newDownstream$id : null,
167
+ config: migrateConfig(oldNode.config, oldToNew)
168
+ }, {
169
+ transaction
170
+ });
171
+ }
172
+ } catch (err) {
173
+ _didIteratorError2 = true;
174
+ _iteratorError2 = err;
175
+ } finally {
176
+ try {
177
+ if (_iteratorAbruptCompletion2 && _iterator2.return != null) {
178
+ yield _iterator2.return();
179
+ }
180
+ } finally {
181
+ if (_didIteratorError2) {
182
+ throw _iteratorError2;
183
+ }
184
+ }
185
+ }
186
+
187
+ return instance;
188
+ });
189
+
190
+ return function (_x3) {
191
+ return _ref.apply(this, arguments);
192
+ };
193
+ }());
194
+ yield next();
195
+ });
196
+ return _revision.apply(this, arguments);
197
+ }
@@ -1,6 +1,6 @@
1
1
  import { Registry } from "@nocobase/utils";
2
- import ExecutionModel from '../models/Execution';
3
2
  import JobModel from '../models/Job';
3
+ import Processor from '../Processor';
4
4
  export declare const calculators: Registry<Function>;
5
5
  export default calculators;
6
6
  export declare type OperandType = '$context' | '$input' | '$jobsMapByNodeId' | '$calculation';
@@ -35,4 +35,4 @@ export declare type Calculation = {
35
35
  options: CalculationOptions;
36
36
  };
37
37
  export declare type Operand = ContextOperand | InputOperand | JobOperand | ConstantOperand | Calculation;
38
- export declare function calculate(operand: Operand, lastJob: JobModel, execution: ExecutionModel): any;
38
+ export declare function calculate(operand: Operand, lastJob: JobModel, processor: Processor): any;