@budibase/server 2.6.19-alpha.4 → 2.6.19-alpha.41

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 (405) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/index.49c9e712.css +6 -0
  4. package/builder/assets/index.e3ce193c.js +1870 -0
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32478 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +44909 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24402 -0
  12. package/dist/query.js.map +7 -0
  13. package/jest.config.ts +3 -0
  14. package/nodemon.json +1 -1
  15. package/package.json +32 -13
  16. package/pm2.config.js +1 -1
  17. package/scripts/build.js +48 -0
  18. package/src/api/controllers/application.ts +21 -22
  19. package/src/api/controllers/automation.ts +37 -9
  20. package/src/api/controllers/datasource.ts +4 -0
  21. package/src/api/controllers/deploy/index.ts +1 -0
  22. package/src/api/controllers/row/index.ts +15 -22
  23. package/src/api/controllers/row/internal.ts +1 -1
  24. package/src/api/controllers/row/utils.ts +12 -0
  25. package/src/api/controllers/static/index.ts +3 -3
  26. package/src/api/controllers/table/index.ts +3 -0
  27. package/src/api/controllers/table/internal.ts +2 -6
  28. package/src/api/controllers/table/utils.ts +32 -1
  29. package/src/api/controllers/view/index.ts +5 -5
  30. package/src/api/controllers/webhook.ts +33 -9
  31. package/src/api/routes/application.ts +5 -0
  32. package/src/api/routes/automation.ts +0 -1
  33. package/src/api/routes/static.ts +3 -1
  34. package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
  35. package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
  36. package/src/app.ts +0 -1
  37. package/src/automations/actions.ts +8 -0
  38. package/src/automations/logging/index.ts +21 -0
  39. package/src/automations/steps/bash.ts +4 -0
  40. package/src/automations/steps/collect.ts +58 -0
  41. package/src/automations/steps/createRow.ts +4 -0
  42. package/src/automations/steps/delay.ts +1 -0
  43. package/src/automations/steps/deleteRow.ts +4 -0
  44. package/src/automations/steps/discord.ts +4 -0
  45. package/src/automations/steps/executeQuery.ts +4 -0
  46. package/src/automations/steps/executeScript.ts +4 -0
  47. package/src/automations/steps/filter.ts +1 -0
  48. package/src/automations/steps/loop.ts +1 -0
  49. package/src/automations/steps/make.ts +4 -0
  50. package/src/automations/steps/openai.ts +106 -0
  51. package/src/automations/steps/outgoingWebhook.ts +4 -0
  52. package/src/automations/steps/queryRows.ts +4 -0
  53. package/src/automations/steps/sendSmtpEmail.ts +4 -0
  54. package/src/automations/steps/serverLog.ts +4 -0
  55. package/src/automations/steps/slack.ts +4 -0
  56. package/src/automations/steps/updateRow.ts +4 -0
  57. package/src/automations/steps/zapier.ts +4 -0
  58. package/src/automations/tests/openai.spec.ts +86 -0
  59. package/src/automations/triggers.ts +3 -2
  60. package/src/constants/index.ts +17 -16
  61. package/src/db/inMemoryView.ts +1 -0
  62. package/src/environment.ts +3 -0
  63. package/src/integrations/airtable.ts +3 -1
  64. package/src/integrations/arangodb.ts +3 -1
  65. package/src/integrations/base/sqlTable.ts +0 -1
  66. package/src/integrations/couchdb.ts +3 -1
  67. package/src/integrations/dynamodb.ts +3 -1
  68. package/src/integrations/elasticsearch.ts +3 -1
  69. package/src/integrations/firebase.ts +3 -1
  70. package/src/integrations/googlesheets.ts +4 -4
  71. package/src/integrations/microsoftSqlServer.ts +4 -4
  72. package/src/integrations/mongodb.ts +3 -1
  73. package/src/integrations/mysql.ts +4 -4
  74. package/src/integrations/oracle.ts +4 -4
  75. package/src/integrations/postgres.ts +4 -4
  76. package/src/integrations/redis.ts +3 -1
  77. package/src/integrations/s3.ts +3 -1
  78. package/src/integrations/snowflake.ts +3 -1
  79. package/src/middleware/builder.ts +26 -18
  80. package/src/sdk/app/automations/index.ts +2 -0
  81. package/src/sdk/app/automations/utils.ts +7 -0
  82. package/src/startup.ts +2 -0
  83. package/src/tests/utilities/TestConfiguration.ts +4 -2
  84. package/src/tests/utilities/structures.ts +42 -0
  85. package/src/threads/automation.ts +82 -22
  86. package/src/threads/index.ts +9 -3
  87. package/src/threads/utils.ts +2 -0
  88. package/src/utilities/fileSystem/app.ts +14 -4
  89. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  90. package/src/utilities/fileSystem/filesystem.ts +3 -1
  91. package/src/utilities/redis.ts +18 -1
  92. package/src/utilities/rowProcessor/map.ts +1 -1
  93. package/src/websockets/builder.ts +74 -0
  94. package/src/websockets/client.ts +2 -2
  95. package/src/websockets/grid.ts +40 -44
  96. package/src/websockets/index.ts +5 -2
  97. package/src/websockets/websocket.ts +198 -7
  98. package/tsconfig.build.json +9 -1
  99. package/tsconfig.json +1 -14
  100. package/builder/assets/index.07382a47.css +0 -6
  101. package/builder/assets/index.3d5c50fb.js +0 -1786
  102. package/dist/api/controllers/analytics.js +0 -46
  103. package/dist/api/controllers/apikeys.js +0 -72
  104. package/dist/api/controllers/application.js +0 -574
  105. package/dist/api/controllers/auth.js +0 -80
  106. package/dist/api/controllers/automation.js +0 -303
  107. package/dist/api/controllers/backup.js +0 -37
  108. package/dist/api/controllers/component.js +0 -59
  109. package/dist/api/controllers/datasource.js +0 -352
  110. package/dist/api/controllers/deploy/Deployment.js +0 -53
  111. package/dist/api/controllers/deploy/index.js +0 -198
  112. package/dist/api/controllers/dev.js +0 -146
  113. package/dist/api/controllers/integration.js +0 -28
  114. package/dist/api/controllers/layout.js +0 -49
  115. package/dist/api/controllers/metadata.js +0 -63
  116. package/dist/api/controllers/migrations.js +0 -29
  117. package/dist/api/controllers/ops.js +0 -40
  118. package/dist/api/controllers/permission.js +0 -162
  119. package/dist/api/controllers/plugin/file.js +0 -24
  120. package/dist/api/controllers/plugin/github.js +0 -69
  121. package/dist/api/controllers/plugin/index.js +0 -112
  122. package/dist/api/controllers/plugin/npm.js +0 -58
  123. package/dist/api/controllers/plugin/uploaders.js +0 -11
  124. package/dist/api/controllers/plugin/url.js +0 -24
  125. package/dist/api/controllers/plugin/utils.js +0 -27
  126. package/dist/api/controllers/public/applications.js +0 -146
  127. package/dist/api/controllers/public/mapping/applications.js +0 -29
  128. package/dist/api/controllers/public/mapping/index.js +0 -11
  129. package/dist/api/controllers/public/mapping/queries.js +0 -36
  130. package/dist/api/controllers/public/mapping/rows.js +0 -24
  131. package/dist/api/controllers/public/mapping/tables.js +0 -23
  132. package/dist/api/controllers/public/mapping/types.js +0 -2
  133. package/dist/api/controllers/public/mapping/users.js +0 -29
  134. package/dist/api/controllers/public/metrics.js +0 -113
  135. package/dist/api/controllers/public/queries.js +0 -58
  136. package/dist/api/controllers/public/rows.js +0 -120
  137. package/dist/api/controllers/public/tables.js +0 -95
  138. package/dist/api/controllers/public/users.js +0 -93
  139. package/dist/api/controllers/public/utils.js +0 -56
  140. package/dist/api/controllers/query/import/index.js +0 -87
  141. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  142. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  143. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  144. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  145. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  146. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  147. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  148. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  149. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  150. package/dist/api/controllers/query/index.js +0 -299
  151. package/dist/api/controllers/query/validation.js +0 -53
  152. package/dist/api/controllers/role.js +0 -109
  153. package/dist/api/controllers/routing.js +0 -105
  154. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  155. package/dist/api/controllers/row/external.js +0 -339
  156. package/dist/api/controllers/row/index.js +0 -203
  157. package/dist/api/controllers/row/internal.js +0 -509
  158. package/dist/api/controllers/row/internalSearch.js +0 -28
  159. package/dist/api/controllers/row/staticFormula.js +0 -165
  160. package/dist/api/controllers/row/utils.js +0 -183
  161. package/dist/api/controllers/screen.js +0 -110
  162. package/dist/api/controllers/script.js +0 -30
  163. package/dist/api/controllers/static/index.js +0 -268
  164. package/dist/api/controllers/table/bulkFormula.js +0 -173
  165. package/dist/api/controllers/table/external.js +0 -279
  166. package/dist/api/controllers/table/index.js +0 -179
  167. package/dist/api/controllers/table/internal.js +0 -197
  168. package/dist/api/controllers/table/utils.js +0 -379
  169. package/dist/api/controllers/templates.js +0 -56
  170. package/dist/api/controllers/user.js +0 -124
  171. package/dist/api/controllers/view/exporters.js +0 -46
  172. package/dist/api/controllers/view/index.js +0 -193
  173. package/dist/api/controllers/view/utils.js +0 -177
  174. package/dist/api/controllers/view/viewBuilder.js +0 -158
  175. package/dist/api/controllers/webhook.js +0 -134
  176. package/dist/api/index.js +0 -55
  177. package/dist/api/routes/analytics.js +0 -34
  178. package/dist/api/routes/apikeys.js +0 -37
  179. package/dist/api/routes/application.js +0 -48
  180. package/dist/api/routes/auth.js +0 -33
  181. package/dist/api/routes/automation.js +0 -50
  182. package/dist/api/routes/backup.js +0 -35
  183. package/dist/api/routes/component.js +0 -35
  184. package/dist/api/routes/datasource.js +0 -45
  185. package/dist/api/routes/deploy.js +0 -37
  186. package/dist/api/routes/dev.js +0 -49
  187. package/dist/api/routes/index.js +0 -75
  188. package/dist/api/routes/integration.js +0 -37
  189. package/dist/api/routes/layout.js +0 -37
  190. package/dist/api/routes/metadata.js +0 -40
  191. package/dist/api/routes/migrations.js +0 -36
  192. package/dist/api/routes/ops.js +0 -52
  193. package/dist/api/routes/permission.js +0 -44
  194. package/dist/api/routes/plugin.js +0 -39
  195. package/dist/api/routes/public/applications.js +0 -174
  196. package/dist/api/routes/public/index.js +0 -140
  197. package/dist/api/routes/public/metrics.js +0 -30
  198. package/dist/api/routes/public/middleware/mapper.js +0 -97
  199. package/dist/api/routes/public/queries.js +0 -72
  200. package/dist/api/routes/public/rows.js +0 -158
  201. package/dist/api/routes/public/tables.js +0 -152
  202. package/dist/api/routes/public/users.js +0 -135
  203. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  204. package/dist/api/routes/query.js +0 -47
  205. package/dist/api/routes/role.js +0 -40
  206. package/dist/api/routes/routing.js +0 -39
  207. package/dist/api/routes/row.js +0 -239
  208. package/dist/api/routes/screen.js +0 -39
  209. package/dist/api/routes/script.js +0 -35
  210. package/dist/api/routes/static.js +0 -80
  211. package/dist/api/routes/table.js +0 -163
  212. package/dist/api/routes/templates.js +0 -37
  213. package/dist/api/routes/user.js +0 -43
  214. package/dist/api/routes/utils/validators.js +0 -238
  215. package/dist/api/routes/view.js +0 -42
  216. package/dist/api/routes/webhook.js +0 -43
  217. package/dist/app.js +0 -132
  218. package/dist/automations/actions.js +0 -137
  219. package/dist/automations/automationUtils.js +0 -173
  220. package/dist/automations/bullboard.js +0 -71
  221. package/dist/automations/index.js +0 -43
  222. package/dist/automations/logging/index.js +0 -53
  223. package/dist/automations/steps/bash.js +0 -111
  224. package/dist/automations/steps/createRow.js +0 -108
  225. package/dist/automations/steps/delay.js +0 -53
  226. package/dist/automations/steps/deleteRow.js +0 -96
  227. package/dist/automations/steps/discord.js +0 -116
  228. package/dist/automations/steps/executeQuery.js +0 -134
  229. package/dist/automations/steps/executeScript.js +0 -106
  230. package/dist/automations/steps/filter.js +0 -112
  231. package/dist/automations/steps/loop.js +0 -54
  232. package/dist/automations/steps/make.js +0 -134
  233. package/dist/automations/steps/outgoingWebhook.js +0 -166
  234. package/dist/automations/steps/queryRows.js +0 -216
  235. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  236. package/dist/automations/steps/serverLog.js +0 -65
  237. package/dist/automations/steps/slack.js +0 -98
  238. package/dist/automations/steps/updateRow.js +0 -144
  239. package/dist/automations/steps/utils.js +0 -56
  240. package/dist/automations/steps/zapier.js +0 -130
  241. package/dist/automations/triggerInfo/app.js +0 -36
  242. package/dist/automations/triggerInfo/cron.js +0 -35
  243. package/dist/automations/triggerInfo/index.js +0 -40
  244. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  245. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  246. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  247. package/dist/automations/triggerInfo/webhook.js +0 -40
  248. package/dist/automations/triggers.js +0 -181
  249. package/dist/automations/utils.js +0 -275
  250. package/dist/constants/definitions.js +0 -2
  251. package/dist/constants/index.js +0 -181
  252. package/dist/constants/layouts.js +0 -148
  253. package/dist/constants/screens.js +0 -51
  254. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  255. package/dist/db/defaultData/employeeImport.js +0 -155
  256. package/dist/db/defaultData/expensesImport.js +0 -117
  257. package/dist/db/defaultData/inventoryImport.js +0 -109
  258. package/dist/db/defaultData/jobsImport.js +0 -152
  259. package/dist/db/dynamoClient.js +0 -124
  260. package/dist/db/inMemoryView.js +0 -62
  261. package/dist/db/index.js +0 -43
  262. package/dist/db/linkedRows/LinkController.js +0 -392
  263. package/dist/db/linkedRows/LinkDocument.js +0 -33
  264. package/dist/db/linkedRows/index.js +0 -206
  265. package/dist/db/linkedRows/linkUtils.js +0 -131
  266. package/dist/db/newid.js +0 -7
  267. package/dist/db/utils.js +0 -248
  268. package/dist/db/views/staticViews.js +0 -144
  269. package/dist/ddApm.js +0 -11
  270. package/dist/definitions/automations.js +0 -8
  271. package/dist/definitions/common.js +0 -2
  272. package/dist/definitions/datasource.js +0 -7
  273. package/dist/definitions/openapi.js +0 -6
  274. package/dist/environment.js +0 -109
  275. package/dist/events/AutomationEmitter.js +0 -53
  276. package/dist/events/BudibaseEmitter.js +0 -25
  277. package/dist/events/docUpdates/index.js +0 -17
  278. package/dist/events/docUpdates/processors.js +0 -18
  279. package/dist/events/docUpdates/syncUsers.js +0 -49
  280. package/dist/events/index.js +0 -11
  281. package/dist/events/utils.js +0 -43
  282. package/dist/integrations/airtable.js +0 -173
  283. package/dist/integrations/arangodb.js +0 -119
  284. package/dist/integrations/base/query.js +0 -32
  285. package/dist/integrations/base/sql.js +0 -600
  286. package/dist/integrations/base/sqlTable.js +0 -167
  287. package/dist/integrations/base/types.js +0 -2
  288. package/dist/integrations/couchdb.js +0 -140
  289. package/dist/integrations/dynamodb.js +0 -210
  290. package/dist/integrations/elasticsearch.js +0 -201
  291. package/dist/integrations/firebase.js +0 -189
  292. package/dist/integrations/googlesheets.js +0 -493
  293. package/dist/integrations/index.js +0 -138
  294. package/dist/integrations/microsoftSqlServer.js +0 -308
  295. package/dist/integrations/mongodb.js +0 -630
  296. package/dist/integrations/mysql.js +0 -291
  297. package/dist/integrations/oracle.js +0 -415
  298. package/dist/integrations/postgres.js +0 -335
  299. package/dist/integrations/queries/sql.js +0 -84
  300. package/dist/integrations/redis.js +0 -187
  301. package/dist/integrations/rest.js +0 -400
  302. package/dist/integrations/s3.js +0 -256
  303. package/dist/integrations/snowflake.js +0 -114
  304. package/dist/integrations/utils.js +0 -295
  305. package/dist/middleware/appInfo.js +0 -22
  306. package/dist/middleware/authorized.js +0 -112
  307. package/dist/middleware/builder.js +0 -93
  308. package/dist/middleware/currentapp.js +0 -103
  309. package/dist/middleware/joi-validator.js +0 -43
  310. package/dist/middleware/publicApi.js +0 -25
  311. package/dist/middleware/resourceId.js +0 -59
  312. package/dist/middleware/selfhost.js +0 -24
  313. package/dist/middleware/utils.js +0 -8
  314. package/dist/migrations/functions/appUrls.js +0 -42
  315. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  316. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  317. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  318. package/dist/migrations/functions/backfill/app/queries.js +0 -49
  319. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  320. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  321. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  322. package/dist/migrations/functions/backfill/app.js +0 -176
  323. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  324. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  325. package/dist/migrations/functions/backfill/global/users.js +0 -50
  326. package/dist/migrations/functions/backfill/global.js +0 -205
  327. package/dist/migrations/functions/backfill/index.js +0 -32
  328. package/dist/migrations/functions/backfill/installation.js +0 -80
  329. package/dist/migrations/functions/syncQuotas.js +0 -52
  330. package/dist/migrations/functions/tableSettings.js +0 -130
  331. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  332. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  333. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  334. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  335. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  336. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  337. package/dist/migrations/index.js +0 -111
  338. package/dist/migrations/tests/helpers.js +0 -72
  339. package/dist/migrations/tests/structures.js +0 -37
  340. package/dist/sdk/app/applications/index.js +0 -28
  341. package/dist/sdk/app/applications/sync.js +0 -164
  342. package/dist/sdk/app/applications/utils.js +0 -21
  343. package/dist/sdk/app/automations/index.js +0 -29
  344. package/dist/sdk/app/automations/webhook.js +0 -54
  345. package/dist/sdk/app/backups/constants.js +0 -6
  346. package/dist/sdk/app/backups/exports.js +0 -160
  347. package/dist/sdk/app/backups/imports.js +0 -170
  348. package/dist/sdk/app/backups/index.js +0 -29
  349. package/dist/sdk/app/backups/statistics.js +0 -73
  350. package/dist/sdk/app/datasources/datasources.js +0 -173
  351. package/dist/sdk/app/datasources/index.js +0 -27
  352. package/dist/sdk/app/queries/index.js +0 -27
  353. package/dist/sdk/app/queries/queries.js +0 -60
  354. package/dist/sdk/app/rows/attachments.js +0 -61
  355. package/dist/sdk/app/rows/index.js +0 -28
  356. package/dist/sdk/app/rows/rows.js +0 -30
  357. package/dist/sdk/app/tables/index.js +0 -65
  358. package/dist/sdk/index.js +0 -27
  359. package/dist/sdk/plugins/index.js +0 -27
  360. package/dist/sdk/plugins/plugins.js +0 -53
  361. package/dist/sdk/users/index.js +0 -27
  362. package/dist/sdk/users/utils.js +0 -87
  363. package/dist/sdk/utils/index.js +0 -29
  364. package/dist/startup.js +0 -158
  365. package/dist/threads/automation.js +0 -450
  366. package/dist/threads/definitions.js +0 -2
  367. package/dist/threads/index.js +0 -140
  368. package/dist/threads/query.js +0 -265
  369. package/dist/threads/utils.js +0 -120
  370. package/dist/tsconfig.build.tsbuildinfo +0 -1
  371. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  372. package/dist/utilities/budibaseDir.js +0 -5
  373. package/dist/utilities/centralPath.js +0 -27
  374. package/dist/utilities/csv.js +0 -33
  375. package/dist/utilities/fileSystem/app.js +0 -88
  376. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  377. package/dist/utilities/fileSystem/filesystem.js +0 -180
  378. package/dist/utilities/fileSystem/index.js +0 -21
  379. package/dist/utilities/fileSystem/plugin.js +0 -76
  380. package/dist/utilities/fileSystem/processor.js +0 -34
  381. package/dist/utilities/fileSystem/template.js +0 -47
  382. package/dist/utilities/global.js +0 -149
  383. package/dist/utilities/index.js +0 -143
  384. package/dist/utilities/redis.js +0 -117
  385. package/dist/utilities/retry.js +0 -30
  386. package/dist/utilities/routing/index.js +0 -39
  387. package/dist/utilities/rowProcessor/index.js +0 -282
  388. package/dist/utilities/rowProcessor/map.js +0 -116
  389. package/dist/utilities/rowProcessor/utils.js +0 -87
  390. package/dist/utilities/schema.js +0 -112
  391. package/dist/utilities/scriptRunner.js +0 -26
  392. package/dist/utilities/security.js +0 -57
  393. package/dist/utilities/statusCodes.js +0 -9
  394. package/dist/utilities/usageQuota/rows.js +0 -88
  395. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  396. package/dist/utilities/users.js +0 -57
  397. package/dist/utilities/workerRequests.js +0 -171
  398. package/dist/watch.js +0 -53
  399. package/dist/websockets/client.js +0 -14
  400. package/dist/websockets/grid.js +0 -60
  401. package/dist/websockets/index.js +0 -17
  402. package/dist/websockets/websocket.js +0 -78
  403. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  404. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  405. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -16,6 +16,7 @@ import {
16
16
  View,
17
17
  } from "@budibase/types"
18
18
  import { cleanExportRows } from "../row/utils"
19
+ import { builderSocket } from "../../../websockets"
19
20
 
20
21
  const { cloneDeep, isEqual } = require("lodash")
21
22
 
@@ -48,7 +49,7 @@ export async function save(ctx: Ctx) {
48
49
  if (!view.meta.schema) {
49
50
  view.meta.schema = table.schema
50
51
  }
51
- table.views[viewName] = view.meta
52
+ table.views[viewName] = { ...view.meta, name: viewName }
52
53
  if (originalName) {
53
54
  delete table.views[originalName]
54
55
  existingTable.views[viewName] = existingTable.views[originalName]
@@ -56,10 +57,8 @@ export async function save(ctx: Ctx) {
56
57
  await db.put(table)
57
58
  await handleViewEvents(existingTable.views[viewName], table.views[viewName])
58
59
 
59
- ctx.body = {
60
- ...table.views[viewToSave.name],
61
- name: viewToSave.name,
62
- }
60
+ ctx.body = table.views[viewName]
61
+ builderSocket.emitTableUpdate(ctx, table)
63
62
  }
64
63
 
65
64
  export async function calculationEvents(existingView: View, newView: View) {
@@ -128,6 +127,7 @@ export async function destroy(ctx: Ctx) {
128
127
  await events.view.deleted(view)
129
128
 
130
129
  ctx.body = view
130
+ builderSocket.emitTableUpdate(ctx, table)
131
131
  }
132
132
 
133
133
  export async function exportView(ctx: Ctx) {
@@ -6,8 +6,11 @@ import {
6
6
  WebhookActionType,
7
7
  BBContext,
8
8
  Automation,
9
+ AutomationActionStepId,
9
10
  } from "@budibase/types"
10
11
  import sdk from "../../sdk"
12
+ import * as pro from "@budibase/pro"
13
+
11
14
  const toJsonSchema = require("to-json-schema")
12
15
  const validate = require("jsonschema").validate
13
16
 
@@ -78,15 +81,36 @@ export async function trigger(ctx: BBContext) {
78
81
  if (webhook.action.type === WebhookActionType.AUTOMATION) {
79
82
  // trigger with both the pure request and then expand it
80
83
  // incase the user has produced a schema to bind to
81
- await triggers.externalTrigger(target, {
82
- body: ctx.request.body,
83
- ...ctx.request.body,
84
- appId: prodAppId,
85
- })
86
- }
87
- ctx.status = 200
88
- ctx.body = {
89
- message: "Webhook trigger fired successfully",
84
+ let hasCollectStep = sdk.automations.utils.checkForCollectStep(target)
85
+
86
+ if (hasCollectStep && (await pro.features.isSyncAutomationsEnabled())) {
87
+ const response = await triggers.externalTrigger(
88
+ target,
89
+ {
90
+ body: ctx.request.body,
91
+ ...ctx.request.body,
92
+ appId: prodAppId,
93
+ },
94
+ { getResponses: true }
95
+ )
96
+
97
+ let collectedValue = response.steps.find(
98
+ (step: any) => step.stepId === AutomationActionStepId.COLLECT
99
+ )
100
+
101
+ ctx.status = 200
102
+ ctx.body = collectedValue.outputs
103
+ } else {
104
+ await triggers.externalTrigger(target, {
105
+ body: ctx.request.body,
106
+ ...ctx.request.body,
107
+ appId: prodAppId,
108
+ })
109
+ ctx.status = 200
110
+ ctx.body = {
111
+ message: "Webhook trigger fired successfully",
112
+ }
113
+ }
90
114
  }
91
115
  } catch (err: any) {
92
116
  if (err.status === 404) {
@@ -38,6 +38,11 @@ router
38
38
  authorized(permissions.BUILDER),
39
39
  controller.revertClient
40
40
  )
41
+ .post(
42
+ "/api/applications/:appId/sample",
43
+ authorized(permissions.BUILDER),
44
+ controller.addSampleData
45
+ )
41
46
  .post(
42
47
  "/api/applications/:appId/publish",
43
48
  authorized(permissions.BUILDER),
@@ -65,7 +65,6 @@ router
65
65
  )
66
66
  .post(
67
67
  "/api/automations/:id/trigger",
68
- appInfoMiddleware({ appType: AppType.PROD }),
69
68
  paramResource("id"),
70
69
  authorized(
71
70
  permissions.PermissionType.AUTOMATION,
@@ -5,6 +5,7 @@ import authorized from "../../middleware/authorized"
5
5
  import { permissions } from "@budibase/backend-core"
6
6
  import env from "../../environment"
7
7
  import { paramResource } from "../../middleware/resourceId"
8
+ import { devClientLibPath } from "../../utilities/fileSystem"
8
9
  const { BUILDER, PermissionType, PermissionLevel } = permissions
9
10
 
10
11
  const router: Router = new Router()
@@ -17,7 +18,8 @@ router.param("file", async (file: any, ctx: any, next: any) => {
17
18
  }
18
19
  // test serves from require
19
20
  if (env.isTest()) {
20
- ctx.devPath = require.resolve("@budibase/client").split(ctx.file)[0]
21
+ const path = devClientLibPath()
22
+ ctx.devPath = path.split(ctx.file)[0]
21
23
  } else if (env.isDev()) {
22
24
  // Serving the client library from your local dir in dev
23
25
  ctx.devPath = budibaseTempDir()
@@ -1,15 +1,27 @@
1
- const {
1
+ import {
2
2
  checkBuilderEndpoint,
3
3
  getAllTableRows,
4
4
  clearAllAutomations,
5
5
  testAutomation,
6
- } = require("./utilities/TestFunctions")
7
- const setup = require("./utilities")
8
- const { basicAutomation, newAutomation, automationTrigger, automationStep } = setup.structures
9
- const MAX_RETRIES = 4
10
- const { TRIGGER_DEFINITIONS, BUILTIN_ACTION_DEFINITIONS } = require("../../../automations")
11
- const { events } = require("@budibase/backend-core")
6
+ } from "./utilities/TestFunctions"
7
+ import * as setup from "./utilities"
8
+ import {
9
+ TRIGGER_DEFINITIONS,
10
+ BUILTIN_ACTION_DEFINITIONS,
11
+ } from "../../../automations"
12
+ import { events } from "@budibase/backend-core"
13
+ import sdk from "../../../sdk"
14
+ import { Automation } from "@budibase/types"
15
+ import { mocks } from "@budibase/backend-core/tests"
12
16
 
17
+ const MAX_RETRIES = 4
18
+ let {
19
+ basicAutomation,
20
+ newAutomation,
21
+ automationTrigger,
22
+ automationStep,
23
+ collectAutomation,
24
+ } = setup.structures
13
25
 
14
26
  jest.setTimeout(30000)
15
27
 
@@ -24,6 +36,7 @@ describe("/automations", () => {
24
36
  })
25
37
 
26
38
  beforeEach(() => {
39
+ // @ts-ignore
27
40
  events.automation.deleted.mockClear()
28
41
  })
29
42
 
@@ -32,7 +45,7 @@ describe("/automations", () => {
32
45
  const res = await request
33
46
  .get(`/api/automations/action/list`)
34
47
  .set(config.defaultHeaders())
35
- .expect('Content-Type', /json/)
48
+ .expect("Content-Type", /json/)
36
49
  .expect(200)
37
50
 
38
51
  expect(Object.keys(res.body).length).not.toEqual(0)
@@ -42,7 +55,7 @@ describe("/automations", () => {
42
55
  const res = await request
43
56
  .get(`/api/automations/trigger/list`)
44
57
  .set(config.defaultHeaders())
45
- .expect('Content-Type', /json/)
58
+ .expect("Content-Type", /json/)
46
59
  .expect(200)
47
60
 
48
61
  expect(Object.keys(res.body).length).not.toEqual(0)
@@ -52,14 +65,18 @@ describe("/automations", () => {
52
65
  const res = await request
53
66
  .get(`/api/automations/definitions/list`)
54
67
  .set(config.defaultHeaders())
55
- .expect('Content-Type', /json/)
68
+ .expect("Content-Type", /json/)
56
69
  .expect(200)
57
70
 
58
71
  let definitionsLength = Object.keys(BUILTIN_ACTION_DEFINITIONS).length
59
72
  definitionsLength-- // OUTGOING_WEBHOOK is deprecated
60
73
 
61
- expect(Object.keys(res.body.action).length).toBeGreaterThanOrEqual(definitionsLength)
62
- expect(Object.keys(res.body.trigger).length).toEqual(Object.keys(TRIGGER_DEFINITIONS).length)
74
+ expect(Object.keys(res.body.action).length).toBeGreaterThanOrEqual(
75
+ definitionsLength
76
+ )
77
+ expect(Object.keys(res.body.trigger).length).toEqual(
78
+ Object.keys(TRIGGER_DEFINITIONS).length
79
+ )
63
80
  })
64
81
  })
65
82
 
@@ -72,7 +89,7 @@ describe("/automations", () => {
72
89
  .post(`/api/automations`)
73
90
  .set(config.defaultHeaders())
74
91
  .send(automation)
75
- .expect('Content-Type', /json/)
92
+ .expect("Content-Type", /json/)
76
93
  .expect(200)
77
94
 
78
95
  expect(res.body.message).toEqual("Automation created successfully")
@@ -91,7 +108,7 @@ describe("/automations", () => {
91
108
  .post(`/api/automations`)
92
109
  .set(config.defaultHeaders())
93
110
  .send(automation)
94
- .expect('Content-Type', /json/)
111
+ .expect("Content-Type", /json/)
95
112
  .expect(200)
96
113
 
97
114
  expect(res.body.message).toEqual("Automation created successfully")
@@ -107,7 +124,7 @@ describe("/automations", () => {
107
124
  config,
108
125
  method: "POST",
109
126
  url: `/api/automations`,
110
- body: automation
127
+ body: automation,
111
128
  })
112
129
  })
113
130
  })
@@ -118,7 +135,7 @@ describe("/automations", () => {
118
135
  const res = await request
119
136
  .get(`/api/automations/${automation._id}`)
120
137
  .set(config.defaultHeaders())
121
- .expect('Content-Type', /json/)
138
+ .expect("Content-Type", /json/)
122
139
  .expect(200)
123
140
  expect(res.body._id).toEqual(automation._id)
124
141
  expect(res.body._rev).toEqual(automation._rev)
@@ -134,8 +151,8 @@ describe("/automations", () => {
134
151
  row: {
135
152
  name: "{{trigger.row.name}}",
136
153
  description: "{{trigger.row.description}}",
137
- tableId: table._id
138
- }
154
+ tableId: table._id,
155
+ },
139
156
  }
140
157
  automation.appId = config.appId
141
158
  automation = await config.createAutomation(automation)
@@ -162,23 +179,68 @@ describe("/automations", () => {
162
179
  })
163
180
  })
164
181
 
165
- describe("update", () => {
182
+ describe("trigger", () => {
183
+ it("does not trigger an automation when not synchronous and in dev", async () => {
184
+ let automation = newAutomation()
185
+ automation = await config.createAutomation(automation)
186
+ const res = await request
187
+ .post(`/api/automations/${automation._id}/trigger`)
188
+ .set(config.defaultHeaders())
189
+ .expect("Content-Type", /json/)
190
+ .expect(400)
191
+
192
+ expect(res.body.message).toEqual(
193
+ "Only apps in production support this endpoint"
194
+ )
195
+ })
196
+
197
+ it("triggers a synchronous automation", async () => {
198
+ mocks.licenses.useSyncAutomations()
199
+ let automation = collectAutomation()
200
+ automation = await config.createAutomation(automation)
201
+ const res = await request
202
+ .post(`/api/automations/${automation._id}/trigger`)
203
+ .set(config.defaultHeaders())
204
+ .expect("Content-Type", /json/)
205
+ .expect(200)
206
+
207
+ expect(res.body.success).toEqual(true)
208
+ expect(res.body.value).toEqual([1, 2, 3])
209
+ })
166
210
 
167
- const update = async (automation) => {
211
+ it("triggers an asynchronous automation", async () => {
212
+ let automation = newAutomation()
213
+ automation = await config.createAutomation(automation)
214
+ await config.publish()
215
+
216
+ const res = await request
217
+ .post(`/api/automations/${automation._id}/trigger`)
218
+ .set(config.defaultHeaders({}, true))
219
+ .expect("Content-Type", /json/)
220
+ .expect(200)
221
+
222
+ expect(res.body.message).toEqual(
223
+ `Automation ${automation._id} has been triggered.`
224
+ )
225
+ })
226
+ })
227
+
228
+ describe("update", () => {
229
+ const update = async (automation: Automation) => {
168
230
  return request
169
231
  .put(`/api/automations`)
170
232
  .set(config.defaultHeaders())
171
233
  .send(automation)
172
- .expect('Content-Type', /json/)
234
+ .expect("Content-Type", /json/)
173
235
  .expect(200)
174
236
  }
175
237
 
176
- const updateWithPost = async (automation) => {
238
+ const updateWithPost = async (automation: Automation) => {
177
239
  return request
178
240
  .post(`/api/automations`)
179
241
  .set(config.defaultHeaders())
180
242
  .send(automation)
181
- .expect('Content-Type', /json/)
243
+ .expect("Content-Type", /json/)
182
244
  .expect(200)
183
245
  }
184
246
 
@@ -199,7 +261,9 @@ describe("/automations", () => {
199
261
  expect(automationRes._rev).not.toEqual(automation._rev)
200
262
  // content updates
201
263
  expect(automationRes.name).toEqual("Updated Name")
202
- expect(message).toEqual(`Automation ${automation._id} updated successfully.`)
264
+ expect(message).toEqual(
265
+ `Automation ${automation._id} updated successfully.`
266
+ )
203
267
  // events
204
268
  expect(events.automation.created).not.toBeCalled()
205
269
  expect(events.automation.stepCreated).not.toBeCalled()
@@ -207,7 +271,6 @@ describe("/automations", () => {
207
271
  expect(events.automation.triggerUpdated).not.toBeCalled()
208
272
  })
209
273
 
210
-
211
274
  it("updates a automations name using POST request", async () => {
212
275
  let automation = newAutomation()
213
276
  await config.createAutomation(automation)
@@ -226,7 +289,9 @@ describe("/automations", () => {
226
289
  expect(automationRes._rev).not.toEqual(automation._rev)
227
290
  // content updates
228
291
  expect(automationRes.name).toEqual("Updated Name")
229
- expect(message).toEqual(`Automation ${automation._id} updated successfully.`)
292
+ expect(message).toEqual(
293
+ `Automation ${automation._id} updated successfully.`
294
+ )
230
295
  // events
231
296
  expect(events.automation.created).not.toBeCalled()
232
297
  expect(events.automation.stepCreated).not.toBeCalled()
@@ -237,7 +302,9 @@ describe("/automations", () => {
237
302
  it("updates an automation trigger", async () => {
238
303
  let automation = newAutomation()
239
304
  automation = await config.createAutomation(automation)
240
- automation.definition.trigger = automationTrigger(TRIGGER_DEFINITIONS.WEBHOOK)
305
+ automation.definition.trigger = automationTrigger(
306
+ TRIGGER_DEFINITIONS.WEBHOOK
307
+ )
241
308
  jest.clearAllMocks()
242
309
 
243
310
  await update(automation)
@@ -266,7 +333,6 @@ describe("/automations", () => {
266
333
  expect(events.automation.triggerUpdated).not.toBeCalled()
267
334
  })
268
335
 
269
-
270
336
  it("removes automation steps", async () => {
271
337
  let automation = newAutomation()
272
338
  automation.definition.steps.push(automationStep())
@@ -305,11 +371,11 @@ describe("/automations", () => {
305
371
  it("return all the automations for an instance", async () => {
306
372
  await clearAllAutomations(config)
307
373
  const autoConfig = basicAutomation()
308
- automation = await config.createAutomation(autoConfig)
374
+ await config.createAutomation(autoConfig)
309
375
  const res = await request
310
376
  .get(`/api/automations`)
311
377
  .set(config.defaultHeaders())
312
- .expect('Content-Type', /json/)
378
+ .expect("Content-Type", /json/)
313
379
  .expect(200)
314
380
 
315
381
  expect(res.body[0]).toEqual(expect.objectContaining(autoConfig))
@@ -330,7 +396,7 @@ describe("/automations", () => {
330
396
  const res = await request
331
397
  .delete(`/api/automations/${automation.id}/${automation.rev}`)
332
398
  .set(config.defaultHeaders())
333
- .expect('Content-Type', /json/)
399
+ .expect("Content-Type", /json/)
334
400
  .expect(200)
335
401
 
336
402
  expect(res.body.id).toEqual(automation._id)
@@ -346,4 +412,13 @@ describe("/automations", () => {
346
412
  })
347
413
  })
348
414
  })
415
+
416
+ describe("checkForCollectStep", () => {
417
+ it("should return true if a collect step exists in an automation", async () => {
418
+ let automation = collectAutomation()
419
+ await config.createAutomation(automation)
420
+ let res = await sdk.automations.utils.checkForCollectStep(automation)
421
+ expect(res).toEqual(true)
422
+ })
423
+ })
349
424
  })
@@ -1,11 +1,13 @@
1
- const setup = require("./utilities")
2
- const { checkBuilderEndpoint } = require("./utilities/TestFunctions")
3
- const { basicWebhook, basicAutomation } = setup.structures
1
+ import { Webhook } from "@budibase/types"
2
+ import * as setup from "./utilities"
3
+ import { checkBuilderEndpoint } from "./utilities/TestFunctions"
4
+ import { mocks } from "@budibase/backend-core/tests"
5
+ const { basicWebhook, basicAutomation, collectAutomation } = setup.structures
4
6
 
5
7
  describe("/webhooks", () => {
6
8
  let request = setup.getRequest()
7
9
  let config = setup.getConfig()
8
- let webhook
10
+ let webhook: Webhook
9
11
 
10
12
  afterAll(setup.afterAll)
11
13
 
@@ -13,10 +15,11 @@ describe("/webhooks", () => {
13
15
  config.modeSelf()
14
16
  await config.init()
15
17
  const autoConfig = basicAutomation()
16
- autoConfig.definition.trigger = {
17
- schema: { outputs: { properties: {} } },
18
- inputs: {},
18
+ autoConfig.definition.trigger.schema = {
19
+ outputs: { properties: {} },
20
+ inputs: { properties: {} },
19
21
  }
22
+ autoConfig.definition.trigger.inputs = {}
20
23
  await config.createAutomation(autoConfig)
21
24
  webhook = await config.createWebhook()
22
25
  }
@@ -70,7 +73,7 @@ describe("/webhooks", () => {
70
73
 
71
74
  describe("delete", () => {
72
75
  beforeAll(setupTest)
73
-
76
+
74
77
  it("should successfully delete", async () => {
75
78
  const res = await request
76
79
  .delete(`/api/webhooks/${webhook._id}/${webhook._rev}`)
@@ -97,7 +100,7 @@ describe("/webhooks", () => {
97
100
  const res = await request
98
101
  .post(`/api/webhooks/schema/${config.getAppId()}/${webhook._id}`)
99
102
  .send({
100
- a: 1
103
+ a: 1,
101
104
  })
102
105
  .set(config.defaultHeaders())
103
106
  .expect("Content-Type", /json/)
@@ -112,7 +115,7 @@ describe("/webhooks", () => {
112
115
  expect(fetch.body[0]).toBeDefined()
113
116
  expect(fetch.body[0].bodySchema).toEqual({
114
117
  properties: {
115
- a: { type: "integer" }
118
+ a: { type: "integer" },
116
119
  },
117
120
  type: "object",
118
121
  })
@@ -131,4 +134,23 @@ describe("/webhooks", () => {
131
134
  expect(res.body.message).toBeDefined()
132
135
  })
133
136
  })
134
- })
137
+
138
+ it("should trigger a synchronous webhook call ", async () => {
139
+ mocks.licenses.useSyncAutomations()
140
+ let automation = collectAutomation()
141
+ let newAutomation = await config.createAutomation(automation)
142
+ let syncWebhook = await config.createWebhook(
143
+ basicWebhook(newAutomation._id)
144
+ )
145
+
146
+ // replicate changes before checking webhook
147
+ await config.publish()
148
+
149
+ const res = await request
150
+ .post(`/api/webhooks/trigger/${config.prodAppId}/${syncWebhook._id}`)
151
+ .expect("Content-Type", /json/)
152
+ .expect(200)
153
+ expect(res.body.success).toEqual(true)
154
+ expect(res.body.value).toEqual([1, 2, 3])
155
+ })
156
+ })
package/src/app.ts CHANGED
@@ -61,7 +61,6 @@ if (env.isProd()) {
61
61
 
62
62
  const server = http.createServer(app.callback())
63
63
  destroyable(server)
64
- initialiseWebsockets(app, server)
65
64
 
66
65
  let shuttingDown = false,
67
66
  errCode = 0
@@ -14,6 +14,7 @@ import * as filter from "./steps/filter"
14
14
  import * as delay from "./steps/delay"
15
15
  import * as queryRow from "./steps/queryRows"
16
16
  import * as loop from "./steps/loop"
17
+ import * as collect from "./steps/collect"
17
18
  import env from "../environment"
18
19
  import {
19
20
  AutomationStepSchema,
@@ -39,6 +40,7 @@ const ACTION_IMPLS: Record<
39
40
  DELAY: delay.run,
40
41
  FILTER: filter.run,
41
42
  QUERY_ROWS: queryRow.run,
43
+ COLLECT: collect.run,
42
44
  // these used to be lowercase step IDs, maintain for backwards compat
43
45
  discord: discord.run,
44
46
  slack: slack.run,
@@ -59,6 +61,7 @@ export const BUILTIN_ACTION_DEFINITIONS: Record<string, AutomationStepSchema> =
59
61
  FILTER: filter.definition,
60
62
  QUERY_ROWS: queryRow.definition,
61
63
  LOOP: loop.definition,
64
+ COLLECT: collect.definition,
62
65
  // these used to be lowercase step IDs, maintain for backwards compat
63
66
  discord: discord.definition,
64
67
  slack: slack.definition,
@@ -71,10 +74,15 @@ export const BUILTIN_ACTION_DEFINITIONS: Record<string, AutomationStepSchema> =
71
74
  // ran at all
72
75
  if (env.SELF_HOSTED) {
73
76
  const bash = require("./steps/bash")
77
+ const openai = require("./steps/openai")
78
+
74
79
  // @ts-ignore
75
80
  ACTION_IMPLS["EXECUTE_BASH"] = bash.run
76
81
  // @ts-ignore
77
82
  BUILTIN_ACTION_DEFINITIONS["EXECUTE_BASH"] = bash.definition
83
+
84
+ ACTION_IMPLS.OPENAI = openai.run
85
+ BUILTIN_ACTION_DEFINITIONS.OPENAI = openai.definition
78
86
  }
79
87
 
80
88
  export async function getActionDefinitions() {
@@ -2,6 +2,23 @@ import env from "../../environment"
2
2
  import { AutomationResults, Automation, App } from "@budibase/types"
3
3
  import { automations } from "@budibase/pro"
4
4
  import { db as dbUtils } from "@budibase/backend-core"
5
+ import sizeof from "object-sizeof"
6
+
7
+ const MAX_LOG_SIZE_MB = 5
8
+ const MB_IN_BYTES = 1024 * 1024
9
+
10
+ function sanitiseResults(results: AutomationResults) {
11
+ const message = `[removed] - max results size of ${MAX_LOG_SIZE_MB}MB exceeded`
12
+ for (let step of results.steps) {
13
+ step.inputs = {
14
+ message,
15
+ }
16
+ step.outputs = {
17
+ message,
18
+ success: step.outputs.success,
19
+ }
20
+ }
21
+ }
5
22
 
6
23
  export async function storeLog(
7
24
  automation: Automation,
@@ -11,6 +28,10 @@ export async function storeLog(
11
28
  if (env.DISABLE_AUTOMATION_LOGS) {
12
29
  return
13
30
  }
31
+ const bytes = sizeof(results)
32
+ if (bytes / MB_IN_BYTES > MAX_LOG_SIZE_MB) {
33
+ sanitiseResults(results)
34
+ }
14
35
  await automations.logs.storeLog(automation, results)
15
36
  }
16
37
 
@@ -5,6 +5,7 @@ import environment from "../../environment"
5
5
  import {
6
6
  AutomationActionStepId,
7
7
  AutomationCustomIOType,
8
+ AutomationFeature,
8
9
  AutomationIOType,
9
10
  AutomationStepInput,
10
11
  AutomationStepSchema,
@@ -18,6 +19,9 @@ export const definition: AutomationStepSchema = {
18
19
  description: "Run a bash script",
19
20
  type: AutomationStepType.ACTION,
20
21
  internal: true,
22
+ features: {
23
+ [AutomationFeature.LOOPING]: true,
24
+ },
21
25
  stepId: AutomationActionStepId.EXECUTE_BASH,
22
26
  inputs: {},
23
27
  schema: {
@@ -0,0 +1,58 @@
1
+ import {
2
+ AutomationActionStepId,
3
+ AutomationStepSchema,
4
+ AutomationStepInput,
5
+ AutomationStepType,
6
+ AutomationIOType,
7
+ AutomationFeature,
8
+ } from "@budibase/types"
9
+
10
+ export const definition: AutomationStepSchema = {
11
+ name: "Collect Data",
12
+ tagline: "Collect data to be sent to design",
13
+ icon: "Collection",
14
+ description:
15
+ "Collects specified data so it can be provided to the design section",
16
+ type: AutomationStepType.ACTION,
17
+ internal: true,
18
+ features: {},
19
+ stepId: AutomationActionStepId.COLLECT,
20
+ inputs: {},
21
+ schema: {
22
+ inputs: {
23
+ properties: {
24
+ collection: {
25
+ type: AutomationIOType.STRING,
26
+ title: "What to Collect",
27
+ },
28
+ },
29
+ required: ["collection"],
30
+ },
31
+ outputs: {
32
+ properties: {
33
+ success: {
34
+ type: AutomationIOType.BOOLEAN,
35
+ description: "Whether the action was successful",
36
+ },
37
+ value: {
38
+ type: AutomationIOType.STRING,
39
+ description: "Collected data",
40
+ },
41
+ },
42
+ required: ["success", "value"],
43
+ },
44
+ },
45
+ }
46
+
47
+ export async function run({ inputs }: AutomationStepInput) {
48
+ if (!inputs.collection) {
49
+ return {
50
+ success: false,
51
+ }
52
+ } else {
53
+ return {
54
+ success: true,
55
+ value: inputs.collection,
56
+ }
57
+ }
58
+ }
@@ -4,6 +4,7 @@ import { buildCtx } from "./utils"
4
4
  import {
5
5
  AutomationActionStepId,
6
6
  AutomationCustomIOType,
7
+ AutomationFeature,
7
8
  AutomationIOType,
8
9
  AutomationStepInput,
9
10
  AutomationStepSchema,
@@ -17,6 +18,9 @@ export const definition: AutomationStepSchema = {
17
18
  description: "Add a row to your database",
18
19
  type: AutomationStepType.ACTION,
19
20
  internal: true,
21
+ features: {
22
+ [AutomationFeature.LOOPING]: true,
23
+ },
20
24
  stepId: AutomationActionStepId.CREATE_ROW,
21
25
  inputs: {},
22
26
  schema: {