@budibase/server 2.6.22 → 2.6.24-alpha.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 (424) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/index.50121870.js +1869 -0
  4. package/builder/assets/index.a86e2071.css +6 -0
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32576 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +45065 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24462 -0
  12. package/dist/query.js.map +7 -0
  13. package/jest.config.ts +6 -3
  14. package/nodemon.json +8 -4
  15. package/package.json +35 -16
  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 +114 -49
  21. package/src/api/controllers/deploy/index.ts +1 -0
  22. package/src/api/controllers/integration.ts +3 -3
  23. package/src/api/controllers/plugin/index.ts +1 -1
  24. package/src/api/controllers/row/external.ts +39 -15
  25. package/src/api/controllers/row/index.ts +18 -24
  26. package/src/api/controllers/row/internal.ts +1 -1
  27. package/src/api/controllers/row/staticFormula.ts +6 -1
  28. package/src/api/controllers/row/utils.ts +12 -0
  29. package/src/api/controllers/static/index.ts +3 -3
  30. package/src/api/controllers/table/index.ts +3 -0
  31. package/src/api/controllers/table/internal.ts +2 -6
  32. package/src/api/controllers/table/utils.ts +32 -1
  33. package/src/api/controllers/view/index.ts +5 -5
  34. package/src/api/controllers/webhook.ts +33 -9
  35. package/src/api/routes/application.ts +5 -0
  36. package/src/api/routes/automation.ts +0 -1
  37. package/src/api/routes/datasource.ts +10 -0
  38. package/src/api/routes/static.ts +3 -1
  39. package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
  40. package/src/api/routes/tests/datasource.spec.ts +1 -1
  41. package/src/api/routes/tests/view.spec.js +4 -3
  42. package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
  43. package/src/app.ts +0 -1
  44. package/src/automations/actions.ts +8 -0
  45. package/src/automations/logging/index.ts +21 -0
  46. package/src/automations/steps/bash.ts +4 -0
  47. package/src/automations/steps/collect.ts +58 -0
  48. package/src/automations/steps/createRow.ts +4 -0
  49. package/src/automations/steps/delay.ts +1 -0
  50. package/src/automations/steps/deleteRow.ts +4 -0
  51. package/src/automations/steps/discord.ts +4 -0
  52. package/src/automations/steps/executeQuery.ts +4 -0
  53. package/src/automations/steps/executeScript.ts +4 -0
  54. package/src/automations/steps/filter.ts +1 -0
  55. package/src/automations/steps/loop.ts +1 -0
  56. package/src/automations/steps/make.ts +22 -1
  57. package/src/automations/steps/openai.ts +106 -0
  58. package/src/automations/steps/outgoingWebhook.ts +4 -0
  59. package/src/automations/steps/queryRows.ts +4 -0
  60. package/src/automations/steps/sendSmtpEmail.ts +4 -0
  61. package/src/automations/steps/serverLog.ts +4 -0
  62. package/src/automations/steps/slack.ts +4 -0
  63. package/src/automations/steps/updateRow.ts +4 -0
  64. package/src/automations/steps/zapier.ts +22 -1
  65. package/src/automations/tests/make.spec.ts +54 -0
  66. package/src/automations/tests/openai.spec.ts +86 -0
  67. package/src/automations/tests/zapier.spec.ts +56 -0
  68. package/src/automations/triggers.ts +3 -2
  69. package/src/constants/index.ts +17 -16
  70. package/src/db/dynamoClient.ts +1 -1
  71. package/src/db/inMemoryView.ts +1 -0
  72. package/src/db/linkedRows/index.ts +5 -3
  73. package/src/environment.ts +3 -0
  74. package/src/integration-test/postgres.spec.ts +47 -5
  75. package/src/integrations/airtable.ts +33 -4
  76. package/src/integrations/arangodb.ts +20 -2
  77. package/src/integrations/base/sqlTable.ts +0 -1
  78. package/src/integrations/couchdb.ts +20 -4
  79. package/src/integrations/dynamodb.ts +36 -5
  80. package/src/integrations/elasticsearch.ts +18 -1
  81. package/src/integrations/firebase.ts +17 -0
  82. package/src/integrations/googlesheets.ts +66 -5
  83. package/src/integrations/index.ts +12 -7
  84. package/src/integrations/microsoftSqlServer.ts +33 -1
  85. package/src/integrations/mongodb.ts +18 -0
  86. package/src/integrations/mysql.ts +53 -26
  87. package/src/integrations/oracle.ts +38 -6
  88. package/src/integrations/postgres.ts +47 -12
  89. package/src/integrations/redis.ts +35 -4
  90. package/src/integrations/s3.ts +21 -3
  91. package/src/integrations/snowflake.ts +25 -1
  92. package/src/integrations/tests/googlesheets.spec.ts +41 -9
  93. package/src/middleware/builder.ts +26 -18
  94. package/src/migrations/functions/backfill/app/queries.ts +1 -1
  95. package/src/sdk/app/automations/index.ts +2 -0
  96. package/src/sdk/app/automations/utils.ts +7 -0
  97. package/src/sdk/app/datasources/datasources.ts +7 -1
  98. package/src/sdk/plugins/plugins.ts +1 -1
  99. package/src/startup.ts +2 -0
  100. package/src/tests/utilities/TestConfiguration.ts +4 -2
  101. package/src/tests/utilities/structures.ts +42 -0
  102. package/src/threads/automation.ts +91 -23
  103. package/src/threads/index.ts +9 -3
  104. package/src/threads/utils.ts +2 -0
  105. package/src/utilities/fileSystem/app.ts +14 -4
  106. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  107. package/src/utilities/fileSystem/filesystem.ts +3 -1
  108. package/src/utilities/redis.ts +25 -3
  109. package/src/utilities/rowProcessor/index.ts +4 -1
  110. package/src/utilities/rowProcessor/map.ts +1 -1
  111. package/src/websockets/builder.ts +95 -0
  112. package/src/websockets/client.ts +2 -2
  113. package/src/websockets/grid.ts +44 -44
  114. package/src/websockets/index.ts +13 -6
  115. package/src/websockets/websocket.ts +211 -7
  116. package/tsconfig.build.json +9 -1
  117. package/tsconfig.json +1 -14
  118. package/builder/assets/index.86c992bf.css +0 -6
  119. package/builder/assets/index.c16c35ca.js +0 -1794
  120. package/dist/api/controllers/analytics.js +0 -46
  121. package/dist/api/controllers/apikeys.js +0 -72
  122. package/dist/api/controllers/application.js +0 -574
  123. package/dist/api/controllers/auth.js +0 -80
  124. package/dist/api/controllers/automation.js +0 -303
  125. package/dist/api/controllers/backup.js +0 -37
  126. package/dist/api/controllers/component.js +0 -59
  127. package/dist/api/controllers/datasource.js +0 -306
  128. package/dist/api/controllers/deploy/Deployment.js +0 -53
  129. package/dist/api/controllers/deploy/index.js +0 -198
  130. package/dist/api/controllers/dev.js +0 -146
  131. package/dist/api/controllers/integration.js +0 -28
  132. package/dist/api/controllers/layout.js +0 -49
  133. package/dist/api/controllers/metadata.js +0 -63
  134. package/dist/api/controllers/migrations.js +0 -29
  135. package/dist/api/controllers/ops.js +0 -40
  136. package/dist/api/controllers/permission.js +0 -162
  137. package/dist/api/controllers/plugin/file.js +0 -24
  138. package/dist/api/controllers/plugin/github.js +0 -69
  139. package/dist/api/controllers/plugin/index.js +0 -112
  140. package/dist/api/controllers/plugin/npm.js +0 -58
  141. package/dist/api/controllers/plugin/uploaders.js +0 -11
  142. package/dist/api/controllers/plugin/url.js +0 -24
  143. package/dist/api/controllers/plugin/utils.js +0 -27
  144. package/dist/api/controllers/public/applications.js +0 -146
  145. package/dist/api/controllers/public/mapping/applications.js +0 -29
  146. package/dist/api/controllers/public/mapping/index.js +0 -11
  147. package/dist/api/controllers/public/mapping/queries.js +0 -36
  148. package/dist/api/controllers/public/mapping/rows.js +0 -24
  149. package/dist/api/controllers/public/mapping/tables.js +0 -23
  150. package/dist/api/controllers/public/mapping/types.js +0 -2
  151. package/dist/api/controllers/public/mapping/users.js +0 -29
  152. package/dist/api/controllers/public/metrics.js +0 -113
  153. package/dist/api/controllers/public/queries.js +0 -58
  154. package/dist/api/controllers/public/rows.js +0 -120
  155. package/dist/api/controllers/public/tables.js +0 -95
  156. package/dist/api/controllers/public/users.js +0 -93
  157. package/dist/api/controllers/public/utils.js +0 -56
  158. package/dist/api/controllers/query/import/index.js +0 -87
  159. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  160. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  161. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  162. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  163. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  164. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  165. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  166. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  167. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  168. package/dist/api/controllers/query/index.js +0 -299
  169. package/dist/api/controllers/query/validation.js +0 -53
  170. package/dist/api/controllers/role.js +0 -109
  171. package/dist/api/controllers/routing.js +0 -105
  172. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  173. package/dist/api/controllers/row/external.js +0 -339
  174. package/dist/api/controllers/row/index.js +0 -203
  175. package/dist/api/controllers/row/internal.js +0 -509
  176. package/dist/api/controllers/row/internalSearch.js +0 -28
  177. package/dist/api/controllers/row/staticFormula.js +0 -165
  178. package/dist/api/controllers/row/utils.js +0 -183
  179. package/dist/api/controllers/screen.js +0 -110
  180. package/dist/api/controllers/script.js +0 -30
  181. package/dist/api/controllers/static/index.js +0 -268
  182. package/dist/api/controllers/table/bulkFormula.js +0 -173
  183. package/dist/api/controllers/table/external.js +0 -279
  184. package/dist/api/controllers/table/index.js +0 -179
  185. package/dist/api/controllers/table/internal.js +0 -197
  186. package/dist/api/controllers/table/utils.js +0 -379
  187. package/dist/api/controllers/templates.js +0 -56
  188. package/dist/api/controllers/user.js +0 -124
  189. package/dist/api/controllers/view/exporters.js +0 -46
  190. package/dist/api/controllers/view/index.js +0 -193
  191. package/dist/api/controllers/view/utils.js +0 -177
  192. package/dist/api/controllers/view/viewBuilder.js +0 -158
  193. package/dist/api/controllers/webhook.js +0 -134
  194. package/dist/api/index.js +0 -55
  195. package/dist/api/routes/analytics.js +0 -34
  196. package/dist/api/routes/apikeys.js +0 -37
  197. package/dist/api/routes/application.js +0 -48
  198. package/dist/api/routes/auth.js +0 -33
  199. package/dist/api/routes/automation.js +0 -50
  200. package/dist/api/routes/backup.js +0 -35
  201. package/dist/api/routes/component.js +0 -35
  202. package/dist/api/routes/datasource.js +0 -43
  203. package/dist/api/routes/deploy.js +0 -37
  204. package/dist/api/routes/dev.js +0 -49
  205. package/dist/api/routes/index.js +0 -75
  206. package/dist/api/routes/integration.js +0 -37
  207. package/dist/api/routes/layout.js +0 -37
  208. package/dist/api/routes/metadata.js +0 -40
  209. package/dist/api/routes/migrations.js +0 -36
  210. package/dist/api/routes/ops.js +0 -52
  211. package/dist/api/routes/permission.js +0 -44
  212. package/dist/api/routes/plugin.js +0 -39
  213. package/dist/api/routes/public/applications.js +0 -174
  214. package/dist/api/routes/public/index.js +0 -140
  215. package/dist/api/routes/public/metrics.js +0 -30
  216. package/dist/api/routes/public/middleware/mapper.js +0 -97
  217. package/dist/api/routes/public/queries.js +0 -72
  218. package/dist/api/routes/public/rows.js +0 -158
  219. package/dist/api/routes/public/tables.js +0 -152
  220. package/dist/api/routes/public/users.js +0 -135
  221. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  222. package/dist/api/routes/query.js +0 -47
  223. package/dist/api/routes/role.js +0 -40
  224. package/dist/api/routes/routing.js +0 -39
  225. package/dist/api/routes/row.js +0 -239
  226. package/dist/api/routes/screen.js +0 -39
  227. package/dist/api/routes/script.js +0 -35
  228. package/dist/api/routes/static.js +0 -80
  229. package/dist/api/routes/table.js +0 -163
  230. package/dist/api/routes/templates.js +0 -37
  231. package/dist/api/routes/user.js +0 -43
  232. package/dist/api/routes/utils/validators.js +0 -238
  233. package/dist/api/routes/view.js +0 -42
  234. package/dist/api/routes/webhook.js +0 -43
  235. package/dist/app.js +0 -132
  236. package/dist/automations/actions.js +0 -137
  237. package/dist/automations/automationUtils.js +0 -173
  238. package/dist/automations/bullboard.js +0 -71
  239. package/dist/automations/index.js +0 -43
  240. package/dist/automations/logging/index.js +0 -53
  241. package/dist/automations/steps/bash.js +0 -111
  242. package/dist/automations/steps/createRow.js +0 -108
  243. package/dist/automations/steps/delay.js +0 -53
  244. package/dist/automations/steps/deleteRow.js +0 -96
  245. package/dist/automations/steps/discord.js +0 -116
  246. package/dist/automations/steps/executeQuery.js +0 -134
  247. package/dist/automations/steps/executeScript.js +0 -106
  248. package/dist/automations/steps/filter.js +0 -112
  249. package/dist/automations/steps/loop.js +0 -54
  250. package/dist/automations/steps/make.js +0 -120
  251. package/dist/automations/steps/outgoingWebhook.js +0 -166
  252. package/dist/automations/steps/queryRows.js +0 -220
  253. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  254. package/dist/automations/steps/serverLog.js +0 -65
  255. package/dist/automations/steps/slack.js +0 -98
  256. package/dist/automations/steps/updateRow.js +0 -144
  257. package/dist/automations/steps/utils.js +0 -56
  258. package/dist/automations/steps/zapier.js +0 -117
  259. package/dist/automations/triggerInfo/app.js +0 -36
  260. package/dist/automations/triggerInfo/cron.js +0 -35
  261. package/dist/automations/triggerInfo/index.js +0 -40
  262. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  263. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  264. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  265. package/dist/automations/triggerInfo/webhook.js +0 -40
  266. package/dist/automations/triggers.js +0 -181
  267. package/dist/automations/utils.js +0 -275
  268. package/dist/constants/definitions.js +0 -2
  269. package/dist/constants/index.js +0 -181
  270. package/dist/constants/layouts.js +0 -148
  271. package/dist/constants/screens.js +0 -51
  272. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  273. package/dist/db/defaultData/employeeImport.js +0 -155
  274. package/dist/db/defaultData/expensesImport.js +0 -117
  275. package/dist/db/defaultData/inventoryImport.js +0 -109
  276. package/dist/db/defaultData/jobsImport.js +0 -152
  277. package/dist/db/dynamoClient.js +0 -124
  278. package/dist/db/inMemoryView.js +0 -62
  279. package/dist/db/index.js +0 -43
  280. package/dist/db/linkedRows/LinkController.js +0 -392
  281. package/dist/db/linkedRows/LinkDocument.js +0 -33
  282. package/dist/db/linkedRows/index.js +0 -206
  283. package/dist/db/linkedRows/linkUtils.js +0 -131
  284. package/dist/db/newid.js +0 -7
  285. package/dist/db/utils.js +0 -248
  286. package/dist/db/views/staticViews.js +0 -144
  287. package/dist/ddApm.js +0 -11
  288. package/dist/definitions/automations.js +0 -8
  289. package/dist/definitions/common.js +0 -2
  290. package/dist/definitions/datasource.js +0 -7
  291. package/dist/definitions/openapi.js +0 -6
  292. package/dist/environment.js +0 -109
  293. package/dist/events/AutomationEmitter.js +0 -53
  294. package/dist/events/BudibaseEmitter.js +0 -25
  295. package/dist/events/docUpdates/index.js +0 -17
  296. package/dist/events/docUpdates/processors.js +0 -18
  297. package/dist/events/docUpdates/syncUsers.js +0 -49
  298. package/dist/events/index.js +0 -11
  299. package/dist/events/utils.js +0 -43
  300. package/dist/integrations/airtable.js +0 -147
  301. package/dist/integrations/arangodb.js +0 -103
  302. package/dist/integrations/base/query.js +0 -32
  303. package/dist/integrations/base/sql.js +0 -600
  304. package/dist/integrations/base/sqlTable.js +0 -167
  305. package/dist/integrations/base/types.js +0 -2
  306. package/dist/integrations/couchdb.js +0 -125
  307. package/dist/integrations/dynamodb.js +0 -194
  308. package/dist/integrations/elasticsearch.js +0 -186
  309. package/dist/integrations/firebase.js +0 -174
  310. package/dist/integrations/googlesheets.js +0 -455
  311. package/dist/integrations/index.js +0 -135
  312. package/dist/integrations/microsoftSqlServer.js +0 -273
  313. package/dist/integrations/mongodb.js +0 -614
  314. package/dist/integrations/mysql.js +0 -256
  315. package/dist/integrations/oracle.js +0 -375
  316. package/dist/integrations/postgres.js +0 -300
  317. package/dist/integrations/queries/sql.js +0 -84
  318. package/dist/integrations/redis.js +0 -168
  319. package/dist/integrations/rest.js +0 -400
  320. package/dist/integrations/s3.js +0 -237
  321. package/dist/integrations/snowflake.js +0 -99
  322. package/dist/integrations/utils.js +0 -295
  323. package/dist/middleware/appInfo.js +0 -22
  324. package/dist/middleware/authorized.js +0 -112
  325. package/dist/middleware/builder.js +0 -93
  326. package/dist/middleware/currentapp.js +0 -103
  327. package/dist/middleware/joi-validator.js +0 -43
  328. package/dist/middleware/publicApi.js +0 -25
  329. package/dist/middleware/resourceId.js +0 -59
  330. package/dist/middleware/selfhost.js +0 -24
  331. package/dist/middleware/utils.js +0 -8
  332. package/dist/migrations/functions/appUrls.js +0 -42
  333. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  334. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  335. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  336. package/dist/migrations/functions/backfill/app/queries.js +0 -50
  337. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  338. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  339. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  340. package/dist/migrations/functions/backfill/app.js +0 -176
  341. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  342. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  343. package/dist/migrations/functions/backfill/global/users.js +0 -50
  344. package/dist/migrations/functions/backfill/global.js +0 -205
  345. package/dist/migrations/functions/backfill/index.js +0 -32
  346. package/dist/migrations/functions/backfill/installation.js +0 -80
  347. package/dist/migrations/functions/syncQuotas.js +0 -52
  348. package/dist/migrations/functions/tableSettings.js +0 -130
  349. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  350. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  351. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  352. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  353. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  354. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  355. package/dist/migrations/index.js +0 -111
  356. package/dist/migrations/tests/helpers.js +0 -72
  357. package/dist/migrations/tests/structures.js +0 -37
  358. package/dist/sdk/app/applications/index.js +0 -28
  359. package/dist/sdk/app/applications/sync.js +0 -164
  360. package/dist/sdk/app/applications/utils.js +0 -21
  361. package/dist/sdk/app/automations/index.js +0 -29
  362. package/dist/sdk/app/automations/webhook.js +0 -54
  363. package/dist/sdk/app/backups/constants.js +0 -6
  364. package/dist/sdk/app/backups/exports.js +0 -160
  365. package/dist/sdk/app/backups/imports.js +0 -170
  366. package/dist/sdk/app/backups/index.js +0 -29
  367. package/dist/sdk/app/backups/statistics.js +0 -73
  368. package/dist/sdk/app/datasources/datasources.js +0 -166
  369. package/dist/sdk/app/datasources/index.js +0 -27
  370. package/dist/sdk/app/queries/index.js +0 -27
  371. package/dist/sdk/app/queries/queries.js +0 -60
  372. package/dist/sdk/app/rows/attachments.js +0 -61
  373. package/dist/sdk/app/rows/index.js +0 -28
  374. package/dist/sdk/app/rows/rows.js +0 -30
  375. package/dist/sdk/app/tables/index.js +0 -65
  376. package/dist/sdk/index.js +0 -27
  377. package/dist/sdk/plugins/index.js +0 -27
  378. package/dist/sdk/plugins/plugins.js +0 -53
  379. package/dist/sdk/users/index.js +0 -27
  380. package/dist/sdk/users/utils.js +0 -94
  381. package/dist/sdk/utils/index.js +0 -29
  382. package/dist/startup.js +0 -158
  383. package/dist/threads/automation.js +0 -450
  384. package/dist/threads/definitions.js +0 -2
  385. package/dist/threads/index.js +0 -140
  386. package/dist/threads/query.js +0 -265
  387. package/dist/threads/utils.js +0 -120
  388. package/dist/tsconfig.build.tsbuildinfo +0 -1
  389. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  390. package/dist/utilities/budibaseDir.js +0 -5
  391. package/dist/utilities/centralPath.js +0 -27
  392. package/dist/utilities/csv.js +0 -33
  393. package/dist/utilities/fileSystem/app.js +0 -88
  394. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  395. package/dist/utilities/fileSystem/filesystem.js +0 -180
  396. package/dist/utilities/fileSystem/index.js +0 -21
  397. package/dist/utilities/fileSystem/plugin.js +0 -76
  398. package/dist/utilities/fileSystem/processor.js +0 -34
  399. package/dist/utilities/fileSystem/template.js +0 -47
  400. package/dist/utilities/global.js +0 -146
  401. package/dist/utilities/index.js +0 -143
  402. package/dist/utilities/redis.js +0 -117
  403. package/dist/utilities/retry.js +0 -30
  404. package/dist/utilities/routing/index.js +0 -39
  405. package/dist/utilities/rowProcessor/index.js +0 -282
  406. package/dist/utilities/rowProcessor/map.js +0 -116
  407. package/dist/utilities/rowProcessor/utils.js +0 -87
  408. package/dist/utilities/schema.js +0 -112
  409. package/dist/utilities/scriptRunner.js +0 -26
  410. package/dist/utilities/security.js +0 -57
  411. package/dist/utilities/statusCodes.js +0 -9
  412. package/dist/utilities/usageQuota/rows.js +0 -88
  413. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  414. package/dist/utilities/users.js +0 -57
  415. package/dist/utilities/workerRequests.js +0 -171
  416. package/dist/watch.js +0 -53
  417. package/dist/websockets/client.js +0 -14
  418. package/dist/websockets/grid.js +0 -60
  419. package/dist/websockets/index.js +0 -17
  420. package/dist/websockets/websocket.js +0 -78
  421. package/src/automations/tests/zapier.spec.js +0 -27
  422. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  423. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  424. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,7 +1,7 @@
1
1
  import {
2
- SortDirection,
3
2
  FieldTypes,
4
3
  NoEmptyFilterStrings,
4
+ SortDirection,
5
5
  } from "../../../constants"
6
6
  import {
7
7
  breakExternalTableId,
@@ -11,20 +11,34 @@ import { ExternalRequest, RunConfig } from "./ExternalRequest"
11
11
  import * as exporters from "../view/exporters"
12
12
  import { apiFileReturn } from "../../../utilities/fileSystem"
13
13
  import {
14
- Operation,
15
- UserCtx,
16
- Row,
17
- PaginationJson,
18
- Table,
19
14
  Datasource,
20
15
  IncludeRelationship,
16
+ Operation,
17
+ PaginationJson,
18
+ Row,
21
19
  SortJson,
20
+ Table,
21
+ UserCtx,
22
22
  } from "@budibase/types"
23
23
  import sdk from "../../../sdk"
24
24
  import * as utils from "./utils"
25
25
 
26
26
  const { cleanExportRows } = require("./utils")
27
27
 
28
+ async function getRow(
29
+ tableId: string,
30
+ rowId: string,
31
+ opts?: { relationships?: boolean }
32
+ ) {
33
+ const response = (await handleRequest(Operation.READ, tableId, {
34
+ id: breakRowIdField(rowId),
35
+ includeSqlRelationships: opts?.relationships
36
+ ? IncludeRelationship.INCLUDE
37
+ : IncludeRelationship.EXCLUDE,
38
+ })) as Row[]
39
+ return response ? response[0] : response
40
+ }
41
+
28
42
  export async function handleRequest(
29
43
  operation: Operation,
30
44
  tableId: string,
@@ -63,11 +77,15 @@ export async function patch(ctx: UserCtx) {
63
77
  if (!validateResult.valid) {
64
78
  throw { validation: validateResult.errors }
65
79
  }
66
- return handleRequest(Operation.UPDATE, tableId, {
80
+ const response = await handleRequest(Operation.UPDATE, tableId, {
67
81
  id: breakRowIdField(id),
68
82
  row: inputs,
69
- includeSqlRelationships: IncludeRelationship.INCLUDE,
70
83
  })
84
+ const row = await getRow(tableId, id, { relationships: true })
85
+ return {
86
+ ...response,
87
+ row,
88
+ }
71
89
  }
72
90
 
73
91
  export async function save(ctx: UserCtx) {
@@ -80,10 +98,20 @@ export async function save(ctx: UserCtx) {
80
98
  if (!validateResult.valid) {
81
99
  throw { validation: validateResult.errors }
82
100
  }
83
- return handleRequest(Operation.CREATE, tableId, {
101
+ const response = await handleRequest(Operation.CREATE, tableId, {
84
102
  row: inputs,
85
- includeSqlRelationships: IncludeRelationship.EXCLUDE,
86
103
  })
104
+ const responseRow = response as { row: Row }
105
+ const rowId = responseRow.row._id
106
+ if (rowId) {
107
+ const row = await getRow(tableId, rowId, { relationships: true })
108
+ return {
109
+ ...response,
110
+ row,
111
+ }
112
+ } else {
113
+ return response
114
+ }
87
115
  }
88
116
 
89
117
  export async function fetchView(ctx: UserCtx) {
@@ -104,11 +132,7 @@ export async function fetch(ctx: UserCtx) {
104
132
  export async function find(ctx: UserCtx) {
105
133
  const id = ctx.params.rowId
106
134
  const tableId = ctx.params.tableId
107
- const response = (await handleRequest(Operation.READ, tableId, {
108
- id: breakRowIdField(id),
109
- includeSqlRelationships: IncludeRelationship.EXCLUDE,
110
- })) as Row[]
111
- return response ? response[0] : response
135
+ return getRow(tableId, id)
112
136
  }
113
137
 
114
138
  export async function destroy(ctx: UserCtx) {
@@ -4,6 +4,7 @@ import * as external from "./external"
4
4
  import { isExternalTable } from "../../../integrations/utils"
5
5
  import { Ctx } from "@budibase/types"
6
6
  import * as utils from "./utils"
7
+ import { gridSocket } from "../../../websockets"
7
8
 
8
9
  function pickApi(tableId: any) {
9
10
  if (isExternalTable(tableId)) {
@@ -12,21 +13,9 @@ function pickApi(tableId: any) {
12
13
  return internal
13
14
  }
14
15
 
15
- function getTableId(ctx: any) {
16
- if (ctx.request.body && ctx.request.body.tableId) {
17
- return ctx.request.body.tableId
18
- }
19
- if (ctx.params && ctx.params.tableId) {
20
- return ctx.params.tableId
21
- }
22
- if (ctx.params && ctx.params.viewName) {
23
- return ctx.params.viewName
24
- }
25
- }
26
-
27
16
  export async function patch(ctx: any): Promise<any> {
28
17
  const appId = ctx.appId
29
- const tableId = getTableId(ctx)
18
+ const tableId = utils.getTableId(ctx)
30
19
  const body = ctx.request.body
31
20
  // if it doesn't have an _id then its save
32
21
  if (body && !body._id) {
@@ -47,6 +36,7 @@ export async function patch(ctx: any): Promise<any> {
47
36
  ctx.eventEmitter.emitRow(`row:update`, appId, row, table)
48
37
  ctx.message = `${table.name} updated successfully.`
49
38
  ctx.body = row
39
+ gridSocket?.emitRowUpdate(ctx, row)
50
40
  } catch (err) {
51
41
  ctx.throw(400, err)
52
42
  }
@@ -54,13 +44,13 @@ export async function patch(ctx: any): Promise<any> {
54
44
 
55
45
  export const save = async (ctx: any) => {
56
46
  const appId = ctx.appId
57
- const tableId = getTableId(ctx)
47
+ const tableId = utils.getTableId(ctx)
58
48
  const body = ctx.request.body
59
49
  // if it has an ID already then its a patch
60
50
  if (body && body._id) {
61
51
  return patch(ctx)
62
52
  }
63
- const { row, table } = await quotas.addRow(() =>
53
+ const { row, table, squashed } = await quotas.addRow(() =>
64
54
  quotas.addQuery(() => pickApi(tableId).save(ctx), {
65
55
  datasourceId: tableId,
66
56
  })
@@ -68,24 +58,26 @@ export const save = async (ctx: any) => {
68
58
  ctx.status = 200
69
59
  ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:save`, appId, row, table)
70
60
  ctx.message = `${table.name} saved successfully`
71
- ctx.body = row
61
+ // prefer squashed for response
62
+ ctx.body = row || squashed
63
+ gridSocket?.emitRowUpdate(ctx, row || squashed)
72
64
  }
73
65
  export async function fetchView(ctx: any) {
74
- const tableId = getTableId(ctx)
66
+ const tableId = utils.getTableId(ctx)
75
67
  ctx.body = await quotas.addQuery(() => pickApi(tableId).fetchView(ctx), {
76
68
  datasourceId: tableId,
77
69
  })
78
70
  }
79
71
 
80
72
  export async function fetch(ctx: any) {
81
- const tableId = getTableId(ctx)
73
+ const tableId = utils.getTableId(ctx)
82
74
  ctx.body = await quotas.addQuery(() => pickApi(tableId).fetch(ctx), {
83
75
  datasourceId: tableId,
84
76
  })
85
77
  }
86
78
 
87
79
  export async function find(ctx: any) {
88
- const tableId = getTableId(ctx)
80
+ const tableId = utils.getTableId(ctx)
89
81
  ctx.body = await quotas.addQuery(() => pickApi(tableId).find(ctx), {
90
82
  datasourceId: tableId,
91
83
  })
@@ -94,7 +86,7 @@ export async function find(ctx: any) {
94
86
  export async function destroy(ctx: any) {
95
87
  const appId = ctx.appId
96
88
  const inputs = ctx.request.body
97
- const tableId = getTableId(ctx)
89
+ const tableId = utils.getTableId(ctx)
98
90
  let response, row
99
91
  if (inputs.rows) {
100
92
  let { rows } = await quotas.addQuery(
@@ -107,6 +99,7 @@ export async function destroy(ctx: any) {
107
99
  response = rows
108
100
  for (let row of rows) {
109
101
  ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:delete`, appId, row)
102
+ gridSocket?.emitRowDeletion(ctx, row._id)
110
103
  }
111
104
  } else {
112
105
  let resp = await quotas.addQuery(() => pickApi(tableId).destroy(ctx), {
@@ -116,6 +109,7 @@ export async function destroy(ctx: any) {
116
109
  response = resp.response
117
110
  row = resp.row
118
111
  ctx.eventEmitter && ctx.eventEmitter.emitRow(`row:delete`, appId, row)
112
+ gridSocket?.emitRowDeletion(ctx, row._id)
119
113
  }
120
114
  ctx.status = 200
121
115
  // for automations include the row that was deleted
@@ -124,7 +118,7 @@ export async function destroy(ctx: any) {
124
118
  }
125
119
 
126
120
  export async function search(ctx: any) {
127
- const tableId = getTableId(ctx)
121
+ const tableId = utils.getTableId(ctx)
128
122
  ctx.status = 200
129
123
  ctx.body = await quotas.addQuery(() => pickApi(tableId).search(ctx), {
130
124
  datasourceId: tableId,
@@ -132,7 +126,7 @@ export async function search(ctx: any) {
132
126
  }
133
127
 
134
128
  export async function validate(ctx: Ctx) {
135
- const tableId = getTableId(ctx)
129
+ const tableId = utils.getTableId(ctx)
136
130
  // external tables are hard to validate currently
137
131
  if (isExternalTable(tableId)) {
138
132
  ctx.body = { valid: true }
@@ -145,7 +139,7 @@ export async function validate(ctx: Ctx) {
145
139
  }
146
140
 
147
141
  export async function fetchEnrichedRow(ctx: any) {
148
- const tableId = getTableId(ctx)
142
+ const tableId = utils.getTableId(ctx)
149
143
  ctx.body = await quotas.addQuery(
150
144
  () => pickApi(tableId).fetchEnrichedRow(ctx),
151
145
  {
@@ -155,7 +149,7 @@ export async function fetchEnrichedRow(ctx: any) {
155
149
  }
156
150
 
157
151
  export const exportRows = async (ctx: any) => {
158
- const tableId = getTableId(ctx)
152
+ const tableId = utils.getTableId(ctx)
159
153
  ctx.body = await quotas.addQuery(() => pickApi(tableId).exportRows(ctx), {
160
154
  datasourceId: tableId,
161
155
  })
@@ -415,7 +415,7 @@ export async function exportRows(ctx: UserCtx) {
415
415
 
416
416
  result = await outputProcessing(table, response)
417
417
  } else if (query) {
418
- let searchResponse = await exports.search(ctx)
418
+ let searchResponse = await search(ctx)
419
419
  result = searchResponse.rows
420
420
  }
421
421
 
@@ -7,6 +7,7 @@ import {
7
7
  import { FieldTypes, FormulaTypes } from "../../../constants"
8
8
  import { context } from "@budibase/backend-core"
9
9
  import { Table, Row } from "@budibase/types"
10
+ import * as linkRows from "../../../db/linkedRows"
10
11
  const { isEqual } = require("lodash")
11
12
  const { cloneDeep } = require("lodash/fp")
12
13
 
@@ -166,5 +167,9 @@ export async function finaliseRow(
166
167
  if (updateFormula) {
167
168
  await updateRelatedFormula(table, enrichedRow)
168
169
  }
169
- return { row: enrichedRow, table }
170
+ const squashed = await linkRows.squashLinksToPrimaryDisplay(
171
+ table,
172
+ enrichedRow
173
+ )
174
+ return { row: enrichedRow, squashed, table }
170
175
  }
@@ -154,3 +154,15 @@ export function cleanExportRows(
154
154
 
155
155
  return cleanRows
156
156
  }
157
+
158
+ export function getTableId(ctx: any) {
159
+ if (ctx.request.body && ctx.request.body.tableId) {
160
+ return ctx.request.body.tableId
161
+ }
162
+ if (ctx.params && ctx.params.tableId) {
163
+ return ctx.params.tableId
164
+ }
165
+ if (ctx.params && ctx.params.viewName) {
166
+ return ctx.params.viewName
167
+ }
168
+ }
@@ -134,7 +134,7 @@ export const serveApp = async function (ctx: any) {
134
134
  ? objectStore.getGlobalFileUrl("settings", "logoUrl")
135
135
  : "",
136
136
  })
137
- const appHbs = loadHandlebarsFile(`${__dirname}/templates/app.hbs`)
137
+ const appHbs = loadHandlebarsFile(`${__dirname}/app.hbs`)
138
138
  ctx.body = await processString(appHbs, {
139
139
  head,
140
140
  body: html,
@@ -161,7 +161,7 @@ export const serveApp = async function (ctx: any) {
161
161
  : "",
162
162
  })
163
163
 
164
- const appHbs = loadHandlebarsFile(`${__dirname}/templates/app.hbs`)
164
+ const appHbs = loadHandlebarsFile(`${__dirname}/app.hbs`)
165
165
  ctx.body = await processString(appHbs, {
166
166
  head,
167
167
  body: html,
@@ -177,7 +177,7 @@ export const serveBuilderPreview = async function (ctx: any) {
177
177
 
178
178
  if (!env.isJest()) {
179
179
  let appId = context.getAppId()
180
- const previewHbs = loadHandlebarsFile(`${__dirname}/templates/preview.hbs`)
180
+ const previewHbs = loadHandlebarsFile(`${__dirname}/preview.hbs`)
181
181
  ctx.body = await processString(previewHbs, {
182
182
  clientLibPath: objectStore.clientLibraryUrl(appId!, appInfo.version),
183
183
  })
@@ -11,6 +11,7 @@ import { context, events } from "@budibase/backend-core"
11
11
  import { Table, UserCtx } from "@budibase/types"
12
12
  import sdk from "../../../sdk"
13
13
  import { jsonFromCsvString } from "../../../utilities/csv"
14
+ import { builderSocket } from "../../../websockets"
14
15
 
15
16
  function pickApi({ tableId, table }: { tableId?: string; table?: Table }) {
16
17
  if (table && !tableId) {
@@ -77,6 +78,7 @@ export async function save(ctx: UserCtx) {
77
78
  ctx.eventEmitter &&
78
79
  ctx.eventEmitter.emitTable(`table:save`, appId, savedTable)
79
80
  ctx.body = savedTable
81
+ builderSocket?.emitTableUpdate(ctx, savedTable)
80
82
  }
81
83
 
82
84
  export async function destroy(ctx: UserCtx) {
@@ -89,6 +91,7 @@ export async function destroy(ctx: UserCtx) {
89
91
  ctx.status = 200
90
92
  ctx.table = deletedTable
91
93
  ctx.body = { message: `Table ${tableId} deleted.` }
94
+ builderSocket?.emitTableDeletion(ctx, tableId)
92
95
  }
93
96
 
94
97
  export async function bulkImport(ctx: UserCtx) {
@@ -186,11 +186,7 @@ export async function destroy(ctx: any) {
186
186
  export async function bulkImport(ctx: any) {
187
187
  const db = context.getAppDB()
188
188
  const table = await sdk.tables.getTable(ctx.params.tableId)
189
- const { rows } = ctx.request.body
190
- await handleDataImport(ctx.user, table, rows)
191
-
192
- // Ensure auto id and other table updates are persisted
193
- await db.put(table)
194
-
189
+ const { rows, identifierFields } = ctx.request.body
190
+ await handleDataImport(ctx.user, table, rows, identifierFields)
195
191
  return table
196
192
  }
@@ -149,7 +149,12 @@ export function importToRows(
149
149
  return finalData
150
150
  }
151
151
 
152
- export async function handleDataImport(user: any, table: any, rows: any) {
152
+ export async function handleDataImport(
153
+ user: any,
154
+ table: any,
155
+ rows: any,
156
+ identifierFields: Array<string> = []
157
+ ) {
153
158
  const schema: unknown = table.schema
154
159
 
155
160
  if (!rows || !isRows(rows) || !isSchema(schema)) {
@@ -161,6 +166,32 @@ export async function handleDataImport(user: any, table: any, rows: any) {
161
166
 
162
167
  let finalData: any = importToRows(data, table, user)
163
168
 
169
+ //Set IDs of finalData to match existing row if an update is expected
170
+ if (identifierFields.length > 0) {
171
+ const allDocs = await db.allDocs(
172
+ getRowParams(table._id, null, {
173
+ include_docs: true,
174
+ })
175
+ )
176
+ allDocs.rows
177
+ .map(existingRow => existingRow.doc)
178
+ .forEach((doc: any) => {
179
+ finalData.forEach((finalItem: any) => {
180
+ let match = true
181
+ for (const field of identifierFields) {
182
+ if (finalItem[field] !== doc[field]) {
183
+ match = false
184
+ break
185
+ }
186
+ }
187
+ if (match) {
188
+ finalItem._id = doc._id
189
+ finalItem._rev = doc._rev
190
+ }
191
+ })
192
+ })
193
+ }
194
+
164
195
  await quotas.addRows(finalData.length, () => db.bulkDocs(finalData), {
165
196
  tableId: table._id,
166
197
  })
@@ -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,
@@ -15,6 +15,16 @@ router
15
15
  authorized(permissions.BUILDER),
16
16
  datasourceController.fetch
17
17
  )
18
+ .post(
19
+ "/api/datasources/verify",
20
+ authorized(permissions.BUILDER),
21
+ datasourceController.verify
22
+ )
23
+ .post(
24
+ "/api/datasources/info",
25
+ authorized(permissions.BUILDER),
26
+ datasourceController.information
27
+ )
18
28
  .get(
19
29
  "/api/datasources/:datasourceId",
20
30
  authorized(
@@ -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()