@budibase/server 2.3.17 → 2.3.18-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 (463) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.4488f38d.css → index.7e76c039.css} +1 -1
  3. package/builder/assets/{index.06e34d35.js → index.e7d5703a.js} +361 -361
  4. package/builder/index.html +2 -2
  5. package/dist/api/controllers/query/index.js +2 -0
  6. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  7. package/dist/api/controllers/row/external.js +12 -1
  8. package/dist/api/controllers/row/staticFormula.js +5 -1
  9. package/dist/api/controllers/table/external.js +8 -8
  10. package/dist/api/index.js +1 -21
  11. package/dist/app.js +7 -1
  12. package/dist/constants/index.js +4 -24
  13. package/dist/db/defaultData/datasource_bb_default.js +6 -5
  14. package/dist/db/linkedRows/LinkController.js +9 -8
  15. package/dist/ddApm.js +11 -0
  16. package/dist/elasticApm.js +14 -0
  17. package/dist/integrations/base/sql.js +10 -3
  18. package/dist/package.json +11 -7
  19. package/dist/sdk/app/backups/exports.js +8 -2
  20. package/dist/sdk/app/datasources/datasources.js +3 -0
  21. package/dist/tsconfig.build.tsbuildinfo +1 -1
  22. package/dist/utilities/retry.js +30 -0
  23. package/jest-testcontainers-config.js +8 -0
  24. package/jest.config.ts +28 -11
  25. package/package.json +12 -8
  26. package/scripts/load/create-many-apps.js +24 -0
  27. package/scripts/load/create-many-rows.js +30 -0
  28. package/scripts/load/utils.js +66 -0
  29. package/specs/openapi.json +6 -6
  30. package/specs/openapi.yaml +3 -3
  31. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  32. package/src/api/controllers/query/index.ts +2 -0
  33. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  34. package/src/api/controllers/row/external.ts +13 -1
  35. package/src/api/controllers/row/staticFormula.ts +7 -1
  36. package/src/api/controllers/table/external.ts +3 -2
  37. package/src/api/index.ts +3 -22
  38. package/src/api/routes/public/applications.ts +0 -1
  39. package/src/api/routes/public/tests/compare.spec.js +1 -1
  40. package/src/api/routes/public/tests/users.spec.js +1 -1
  41. package/src/api/routes/public/tests/utils.ts +25 -8
  42. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  43. package/src/api/routes/tests/analytics.spec.js +4 -1
  44. package/src/api/routes/tests/apikeys.spec.js +1 -1
  45. package/src/api/routes/tests/application.spec.ts +20 -6
  46. package/src/api/routes/tests/auth.spec.js +2 -2
  47. package/src/api/routes/tests/automation.spec.js +6 -2
  48. package/src/api/routes/tests/backup.spec.ts +4 -14
  49. package/src/api/routes/tests/{cloud.spec.ts → cloud.seq.spec.ts} +11 -15
  50. package/src/api/routes/tests/component.spec.js +1 -1
  51. package/src/api/routes/tests/datasource.spec.ts +20 -3
  52. package/src/api/routes/tests/dev.spec.js +1 -1
  53. package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
  54. package/src/api/routes/tests/integration.spec.js +1 -1
  55. package/src/api/routes/tests/layout.spec.js +1 -1
  56. package/src/api/routes/tests/metadata.spec.js +1 -1
  57. package/src/api/routes/tests/misc.spec.js +1 -1
  58. package/src/api/routes/tests/permissions.spec.js +4 -1
  59. package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
  60. package/src/api/routes/tests/role.spec.js +6 -1
  61. package/src/api/routes/tests/routing.spec.js +1 -1
  62. package/src/api/routes/tests/row.spec.js +11 -3
  63. package/src/api/routes/tests/screen.spec.js +1 -1
  64. package/src/api/routes/tests/static.spec.js +2 -1
  65. package/src/api/routes/tests/table.spec.js +1 -1
  66. package/src/api/routes/tests/templates.spec.js +1 -1
  67. package/src/api/routes/tests/user.spec.js +12 -12
  68. package/src/api/routes/tests/utilities/TestFunctions.ts +25 -2
  69. package/src/api/routes/tests/utilities/index.ts +5 -3
  70. package/src/api/routes/tests/view.spec.js +4 -1
  71. package/src/api/routes/tests/webhook.spec.js +11 -2
  72. package/src/app.ts +10 -1
  73. package/src/automations/tests/automation.spec.js +4 -4
  74. package/src/automations/tests/bash.spec.js +1 -1
  75. package/src/automations/tests/discord.spec.js +1 -1
  76. package/src/automations/tests/executeQuery.spec.js +2 -3
  77. package/src/automations/tests/executeScript.spec.js +1 -1
  78. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  79. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  80. package/src/automations/tests/serverLog.spec.js +1 -1
  81. package/src/automations/tests/updateRow.spec.js +1 -1
  82. package/src/automations/tests/zapier.spec.js +1 -1
  83. package/src/constants/index.ts +1 -23
  84. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  85. package/src/db/linkedRows/LinkController.ts +2 -1
  86. package/src/db/tests/linkController.spec.js +4 -1
  87. package/src/db/tests/linkTests.spec.js +1 -1
  88. package/src/ddApm.ts +7 -0
  89. package/src/elasticApm.ts +10 -0
  90. package/src/integration-test/postgres.spec.ts +762 -0
  91. package/src/integrations/base/sql.ts +15 -5
  92. package/src/integrations/oracle.ts +1 -1
  93. package/src/integrations/tests/couchdb.spec.ts +0 -2
  94. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  95. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  96. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  97. package/src/migrations/tests/index.spec.ts +13 -20
  98. package/src/sdk/app/backups/exports.ts +8 -2
  99. package/src/sdk/app/datasources/datasources.ts +3 -0
  100. package/src/tests/jestEnv.ts +8 -11
  101. package/src/tests/jestSetup.ts +9 -7
  102. package/src/tests/logging.ts +34 -0
  103. package/src/tests/utilities/TestConfiguration.ts +166 -92
  104. package/src/tests/utilities/structures.ts +16 -2
  105. package/src/utilities/retry.ts +18 -0
  106. package/tsconfig.build.json +1 -0
  107. package/coverage/clover.xml +0 -11771
  108. package/coverage/coverage-final.json +0 -284
  109. package/coverage/lcov-report/base.css +0 -224
  110. package/coverage/lcov-report/block-navigation.js +0 -87
  111. package/coverage/lcov-report/favicon.png +0 -0
  112. package/coverage/lcov-report/index.html +0 -1031
  113. package/coverage/lcov-report/prettify.css +0 -1
  114. package/coverage/lcov-report/prettify.js +0 -2
  115. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  116. package/coverage/lcov-report/sorter.js +0 -196
  117. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
  118. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
  119. package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
  120. package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
  121. package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
  122. package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
  123. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
  124. package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
  125. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
  126. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
  127. package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
  128. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
  129. package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
  130. package/coverage/lcov-report/src/api/controllers/index.html +0 -431
  131. package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
  132. package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
  133. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
  134. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
  135. package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
  136. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
  137. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
  138. package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
  139. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
  140. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
  141. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
  142. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
  143. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
  144. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
  145. package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
  146. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
  147. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
  148. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
  149. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
  150. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
  151. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
  152. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
  153. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
  154. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
  155. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
  156. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
  157. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
  158. package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
  159. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
  160. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
  161. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
  162. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
  163. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
  164. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
  165. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
  166. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
  167. package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
  168. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
  169. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
  170. package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
  171. package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
  172. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
  173. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
  174. package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
  175. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
  176. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
  177. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
  178. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -577
  179. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
  180. package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
  181. package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
  182. package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
  183. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
  184. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
  185. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
  186. package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
  187. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
  188. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
  189. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
  190. package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
  191. package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
  192. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
  193. package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
  194. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
  195. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
  196. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
  197. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
  198. package/coverage/lcov-report/src/api/index.html +0 -116
  199. package/coverage/lcov-report/src/api/index.ts.html +0 -352
  200. package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
  201. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
  202. package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
  203. package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
  204. package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
  205. package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
  206. package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
  207. package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
  208. package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
  209. package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
  210. package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
  211. package/coverage/lcov-report/src/api/routes/index.html +0 -551
  212. package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
  213. package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
  214. package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
  215. package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
  216. package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
  217. package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
  218. package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
  219. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
  220. package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
  221. package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
  222. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
  223. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
  224. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
  225. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
  226. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
  227. package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
  228. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
  229. package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
  230. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
  231. package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
  232. package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
  233. package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
  234. package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
  235. package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
  236. package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
  237. package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
  238. package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
  239. package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
  240. package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
  241. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
  242. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
  243. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
  244. package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
  245. package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
  246. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
  247. package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
  248. package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
  249. package/coverage/lcov-report/src/app.ts.html +0 -424
  250. package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
  251. package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
  252. package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
  253. package/coverage/lcov-report/src/automations/index.html +0 -191
  254. package/coverage/lcov-report/src/automations/index.ts.html +0 -163
  255. package/coverage/lcov-report/src/automations/logging/index.html +0 -116
  256. package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
  257. package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
  258. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
  259. package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
  260. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
  261. package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -397
  262. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
  263. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
  264. package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
  265. package/coverage/lcov-report/src/automations/steps/index.html +0 -371
  266. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -409
  267. package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
  268. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
  269. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
  270. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
  271. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
  272. package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -340
  273. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
  274. package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
  275. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -403
  276. package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
  277. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
  278. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
  279. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
  280. package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
  281. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
  282. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
  283. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
  284. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
  285. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
  286. package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
  287. package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
  288. package/coverage/lcov-report/src/constants/index.html +0 -146
  289. package/coverage/lcov-report/src/constants/index.ts.html +0 -697
  290. package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
  291. package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
  292. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
  293. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
  294. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
  295. package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
  296. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
  297. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
  298. package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
  299. package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
  300. package/coverage/lcov-report/src/db/index.html +0 -176
  301. package/coverage/lcov-report/src/db/index.ts.html +0 -133
  302. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
  303. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
  304. package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
  305. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
  306. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
  307. package/coverage/lcov-report/src/db/newid.ts.html +0 -100
  308. package/coverage/lcov-report/src/db/utils.ts.html +0 -913
  309. package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
  310. package/coverage/lcov-report/src/definitions/index.html +0 -116
  311. package/coverage/lcov-report/src/environment.ts.html +0 -472
  312. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
  313. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
  314. package/coverage/lcov-report/src/events/index.html +0 -161
  315. package/coverage/lcov-report/src/events/index.ts.html +0 -100
  316. package/coverage/lcov-report/src/events/utils.ts.html +0 -319
  317. package/coverage/lcov-report/src/index.html +0 -191
  318. package/coverage/lcov-report/src/index.ts.html +0 -133
  319. package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
  320. package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
  321. package/coverage/lcov-report/src/integrations/base/index.html +0 -161
  322. package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
  323. package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
  324. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
  325. package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
  326. package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
  327. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
  328. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
  329. package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
  330. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
  331. package/coverage/lcov-report/src/integrations/index.html +0 -371
  332. package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
  333. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
  334. package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
  335. package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
  336. package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
  337. package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
  338. package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
  339. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
  340. package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
  341. package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
  342. package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
  343. package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
  344. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
  345. package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
  346. package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
  347. package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
  348. package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
  349. package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
  350. package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
  351. package/coverage/lcov-report/src/middleware/index.html +0 -236
  352. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
  353. package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
  354. package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
  355. package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
  356. package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
  357. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
  358. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
  359. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
  360. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
  361. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
  362. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
  363. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
  364. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
  365. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
  366. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
  367. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
  368. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
  369. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
  370. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
  371. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
  372. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
  373. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
  374. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
  375. package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
  376. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
  377. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
  378. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
  379. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
  380. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
  381. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
  382. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
  383. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
  384. package/coverage/lcov-report/src/migrations/index.html +0 -116
  385. package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
  386. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
  387. package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
  388. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
  389. package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
  390. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
  391. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
  392. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
  393. package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
  394. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
  395. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
  396. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
  397. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
  398. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
  399. package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
  400. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
  401. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
  402. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
  403. package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
  404. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
  405. package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
  406. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
  407. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
  408. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
  409. package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
  410. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
  411. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
  412. package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
  413. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
  414. package/coverage/lcov-report/src/sdk/index.html +0 -116
  415. package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
  416. package/coverage/lcov-report/src/sdk/users/index.html +0 -131
  417. package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
  418. package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
  419. package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
  420. package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
  421. package/coverage/lcov-report/src/startup.ts.html +0 -484
  422. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
  423. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
  424. package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
  425. package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
  426. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
  427. package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
  428. package/coverage/lcov-report/src/threads/index.html +0 -161
  429. package/coverage/lcov-report/src/threads/index.ts.html +0 -418
  430. package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
  431. package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
  432. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
  433. package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
  434. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  435. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
  436. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
  437. package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
  438. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
  439. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
  440. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
  441. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  442. package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
  443. package/coverage/lcov-report/src/utilities/index.html +0 -251
  444. package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
  445. package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
  446. package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
  447. package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
  448. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
  449. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
  450. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
  451. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
  452. package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
  453. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
  454. package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
  455. package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
  456. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
  457. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
  458. package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
  459. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
  460. package/coverage/lcov-report/src/watch.ts.html +0 -196
  461. package/coverage/lcov-report/src/websocket.ts.html +0 -163
  462. package/coverage/lcov.info +0 -21770
  463. package/dist/api/routes/public/tests/utils.js +0 -33
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.retry = void 0;
13
+ function retry(fn, maxTry = 5, retryCount = 1) {
14
+ return __awaiter(this, void 0, void 0, function* () {
15
+ const currRetry = typeof retryCount === "number" ? retryCount : 1;
16
+ try {
17
+ const result = yield fn();
18
+ return result;
19
+ }
20
+ catch (e) {
21
+ console.log(`Retry ${currRetry} failed.`);
22
+ if (currRetry > maxTry) {
23
+ console.log(`All ${maxTry} retry attempts exhausted`);
24
+ throw e;
25
+ }
26
+ return retry(fn, maxTry, currRetry + 1);
27
+ }
28
+ });
29
+ }
30
+ exports.retry = retry;
@@ -0,0 +1,8 @@
1
+ const { join } = require("path")
2
+ require("dotenv").config({
3
+ path: join(__dirname, "..", "..", "hosting", ".env"),
4
+ })
5
+
6
+ const jestTestcontainersConfigGenerator = require("../../jestTestcontainersConfigGenerator")
7
+
8
+ module.exports = jestTestcontainersConfigGenerator()
package/jest.config.ts CHANGED
@@ -1,16 +1,13 @@
1
1
  import { Config } from "@jest/types"
2
+
2
3
  import * as fs from "fs"
4
+ const preset = require("ts-jest/jest-preset")
3
5
 
4
- const config: Config.InitialOptions = {
5
- testEnvironment: "node",
6
+ const baseConfig: Config.InitialProjectOptions = {
7
+ ...preset,
8
+ preset: "@trendyol/jest-testcontainers",
6
9
  setupFiles: ["./src/tests/jestEnv.ts"],
7
10
  setupFilesAfterEnv: ["./src/tests/jestSetup.ts"],
8
- collectCoverageFrom: [
9
- "src/**/*.{js,ts}",
10
- // The use of coverage with couchdb view functions breaks tests
11
- "!src/db/views/staticViews.*",
12
- ],
13
- coverageReporters: ["lcov", "json", "clover"],
14
11
  transform: {
15
12
  "^.+\\.ts?$": "@swc/jest",
16
13
  },
@@ -18,19 +15,39 @@ const config: Config.InitialOptions = {
18
15
 
19
16
  if (!process.env.CI) {
20
17
  // use sources when not in CI
21
- config.moduleNameMapper = {
18
+ baseConfig.moduleNameMapper = {
22
19
  "@budibase/backend-core/(.*)": "<rootDir>/../backend-core/$1",
23
20
  "@budibase/backend-core": "<rootDir>/../backend-core/src",
24
21
  "@budibase/types": "<rootDir>/../types/src",
25
- "^axios.*$": "<rootDir>/node_modules/axios/lib/axios.js",
26
22
  }
27
23
  // add pro sources if they exist
28
24
  if (fs.existsSync("../../../budibase-pro")) {
29
- config.moduleNameMapper["@budibase/pro"] =
25
+ baseConfig.moduleNameMapper["@budibase/pro"] =
30
26
  "<rootDir>/../../../budibase-pro/packages/pro/src"
31
27
  }
32
28
  } else {
33
29
  console.log("Running tests with compiled dependency sources")
34
30
  }
35
31
 
32
+ const config: Config.InitialOptions = {
33
+ projects: [
34
+ {
35
+ ...baseConfig,
36
+ displayName: "sequential test",
37
+ testMatch: ["<rootDir>/**/*.seq.spec.[jt]s"],
38
+ runner: "jest-serial-runner",
39
+ },
40
+ {
41
+ ...baseConfig,
42
+ testMatch: ["<rootDir>/**/!(*.seq).spec.[jt]s"],
43
+ },
44
+ ],
45
+ collectCoverageFrom: [
46
+ "src/**/*.{js,ts}",
47
+ // The use of coverage with couchdb view functions breaks tests
48
+ "!src/db/views/staticViews.*",
49
+ ],
50
+ coverageReporters: ["lcov", "json", "clover"],
51
+ }
52
+
36
53
  export default config
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@budibase/server",
3
3
  "email": "hi@budibase.com",
4
- "version": "2.3.17",
4
+ "version": "2.3.18-alpha.0",
5
5
  "description": "Budibase Web Server",
6
6
  "main": "src/index.ts",
7
7
  "repository": {
@@ -43,11 +43,11 @@
43
43
  "license": "GPL-3.0",
44
44
  "dependencies": {
45
45
  "@apidevtools/swagger-parser": "10.0.3",
46
- "@budibase/backend-core": "^2.3.17",
47
- "@budibase/client": "^2.3.17",
48
- "@budibase/pro": "2.3.16",
49
- "@budibase/string-templates": "^2.3.17",
50
- "@budibase/types": "^2.3.17",
46
+ "@budibase/backend-core": "2.3.18-alpha.0",
47
+ "@budibase/client": "2.3.18-alpha.0",
48
+ "@budibase/pro": "2.3.17",
49
+ "@budibase/string-templates": "2.3.18-alpha.0",
50
+ "@budibase/types": "2.3.18-alpha.0",
51
51
  "@bull-board/api": "3.7.0",
52
52
  "@bull-board/koa": "3.9.4",
53
53
  "@elastic/elasticsearch": "7.10.0",
@@ -64,6 +64,7 @@
64
64
  "chokidar": "3.5.3",
65
65
  "csvtojson": "2.0.10",
66
66
  "curlconverter": "3.21.0",
67
+ "dd-trace": "3.13.2",
67
68
  "dotenv": "8.2.0",
68
69
  "download": "8.0.0",
69
70
  "elastic-apm-node": "3.38.0",
@@ -125,6 +126,7 @@
125
126
  "@jest/test-sequencer": "24.9.0",
126
127
  "@swc/core": "^1.3.25",
127
128
  "@swc/jest": "^0.2.24",
129
+ "@trendyol/jest-testcontainers": "^2.1.1",
128
130
  "@types/apidoc": "0.50.0",
129
131
  "@types/bson": "4.2.0",
130
132
  "@types/global-agent": "2.1.1",
@@ -140,6 +142,7 @@
140
142
  "@types/pouchdb": "6.4.0",
141
143
  "@types/redis": "4.0.11",
142
144
  "@types/server-destroy": "1.0.1",
145
+ "@types/supertest": "2.0.12",
143
146
  "@types/tar": "6.1.3",
144
147
  "@typescript-eslint/parser": "5.45.0",
145
148
  "apidoc": "0.50.4",
@@ -151,13 +154,14 @@
151
154
  "is-wsl": "2.2.0",
152
155
  "jest": "28.1.1",
153
156
  "jest-openapi": "0.14.2",
157
+ "jest-serial-runner": "^1.2.1",
154
158
  "nodemon": "2.0.15",
155
159
  "openapi-types": "9.3.1",
156
160
  "openapi-typescript": "5.2.0",
157
161
  "path-to-regexp": "6.2.0",
158
162
  "prettier": "2.5.1",
159
163
  "rimraf": "3.0.2",
160
- "supertest": "4.0.2",
164
+ "supertest": "6.2.2",
161
165
  "swagger-jsdoc": "6.1.0",
162
166
  "timekeeper": "2.2.0",
163
167
  "ts-jest": "28.0.4",
@@ -169,5 +173,5 @@
169
173
  "optionalDependencies": {
170
174
  "oracledb": "5.3.0"
171
175
  },
172
- "gitHead": "a57c922b91c1df8dc276588a5ad583a0c1aea52c"
176
+ "gitHead": "f4dd710b75eb0a7a65e6f9d8b8f709d3b76c435b"
173
177
  }
@@ -0,0 +1,24 @@
1
+ #!/bin/node
2
+ const { createApp } = require("./utils")
3
+
4
+ const APP_COUNT = 100
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ for (let i = 0; i < APP_COUNT; i++) {
13
+ const app = await createApp(process.argv[2])
14
+ console.log(`App created: ${app._id}`)
15
+ }
16
+ }
17
+
18
+ run()
19
+ .then(() => {
20
+ console.log(`Finished creating ${APP_COUNT} apps.`)
21
+ })
22
+ .catch(err => {
23
+ console.error(err)
24
+ })
@@ -0,0 +1,30 @@
1
+ #!/bin/node
2
+ const { createApp, getTable, createRow } = require("./utils")
3
+
4
+ const ROW_COUNT = 1000
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ const apiKey = process.argv[2]
13
+ const app = await createApp(apiKey)
14
+ console.log(`App created: ${app._id}`)
15
+ const table = await getTable(apiKey, app._id)
16
+ console.log(`Table found: ${table.name}`)
17
+ const promises = []
18
+ for (let i = 0; i < ROW_COUNT; i++) {
19
+ promises.push(await createRow(apiKey, app._id, table))
20
+ }
21
+ await Promise.all(promises)
22
+ }
23
+
24
+ run()
25
+ .then(() => {
26
+ console.log(`Finished creating ${ROW_COUNT} rows.`)
27
+ })
28
+ .catch(err => {
29
+ console.error(err)
30
+ })
@@ -0,0 +1,66 @@
1
+ const fetch = require("node-fetch")
2
+ const uuid = require("uuid/v4")
3
+
4
+ const URL_APP = "http://localhost:10000/api/public/v1/applications"
5
+ const URL_TABLE = "http://localhost:10000/api/public/v1/tables/search"
6
+
7
+ async function request(apiKey, url, method, body, appId = undefined) {
8
+ const headers = {
9
+ "x-budibase-api-key": apiKey,
10
+ "Content-Type": "application/json",
11
+ }
12
+ if (appId) {
13
+ headers["x-budibase-app-id"] = appId
14
+ }
15
+ const res = await fetch(url, {
16
+ method,
17
+ headers,
18
+ body: JSON.stringify(body),
19
+ })
20
+ if (res.status !== 200) {
21
+ throw new Error(await res.text())
22
+ }
23
+ return res
24
+ }
25
+
26
+ exports.createApp = async apiKey => {
27
+ const name = uuid().replace(/-/g, "")
28
+ const body = {
29
+ name,
30
+ url: `/${name}`,
31
+ useTemplate: "true",
32
+ templateKey: "app/school-admin-panel",
33
+ templateName: "School Admin Panel",
34
+ }
35
+ const res = await request(apiKey, URL_APP, "POST", body)
36
+ const json = await res.json()
37
+ return json.data
38
+ }
39
+
40
+ exports.getTable = async (apiKey, appId) => {
41
+ const res = await request(apiKey, URL_TABLE, "POST", {}, appId)
42
+ const json = await res.json()
43
+ return json.data[0]
44
+ }
45
+
46
+ exports.createRow = async (apiKey, appId, table) => {
47
+ const body = {}
48
+ for (let [key, schema] of Object.entries(table.schema)) {
49
+ let fake
50
+ switch (schema.type) {
51
+ default:
52
+ case "string":
53
+ fake = schema.constraints.inclusion
54
+ ? schema.constraints.inclusion[0]
55
+ : "a"
56
+ break
57
+ case "number":
58
+ fake = 1
59
+ break
60
+ }
61
+ body[key] = fake
62
+ }
63
+ const url = `http://localhost:10000/api/public/v1/tables/${table._id}/rows`
64
+ const res = await request(apiKey, url, "POST", body, appId)
65
+ return (await res.json()).data
66
+ }
@@ -817,7 +817,6 @@
817
817
  "type": "string",
818
818
  "enum": [
819
819
  "string",
820
- "barcodeqr",
821
820
  "longform",
822
821
  "options",
823
822
  "number",
@@ -829,7 +828,8 @@
829
828
  "formula",
830
829
  "auto",
831
830
  "json",
832
- "internal"
831
+ "internal",
832
+ "barcodeqr"
833
833
  ],
834
834
  "description": "Defines the type of the column, most explain themselves, a link column is a relationship."
835
835
  },
@@ -1021,7 +1021,6 @@
1021
1021
  "type": "string",
1022
1022
  "enum": [
1023
1023
  "string",
1024
- "barcodeqr",
1025
1024
  "longform",
1026
1025
  "options",
1027
1026
  "number",
@@ -1033,7 +1032,8 @@
1033
1032
  "formula",
1034
1033
  "auto",
1035
1034
  "json",
1036
- "internal"
1035
+ "internal",
1036
+ "barcodeqr"
1037
1037
  ],
1038
1038
  "description": "Defines the type of the column, most explain themselves, a link column is a relationship."
1039
1039
  },
@@ -1236,7 +1236,6 @@
1236
1236
  "type": "string",
1237
1237
  "enum": [
1238
1238
  "string",
1239
- "barcodeqr",
1240
1239
  "longform",
1241
1240
  "options",
1242
1241
  "number",
@@ -1248,7 +1247,8 @@
1248
1247
  "formula",
1249
1248
  "auto",
1250
1249
  "json",
1251
- "internal"
1250
+ "internal",
1251
+ "barcodeqr"
1252
1252
  ],
1253
1253
  "description": "Defines the type of the column, most explain themselves, a link column is a relationship."
1254
1254
  },
@@ -603,7 +603,6 @@ components:
603
603
  type: string
604
604
  enum:
605
605
  - string
606
- - barcodeqr
607
606
  - longform
608
607
  - options
609
608
  - number
@@ -616,6 +615,7 @@ components:
616
615
  - auto
617
616
  - json
618
617
  - internal
618
+ - barcodeqr
619
619
  description: Defines the type of the column, most explain themselves, a link
620
620
  column is a relationship.
621
621
  constraints:
@@ -766,7 +766,6 @@ components:
766
766
  type: string
767
767
  enum:
768
768
  - string
769
- - barcodeqr
770
769
  - longform
771
770
  - options
772
771
  - number
@@ -779,6 +778,7 @@ components:
779
778
  - auto
780
779
  - json
781
780
  - internal
781
+ - barcodeqr
782
782
  description: Defines the type of the column, most explain themselves, a link
783
783
  column is a relationship.
784
784
  constraints:
@@ -936,7 +936,6 @@ components:
936
936
  type: string
937
937
  enum:
938
938
  - string
939
- - barcodeqr
940
939
  - longform
941
940
  - options
942
941
  - number
@@ -949,6 +948,7 @@ components:
949
948
  - auto
950
949
  - json
951
950
  - internal
951
+ - barcodeqr
952
952
  description: Defines the type of the column, most explain themselves, a link
953
953
  column is a relationship.
954
954
  constraints:
@@ -41,7 +41,7 @@ const datasets = {
41
41
  describe("Rest Importer", () => {
42
42
  const config = new TestConfig(false)
43
43
 
44
- beforeEach(async () => {
44
+ beforeAll(async () => {
45
45
  await config.init()
46
46
  })
47
47
 
@@ -186,6 +186,8 @@ export async function preview(ctx: any) {
186
186
  schemaFields[key] = fieldType
187
187
  }
188
188
  }
189
+ // remove configuration before sending event
190
+ delete datasource.config
189
191
  await events.query.previewed(datasource, query)
190
192
  ctx.body = {
191
193
  rows,
@@ -10,6 +10,7 @@ import {
10
10
  FieldSchema,
11
11
  Row,
12
12
  Table,
13
+ RelationshipTypes,
13
14
  } from "@budibase/types"
14
15
  import {
15
16
  breakRowIdField,
@@ -18,7 +19,7 @@ import {
18
19
  convertRowId,
19
20
  } from "../../../integrations/utils"
20
21
  import { getDatasourceAndQuery } from "./utils"
21
- import { FieldTypes, RelationshipTypes } from "../../../constants"
22
+ import { FieldTypes } from "../../../constants"
22
23
  import { breakExternalTableId, isSQL } from "../../../integrations/utils"
23
24
  import { processObjectSync } from "@budibase/string-templates"
24
25
  import { cloneDeep } from "lodash/fp"
@@ -44,6 +45,7 @@ export interface RunConfig {
44
45
  row?: Row
45
46
  rows?: Row[]
46
47
  tables?: Record<string, Table>
48
+ includeSqlRelationships?: IncludeRelationship
47
49
  }
48
50
 
49
51
  function buildFilters(
@@ -706,7 +708,9 @@ export class ExternalRequest {
706
708
  },
707
709
  resource: {
708
710
  // have to specify the fields to avoid column overlap (for SQL)
709
- fields: isSql ? this.buildFields(table) : [],
711
+ fields: isSql
712
+ ? this.buildFields(table, config.includeSqlRelationships)
713
+ : [],
710
714
  },
711
715
  filters,
712
716
  sort,
@@ -18,6 +18,7 @@ import {
18
18
  PaginationJson,
19
19
  Table,
20
20
  Datasource,
21
+ IncludeRelationship,
21
22
  } from "@budibase/types"
22
23
  import sdk from "../../../sdk"
23
24
 
@@ -57,6 +58,7 @@ export async function patch(ctx: BBContext) {
57
58
  return handleRequest(Operation.UPDATE, tableId, {
58
59
  id: breakRowIdField(id),
59
60
  row: inputs,
61
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
60
62
  })
61
63
  }
62
64
 
@@ -65,6 +67,7 @@ export async function save(ctx: BBContext) {
65
67
  const tableId = ctx.params.tableId
66
68
  return handleRequest(Operation.CREATE, tableId, {
67
69
  row: inputs,
70
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
68
71
  })
69
72
  }
70
73
 
@@ -78,7 +81,9 @@ export async function fetchView(ctx: BBContext) {
78
81
 
79
82
  export async function fetch(ctx: BBContext) {
80
83
  const tableId = ctx.params.tableId
81
- return handleRequest(Operation.READ, tableId)
84
+ return handleRequest(Operation.READ, tableId, {
85
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
86
+ })
82
87
  }
83
88
 
84
89
  export async function find(ctx: BBContext) {
@@ -86,6 +91,7 @@ export async function find(ctx: BBContext) {
86
91
  const tableId = ctx.params.tableId
87
92
  const response = (await handleRequest(Operation.READ, tableId, {
88
93
  id: breakRowIdField(id),
94
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
89
95
  })) as Row[]
90
96
  return response ? response[0] : response
91
97
  }
@@ -95,6 +101,7 @@ export async function destroy(ctx: BBContext) {
95
101
  const id = ctx.request.body._id
96
102
  const { row } = (await handleRequest(Operation.DELETE, tableId, {
97
103
  id: breakRowIdField(id),
104
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
98
105
  })) as { row: Row }
99
106
  return { response: { ok: true }, row }
100
107
  }
@@ -107,6 +114,7 @@ export async function bulkDestroy(ctx: BBContext) {
107
114
  promises.push(
108
115
  handleRequest(Operation.DELETE, tableId, {
109
116
  id: breakRowIdField(row._id),
117
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
110
118
  })
111
119
  )
112
120
  }
@@ -149,6 +157,7 @@ export async function search(ctx: BBContext) {
149
157
  filters: query,
150
158
  sort,
151
159
  paginate: paginateObj as PaginationJson,
160
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
152
161
  })) as Row[]
153
162
  let hasNextPage = false
154
163
  if (paginate && rows.length === limit) {
@@ -159,6 +168,7 @@ export async function search(ctx: BBContext) {
159
168
  limit: 1,
160
169
  page: bookmark * limit + 1,
161
170
  },
171
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
162
172
  })) as Row[]
163
173
  hasNextPage = nextRows.length > 0
164
174
  }
@@ -249,6 +259,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
249
259
  const response = (await handleRequest(Operation.READ, tableId, {
250
260
  id,
251
261
  datasource,
262
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
252
263
  })) as Row[]
253
264
  const table: Table = tables[tableName]
254
265
  const row = response[0]
@@ -276,6 +287,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
276
287
  [primaryLink]: linkedIds,
277
288
  },
278
289
  },
290
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
279
291
  })
280
292
  }
281
293
  return row
@@ -38,7 +38,13 @@ export async function updateRelatedFormula(
38
38
  if (!relatedRows[relatedTableId]) {
39
39
  relatedRows[relatedTableId] = []
40
40
  }
41
- relatedRows[relatedTableId] = relatedRows[relatedTableId].concat(field)
41
+ // filter down to the rows which are not already included in related
42
+ const currentIds = relatedRows[relatedTableId].map(row => row._id)
43
+ const uniqueRelatedRows = field.filter(
44
+ (row: Row) => !currentIds.includes(row._id)
45
+ )
46
+ relatedRows[relatedTableId] =
47
+ relatedRows[relatedTableId].concat(uniqueRelatedRows)
42
48
  }
43
49
  }
44
50
  for (let tableId of table.relatedFormula) {
@@ -8,7 +8,7 @@ import {
8
8
  foreignKeyStructure,
9
9
  hasTypeChanged,
10
10
  } from "./utils"
11
- import { FieldTypes, RelationshipTypes } from "../../../constants"
11
+ import { FieldTypes } from "../../../constants"
12
12
  import { makeExternalQuery } from "../../../integrations/base/query"
13
13
  import { handleRequest } from "../row/external"
14
14
  import { events, context } from "@budibase/backend-core"
@@ -22,6 +22,7 @@ import {
22
22
  FieldSchema,
23
23
  BBContext,
24
24
  TableRequest,
25
+ RelationshipTypes,
25
26
  } from "@budibase/types"
26
27
  import sdk from "../../../sdk"
27
28
  const { cloneDeep } = require("lodash/fp")
@@ -146,7 +147,7 @@ function generateLinkSchema(
146
147
  column: FieldSchema,
147
148
  table: Table,
148
149
  relatedTable: Table,
149
- type: string
150
+ type: RelationshipTypes
150
151
  ) {
151
152
  if (!table.primary || !relatedTable.primary) {
152
153
  throw new Error("Unable to generate link schema, no primary keys")
package/src/api/index.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import Router from "@koa/router"
2
- import { errors, auth } from "@budibase/backend-core"
2
+ import { auth, middleware } from "@budibase/backend-core"
3
3
  import currentApp from "../middleware/currentapp"
4
4
  import zlib from "zlib"
5
5
  import { mainRoutes, staticRoutes, publicRoutes } from "./routes"
@@ -14,6 +14,8 @@ export const router: Router = new Router()
14
14
  router.get("/health", ctx => (ctx.status = 200))
15
15
  router.get("/version", ctx => (ctx.body = pkg.version))
16
16
 
17
+ router.use(middleware.errorHandling)
18
+
17
19
  router
18
20
  .use(
19
21
  compress({
@@ -54,27 +56,6 @@ router
54
56
  .use(currentApp)
55
57
  .use(auth.auditLog)
56
58
 
57
- // error handling middleware
58
- router.use(async (ctx, next) => {
59
- try {
60
- await next()
61
- } catch (err: any) {
62
- ctx.status = err.status || err.statusCode || 500
63
- const error = errors.getPublicError(err)
64
- ctx.body = {
65
- message: err.message,
66
- status: ctx.status,
67
- validationErrors: err.validation,
68
- error,
69
- }
70
- ctx.log.error(err)
71
- // unauthorised errors don't provide a useful trace
72
- if (!env.isTest()) {
73
- console.trace(err)
74
- }
75
- }
76
- })
77
-
78
59
  // authenticated routes
79
60
  for (let route of mainRoutes) {
80
61
  router.use(route.routes())
@@ -1,7 +1,6 @@
1
1
  import controller from "../../controllers/public/applications"
2
2
  import Endpoint from "./utils/Endpoint"
3
3
  const { nameValidator, applicationValidator } = require("../utils/validators")
4
- import { db } from "@budibase/backend-core"
5
4
 
6
5
  const read = [],
7
6
  write = []
@@ -13,7 +13,7 @@ beforeAll(async () => {
13
13
  app = await config.init()
14
14
  table = await config.updateTable()
15
15
  apiKey = await config.generateApiKey()
16
- makeRequest = generateMakeRequest(apiKey, setup)
16
+ makeRequest = generateMakeRequest(apiKey)
17
17
  })
18
18
 
19
19
  afterAll(setup.afterAll)
@@ -10,7 +10,7 @@ beforeAll(async () => {
10
10
  await config.init()
11
11
  globalUser = await config.globalUser()
12
12
  apiKey = await config.generateApiKey(globalUser._id)
13
- makeRequest = generateMakeRequest(apiKey, setup)
13
+ makeRequest = generateMakeRequest(apiKey)
14
14
  workerRequests.readGlobalUser.mockReturnValue(globalUser)
15
15
  })
16
16