@budibase/server 2.3.2-alpha.1 → 2.3.2-alpha.3

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 (482) hide show
  1. package/builder/assets/{index.f9a5e06c.js → index.bef36368.js} +233 -233
  2. package/builder/index.html +1 -1
  3. package/coverage/clover.xml +4143 -3896
  4. package/coverage/coverage-final.json +271 -270
  5. package/coverage/lcov-report/index.html +113 -98
  6. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +6 -6
  7. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +5 -5
  8. package/coverage/lcov-report/src/api/controllers/application.ts.html +82 -82
  9. package/coverage/lcov-report/src/api/controllers/auth.ts.html +9 -9
  10. package/coverage/lcov-report/src/api/controllers/automation.ts.html +24 -24
  11. package/coverage/lcov-report/src/api/controllers/backup.ts.html +6 -6
  12. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +12 -12
  13. package/coverage/lcov-report/src/api/controllers/component.ts.html +5 -5
  14. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +37 -37
  15. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +14 -14
  16. package/coverage/lcov-report/src/api/controllers/deploy/index.html +1 -1
  17. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +80 -80
  18. package/coverage/lcov-report/src/api/controllers/dev.ts.html +17 -17
  19. package/coverage/lcov-report/src/api/controllers/index.html +5 -5
  20. package/coverage/lcov-report/src/api/controllers/integration.ts.html +4 -4
  21. package/coverage/lcov-report/src/api/controllers/layout.ts.html +6 -6
  22. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +9 -9
  23. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +4 -4
  24. package/coverage/lcov-report/src/api/controllers/permission.ts.html +13 -13
  25. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +2 -2
  26. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +4 -4
  27. package/coverage/lcov-report/src/api/controllers/plugin/index.html +1 -1
  28. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +18 -18
  29. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +5 -5
  30. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +5 -5
  31. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +3 -3
  32. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +3 -3
  33. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +6 -6
  34. package/coverage/lcov-report/src/api/controllers/public/index.html +1 -1
  35. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +2 -2
  36. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +1 -1
  37. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +7 -7
  38. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +2 -2
  39. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +2 -2
  40. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +2 -2
  41. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +2 -2
  42. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +4 -4
  43. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +5 -5
  44. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +4 -4
  45. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +6 -6
  46. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +4 -4
  47. package/coverage/lcov-report/src/api/controllers/query/import/index.html +1 -1
  48. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +7 -7
  49. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +1 -1
  50. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +3 -3
  51. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +5 -5
  52. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +7 -7
  53. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +1 -1
  54. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +9 -9
  55. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +13 -13
  56. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/curl/curl.spec.js.html +1 -1
  57. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/curl/index.html +1 -1
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi2/index.html +1 -1
  59. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi2/openapi2.spec.js.html +1 -1
  60. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi3/index.html +1 -1
  61. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi3/openapi3.spec.js.html +1 -1
  62. package/coverage/lcov-report/src/api/controllers/query/import/tests/index.html +1 -1
  63. package/coverage/lcov-report/src/api/controllers/query/import/tests/index.spec.js.html +1 -1
  64. package/coverage/lcov-report/src/api/controllers/query/index.html +1 -1
  65. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +22 -22
  66. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +9 -9
  67. package/coverage/lcov-report/src/api/controllers/role.ts.html +8 -8
  68. package/coverage/lcov-report/src/api/controllers/routing.ts.html +6 -6
  69. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +431 -419
  70. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +211 -175
  71. package/coverage/lcov-report/src/api/controllers/row/index.html +40 -40
  72. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +77 -77
  73. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +19 -19
  74. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +6 -6
  75. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +7 -7
  76. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +17 -17
  77. package/coverage/lcov-report/src/api/controllers/screen.ts.html +7 -7
  78. package/coverage/lcov-report/src/api/controllers/script.ts.html +2 -2
  79. package/coverage/lcov-report/src/api/controllers/static/index.html +1 -1
  80. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +22 -22
  81. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +10 -10
  82. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +198 -195
  83. package/coverage/lcov-report/src/api/controllers/table/index.html +36 -36
  84. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +40 -40
  85. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +13 -13
  86. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +33 -33
  87. package/coverage/lcov-report/src/api/controllers/templates.ts.html +7 -7
  88. package/coverage/lcov-report/src/api/controllers/user.ts.html +14 -14
  89. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +2 -2
  90. package/coverage/lcov-report/src/api/controllers/view/index.html +1 -1
  91. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +16 -16
  92. package/coverage/lcov-report/src/api/controllers/view/tests/index.html +1 -1
  93. package/coverage/lcov-report/src/api/controllers/view/tests/viewBuilder.spec.js.html +1 -1
  94. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +5 -5
  95. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +7 -7
  96. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +14 -14
  97. package/coverage/lcov-report/src/api/index.html +1 -1
  98. package/coverage/lcov-report/src/api/index.ts.html +27 -27
  99. package/coverage/lcov-report/src/api/routes/analytics.ts.html +7 -7
  100. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +8 -8
  101. package/coverage/lcov-report/src/api/routes/application.ts.html +10 -10
  102. package/coverage/lcov-report/src/api/routes/auth.ts.html +6 -6
  103. package/coverage/lcov-report/src/api/routes/automation.ts.html +11 -11
  104. package/coverage/lcov-report/src/api/routes/backup.ts.html +8 -8
  105. package/coverage/lcov-report/src/api/routes/cloud.ts.html +8 -8
  106. package/coverage/lcov-report/src/api/routes/component.ts.html +8 -8
  107. package/coverage/lcov-report/src/api/routes/datasource.ts.html +9 -9
  108. package/coverage/lcov-report/src/api/routes/deploy.ts.html +8 -8
  109. package/coverage/lcov-report/src/api/routes/dev.ts.html +13 -13
  110. package/coverage/lcov-report/src/api/routes/index.html +1 -1
  111. package/coverage/lcov-report/src/api/routes/index.ts.html +35 -35
  112. package/coverage/lcov-report/src/api/routes/integration.ts.html +8 -8
  113. package/coverage/lcov-report/src/api/routes/layout.ts.html +8 -8
  114. package/coverage/lcov-report/src/api/routes/metadata.ts.html +9 -9
  115. package/coverage/lcov-report/src/api/routes/migrations.ts.html +7 -7
  116. package/coverage/lcov-report/src/api/routes/permission.ts.html +9 -9
  117. package/coverage/lcov-report/src/api/routes/plugin.ts.html +8 -8
  118. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +14 -14
  119. package/coverage/lcov-report/src/api/routes/public/index.html +1 -1
  120. package/coverage/lcov-report/src/api/routes/public/index.ts.html +52 -52
  121. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +1 -1
  122. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +4 -4
  123. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +9 -9
  124. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +12 -12
  125. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +12 -12
  126. package/coverage/lcov-report/src/api/routes/public/tests/compare.spec.js.html +2 -2
  127. package/coverage/lcov-report/src/api/routes/public/tests/index.html +9 -9
  128. package/coverage/lcov-report/src/api/routes/public/tests/users.spec.js.html +2 -2
  129. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +78 -27
  130. package/coverage/lcov-report/src/api/routes/public/users.ts.html +12 -12
  131. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +19 -19
  132. package/coverage/lcov-report/src/api/routes/public/utils/index.html +1 -1
  133. package/coverage/lcov-report/src/api/routes/query.ts.html +11 -11
  134. package/coverage/lcov-report/src/api/routes/role.ts.html +9 -9
  135. package/coverage/lcov-report/src/api/routes/routing.ts.html +8 -8
  136. package/coverage/lcov-report/src/api/routes/row.ts.html +11 -11
  137. package/coverage/lcov-report/src/api/routes/screen.ts.html +9 -9
  138. package/coverage/lcov-report/src/api/routes/script.ts.html +1 -1
  139. package/coverage/lcov-report/src/api/routes/static.ts.html +14 -14
  140. package/coverage/lcov-report/src/api/routes/table.ts.html +11 -11
  141. package/coverage/lcov-report/src/api/routes/templates.ts.html +8 -8
  142. package/coverage/lcov-report/src/api/routes/tests/analytics.spec.js.html +1 -1
  143. package/coverage/lcov-report/src/api/routes/tests/apikeys.spec.js.html +1 -1
  144. package/coverage/lcov-report/src/api/routes/tests/application.spec.ts.html +1 -1
  145. package/coverage/lcov-report/src/api/routes/tests/auth.spec.js.html +1 -1
  146. package/coverage/lcov-report/src/api/routes/tests/automation.spec.js.html +1 -1
  147. package/coverage/lcov-report/src/api/routes/tests/backup.spec.ts.html +1 -1
  148. package/coverage/lcov-report/src/api/routes/tests/cloud.seq.spec.ts.html +2 -2
  149. package/coverage/lcov-report/src/api/routes/tests/component.spec.js.html +1 -1
  150. package/coverage/lcov-report/src/api/routes/tests/datasource.spec.ts.html +1 -1
  151. package/coverage/lcov-report/src/api/routes/tests/dev.spec.js.html +1 -1
  152. package/coverage/lcov-report/src/api/routes/tests/index.html +1 -1
  153. package/coverage/lcov-report/src/api/routes/tests/integration.spec.js.html +1 -1
  154. package/coverage/lcov-report/src/api/routes/tests/internalSearch.spec.js.html +1 -1
  155. package/coverage/lcov-report/src/api/routes/tests/layout.spec.js.html +1 -1
  156. package/coverage/lcov-report/src/api/routes/tests/metadata.spec.js.html +1 -1
  157. package/coverage/lcov-report/src/api/routes/tests/misc.spec.js.html +1 -1
  158. package/coverage/lcov-report/src/api/routes/tests/permissions.spec.js.html +1 -1
  159. package/coverage/lcov-report/src/api/routes/tests/plugin.spec.ts.html +1 -1
  160. package/coverage/lcov-report/src/api/routes/tests/query.seq.spec.js.html +1 -1
  161. package/coverage/lcov-report/src/api/routes/tests/role.spec.js.html +1 -1
  162. package/coverage/lcov-report/src/api/routes/tests/routing.spec.js.html +1 -1
  163. package/coverage/lcov-report/src/api/routes/tests/row.spec.js.html +1 -1
  164. package/coverage/lcov-report/src/api/routes/tests/screen.spec.js.html +1 -1
  165. package/coverage/lcov-report/src/api/routes/tests/static.spec.js.html +1 -1
  166. package/coverage/lcov-report/src/api/routes/tests/table.spec.js.html +1 -1
  167. package/coverage/lcov-report/src/api/routes/tests/templates.spec.js.html +1 -1
  168. package/coverage/lcov-report/src/api/routes/tests/user.spec.js.html +1 -1
  169. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +2 -2
  170. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +1 -1
  171. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +14 -14
  172. package/coverage/lcov-report/src/api/routes/tests/view.spec.js.html +1 -1
  173. package/coverage/lcov-report/src/api/routes/tests/webhook.spec.js.html +1 -1
  174. package/coverage/lcov-report/src/api/routes/user.ts.html +9 -9
  175. package/coverage/lcov-report/src/api/routes/utils/index.html +1 -1
  176. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +42 -42
  177. package/coverage/lcov-report/src/api/routes/view.ts.html +10 -10
  178. package/coverage/lcov-report/src/api/routes/webhook.ts.html +10 -10
  179. package/coverage/lcov-report/src/app.ts.html +33 -33
  180. package/coverage/lcov-report/src/automations/actions.ts.html +24 -24
  181. package/coverage/lcov-report/src/automations/automationUtils.ts.html +4 -4
  182. package/coverage/lcov-report/src/automations/bullboard.ts.html +9 -9
  183. package/coverage/lcov-report/src/automations/index.html +1 -1
  184. package/coverage/lcov-report/src/automations/index.ts.html +9 -9
  185. package/coverage/lcov-report/src/automations/logging/index.html +1 -1
  186. package/coverage/lcov-report/src/automations/logging/index.ts.html +4 -4
  187. package/coverage/lcov-report/src/automations/steps/bash.ts.html +8 -8
  188. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +7 -7
  189. package/coverage/lcov-report/src/automations/steps/delay.ts.html +5 -5
  190. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +7 -7
  191. package/coverage/lcov-report/src/automations/steps/discord.ts.html +8 -8
  192. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +7 -7
  193. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +7 -7
  194. package/coverage/lcov-report/src/automations/steps/filter.ts.html +6 -6
  195. package/coverage/lcov-report/src/automations/steps/index.html +1 -1
  196. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +6 -6
  197. package/coverage/lcov-report/src/automations/steps/loop.ts.html +3 -3
  198. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +9 -9
  199. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +13 -13
  200. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +6 -6
  201. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +4 -4
  202. package/coverage/lcov-report/src/automations/steps/slack.ts.html +6 -6
  203. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +7 -7
  204. package/coverage/lcov-report/src/automations/steps/utils.ts.html +1 -1
  205. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +6 -6
  206. package/coverage/lcov-report/src/automations/tests/automation.spec.js.html +1 -1
  207. package/coverage/lcov-report/src/automations/tests/bash.spec.js.html +1 -1
  208. package/coverage/lcov-report/src/automations/tests/createRow.spec.ts.html +1 -1
  209. package/coverage/lcov-report/src/automations/tests/delay.spec.js.html +1 -1
  210. package/coverage/lcov-report/src/automations/tests/deleteRow.spec.ts.html +1 -1
  211. package/coverage/lcov-report/src/automations/tests/discord.spec.js.html +1 -1
  212. package/coverage/lcov-report/src/automations/tests/executeQuery.spec.js.html +1 -1
  213. package/coverage/lcov-report/src/automations/tests/executeScript.spec.js.html +1 -1
  214. package/coverage/lcov-report/src/automations/tests/filter.spec.js.html +1 -1
  215. package/coverage/lcov-report/src/automations/tests/index.html +1 -1
  216. package/coverage/lcov-report/src/automations/tests/loop.spec.ts.html +1 -1
  217. package/coverage/lcov-report/src/automations/tests/outgoingWebhook.spec.js.html +1 -1
  218. package/coverage/lcov-report/src/automations/tests/queryRows.spec.js.html +1 -1
  219. package/coverage/lcov-report/src/automations/tests/sendSmtpEmail.spec.js.html +1 -1
  220. package/coverage/lcov-report/src/automations/tests/serverLog.spec.js.html +1 -1
  221. package/coverage/lcov-report/src/automations/tests/updateRow.spec.js.html +1 -1
  222. package/coverage/lcov-report/src/automations/tests/utilities/index.html +1 -1
  223. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +1 -1
  224. package/coverage/lcov-report/src/automations/tests/zapier.spec.js.html +1 -1
  225. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +3 -3
  226. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +3 -3
  227. package/coverage/lcov-report/src/automations/triggerInfo/index.html +1 -1
  228. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +8 -8
  229. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +3 -3
  230. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +3 -3
  231. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +3 -3
  232. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +3 -3
  233. package/coverage/lcov-report/src/automations/triggers.ts.html +29 -29
  234. package/coverage/lcov-report/src/automations/unitTests/automationUtils.spec.ts.html +1 -1
  235. package/coverage/lcov-report/src/automations/unitTests/index.html +1 -1
  236. package/coverage/lcov-report/src/automations/utils.ts.html +36 -36
  237. package/coverage/lcov-report/src/constants/index.html +16 -16
  238. package/coverage/lcov-report/src/constants/index.ts.html +33 -99
  239. package/coverage/lcov-report/src/constants/layouts.ts.html +4 -4
  240. package/coverage/lcov-report/src/constants/screens.ts.html +3 -3
  241. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +33 -45
  242. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +2 -2
  243. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +2 -2
  244. package/coverage/lcov-report/src/db/defaultData/index.html +11 -11
  245. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +2 -2
  246. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +2 -2
  247. package/coverage/lcov-report/src/db/dynamoClient.ts.html +15 -15
  248. package/coverage/lcov-report/src/db/inMemoryView.ts.html +4 -4
  249. package/coverage/lcov-report/src/db/index.html +5 -5
  250. package/coverage/lcov-report/src/db/index.ts.html +7 -7
  251. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +15 -12
  252. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +4 -4
  253. package/coverage/lcov-report/src/db/linkedRows/index.html +10 -10
  254. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +9 -9
  255. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +5 -5
  256. package/coverage/lcov-report/src/db/newid.ts.html +4 -4
  257. package/coverage/lcov-report/src/db/tests/index.html +1 -1
  258. package/coverage/lcov-report/src/db/tests/linkController.spec.js.html +1 -1
  259. package/coverage/lcov-report/src/db/tests/linkTests.spec.js.html +1 -1
  260. package/coverage/lcov-report/src/db/utils.ts.html +36 -36
  261. package/coverage/lcov-report/src/definitions/automations.ts.html +2 -2
  262. package/coverage/lcov-report/src/definitions/index.html +1 -1
  263. package/coverage/lcov-report/src/environment.ts.html +21 -21
  264. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +6 -6
  265. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +6 -6
  266. package/coverage/lcov-report/src/events/index.html +1 -1
  267. package/coverage/lcov-report/src/events/index.ts.html +4 -4
  268. package/coverage/lcov-report/src/events/utils.ts.html +10 -10
  269. package/coverage/lcov-report/src/index.html +1 -1
  270. package/coverage/lcov-report/src/index.ts.html +1 -1
  271. package/coverage/lcov-report/src/integration-test/index.html +116 -0
  272. package/coverage/lcov-report/src/integration-test/postgres.spec.ts.html +2341 -0
  273. package/coverage/lcov-report/src/integrations/airtable.ts.html +5 -5
  274. package/coverage/lcov-report/src/integrations/arangodb.ts.html +5 -5
  275. package/coverage/lcov-report/src/integrations/base/index.html +30 -30
  276. package/coverage/lcov-report/src/integrations/base/query.ts.html +9 -9
  277. package/coverage/lcov-report/src/integrations/base/sql.ts.html +217 -187
  278. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +107 -107
  279. package/coverage/lcov-report/src/integrations/base/utils.ts.html +5 -5
  280. package/coverage/lcov-report/src/integrations/couchdb.ts.html +5 -5
  281. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +6 -6
  282. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +5 -5
  283. package/coverage/lcov-report/src/integrations/firebase.ts.html +5 -5
  284. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +11 -11
  285. package/coverage/lcov-report/src/integrations/index.html +27 -27
  286. package/coverage/lcov-report/src/integrations/index.ts.html +37 -37
  287. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +8 -8
  288. package/coverage/lcov-report/src/integrations/mongodb.ts.html +11 -11
  289. package/coverage/lcov-report/src/integrations/mysql.ts.html +10 -10
  290. package/coverage/lcov-report/src/integrations/oracle.ts.html +14 -14
  291. package/coverage/lcov-report/src/integrations/postgres.ts.html +65 -65
  292. package/coverage/lcov-report/src/integrations/queries/index.html +1 -1
  293. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +1 -1
  294. package/coverage/lcov-report/src/integrations/redis.ts.html +5 -5
  295. package/coverage/lcov-report/src/integrations/rest.ts.html +15 -15
  296. package/coverage/lcov-report/src/integrations/s3.ts.html +6 -6
  297. package/coverage/lcov-report/src/integrations/snowflake.ts.html +5 -5
  298. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
  299. package/coverage/lcov-report/src/integrations/tests/airtable.spec.ts.html +1 -1
  300. package/coverage/lcov-report/src/integrations/tests/arangodb.spec.ts.html +1 -1
  301. package/coverage/lcov-report/src/integrations/tests/couchdb.spec.ts.html +1 -1
  302. package/coverage/lcov-report/src/integrations/tests/dynamodb.spec.ts.html +1 -1
  303. package/coverage/lcov-report/src/integrations/tests/elasticsearch.spec.ts.html +1 -1
  304. package/coverage/lcov-report/src/integrations/tests/firebase.spec.ts.html +1 -1
  305. package/coverage/lcov-report/src/integrations/tests/index.html +1 -1
  306. package/coverage/lcov-report/src/integrations/tests/microsoftSqlServer.spec.ts.html +1 -1
  307. package/coverage/lcov-report/src/integrations/tests/mongo.spec.ts.html +1 -1
  308. package/coverage/lcov-report/src/integrations/tests/mysql.spec.ts.html +1 -1
  309. package/coverage/lcov-report/src/integrations/tests/oracle.spec.ts.html +1 -1
  310. package/coverage/lcov-report/src/integrations/tests/postgres.spec.ts.html +1 -1
  311. package/coverage/lcov-report/src/integrations/tests/redis.spec.ts.html +1 -1
  312. package/coverage/lcov-report/src/integrations/tests/rest.spec.ts.html +1 -1
  313. package/coverage/lcov-report/src/integrations/tests/s3.spec.ts.html +1 -1
  314. package/coverage/lcov-report/src/integrations/tests/sql.spec.ts.html +1 -1
  315. package/coverage/lcov-report/src/integrations/utils.ts.html +74 -74
  316. package/coverage/lcov-report/src/middleware/appInfo.ts.html +5 -5
  317. package/coverage/lcov-report/src/middleware/authorized.ts.html +29 -29
  318. package/coverage/lcov-report/src/middleware/builder.ts.html +17 -17
  319. package/coverage/lcov-report/src/middleware/currentapp.ts.html +39 -39
  320. package/coverage/lcov-report/src/middleware/index.html +1 -1
  321. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +1 -1
  322. package/coverage/lcov-report/src/middleware/publicApi.ts.html +4 -4
  323. package/coverage/lcov-report/src/middleware/resourceId.ts.html +28 -28
  324. package/coverage/lcov-report/src/middleware/selfhost.ts.html +1 -1
  325. package/coverage/lcov-report/src/middleware/tests/authorized.spec.js.html +1 -1
  326. package/coverage/lcov-report/src/middleware/tests/currentapp.spec.js.html +1 -1
  327. package/coverage/lcov-report/src/middleware/tests/index.html +1 -1
  328. package/coverage/lcov-report/src/middleware/tests/resourceId.spec.js.html +1 -1
  329. package/coverage/lcov-report/src/middleware/tests/selfhost.spec.js.html +1 -1
  330. package/coverage/lcov-report/src/middleware/utils.ts.html +4 -4
  331. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +4 -4
  332. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +5 -5
  333. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +5 -5
  334. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +1 -1
  335. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +5 -5
  336. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +7 -7
  337. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +5 -5
  338. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +5 -5
  339. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +4 -4
  340. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +19 -19
  341. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +6 -6
  342. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +1 -1
  343. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +7 -7
  344. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +6 -6
  345. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +15 -15
  346. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +1 -1
  347. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +5 -5
  348. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +8 -8
  349. package/coverage/lcov-report/src/migrations/functions/index.html +1 -1
  350. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +6 -6
  351. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +6 -6
  352. package/coverage/lcov-report/src/migrations/functions/tests/appUrls.spec.js.html +1 -1
  353. package/coverage/lcov-report/src/migrations/functions/tests/index.html +1 -1
  354. package/coverage/lcov-report/src/migrations/functions/tests/syncQuotas.spec.js.html +1 -1
  355. package/coverage/lcov-report/src/migrations/functions/tests/tableSettings.spec.ts.html +1 -1
  356. package/coverage/lcov-report/src/migrations/functions/tests/userEmailViewCasing.spec.js.html +1 -1
  357. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +1 -1
  358. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +2 -2
  359. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +5 -5
  360. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +4 -4
  361. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +6 -6
  362. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/index.html +1 -1
  363. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/syncApps.spec.ts.html +1 -1
  364. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/syncRows.spec.ts.html +1 -1
  365. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +3 -3
  366. package/coverage/lcov-report/src/migrations/index.html +1 -1
  367. package/coverage/lcov-report/src/migrations/index.ts.html +32 -32
  368. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +1 -1
  369. package/coverage/lcov-report/src/migrations/tests/index.html +1 -1
  370. package/coverage/lcov-report/src/migrations/tests/index.spec.ts.html +1 -1
  371. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +1 -1
  372. package/coverage/lcov-report/src/sdk/app/applications/index.html +1 -1
  373. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +4 -4
  374. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +22 -22
  375. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +9 -9
  376. package/coverage/lcov-report/src/sdk/app/automations/index.html +1 -1
  377. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +3 -3
  378. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +3 -3
  379. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +3 -3
  380. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +17 -17
  381. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +18 -18
  382. package/coverage/lcov-report/src/sdk/app/backups/index.html +1 -1
  383. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +5 -5
  384. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +7 -7
  385. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +39 -39
  386. package/coverage/lcov-report/src/sdk/app/datasources/index.html +1 -1
  387. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +3 -3
  388. package/coverage/lcov-report/src/sdk/app/queries/index.html +1 -1
  389. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +3 -3
  390. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +4 -4
  391. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +6 -6
  392. package/coverage/lcov-report/src/sdk/app/rows/index.html +1 -1
  393. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +4 -4
  394. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +4 -4
  395. package/coverage/lcov-report/src/sdk/app/tables/index.html +1 -1
  396. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +6 -6
  397. package/coverage/lcov-report/src/sdk/index.html +1 -1
  398. package/coverage/lcov-report/src/sdk/index.ts.html +11 -11
  399. package/coverage/lcov-report/src/sdk/tests/attachments.spec.ts.html +1 -1
  400. package/coverage/lcov-report/src/sdk/tests/index.html +1 -1
  401. package/coverage/lcov-report/src/sdk/users/index.html +1 -1
  402. package/coverage/lcov-report/src/sdk/users/index.ts.html +3 -3
  403. package/coverage/lcov-report/src/sdk/users/utils.ts.html +26 -26
  404. package/coverage/lcov-report/src/sdk/utils/index.html +1 -1
  405. package/coverage/lcov-report/src/sdk/utils/index.ts.html +11 -11
  406. package/coverage/lcov-report/src/startup.ts.html +41 -41
  407. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +176 -146
  408. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +15 -15
  409. package/coverage/lcov-report/src/tests/utilities/index.html +14 -14
  410. package/coverage/lcov-report/src/tests/utilities/index.ts.html +1 -1
  411. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +16 -10
  412. package/coverage/lcov-report/src/threads/automation.ts.html +22 -22
  413. package/coverage/lcov-report/src/threads/index.html +1 -1
  414. package/coverage/lcov-report/src/threads/index.ts.html +10 -10
  415. package/coverage/lcov-report/src/threads/query.ts.html +1 -1
  416. package/coverage/lcov-report/src/threads/utils.ts.html +9 -9
  417. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +3 -3
  418. package/coverage/lcov-report/src/utilities/centralPath.ts.html +2 -2
  419. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +17 -17
  420. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +8 -8
  421. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +25 -25
  422. package/coverage/lcov-report/src/utilities/fileSystem/index.html +1 -1
  423. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +6 -6
  424. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +8 -8
  425. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +1 -1
  426. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +7 -7
  427. package/coverage/lcov-report/src/utilities/global.ts.html +35 -35
  428. package/coverage/lcov-report/src/utilities/index.html +1 -1
  429. package/coverage/lcov-report/src/utilities/index.ts.html +11 -11
  430. package/coverage/lcov-report/src/utilities/redis.ts.html +12 -12
  431. package/coverage/lcov-report/src/utilities/retry.ts.html +1 -1
  432. package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
  433. package/coverage/lcov-report/src/utilities/routing/index.ts.html +4 -4
  434. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +19 -19
  435. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +9 -9
  436. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +2 -2
  437. package/coverage/lcov-report/src/utilities/rowProcessor/tests/index.html +1 -1
  438. package/coverage/lcov-report/src/utilities/rowProcessor/tests/utils.spec.ts.html +1 -1
  439. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +38 -38
  440. package/coverage/lcov-report/src/utilities/schema.ts.html +3 -3
  441. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +5 -5
  442. package/coverage/lcov-report/src/utilities/security.ts.html +4 -4
  443. package/coverage/lcov-report/src/utilities/usageQuota/index.html +1 -1
  444. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +4 -4
  445. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +1 -1
  446. package/coverage/lcov-report/src/utilities/users.ts.html +4 -4
  447. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +1 -1
  448. package/coverage/lcov-report/src/watch.ts.html +7 -7
  449. package/coverage/lcov-report/src/websocket.ts.html +5 -5
  450. package/coverage/lcov.info +6276 -5874
  451. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  452. package/dist/api/controllers/row/external.js +12 -1
  453. package/dist/api/controllers/table/external.js +8 -8
  454. package/dist/api/routes/public/tests/utils.js +29 -2
  455. package/dist/api/routes/tests/utilities/index.js +131 -0
  456. package/dist/constants/index.js +4 -24
  457. package/dist/db/defaultData/datasource_bb_default.js +6 -5
  458. package/dist/db/linkedRows/LinkController.js +9 -8
  459. package/dist/integrations/base/sql.js +10 -3
  460. package/dist/package.json +6 -6
  461. package/dist/tests/utilities/TestConfiguration.js +618 -0
  462. package/dist/tests/utilities/controllers.js +40 -0
  463. package/dist/tests/utilities/structures.js +226 -0
  464. package/dist/tsconfig.build.tsbuildinfo +1 -1
  465. package/package.json +7 -7
  466. package/specs/openapi.json +6 -6
  467. package/specs/openapi.yaml +3 -3
  468. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  469. package/src/api/controllers/row/external.ts +13 -1
  470. package/src/api/controllers/table/external.ts +3 -2
  471. package/src/api/routes/public/tests/compare.spec.js +1 -1
  472. package/src/api/routes/public/tests/users.spec.js +1 -1
  473. package/src/api/routes/public/tests/utils.ts +25 -8
  474. package/src/api/routes/tests/cloud.seq.spec.ts +1 -1
  475. package/src/constants/index.ts +1 -23
  476. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  477. package/src/db/linkedRows/LinkController.ts +2 -1
  478. package/src/integration-test/postgres.spec.ts +752 -0
  479. package/src/integrations/base/sql.ts +15 -5
  480. package/src/integrations/oracle.ts +1 -1
  481. package/src/tests/utilities/TestConfiguration.ts +22 -12
  482. package/src/tests/utilities/structures.ts +4 -2
@@ -439,7 +439,7 @@ class ExternalRequest {
439
439
  isOneSide(field)) {
440
440
  continue;
441
441
  }
442
- const isMany = field.relationshipType === constants_1.RelationshipTypes.MANY_TO_MANY;
442
+ const isMany = field.relationshipType === types_1.RelationshipTypes.MANY_TO_MANY;
443
443
  const tableId = isMany ? field.through : field.tableId;
444
444
  const { tableName: relatedTableName } = (0, utils_3.breakExternalTableId)(tableId);
445
445
  // @ts-ignore
@@ -609,7 +609,9 @@ class ExternalRequest {
609
609
  },
610
610
  resource: {
611
611
  // have to specify the fields to avoid column overlap (for SQL)
612
- fields: isSql ? this.buildFields(table) : [],
612
+ fields: isSql
613
+ ? this.buildFields(table, config.includeSqlRelationships)
614
+ : [],
613
615
  },
614
616
  filters,
615
617
  sort,
@@ -86,6 +86,7 @@ function patch(ctx) {
86
86
  return handleRequest(types_1.Operation.UPDATE, tableId, {
87
87
  id: (0, utils_1.breakRowIdField)(id),
88
88
  row: inputs,
89
+ includeSqlRelationships: types_1.IncludeRelationship.EXCLUDE,
89
90
  });
90
91
  });
91
92
  }
@@ -96,6 +97,7 @@ function save(ctx) {
96
97
  const tableId = ctx.params.tableId;
97
98
  return handleRequest(types_1.Operation.CREATE, tableId, {
98
99
  row: inputs,
100
+ includeSqlRelationships: types_1.IncludeRelationship.EXCLUDE,
99
101
  });
100
102
  });
101
103
  }
@@ -113,7 +115,9 @@ exports.fetchView = fetchView;
113
115
  function fetch(ctx) {
114
116
  return __awaiter(this, void 0, void 0, function* () {
115
117
  const tableId = ctx.params.tableId;
116
- return handleRequest(types_1.Operation.READ, tableId);
118
+ return handleRequest(types_1.Operation.READ, tableId, {
119
+ includeSqlRelationships: types_1.IncludeRelationship.INCLUDE,
120
+ });
117
121
  });
118
122
  }
119
123
  exports.fetch = fetch;
@@ -123,6 +127,7 @@ function find(ctx) {
123
127
  const tableId = ctx.params.tableId;
124
128
  const response = (yield handleRequest(types_1.Operation.READ, tableId, {
125
129
  id: (0, utils_1.breakRowIdField)(id),
130
+ includeSqlRelationships: types_1.IncludeRelationship.EXCLUDE,
126
131
  }));
127
132
  return response ? response[0] : response;
128
133
  });
@@ -134,6 +139,7 @@ function destroy(ctx) {
134
139
  const id = ctx.request.body._id;
135
140
  const { row } = (yield handleRequest(types_1.Operation.DELETE, tableId, {
136
141
  id: (0, utils_1.breakRowIdField)(id),
142
+ includeSqlRelationships: types_1.IncludeRelationship.EXCLUDE,
137
143
  }));
138
144
  return { response: { ok: true }, row };
139
145
  });
@@ -147,6 +153,7 @@ function bulkDestroy(ctx) {
147
153
  for (let row of rows) {
148
154
  promises.push(handleRequest(types_1.Operation.DELETE, tableId, {
149
155
  id: (0, utils_1.breakRowIdField)(row._id),
156
+ includeSqlRelationships: types_1.IncludeRelationship.EXCLUDE,
150
157
  }));
151
158
  }
152
159
  const responses = (yield Promise.all(promises));
@@ -189,6 +196,7 @@ function search(ctx) {
189
196
  filters: query,
190
197
  sort,
191
198
  paginate: paginateObj,
199
+ includeSqlRelationships: types_1.IncludeRelationship.INCLUDE,
192
200
  }));
193
201
  let hasNextPage = false;
194
202
  if (paginate && rows.length === limit) {
@@ -199,6 +207,7 @@ function search(ctx) {
199
207
  limit: 1,
200
208
  page: bookmark * limit + 1,
201
209
  },
210
+ includeSqlRelationships: types_1.IncludeRelationship.INCLUDE,
202
211
  }));
203
212
  hasNextPage = nextRows.length > 0;
204
213
  }
@@ -285,6 +294,7 @@ function fetchEnrichedRow(ctx) {
285
294
  const response = (yield handleRequest(types_1.Operation.READ, tableId, {
286
295
  id,
287
296
  datasource,
297
+ includeSqlRelationships: types_1.IncludeRelationship.INCLUDE,
288
298
  }));
289
299
  const table = tables[tableName];
290
300
  const row = response[0];
@@ -310,6 +320,7 @@ function fetchEnrichedRow(ctx) {
310
320
  [primaryLink]: linkedIds,
311
321
  },
312
322
  },
323
+ includeSqlRelationships: types_1.IncludeRelationship.INCLUDE,
313
324
  });
314
325
  }
315
326
  return row;
@@ -75,12 +75,12 @@ function getDatasourceId(table) {
75
75
  return (0, utils_1.breakExternalTableId)(table._id).datasourceId;
76
76
  }
77
77
  function otherRelationshipType(type) {
78
- if (type === constants_1.RelationshipTypes.MANY_TO_MANY) {
79
- return constants_1.RelationshipTypes.MANY_TO_MANY;
78
+ if (type === types_1.RelationshipTypes.MANY_TO_MANY) {
79
+ return types_1.RelationshipTypes.MANY_TO_MANY;
80
80
  }
81
- return type === constants_1.RelationshipTypes.ONE_TO_MANY
82
- ? constants_1.RelationshipTypes.MANY_TO_ONE
83
- : constants_1.RelationshipTypes.ONE_TO_MANY;
81
+ return type === types_1.RelationshipTypes.ONE_TO_MANY
82
+ ? types_1.RelationshipTypes.MANY_TO_ONE
83
+ : types_1.RelationshipTypes.ONE_TO_MANY;
84
84
  }
85
85
  function generateManyLinkSchema(datasource, column, table, relatedTable) {
86
86
  if (!table.primary || !relatedTable.primary) {
@@ -116,7 +116,7 @@ function generateLinkSchema(column, table, relatedTable, type) {
116
116
  if (!table.primary || !relatedTable.primary) {
117
117
  throw new Error("Unable to generate link schema, no primary keys");
118
118
  }
119
- const isOneSide = type === constants_1.RelationshipTypes.ONE_TO_MANY;
119
+ const isOneSide = type === types_1.RelationshipTypes.ONE_TO_MANY;
120
120
  const primary = isOneSide ? relatedTable.primary[0] : table.primary[0];
121
121
  // generate a foreign key
122
122
  const foreignKey = (0, utils_2.generateForeignKey)(column, relatedTable);
@@ -186,7 +186,7 @@ function save(ctx) {
186
186
  }
187
187
  const relatedColumnName = schema.fieldName;
188
188
  const relationType = schema.relationshipType;
189
- if (relationType === constants_1.RelationshipTypes.MANY_TO_MANY) {
189
+ if (relationType === types_1.RelationshipTypes.MANY_TO_MANY) {
190
190
  const junctionTable = generateManyLinkSchema(datasource, schema, table, relatedTable);
191
191
  if (tables[junctionTable.name]) {
192
192
  throw "Junction table already exists, cannot create another relationship.";
@@ -195,7 +195,7 @@ function save(ctx) {
195
195
  extraTablesToUpdate.push(junctionTable);
196
196
  }
197
197
  else {
198
- const fkTable = relationType === constants_1.RelationshipTypes.ONE_TO_MANY ? table : relatedTable;
198
+ const fkTable = relationType === types_1.RelationshipTypes.ONE_TO_MANY ? table : relatedTable;
199
199
  const foreignKey = generateLinkSchema(schema, table, relatedTable, relationType);
200
200
  fkTable.schema[foreignKey] = (0, utils_2.foreignKeyStructure)(foreignKey);
201
201
  if (fkTable.constrained == null) {
@@ -1,4 +1,27 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
2
25
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
26
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
27
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -10,8 +33,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
10
33
  };
11
34
  Object.defineProperty(exports, "__esModule", { value: true });
12
35
  exports.generateMakeRequest = void 0;
36
+ const setup = __importStar(require("../../tests/utilities"));
13
37
  const utilities_1 = require("../../../../utilities");
14
- function generateMakeRequest(apiKey, setup) {
38
+ function generateMakeRequest(apiKey, isInternal = false) {
15
39
  const request = setup.getRequest();
16
40
  const config = setup.getConfig();
17
41
  return (method, endpoint, body, intAppId = config.getAppId()) => __awaiter(this, void 0, void 0, function* () {
@@ -21,7 +45,10 @@ function generateMakeRequest(apiKey, setup) {
21
45
  if (intAppId) {
22
46
  extraHeaders["x-budibase-app-id"] = intAppId;
23
47
  }
24
- const req = request[method]((0, utilities_1.checkSlashesInUrl)(`/api/public/v1/${endpoint}`)).set(config.defaultHeaders(extraHeaders));
48
+ const url = isInternal
49
+ ? endpoint
50
+ : (0, utilities_1.checkSlashesInUrl)(`/api/public/v1/${endpoint}`);
51
+ const req = request[method](url).set(config.defaultHeaders(extraHeaders));
25
52
  if (body) {
26
53
  req.send(body);
27
54
  }
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
+ return new (P || (P = Promise))(function (resolve, reject) {
28
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
32
+ });
33
+ };
34
+ var __importDefault = (this && this.__importDefault) || function (mod) {
35
+ return (mod && mod.__esModule) ? mod : { "default": mod };
36
+ };
37
+ Object.defineProperty(exports, "__esModule", { value: true });
38
+ exports.switchToSelfHosted = exports.getConfig = exports.getRequest = exports.afterAll = exports.beforeAll = exports.delay = exports.structures = void 0;
39
+ const TestConfiguration_1 = __importDefault(require("../../../../tests/utilities/TestConfiguration"));
40
+ const environment_1 = __importDefault(require("../../../../environment"));
41
+ exports.structures = __importStar(require("../../../../tests/utilities/structures"));
42
+ function user() {
43
+ return {
44
+ _id: "user",
45
+ _rev: "rev",
46
+ createdAt: Date.now(),
47
+ email: "test@test.com",
48
+ roles: {},
49
+ tenantId: "default",
50
+ status: "active",
51
+ };
52
+ }
53
+ jest.mock("../../../../utilities/workerRequests", () => ({
54
+ getGlobalUsers: jest.fn(() => {
55
+ return {
56
+ _id: "us_uuid1",
57
+ };
58
+ }),
59
+ getGlobalSelf: jest.fn(() => {
60
+ return {
61
+ _id: "us_uuid1",
62
+ };
63
+ }),
64
+ allGlobalUsers: jest.fn(() => {
65
+ return [user()];
66
+ }),
67
+ readGlobalUser: jest.fn(() => {
68
+ return user();
69
+ }),
70
+ saveGlobalUser: jest.fn(() => {
71
+ return { _id: "user", _rev: "rev" };
72
+ }),
73
+ deleteGlobalUser: jest.fn(() => {
74
+ return { message: "deleted user" };
75
+ }),
76
+ removeAppFromUserRoles: jest.fn(),
77
+ }));
78
+ function delay(ms) {
79
+ return new Promise(resolve => setTimeout(resolve, ms));
80
+ }
81
+ exports.delay = delay;
82
+ let request, config;
83
+ function beforeAll() {
84
+ config = new TestConfiguration_1.default();
85
+ request = config.getRequest();
86
+ }
87
+ exports.beforeAll = beforeAll;
88
+ function afterAll() {
89
+ if (config) {
90
+ config.end();
91
+ }
92
+ // clear app files
93
+ request = null;
94
+ config = null;
95
+ }
96
+ exports.afterAll = afterAll;
97
+ function getRequest() {
98
+ if (!request) {
99
+ beforeAll();
100
+ }
101
+ return request;
102
+ }
103
+ exports.getRequest = getRequest;
104
+ function getConfig() {
105
+ if (!config) {
106
+ beforeAll();
107
+ }
108
+ return config;
109
+ }
110
+ exports.getConfig = getConfig;
111
+ function switchToSelfHosted(func) {
112
+ return __awaiter(this, void 0, void 0, function* () {
113
+ // self hosted stops any attempts to Dynamo
114
+ environment_1.default._set("NODE_ENV", "production");
115
+ environment_1.default._set("SELF_HOSTED", true);
116
+ let error;
117
+ try {
118
+ yield func();
119
+ }
120
+ catch (err) {
121
+ error = err;
122
+ }
123
+ environment_1.default._set("NODE_ENV", "jest");
124
+ environment_1.default._set("SELF_HOSTED", false);
125
+ // don't throw error until after reset
126
+ if (error) {
127
+ throw error;
128
+ }
129
+ });
130
+ }
131
+ exports.switchToSelfHosted = switchToSelfHosted;
@@ -1,7 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MAX_AUTOMATION_RECURRING_ERRORS = exports.ObjectStoreBuckets = exports.AutomationErrors = exports.BuildSchemaErrors = exports.InvalidColumns = exports.MetadataTypes = exports.BaseQueryVerbs = exports.OBJ_STORE_DIRECTORY = exports.AutoFieldDefaultNames = exports.AutoFieldSubTypes = exports.USERS_TABLE_SCHEMA = exports.SortDirection = exports.DatasourceAuthTypes = exports.DataSourceOperation = exports.AuthTypes = exports.FormulaTypes = exports.RelationshipTypes = exports.SwitchableTypes = exports.CanSwitchTypes = exports.FieldTypes = exports.NoEmptyFilterStrings = exports.FilterTypes = void 0;
3
+ exports.MAX_AUTOMATION_RECURRING_ERRORS = exports.ObjectStoreBuckets = exports.AutomationErrors = exports.BuildSchemaErrors = exports.InvalidColumns = exports.MetadataTypes = exports.BaseQueryVerbs = exports.OBJ_STORE_DIRECTORY = exports.AutoFieldDefaultNames = exports.AutoFieldSubTypes = exports.USERS_TABLE_SCHEMA = exports.SortDirection = exports.DatasourceAuthTypes = exports.DataSourceOperation = exports.AuthTypes = exports.FormulaTypes = exports.SwitchableTypes = exports.CanSwitchTypes = exports.NoEmptyFilterStrings = exports.FilterTypes = exports.RelationshipTypes = exports.FieldTypes = void 0;
4
4
  const backend_core_1 = require("@budibase/backend-core");
5
+ var types_1 = require("@budibase/types");
6
+ Object.defineProperty(exports, "FieldTypes", { enumerable: true, get: function () { return types_1.FieldType; } });
7
+ Object.defineProperty(exports, "RelationshipTypes", { enumerable: true, get: function () { return types_1.RelationshipTypes; } });
5
8
  var FilterTypes;
6
9
  (function (FilterTypes) {
7
10
  FilterTypes["STRING"] = "string";
@@ -23,23 +26,6 @@ exports.NoEmptyFilterStrings = [
23
26
  FilterTypes.CONTAINS,
24
27
  FilterTypes.NOT_CONTAINS,
25
28
  ];
26
- var FieldTypes;
27
- (function (FieldTypes) {
28
- FieldTypes["STRING"] = "string";
29
- FieldTypes["BARCODEQR"] = "barcodeqr";
30
- FieldTypes["LONGFORM"] = "longform";
31
- FieldTypes["OPTIONS"] = "options";
32
- FieldTypes["NUMBER"] = "number";
33
- FieldTypes["BOOLEAN"] = "boolean";
34
- FieldTypes["ARRAY"] = "array";
35
- FieldTypes["DATETIME"] = "datetime";
36
- FieldTypes["ATTACHMENT"] = "attachment";
37
- FieldTypes["LINK"] = "link";
38
- FieldTypes["FORMULA"] = "formula";
39
- FieldTypes["AUTO"] = "auto";
40
- FieldTypes["JSON"] = "json";
41
- FieldTypes["INTERNAL"] = "internal";
42
- })(FieldTypes = exports.FieldTypes || (exports.FieldTypes = {}));
43
29
  exports.CanSwitchTypes = [
44
30
  [exports.FieldTypes.JSON, exports.FieldTypes.ARRAY],
45
31
  [
@@ -51,12 +37,6 @@ exports.CanSwitchTypes = [
51
37
  [exports.FieldTypes.BOOLEAN, exports.FieldTypes.NUMBER],
52
38
  ];
53
39
  exports.SwitchableTypes = exports.CanSwitchTypes.reduce((prev, current) => prev ? prev.concat(current) : current);
54
- var RelationshipTypes;
55
- (function (RelationshipTypes) {
56
- RelationshipTypes["ONE_TO_MANY"] = "one-to-many";
57
- RelationshipTypes["MANY_TO_ONE"] = "many-to-one";
58
- RelationshipTypes["MANY_TO_MANY"] = "many-to-many";
59
- })(RelationshipTypes = exports.RelationshipTypes || (exports.RelationshipTypes = {}));
60
40
  var FormulaTypes;
61
41
  (function (FormulaTypes) {
62
42
  FormulaTypes["STATIC"] = "static";
@@ -13,6 +13,7 @@ const employeeImport_1 = require("./employeeImport");
13
13
  const jobsImport_1 = require("./jobsImport");
14
14
  const expensesImport_1 = require("./expensesImport");
15
15
  const backend_core_1 = require("@budibase/backend-core");
16
+ const types_1 = require("@budibase/types");
16
17
  exports.DEFAULT_JOBS_TABLE_ID = "ta_bb_jobs";
17
18
  exports.DEFAULT_INVENTORY_TABLE_ID = "ta_bb_inventory";
18
19
  exports.DEFAULT_EXPENSES_TABLE_ID = "ta_bb_expenses";
@@ -260,7 +261,7 @@ exports.DEFAULT_EMPLOYEE_TABLE_SCHEMA = {
260
261
  name: "Employee Level",
261
262
  sortable: false,
262
263
  }, "Badge Photo": {
263
- type: "attachment",
264
+ type: constants_1.FieldTypes.ATTACHMENT,
264
265
  constraints: {
265
266
  type: constants_1.FieldTypes.ARRAY,
266
267
  presence: false,
@@ -275,7 +276,7 @@ exports.DEFAULT_EMPLOYEE_TABLE_SCHEMA = {
275
276
  },
276
277
  fieldName: "Assigned",
277
278
  name: "Jobs",
278
- relationshipType: constants_1.RelationshipTypes.MANY_TO_MANY,
279
+ relationshipType: types_1.RelationshipTypes.MANY_TO_MANY,
279
280
  tableId: exports.DEFAULT_JOBS_TABLE_ID,
280
281
  }, "Start Date": {
281
282
  type: constants_1.FieldTypes.DATETIME,
@@ -419,10 +420,10 @@ exports.DEFAULT_JOBS_TABLE_SCHEMA = {
419
420
  type: constants_1.FieldTypes.LINK,
420
421
  tableId: exports.DEFAULT_EMPLOYEE_TABLE_ID,
421
422
  fieldName: "Jobs",
422
- relationshipType: constants_1.RelationshipTypes.MANY_TO_MANY,
423
+ relationshipType: types_1.RelationshipTypes.MANY_TO_MANY,
423
424
  // sortable: true,
424
425
  }, "Works End": {
425
- type: "datetime",
426
+ type: constants_1.FieldTypes.DATETIME,
426
427
  constraints: {
427
428
  type: "string",
428
429
  length: {},
@@ -435,7 +436,7 @@ exports.DEFAULT_JOBS_TABLE_SCHEMA = {
435
436
  name: "Works End",
436
437
  ignoreTimezones: true,
437
438
  }, "Updated Price": {
438
- type: "number",
439
+ type: constants_1.FieldTypes.NUMBER,
439
440
  constraints: {
440
441
  type: "number",
441
442
  presence: false,
@@ -18,6 +18,7 @@ const node_1 = __importDefault(require("@sentry/node"));
18
18
  const constants_1 = require("../../constants");
19
19
  const backend_core_1 = require("@budibase/backend-core");
20
20
  const LinkDocument_1 = __importDefault(require("./LinkDocument"));
21
+ const types_1 = require("@budibase/types");
21
22
  class LinkController {
22
23
  constructor({ tableId, row, table, oldTable }) {
23
24
  this._db = backend_core_1.context.getAppDB();
@@ -124,17 +125,17 @@ class LinkController {
124
125
  */
125
126
  handleRelationshipType(linkerField, linkedField) {
126
127
  if (!linkerField.relationshipType ||
127
- linkerField.relationshipType === constants_1.RelationshipTypes.MANY_TO_MANY) {
128
- linkedField.relationshipType = constants_1.RelationshipTypes.MANY_TO_MANY;
128
+ linkerField.relationshipType === types_1.RelationshipTypes.MANY_TO_MANY) {
129
+ linkedField.relationshipType = types_1.RelationshipTypes.MANY_TO_MANY;
129
130
  // make sure by default all are many to many (if not specified)
130
- linkerField.relationshipType = constants_1.RelationshipTypes.MANY_TO_MANY;
131
+ linkerField.relationshipType = types_1.RelationshipTypes.MANY_TO_MANY;
131
132
  }
132
- else if (linkerField.relationshipType === constants_1.RelationshipTypes.MANY_TO_ONE) {
133
+ else if (linkerField.relationshipType === types_1.RelationshipTypes.MANY_TO_ONE) {
133
134
  // Ensure that the other side of the relationship is locked to one record
134
- linkedField.relationshipType = constants_1.RelationshipTypes.ONE_TO_MANY;
135
+ linkedField.relationshipType = types_1.RelationshipTypes.ONE_TO_MANY;
135
136
  }
136
- else if (linkerField.relationshipType === constants_1.RelationshipTypes.ONE_TO_MANY) {
137
- linkedField.relationshipType = constants_1.RelationshipTypes.MANY_TO_ONE;
137
+ else if (linkerField.relationshipType === types_1.RelationshipTypes.ONE_TO_MANY) {
138
+ linkedField.relationshipType = types_1.RelationshipTypes.MANY_TO_ONE;
138
139
  }
139
140
  return { linkerField, linkedField };
140
141
  }
@@ -178,7 +179,7 @@ class LinkController {
178
179
  }
179
180
  // iterate through the link IDs in the row field, see if any don't exist already
180
181
  for (let linkId of rowField) {
181
- if ((linkedSchema === null || linkedSchema === void 0 ? void 0 : linkedSchema.relationshipType) === constants_1.RelationshipTypes.ONE_TO_MANY) {
182
+ if ((linkedSchema === null || linkedSchema === void 0 ? void 0 : linkedSchema.relationshipType) === types_1.RelationshipTypes.ONE_TO_MANY) {
182
183
  let links = (yield (0, linkUtils_1.getLinkDocuments)({
183
184
  tableId: field.tableId,
184
185
  rowId: linkId,
@@ -90,6 +90,9 @@ function parseFilters(filters) {
90
90
  function generateSelectStatement(json, knex) {
91
91
  var _a;
92
92
  const { resource, meta } = json;
93
+ if (!resource) {
94
+ return "*";
95
+ }
93
96
  const schema = (_a = meta === null || meta === void 0 ? void 0 : meta.table) === null || _a === void 0 ? void 0 : _a.schema;
94
97
  return resource.fields.map(field => {
95
98
  const fieldNames = field.split(/\./g);
@@ -368,7 +371,9 @@ class InternalBuilder {
368
371
  return query.insert(parsedBody);
369
372
  }
370
373
  else {
371
- return query.insert(parsedBody).returning("*");
374
+ return query
375
+ .insert(parsedBody)
376
+ .returning(generateSelectStatement(json, knex));
372
377
  }
373
378
  }
374
379
  bulkCreate(knex, json) {
@@ -447,7 +452,9 @@ class InternalBuilder {
447
452
  return query.update(parsedBody);
448
453
  }
449
454
  else {
450
- return query.update(parsedBody).returning("*");
455
+ return query
456
+ .update(parsedBody)
457
+ .returning(generateSelectStatement(json, knex));
451
458
  }
452
459
  }
453
460
  delete(knex, json, opts) {
@@ -462,7 +469,7 @@ class InternalBuilder {
462
469
  return query.delete();
463
470
  }
464
471
  else {
465
- return query.delete().returning("*");
472
+ return query.delete().returning(generateSelectStatement(json, knex));
466
473
  }
467
474
  }
468
475
  }
package/dist/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@budibase/server",
3
3
  "email": "hi@budibase.com",
4
- "version": "2.3.2-alpha.0",
4
+ "version": "2.3.2-alpha.2",
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.2-alpha.0",
47
- "@budibase/client": "2.3.2-alpha.0",
48
- "@budibase/pro": "2.3.2-alpha.0",
49
- "@budibase/string-templates": "2.3.2-alpha.0",
50
- "@budibase/types": "2.3.2-alpha.0",
46
+ "@budibase/backend-core": "2.3.2-alpha.2",
47
+ "@budibase/client": "2.3.2-alpha.2",
48
+ "@budibase/pro": "2.3.2-alpha.2",
49
+ "@budibase/string-templates": "2.3.2-alpha.2",
50
+ "@budibase/types": "2.3.2-alpha.2",
51
51
  "@bull-board/api": "3.7.0",
52
52
  "@bull-board/koa": "3.9.4",
53
53
  "@elastic/elasticsearch": "7.10.0",