@budibase/server 2.3.2-alpha.2 → 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.b05c7fc9.js → index.bef36368.js} +1 -1
  2. package/builder/index.html +1 -1
  3. package/coverage/clover.xml +4152 -3905
  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
@@ -0,0 +1,618 @@
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 __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
35
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
36
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
37
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
38
+ };
39
+ var __importDefault = (this && this.__importDefault) || function (mod) {
40
+ return (mod && mod.__esModule) ? mod : { "default": mod };
41
+ };
42
+ var _TestConfiguration_setMultiTenancy, _TestConfiguration_setSelfHosted;
43
+ const tests_1 = require("@budibase/backend-core/tests");
44
+ // init the licensing mock
45
+ const pro = __importStar(require("@budibase/pro"));
46
+ tests_1.mocks.licenses.init(pro);
47
+ // use unlimited license by default
48
+ tests_1.mocks.licenses.useUnlimited();
49
+ const db_1 = require("../../db");
50
+ (0, db_1.init)();
51
+ const environment_1 = __importDefault(require("../../environment"));
52
+ const backend_core_1 = require("@budibase/backend-core");
53
+ const structures_1 = require("./structures");
54
+ const backend_core_2 = require("@budibase/backend-core");
55
+ const controllers = __importStar(require("./controllers"));
56
+ const fileSystem_1 = require("../../utilities/fileSystem");
57
+ const newid_1 = __importDefault(require("../../db/newid"));
58
+ const utils_1 = require("../../db/utils");
59
+ const startup_1 = require("../../startup");
60
+ const supertest_1 = __importDefault(require("supertest"));
61
+ const types_1 = require("@budibase/types");
62
+ class TestConfiguration {
63
+ constructor(openServer = true) {
64
+ // MODES
65
+ _TestConfiguration_setMultiTenancy.set(this, (value) => {
66
+ environment_1.default._set("MULTI_TENANCY", value);
67
+ backend_core_1.env._set("MULTI_TENANCY", value);
68
+ });
69
+ _TestConfiguration_setSelfHosted.set(this, (value) => {
70
+ environment_1.default._set("SELF_HOSTED", value);
71
+ backend_core_1.env._set("SELF_HOSTED", value);
72
+ });
73
+ this.modeCloud = () => {
74
+ __classPrivateFieldGet(this, _TestConfiguration_setSelfHosted, "f").call(this, false);
75
+ __classPrivateFieldGet(this, _TestConfiguration_setMultiTenancy, "f").call(this, true);
76
+ };
77
+ this.modeSelf = () => {
78
+ __classPrivateFieldGet(this, _TestConfiguration_setSelfHosted, "f").call(this, true);
79
+ __classPrivateFieldGet(this, _TestConfiguration_setMultiTenancy, "f").call(this, false);
80
+ };
81
+ if (openServer) {
82
+ // use a random port because it doesn't matter
83
+ environment_1.default.PORT = "0";
84
+ this.server = require("../../app").default;
85
+ // we need the request for logging in, involves cookies, hard to fake
86
+ this.request = (0, supertest_1.default)(this.server);
87
+ this.started = true;
88
+ }
89
+ else {
90
+ this.started = false;
91
+ }
92
+ this.appId = null;
93
+ this.allApps = [];
94
+ this.tenantId = null;
95
+ this.defaultUserValues = this.populateDefaultUserValues();
96
+ }
97
+ populateDefaultUserValues() {
98
+ return {
99
+ globalUserId: `us_${(0, newid_1.default)()}`,
100
+ email: tests_1.generator.email(),
101
+ firstName: tests_1.generator.first(),
102
+ lastName: tests_1.generator.last(),
103
+ csrfToken: tests_1.generator.hash(),
104
+ };
105
+ }
106
+ getRequest() {
107
+ return this.request;
108
+ }
109
+ getApp() {
110
+ return this.app;
111
+ }
112
+ getProdApp() {
113
+ return this.prodApp;
114
+ }
115
+ getAppId() {
116
+ return this.appId;
117
+ }
118
+ getProdAppId() {
119
+ return this.prodAppId;
120
+ }
121
+ getUserDetails() {
122
+ return {
123
+ globalId: this.defaultUserValues.globalUserId,
124
+ email: this.defaultUserValues.email,
125
+ firstName: this.defaultUserValues.firstName,
126
+ lastName: this.defaultUserValues.lastName,
127
+ };
128
+ }
129
+ doInContext(appId, task) {
130
+ return __awaiter(this, void 0, void 0, function* () {
131
+ if (!appId) {
132
+ appId = this.appId;
133
+ }
134
+ const tenant = this.getTenantId();
135
+ return backend_core_2.tenancy.doInTenant(tenant, () => {
136
+ // check if already in a context
137
+ if (backend_core_2.context.getAppId() == null && appId !== null) {
138
+ return backend_core_2.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
139
+ return task();
140
+ }));
141
+ }
142
+ else {
143
+ return task();
144
+ }
145
+ });
146
+ });
147
+ }
148
+ // SETUP / TEARDOWN
149
+ // use a new id as the name to avoid name collisions
150
+ init(appName = (0, newid_1.default)()) {
151
+ return __awaiter(this, void 0, void 0, function* () {
152
+ this.defaultUserValues = this.populateDefaultUserValues();
153
+ if (backend_core_2.context.isMultiTenant()) {
154
+ this.tenantId = tests_1.structures.tenant.id();
155
+ }
156
+ if (!this.started) {
157
+ yield (0, startup_1.startup)();
158
+ }
159
+ this.user = yield this.globalUser();
160
+ this.globalUserId = this.user._id;
161
+ this.userMetadataId = (0, utils_1.generateUserMetadataID)(this.globalUserId);
162
+ return this.createApp(appName);
163
+ });
164
+ }
165
+ end() {
166
+ if (!this) {
167
+ return;
168
+ }
169
+ if (this.server) {
170
+ this.server.close();
171
+ }
172
+ if (this.allApps) {
173
+ (0, fileSystem_1.cleanup)(this.allApps.map(app => app.appId));
174
+ }
175
+ }
176
+ // UTILS
177
+ _req(body, params, controlFunc) {
178
+ // create a fake request ctx
179
+ const request = {};
180
+ const appId = this.appId;
181
+ request.appId = appId;
182
+ // fake cookies, we don't need them
183
+ request.cookies = { set: () => { }, get: () => { } };
184
+ request.config = { jwtSecret: environment_1.default.JWT_SECRET };
185
+ request.user = { appId, tenantId: this.getTenantId() };
186
+ request.query = {};
187
+ request.request = {
188
+ body,
189
+ };
190
+ if (params) {
191
+ request.params = params;
192
+ }
193
+ return this.doInContext(appId, () => __awaiter(this, void 0, void 0, function* () {
194
+ yield controlFunc(request);
195
+ return request.body;
196
+ }));
197
+ }
198
+ // USER / AUTH
199
+ globalUser({ id = this.defaultUserValues.globalUserId, firstName = this.defaultUserValues.firstName, lastName = this.defaultUserValues.lastName, builder = true, admin = false, email = this.defaultUserValues.email, roles, } = {}) {
200
+ return __awaiter(this, void 0, void 0, function* () {
201
+ return backend_core_2.tenancy.doWithGlobalDB(this.getTenantId(), (db) => __awaiter(this, void 0, void 0, function* () {
202
+ let existing;
203
+ try {
204
+ existing = yield db.get(id);
205
+ }
206
+ catch (err) {
207
+ existing = { email };
208
+ }
209
+ const user = Object.assign(Object.assign({ _id: id }, existing), { roles: roles || {}, tenantId: this.getTenantId(), firstName,
210
+ lastName });
211
+ yield backend_core_2.sessions.createASession(id, {
212
+ sessionId: "sessionid",
213
+ tenantId: this.getTenantId(),
214
+ csrfToken: this.defaultUserValues.csrfToken,
215
+ });
216
+ if (builder) {
217
+ user.builder = { global: true };
218
+ }
219
+ else {
220
+ user.builder = { global: false };
221
+ }
222
+ if (admin) {
223
+ user.admin = { global: true };
224
+ }
225
+ else {
226
+ user.admin = { global: false };
227
+ }
228
+ const resp = yield db.put(user);
229
+ return Object.assign({ _rev: resp.rev }, user);
230
+ }));
231
+ });
232
+ }
233
+ createUser(id = null, firstName = this.defaultUserValues.firstName, lastName = this.defaultUserValues.lastName, email = this.defaultUserValues.email, builder = true, admin = false, roles = {}) {
234
+ return __awaiter(this, void 0, void 0, function* () {
235
+ const globalId = !id ? `us_${Math.random()}` : `us_${id}`;
236
+ const resp = yield this.globalUser({
237
+ id: globalId,
238
+ firstName,
239
+ lastName,
240
+ email,
241
+ builder,
242
+ admin,
243
+ roles,
244
+ });
245
+ yield backend_core_2.cache.user.invalidateUser(globalId);
246
+ return Object.assign(Object.assign({}, resp), { globalId });
247
+ });
248
+ }
249
+ login({ roleId, userId, builder, prodApp = false } = {}) {
250
+ return __awaiter(this, void 0, void 0, function* () {
251
+ const appId = prodApp ? this.prodAppId : this.appId;
252
+ return backend_core_2.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
253
+ userId = !userId ? `us_uuid1` : userId;
254
+ if (!this.request) {
255
+ throw "Server has not been opened, cannot login.";
256
+ }
257
+ // make sure the user exists in the global DB
258
+ if (roleId !== backend_core_2.roles.BUILTIN_ROLE_IDS.PUBLIC) {
259
+ yield this.globalUser({
260
+ id: userId,
261
+ builder,
262
+ roles: { [this.prodAppId]: roleId },
263
+ });
264
+ }
265
+ yield backend_core_2.sessions.createASession(userId, {
266
+ sessionId: "sessionid",
267
+ tenantId: this.getTenantId(),
268
+ });
269
+ // have to fake this
270
+ const authObj = {
271
+ userId,
272
+ sessionId: "sessionid",
273
+ tenantId: this.getTenantId(),
274
+ };
275
+ const app = {
276
+ roleId: roleId,
277
+ appId,
278
+ };
279
+ const authToken = backend_core_2.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
280
+ const appToken = backend_core_2.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
281
+ // returning necessary request headers
282
+ yield backend_core_2.cache.user.invalidateUser(userId);
283
+ return {
284
+ Accept: "application/json",
285
+ Cookie: [
286
+ `${backend_core_2.constants.Cookie.Auth}=${authToken}`,
287
+ `${backend_core_2.constants.Cookie.CurrentApp}=${appToken}`,
288
+ ],
289
+ [backend_core_2.constants.Header.APP_ID]: appId,
290
+ };
291
+ }));
292
+ });
293
+ }
294
+ defaultHeaders(extras = {}) {
295
+ const tenantId = this.getTenantId();
296
+ const authObj = {
297
+ userId: this.defaultUserValues.globalUserId,
298
+ sessionId: "sessionid",
299
+ tenantId,
300
+ };
301
+ const app = {
302
+ roleId: backend_core_2.roles.BUILTIN_ROLE_IDS.ADMIN,
303
+ appId: this.appId,
304
+ };
305
+ const authToken = backend_core_2.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
306
+ const appToken = backend_core_2.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
307
+ const headers = Object.assign({ Accept: "application/json", Cookie: [
308
+ `${backend_core_2.constants.Cookie.Auth}=${authToken}`,
309
+ `${backend_core_2.constants.Cookie.CurrentApp}=${appToken}`,
310
+ ], [backend_core_2.constants.Header.CSRF_TOKEN]: this.defaultUserValues.csrfToken }, extras);
311
+ if (this.appId) {
312
+ headers[backend_core_2.constants.Header.APP_ID] = this.appId;
313
+ }
314
+ return headers;
315
+ }
316
+ getTenantId() {
317
+ return this.tenantId || structures_1.TENANT_ID;
318
+ }
319
+ publicHeaders({ prodApp = true } = {}) {
320
+ const appId = prodApp ? this.prodAppId : this.appId;
321
+ const headers = {
322
+ Accept: "application/json",
323
+ };
324
+ if (appId) {
325
+ headers[backend_core_2.constants.Header.APP_ID] = appId;
326
+ }
327
+ if (this.tenantId) {
328
+ headers[backend_core_2.constants.Header.TENANT_ID] = this.tenantId;
329
+ }
330
+ return headers;
331
+ }
332
+ roleHeaders({ email = this.defaultUserValues.email, roleId = backend_core_2.roles.BUILTIN_ROLE_IDS.ADMIN, builder = false, prodApp = true, } = {}) {
333
+ return __awaiter(this, void 0, void 0, function* () {
334
+ return this.login({ email, roleId, builder, prodApp });
335
+ });
336
+ }
337
+ // API
338
+ generateApiKey(userId = this.defaultUserValues.globalUserId) {
339
+ return __awaiter(this, void 0, void 0, function* () {
340
+ return backend_core_2.tenancy.doWithGlobalDB(this.getTenantId(), (db) => __awaiter(this, void 0, void 0, function* () {
341
+ const id = backend_core_2.db.generateDevInfoID(userId);
342
+ let devInfo;
343
+ try {
344
+ devInfo = yield db.get(id);
345
+ }
346
+ catch (err) {
347
+ devInfo = { _id: id, userId };
348
+ }
349
+ devInfo.apiKey = backend_core_2.encryption.encrypt(`${this.getTenantId()}${backend_core_2.db.SEPARATOR}${(0, newid_1.default)()}`);
350
+ yield db.put(devInfo);
351
+ return devInfo.apiKey;
352
+ }));
353
+ });
354
+ }
355
+ // APP
356
+ createApp(appName) {
357
+ return __awaiter(this, void 0, void 0, function* () {
358
+ // create dev app
359
+ // clear any old app
360
+ this.appId = null;
361
+ yield backend_core_2.context.doInAppContext(null, () => __awaiter(this, void 0, void 0, function* () {
362
+ this.app = yield this._req({ name: appName }, null, controllers.app.create);
363
+ this.appId = this.app.appId;
364
+ }));
365
+ return yield backend_core_2.context.doInAppContext(this.appId, () => __awaiter(this, void 0, void 0, function* () {
366
+ // create production app
367
+ this.prodApp = yield this.publish();
368
+ this.allApps.push(this.prodApp);
369
+ this.allApps.push(this.app);
370
+ return this.app;
371
+ }));
372
+ });
373
+ }
374
+ publish() {
375
+ return __awaiter(this, void 0, void 0, function* () {
376
+ yield this._req(null, null, controllers.deploy.publishApp);
377
+ // @ts-ignore
378
+ const prodAppId = this.getAppId().replace("_dev", "");
379
+ this.prodAppId = prodAppId;
380
+ return backend_core_2.context.doInAppContext(prodAppId, () => __awaiter(this, void 0, void 0, function* () {
381
+ const db = backend_core_2.context.getProdAppDB();
382
+ return yield db.get(backend_core_2.db.DocumentType.APP_METADATA);
383
+ }));
384
+ });
385
+ }
386
+ unpublish() {
387
+ return __awaiter(this, void 0, void 0, function* () {
388
+ const response = yield this._req(null, { appId: this.appId }, controllers.app.unpublish);
389
+ this.prodAppId = null;
390
+ this.prodApp = null;
391
+ return response;
392
+ });
393
+ }
394
+ // TABLE
395
+ updateTable(config) {
396
+ return __awaiter(this, void 0, void 0, function* () {
397
+ config = config || (0, structures_1.basicTable)();
398
+ this.table = yield this._req(config, null, controllers.table.save);
399
+ return this.table;
400
+ });
401
+ }
402
+ createTable(config) {
403
+ return __awaiter(this, void 0, void 0, function* () {
404
+ if (config != null && config._id) {
405
+ delete config._id;
406
+ }
407
+ return this.updateTable(config);
408
+ });
409
+ }
410
+ getTable(tableId) {
411
+ return __awaiter(this, void 0, void 0, function* () {
412
+ tableId = tableId || this.table._id;
413
+ return this._req(null, { tableId }, controllers.table.find);
414
+ });
415
+ }
416
+ createLinkedTable(relationshipType, links = ["link"]) {
417
+ return __awaiter(this, void 0, void 0, function* () {
418
+ if (!this.table) {
419
+ throw "Must have created a table first.";
420
+ }
421
+ const tableConfig = (0, structures_1.basicTable)();
422
+ tableConfig.primaryDisplay = "name";
423
+ for (let link of links) {
424
+ tableConfig.schema[link] = {
425
+ type: "link",
426
+ fieldName: link,
427
+ tableId: this.table._id,
428
+ name: link,
429
+ };
430
+ if (relationshipType) {
431
+ tableConfig.schema[link].relationshipType = relationshipType;
432
+ }
433
+ }
434
+ const linkedTable = yield this.createTable(tableConfig);
435
+ this.linkedTable = linkedTable;
436
+ return linkedTable;
437
+ });
438
+ }
439
+ createAttachmentTable() {
440
+ return __awaiter(this, void 0, void 0, function* () {
441
+ const table = (0, structures_1.basicTable)();
442
+ table.schema.attachment = {
443
+ type: "attachment",
444
+ };
445
+ return this.createTable(table);
446
+ });
447
+ }
448
+ // ROW
449
+ createRow(config) {
450
+ return __awaiter(this, void 0, void 0, function* () {
451
+ if (!this.table) {
452
+ throw "Test requires table to be configured.";
453
+ }
454
+ const tableId = (config && config.tableId) || this.table._id;
455
+ config = config || (0, structures_1.basicRow)(tableId);
456
+ return this._req(config, { tableId }, controllers.row.save);
457
+ });
458
+ }
459
+ getRow(tableId, rowId) {
460
+ return __awaiter(this, void 0, void 0, function* () {
461
+ return this._req(null, { tableId, rowId }, controllers.row.find);
462
+ });
463
+ }
464
+ getRows(tableId) {
465
+ return __awaiter(this, void 0, void 0, function* () {
466
+ if (!tableId && this.table) {
467
+ tableId = this.table._id;
468
+ }
469
+ return this._req(null, { tableId }, controllers.row.fetch);
470
+ });
471
+ }
472
+ // ROLE
473
+ createRole(config) {
474
+ return __awaiter(this, void 0, void 0, function* () {
475
+ config = config || (0, structures_1.basicRole)();
476
+ return this._req(config, null, controllers.role.save);
477
+ });
478
+ }
479
+ addPermission(roleId, resourceId, level = "read") {
480
+ return __awaiter(this, void 0, void 0, function* () {
481
+ return this._req(null, {
482
+ roleId,
483
+ resourceId,
484
+ level,
485
+ }, controllers.perms.addPermission);
486
+ });
487
+ }
488
+ // VIEW
489
+ createView(config) {
490
+ return __awaiter(this, void 0, void 0, function* () {
491
+ if (!this.table) {
492
+ throw "Test requires table to be configured.";
493
+ }
494
+ const view = config || {
495
+ tableId: this.table._id,
496
+ name: "ViewTest",
497
+ };
498
+ return this._req(view, null, controllers.view.save);
499
+ });
500
+ }
501
+ // AUTOMATION
502
+ createAutomation(config) {
503
+ return __awaiter(this, void 0, void 0, function* () {
504
+ config = config || (0, structures_1.basicAutomation)();
505
+ if (config._rev) {
506
+ delete config._rev;
507
+ }
508
+ this.automation = (yield this._req(config, null, controllers.automation.create)).automation;
509
+ return this.automation;
510
+ });
511
+ }
512
+ getAllAutomations() {
513
+ return __awaiter(this, void 0, void 0, function* () {
514
+ return this._req(null, null, controllers.automation.fetch);
515
+ });
516
+ }
517
+ deleteAutomation(automation) {
518
+ return __awaiter(this, void 0, void 0, function* () {
519
+ automation = automation || this.automation;
520
+ if (!automation) {
521
+ return;
522
+ }
523
+ return this._req(null, { id: automation._id, rev: automation._rev }, controllers.automation.destroy);
524
+ });
525
+ }
526
+ createWebhook(config) {
527
+ return __awaiter(this, void 0, void 0, function* () {
528
+ if (!this.automation) {
529
+ throw "Must create an automation before creating webhook.";
530
+ }
531
+ config = config || (0, structures_1.basicWebhook)(this.automation._id);
532
+ return (yield this._req(config, null, controllers.webhook.save)).webhook;
533
+ });
534
+ }
535
+ // DATASOURCE
536
+ createDatasource(config) {
537
+ return __awaiter(this, void 0, void 0, function* () {
538
+ config = config || (0, structures_1.basicDatasource)();
539
+ const response = yield this._req(config, null, controllers.datasource.save);
540
+ this.datasource = response.datasource;
541
+ return this.datasource;
542
+ });
543
+ }
544
+ updateDatasource(datasource) {
545
+ return __awaiter(this, void 0, void 0, function* () {
546
+ const response = yield this._req(datasource, { datasourceId: datasource._id }, controllers.datasource.update);
547
+ this.datasource = response.datasource;
548
+ return this.datasource;
549
+ });
550
+ }
551
+ restDatasource(cfg) {
552
+ return __awaiter(this, void 0, void 0, function* () {
553
+ return this.createDatasource({
554
+ datasource: Object.assign(Object.assign({}, (0, structures_1.basicDatasource)().datasource), { source: types_1.SourceName.REST, config: cfg || {} }),
555
+ });
556
+ });
557
+ }
558
+ dynamicVariableDatasource() {
559
+ return __awaiter(this, void 0, void 0, function* () {
560
+ let datasource = yield this.restDatasource();
561
+ const basedOnQuery = yield this.createQuery(Object.assign(Object.assign({}, (0, structures_1.basicQuery)(datasource._id)), { fields: {
562
+ path: "www.google.com",
563
+ } }));
564
+ datasource = yield this.updateDatasource(Object.assign(Object.assign({}, datasource), { config: {
565
+ dynamicVariables: [
566
+ {
567
+ queryId: basedOnQuery._id,
568
+ name: "variable3",
569
+ value: "{{ data.0.[value] }}",
570
+ },
571
+ ],
572
+ } }));
573
+ return { datasource, query: basedOnQuery };
574
+ });
575
+ }
576
+ // QUERY
577
+ previewQuery(request, config, datasource, fields, params, verb) {
578
+ return __awaiter(this, void 0, void 0, function* () {
579
+ return request
580
+ .post(`/api/queries/preview`)
581
+ .send({
582
+ datasourceId: datasource._id,
583
+ parameters: params || {},
584
+ fields,
585
+ queryVerb: verb || "read",
586
+ name: datasource.name,
587
+ })
588
+ .set(config.defaultHeaders())
589
+ .expect("Content-Type", /json/)
590
+ .expect(200);
591
+ });
592
+ }
593
+ createQuery(config) {
594
+ return __awaiter(this, void 0, void 0, function* () {
595
+ if (!this.datasource && !config) {
596
+ throw "No datasource created for query.";
597
+ }
598
+ config = config || (0, structures_1.basicQuery)(this.datasource._id);
599
+ return this._req(config, null, controllers.query.save);
600
+ });
601
+ }
602
+ // SCREEN
603
+ createScreen(config) {
604
+ return __awaiter(this, void 0, void 0, function* () {
605
+ config = config || (0, structures_1.basicScreen)();
606
+ return this._req(config, null, controllers.screen.save);
607
+ });
608
+ }
609
+ // LAYOUT
610
+ createLayout(config) {
611
+ return __awaiter(this, void 0, void 0, function* () {
612
+ config = config || (0, structures_1.basicLayout)();
613
+ return yield this._req(config, null, controllers.layout.save);
614
+ });
615
+ }
616
+ }
617
+ _TestConfiguration_setMultiTenancy = new WeakMap(), _TestConfiguration_setSelfHosted = new WeakMap();
618
+ module.exports = TestConfiguration;
@@ -0,0 +1,40 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.deploy = exports.layout = exports.webhook = exports.screen = exports.query = exports.datasource = exports.automation = exports.user = exports.app = exports.view = exports.perms = exports.role = exports.row = exports.table = void 0;
27
+ exports.table = __importStar(require("../../api/controllers/table"));
28
+ exports.row = __importStar(require("../../api/controllers/row"));
29
+ exports.role = __importStar(require("../../api/controllers/role"));
30
+ exports.perms = __importStar(require("../../api/controllers/permission"));
31
+ exports.view = __importStar(require("../../api/controllers/view"));
32
+ exports.app = __importStar(require("../../api/controllers/application"));
33
+ exports.user = __importStar(require("../../api/controllers/user"));
34
+ exports.automation = __importStar(require("../../api/controllers/automation"));
35
+ exports.datasource = __importStar(require("../../api/controllers/datasource"));
36
+ exports.query = __importStar(require("../../api/controllers/query"));
37
+ exports.screen = __importStar(require("../../api/controllers/screen"));
38
+ exports.webhook = __importStar(require("../../api/controllers/webhook"));
39
+ exports.layout = __importStar(require("../../api/controllers/layout"));
40
+ exports.deploy = __importStar(require("../../api/controllers/deploy"));