@budibase/server 2.3.15 → 2.3.17-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (458) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.4488f38d.css → index.7e76c039.css} +1 -1
  3. package/builder/assets/{index.e88df740.js → index.e8838b62.js} +364 -364
  4. package/builder/index.html +2 -2
  5. package/dist/api/controllers/query/index.js +2 -0
  6. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  7. package/dist/api/controllers/row/external.js +12 -1
  8. package/dist/api/controllers/table/external.js +8 -8
  9. package/dist/api/routes/public/tests/utils.js +29 -2
  10. package/dist/api/routes/tests/utilities/index.js +131 -0
  11. package/dist/app.js +7 -1
  12. package/dist/constants/index.js +4 -24
  13. package/dist/db/defaultData/datasource_bb_default.js +6 -5
  14. package/dist/db/linkedRows/LinkController.js +9 -8
  15. package/dist/ddApm.js +11 -0
  16. package/dist/elasticApm.js +14 -0
  17. package/dist/integrations/base/sql.js +10 -3
  18. package/dist/package.json +9 -6
  19. package/dist/sdk/app/backups/exports.js +8 -2
  20. package/dist/sdk/app/datasources/datasources.js +3 -0
  21. package/dist/tests/utilities/TestConfiguration.js +626 -0
  22. package/dist/tests/utilities/controllers.js +40 -0
  23. package/dist/tests/utilities/structures.js +234 -0
  24. package/dist/tsconfig.build.tsbuildinfo +1 -1
  25. package/dist/utilities/retry.js +30 -0
  26. package/jest-testcontainers-config.js +8 -0
  27. package/jest.config.ts +28 -11
  28. package/package.json +10 -7
  29. package/scripts/load/create-many-apps.js +24 -0
  30. package/scripts/load/create-many-rows.js +30 -0
  31. package/scripts/load/utils.js +66 -0
  32. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  33. package/src/api/controllers/query/index.ts +2 -0
  34. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  35. package/src/api/controllers/row/external.ts +13 -1
  36. package/src/api/controllers/table/external.ts +3 -2
  37. package/src/api/routes/public/applications.ts +0 -1
  38. package/src/api/routes/public/tests/compare.spec.js +1 -1
  39. package/src/api/routes/public/tests/users.spec.js +1 -1
  40. package/src/api/routes/public/tests/utils.ts +25 -8
  41. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  42. package/src/api/routes/tests/analytics.spec.js +4 -1
  43. package/src/api/routes/tests/apikeys.spec.js +1 -1
  44. package/src/api/routes/tests/application.spec.ts +20 -6
  45. package/src/api/routes/tests/auth.spec.js +2 -2
  46. package/src/api/routes/tests/automation.spec.js +6 -2
  47. package/src/api/routes/tests/backup.spec.ts +4 -13
  48. package/src/api/routes/tests/{cloud.spec.ts → cloud.seq.spec.ts} +11 -15
  49. package/src/api/routes/tests/component.spec.js +1 -1
  50. package/src/api/routes/tests/datasource.spec.ts +20 -3
  51. package/src/api/routes/tests/dev.spec.js +1 -1
  52. package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
  53. package/src/api/routes/tests/integration.spec.js +1 -1
  54. package/src/api/routes/tests/layout.spec.js +1 -1
  55. package/src/api/routes/tests/metadata.spec.js +1 -1
  56. package/src/api/routes/tests/misc.spec.js +1 -1
  57. package/src/api/routes/tests/permissions.spec.js +4 -1
  58. package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
  59. package/src/api/routes/tests/role.spec.js +6 -1
  60. package/src/api/routes/tests/routing.spec.js +1 -1
  61. package/src/api/routes/tests/row.spec.js +11 -3
  62. package/src/api/routes/tests/screen.spec.js +1 -1
  63. package/src/api/routes/tests/static.spec.js +2 -1
  64. package/src/api/routes/tests/table.spec.js +1 -1
  65. package/src/api/routes/tests/templates.spec.js +1 -1
  66. package/src/api/routes/tests/user.spec.js +12 -12
  67. package/src/api/routes/tests/utilities/TestFunctions.ts +25 -2
  68. package/src/api/routes/tests/utilities/index.ts +5 -3
  69. package/src/api/routes/tests/view.spec.js +4 -1
  70. package/src/api/routes/tests/webhook.spec.js +11 -2
  71. package/src/app.ts +10 -1
  72. package/src/automations/tests/automation.spec.js +4 -4
  73. package/src/automations/tests/bash.spec.js +1 -1
  74. package/src/automations/tests/discord.spec.js +1 -1
  75. package/src/automations/tests/executeQuery.spec.js +2 -3
  76. package/src/automations/tests/executeScript.spec.js +1 -1
  77. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  78. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  79. package/src/automations/tests/serverLog.spec.js +1 -1
  80. package/src/automations/tests/updateRow.spec.js +1 -1
  81. package/src/automations/tests/zapier.spec.js +1 -1
  82. package/src/constants/index.ts +1 -23
  83. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  84. package/src/db/linkedRows/LinkController.ts +2 -1
  85. package/src/db/tests/linkController.spec.js +4 -1
  86. package/src/db/tests/linkTests.spec.js +1 -1
  87. package/src/ddApm.ts +7 -0
  88. package/src/elasticApm.ts +10 -0
  89. package/src/integration-test/postgres.spec.ts +752 -0
  90. package/src/integrations/base/sql.ts +15 -5
  91. package/src/integrations/oracle.ts +1 -1
  92. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  93. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  94. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  95. package/src/migrations/tests/index.spec.ts +13 -20
  96. package/src/sdk/app/backups/exports.ts +8 -2
  97. package/src/sdk/app/datasources/datasources.ts +3 -0
  98. package/src/tests/jestEnv.ts +2 -6
  99. package/src/tests/jestSetup.ts +8 -7
  100. package/src/tests/utilities/TestConfiguration.ts +126 -50
  101. package/src/tests/utilities/structures.ts +16 -2
  102. package/src/utilities/retry.ts +18 -0
  103. package/coverage/clover.xml +0 -11755
  104. package/coverage/coverage-final.json +0 -284
  105. package/coverage/lcov-report/base.css +0 -224
  106. package/coverage/lcov-report/block-navigation.js +0 -87
  107. package/coverage/lcov-report/favicon.png +0 -0
  108. package/coverage/lcov-report/index.html +0 -1031
  109. package/coverage/lcov-report/prettify.css +0 -1
  110. package/coverage/lcov-report/prettify.js +0 -2
  111. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  112. package/coverage/lcov-report/sorter.js +0 -196
  113. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
  114. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
  115. package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
  116. package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
  117. package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
  118. package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
  119. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
  120. package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
  121. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
  122. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
  123. package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
  124. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
  125. package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
  126. package/coverage/lcov-report/src/api/controllers/index.html +0 -431
  127. package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
  128. package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
  129. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
  130. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
  131. package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
  132. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
  133. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
  134. package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
  135. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
  136. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
  137. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
  138. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
  139. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
  140. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
  141. package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
  142. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
  143. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
  144. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
  145. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
  146. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
  147. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
  148. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
  149. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
  150. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
  151. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
  152. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
  153. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
  154. package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
  155. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
  156. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
  157. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
  158. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
  159. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
  160. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
  161. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
  162. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
  163. package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
  164. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
  165. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
  166. package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
  167. package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
  168. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
  169. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
  170. package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
  171. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
  172. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
  173. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
  174. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -577
  175. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
  176. package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
  177. package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
  178. package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
  179. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
  180. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
  181. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
  182. package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
  183. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
  184. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
  185. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
  186. package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
  187. package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
  188. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
  189. package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
  190. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
  191. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
  192. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
  193. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
  194. package/coverage/lcov-report/src/api/index.html +0 -116
  195. package/coverage/lcov-report/src/api/index.ts.html +0 -352
  196. package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
  197. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
  198. package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
  199. package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
  200. package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
  201. package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
  202. package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
  203. package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
  204. package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
  205. package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
  206. package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
  207. package/coverage/lcov-report/src/api/routes/index.html +0 -551
  208. package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
  209. package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
  210. package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
  211. package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
  212. package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
  213. package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
  214. package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
  215. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
  216. package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
  217. package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
  218. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
  219. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
  220. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
  221. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
  222. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
  223. package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
  224. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
  225. package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
  226. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
  227. package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
  228. package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
  229. package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
  230. package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
  231. package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
  232. package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
  233. package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
  234. package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
  235. package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
  236. package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
  237. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
  238. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
  239. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
  240. package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
  241. package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
  242. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
  243. package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
  244. package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
  245. package/coverage/lcov-report/src/app.ts.html +0 -424
  246. package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
  247. package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
  248. package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
  249. package/coverage/lcov-report/src/automations/index.html +0 -191
  250. package/coverage/lcov-report/src/automations/index.ts.html +0 -163
  251. package/coverage/lcov-report/src/automations/logging/index.html +0 -116
  252. package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
  253. package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
  254. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
  255. package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
  256. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
  257. package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -349
  258. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
  259. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
  260. package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
  261. package/coverage/lcov-report/src/automations/steps/index.html +0 -371
  262. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -361
  263. package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
  264. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
  265. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
  266. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
  267. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
  268. package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -292
  269. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
  270. package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
  271. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -355
  272. package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
  273. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
  274. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
  275. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
  276. package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
  277. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
  278. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
  279. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
  280. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
  281. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
  282. package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
  283. package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
  284. package/coverage/lcov-report/src/constants/index.html +0 -146
  285. package/coverage/lcov-report/src/constants/index.ts.html +0 -697
  286. package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
  287. package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
  288. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
  289. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
  290. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
  291. package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
  292. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
  293. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
  294. package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
  295. package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
  296. package/coverage/lcov-report/src/db/index.html +0 -176
  297. package/coverage/lcov-report/src/db/index.ts.html +0 -133
  298. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
  299. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
  300. package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
  301. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
  302. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
  303. package/coverage/lcov-report/src/db/newid.ts.html +0 -100
  304. package/coverage/lcov-report/src/db/utils.ts.html +0 -913
  305. package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
  306. package/coverage/lcov-report/src/definitions/index.html +0 -116
  307. package/coverage/lcov-report/src/environment.ts.html +0 -472
  308. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
  309. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
  310. package/coverage/lcov-report/src/events/index.html +0 -161
  311. package/coverage/lcov-report/src/events/index.ts.html +0 -100
  312. package/coverage/lcov-report/src/events/utils.ts.html +0 -319
  313. package/coverage/lcov-report/src/index.html +0 -191
  314. package/coverage/lcov-report/src/index.ts.html +0 -133
  315. package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
  316. package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
  317. package/coverage/lcov-report/src/integrations/base/index.html +0 -161
  318. package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
  319. package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
  320. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
  321. package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
  322. package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
  323. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
  324. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
  325. package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
  326. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
  327. package/coverage/lcov-report/src/integrations/index.html +0 -371
  328. package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
  329. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
  330. package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
  331. package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
  332. package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
  333. package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
  334. package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
  335. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
  336. package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
  337. package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
  338. package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
  339. package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
  340. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
  341. package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
  342. package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
  343. package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
  344. package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
  345. package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
  346. package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
  347. package/coverage/lcov-report/src/middleware/index.html +0 -236
  348. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
  349. package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
  350. package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
  351. package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
  352. package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
  353. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
  354. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
  355. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
  356. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
  357. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
  358. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
  359. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
  360. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
  361. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
  362. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
  363. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
  364. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
  365. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
  366. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
  367. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
  368. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
  369. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
  370. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
  371. package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
  372. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
  373. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
  374. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
  375. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
  376. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
  377. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
  378. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
  379. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
  380. package/coverage/lcov-report/src/migrations/index.html +0 -116
  381. package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
  382. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
  383. package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
  384. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
  385. package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
  386. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
  387. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
  388. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
  389. package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
  390. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
  391. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
  392. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
  393. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
  394. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
  395. package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
  396. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
  397. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
  398. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
  399. package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
  400. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
  401. package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
  402. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
  403. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
  404. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
  405. package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
  406. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
  407. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
  408. package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
  409. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
  410. package/coverage/lcov-report/src/sdk/index.html +0 -116
  411. package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
  412. package/coverage/lcov-report/src/sdk/users/index.html +0 -131
  413. package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
  414. package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
  415. package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
  416. package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
  417. package/coverage/lcov-report/src/startup.ts.html +0 -484
  418. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
  419. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
  420. package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
  421. package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
  422. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
  423. package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
  424. package/coverage/lcov-report/src/threads/index.html +0 -161
  425. package/coverage/lcov-report/src/threads/index.ts.html +0 -418
  426. package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
  427. package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
  428. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
  429. package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
  430. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  431. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
  432. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
  433. package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
  434. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
  435. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
  436. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
  437. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  438. package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
  439. package/coverage/lcov-report/src/utilities/index.html +0 -251
  440. package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
  441. package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
  442. package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
  443. package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
  444. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
  445. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
  446. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
  447. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
  448. package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
  449. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
  450. package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
  451. package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
  452. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
  453. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
  454. package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
  455. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
  456. package/coverage/lcov-report/src/watch.ts.html +0 -196
  457. package/coverage/lcov-report/src/websocket.ts.html +0 -163
  458. package/coverage/lcov.info +0 -21750
@@ -89,6 +89,9 @@ function removeSecrets(datasources) {
89
89
  const definitions = yield (0, integrations_1.getDefinitions)();
90
90
  for (let datasource of datasources) {
91
91
  const schema = definitions[datasource.source];
92
+ if (!schema) {
93
+ continue;
94
+ }
92
95
  if (datasource.config) {
93
96
  // strip secrets from response, so they don't show in the network request
94
97
  if (datasource.config.auth) {
@@ -0,0 +1,626 @@
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(user = {}) {
234
+ return __awaiter(this, void 0, void 0, function* () {
235
+ let { id, firstName, lastName, email, builder, admin, roles } = user;
236
+ firstName = firstName || this.defaultUserValues.firstName;
237
+ lastName = lastName || this.defaultUserValues.lastName;
238
+ email = email || this.defaultUserValues.email;
239
+ roles = roles || {};
240
+ if (builder == null) {
241
+ builder = true;
242
+ }
243
+ const globalId = !id ? `us_${Math.random()}` : `us_${id}`;
244
+ const resp = yield this.globalUser({
245
+ id: globalId,
246
+ firstName,
247
+ lastName,
248
+ email,
249
+ builder,
250
+ admin,
251
+ roles,
252
+ });
253
+ yield backend_core_2.cache.user.invalidateUser(globalId);
254
+ return Object.assign(Object.assign({}, resp), { globalId });
255
+ });
256
+ }
257
+ login({ roleId, userId, builder, prodApp = false } = {}) {
258
+ return __awaiter(this, void 0, void 0, function* () {
259
+ const appId = prodApp ? this.prodAppId : this.appId;
260
+ return backend_core_2.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
261
+ userId = !userId ? `us_uuid1` : userId;
262
+ if (!this.request) {
263
+ throw "Server has not been opened, cannot login.";
264
+ }
265
+ // make sure the user exists in the global DB
266
+ if (roleId !== backend_core_2.roles.BUILTIN_ROLE_IDS.PUBLIC) {
267
+ yield this.globalUser({
268
+ id: userId,
269
+ builder,
270
+ roles: { [this.prodAppId]: roleId },
271
+ });
272
+ }
273
+ yield backend_core_2.sessions.createASession(userId, {
274
+ sessionId: "sessionid",
275
+ tenantId: this.getTenantId(),
276
+ });
277
+ // have to fake this
278
+ const authObj = {
279
+ userId,
280
+ sessionId: "sessionid",
281
+ tenantId: this.getTenantId(),
282
+ };
283
+ const app = {
284
+ roleId: roleId,
285
+ appId,
286
+ };
287
+ const authToken = backend_core_2.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
288
+ const appToken = backend_core_2.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
289
+ // returning necessary request headers
290
+ yield backend_core_2.cache.user.invalidateUser(userId);
291
+ return {
292
+ Accept: "application/json",
293
+ Cookie: [
294
+ `${backend_core_2.constants.Cookie.Auth}=${authToken}`,
295
+ `${backend_core_2.constants.Cookie.CurrentApp}=${appToken}`,
296
+ ],
297
+ [backend_core_2.constants.Header.APP_ID]: appId,
298
+ };
299
+ }));
300
+ });
301
+ }
302
+ defaultHeaders(extras = {}) {
303
+ const tenantId = this.getTenantId();
304
+ const authObj = {
305
+ userId: this.defaultUserValues.globalUserId,
306
+ sessionId: "sessionid",
307
+ tenantId,
308
+ };
309
+ const app = {
310
+ roleId: backend_core_2.roles.BUILTIN_ROLE_IDS.ADMIN,
311
+ appId: this.appId,
312
+ };
313
+ const authToken = backend_core_2.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
314
+ const appToken = backend_core_2.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
315
+ const headers = Object.assign({ Accept: "application/json", Cookie: [
316
+ `${backend_core_2.constants.Cookie.Auth}=${authToken}`,
317
+ `${backend_core_2.constants.Cookie.CurrentApp}=${appToken}`,
318
+ ], [backend_core_2.constants.Header.CSRF_TOKEN]: this.defaultUserValues.csrfToken }, extras);
319
+ if (this.appId) {
320
+ headers[backend_core_2.constants.Header.APP_ID] = this.appId;
321
+ }
322
+ return headers;
323
+ }
324
+ getTenantId() {
325
+ return this.tenantId || structures_1.TENANT_ID;
326
+ }
327
+ publicHeaders({ prodApp = true } = {}) {
328
+ const appId = prodApp ? this.prodAppId : this.appId;
329
+ const headers = {
330
+ Accept: "application/json",
331
+ };
332
+ if (appId) {
333
+ headers[backend_core_2.constants.Header.APP_ID] = appId;
334
+ }
335
+ if (this.tenantId) {
336
+ headers[backend_core_2.constants.Header.TENANT_ID] = this.tenantId;
337
+ }
338
+ return headers;
339
+ }
340
+ roleHeaders({ email = this.defaultUserValues.email, roleId = backend_core_2.roles.BUILTIN_ROLE_IDS.ADMIN, builder = false, prodApp = true, } = {}) {
341
+ return __awaiter(this, void 0, void 0, function* () {
342
+ return this.login({ email, roleId, builder, prodApp });
343
+ });
344
+ }
345
+ // API
346
+ generateApiKey(userId = this.defaultUserValues.globalUserId) {
347
+ return __awaiter(this, void 0, void 0, function* () {
348
+ return backend_core_2.tenancy.doWithGlobalDB(this.getTenantId(), (db) => __awaiter(this, void 0, void 0, function* () {
349
+ const id = backend_core_2.db.generateDevInfoID(userId);
350
+ let devInfo;
351
+ try {
352
+ devInfo = yield db.get(id);
353
+ }
354
+ catch (err) {
355
+ devInfo = { _id: id, userId };
356
+ }
357
+ devInfo.apiKey = backend_core_2.encryption.encrypt(`${this.getTenantId()}${backend_core_2.db.SEPARATOR}${(0, newid_1.default)()}`);
358
+ yield db.put(devInfo);
359
+ return devInfo.apiKey;
360
+ }));
361
+ });
362
+ }
363
+ // APP
364
+ createApp(appName) {
365
+ return __awaiter(this, void 0, void 0, function* () {
366
+ // create dev app
367
+ // clear any old app
368
+ this.appId = null;
369
+ yield backend_core_2.context.doInAppContext(null, () => __awaiter(this, void 0, void 0, function* () {
370
+ this.app = yield this._req({ name: appName }, null, controllers.app.create);
371
+ this.appId = this.app.appId;
372
+ }));
373
+ return yield backend_core_2.context.doInAppContext(this.appId, () => __awaiter(this, void 0, void 0, function* () {
374
+ // create production app
375
+ this.prodApp = yield this.publish();
376
+ this.allApps.push(this.prodApp);
377
+ this.allApps.push(this.app);
378
+ return this.app;
379
+ }));
380
+ });
381
+ }
382
+ publish() {
383
+ return __awaiter(this, void 0, void 0, function* () {
384
+ yield this._req(null, null, controllers.deploy.publishApp);
385
+ // @ts-ignore
386
+ const prodAppId = this.getAppId().replace("_dev", "");
387
+ this.prodAppId = prodAppId;
388
+ return backend_core_2.context.doInAppContext(prodAppId, () => __awaiter(this, void 0, void 0, function* () {
389
+ const db = backend_core_2.context.getProdAppDB();
390
+ return yield db.get(backend_core_2.db.DocumentType.APP_METADATA);
391
+ }));
392
+ });
393
+ }
394
+ unpublish() {
395
+ return __awaiter(this, void 0, void 0, function* () {
396
+ const response = yield this._req(null, { appId: this.appId }, controllers.app.unpublish);
397
+ this.prodAppId = null;
398
+ this.prodApp = null;
399
+ return response;
400
+ });
401
+ }
402
+ // TABLE
403
+ updateTable(config) {
404
+ return __awaiter(this, void 0, void 0, function* () {
405
+ config = config || (0, structures_1.basicTable)();
406
+ this.table = yield this._req(config, null, controllers.table.save);
407
+ return this.table;
408
+ });
409
+ }
410
+ createTable(config) {
411
+ return __awaiter(this, void 0, void 0, function* () {
412
+ if (config != null && config._id) {
413
+ delete config._id;
414
+ }
415
+ return this.updateTable(config);
416
+ });
417
+ }
418
+ getTable(tableId) {
419
+ return __awaiter(this, void 0, void 0, function* () {
420
+ tableId = tableId || this.table._id;
421
+ return this._req(null, { tableId }, controllers.table.find);
422
+ });
423
+ }
424
+ createLinkedTable(relationshipType, links = ["link"]) {
425
+ return __awaiter(this, void 0, void 0, function* () {
426
+ if (!this.table) {
427
+ throw "Must have created a table first.";
428
+ }
429
+ const tableConfig = (0, structures_1.basicTable)();
430
+ tableConfig.primaryDisplay = "name";
431
+ for (let link of links) {
432
+ tableConfig.schema[link] = {
433
+ type: "link",
434
+ fieldName: link,
435
+ tableId: this.table._id,
436
+ name: link,
437
+ };
438
+ if (relationshipType) {
439
+ tableConfig.schema[link].relationshipType = relationshipType;
440
+ }
441
+ }
442
+ const linkedTable = yield this.createTable(tableConfig);
443
+ this.linkedTable = linkedTable;
444
+ return linkedTable;
445
+ });
446
+ }
447
+ createAttachmentTable() {
448
+ return __awaiter(this, void 0, void 0, function* () {
449
+ const table = (0, structures_1.basicTable)();
450
+ table.schema.attachment = {
451
+ type: "attachment",
452
+ };
453
+ return this.createTable(table);
454
+ });
455
+ }
456
+ // ROW
457
+ createRow(config) {
458
+ return __awaiter(this, void 0, void 0, function* () {
459
+ if (!this.table) {
460
+ throw "Test requires table to be configured.";
461
+ }
462
+ const tableId = (config && config.tableId) || this.table._id;
463
+ config = config || (0, structures_1.basicRow)(tableId);
464
+ return this._req(config, { tableId }, controllers.row.save);
465
+ });
466
+ }
467
+ getRow(tableId, rowId) {
468
+ return __awaiter(this, void 0, void 0, function* () {
469
+ return this._req(null, { tableId, rowId }, controllers.row.find);
470
+ });
471
+ }
472
+ getRows(tableId) {
473
+ return __awaiter(this, void 0, void 0, function* () {
474
+ if (!tableId && this.table) {
475
+ tableId = this.table._id;
476
+ }
477
+ return this._req(null, { tableId }, controllers.row.fetch);
478
+ });
479
+ }
480
+ // ROLE
481
+ createRole(config) {
482
+ return __awaiter(this, void 0, void 0, function* () {
483
+ config = config || (0, structures_1.basicRole)();
484
+ return this._req(config, null, controllers.role.save);
485
+ });
486
+ }
487
+ addPermission(roleId, resourceId, level = "read") {
488
+ return __awaiter(this, void 0, void 0, function* () {
489
+ return this._req(null, {
490
+ roleId,
491
+ resourceId,
492
+ level,
493
+ }, controllers.perms.addPermission);
494
+ });
495
+ }
496
+ // VIEW
497
+ createView(config) {
498
+ return __awaiter(this, void 0, void 0, function* () {
499
+ if (!this.table) {
500
+ throw "Test requires table to be configured.";
501
+ }
502
+ const view = config || {
503
+ tableId: this.table._id,
504
+ name: "ViewTest",
505
+ };
506
+ return this._req(view, null, controllers.view.save);
507
+ });
508
+ }
509
+ // AUTOMATION
510
+ createAutomation(config) {
511
+ return __awaiter(this, void 0, void 0, function* () {
512
+ config = config || (0, structures_1.basicAutomation)();
513
+ if (config._rev) {
514
+ delete config._rev;
515
+ }
516
+ this.automation = (yield this._req(config, null, controllers.automation.create)).automation;
517
+ return this.automation;
518
+ });
519
+ }
520
+ getAllAutomations() {
521
+ return __awaiter(this, void 0, void 0, function* () {
522
+ return this._req(null, null, controllers.automation.fetch);
523
+ });
524
+ }
525
+ deleteAutomation(automation) {
526
+ return __awaiter(this, void 0, void 0, function* () {
527
+ automation = automation || this.automation;
528
+ if (!automation) {
529
+ return;
530
+ }
531
+ return this._req(null, { id: automation._id, rev: automation._rev }, controllers.automation.destroy);
532
+ });
533
+ }
534
+ createWebhook(config) {
535
+ return __awaiter(this, void 0, void 0, function* () {
536
+ if (!this.automation) {
537
+ throw "Must create an automation before creating webhook.";
538
+ }
539
+ config = config || (0, structures_1.basicWebhook)(this.automation._id);
540
+ return (yield this._req(config, null, controllers.webhook.save)).webhook;
541
+ });
542
+ }
543
+ // DATASOURCE
544
+ createDatasource(config) {
545
+ return __awaiter(this, void 0, void 0, function* () {
546
+ config = config || (0, structures_1.basicDatasource)();
547
+ const response = yield this._req(config, null, controllers.datasource.save);
548
+ this.datasource = response.datasource;
549
+ return this.datasource;
550
+ });
551
+ }
552
+ updateDatasource(datasource) {
553
+ return __awaiter(this, void 0, void 0, function* () {
554
+ const response = yield this._req(datasource, { datasourceId: datasource._id }, controllers.datasource.update);
555
+ this.datasource = response.datasource;
556
+ return this.datasource;
557
+ });
558
+ }
559
+ restDatasource(cfg) {
560
+ return __awaiter(this, void 0, void 0, function* () {
561
+ return this.createDatasource({
562
+ datasource: Object.assign(Object.assign({}, (0, structures_1.basicDatasource)().datasource), { source: types_1.SourceName.REST, config: cfg || {} }),
563
+ });
564
+ });
565
+ }
566
+ dynamicVariableDatasource() {
567
+ return __awaiter(this, void 0, void 0, function* () {
568
+ let datasource = yield this.restDatasource();
569
+ const basedOnQuery = yield this.createQuery(Object.assign(Object.assign({}, (0, structures_1.basicQuery)(datasource._id)), { fields: {
570
+ path: "www.google.com",
571
+ } }));
572
+ datasource = yield this.updateDatasource(Object.assign(Object.assign({}, datasource), { config: {
573
+ dynamicVariables: [
574
+ {
575
+ queryId: basedOnQuery._id,
576
+ name: "variable3",
577
+ value: "{{ data.0.[value] }}",
578
+ },
579
+ ],
580
+ } }));
581
+ return { datasource, query: basedOnQuery };
582
+ });
583
+ }
584
+ // QUERY
585
+ previewQuery(request, config, datasource, fields, params, verb) {
586
+ return __awaiter(this, void 0, void 0, function* () {
587
+ return request
588
+ .post(`/api/queries/preview`)
589
+ .send({
590
+ datasourceId: datasource._id,
591
+ parameters: params || {},
592
+ fields,
593
+ queryVerb: verb || "read",
594
+ name: datasource.name,
595
+ })
596
+ .set(config.defaultHeaders())
597
+ .expect("Content-Type", /json/)
598
+ .expect(200);
599
+ });
600
+ }
601
+ createQuery(config) {
602
+ return __awaiter(this, void 0, void 0, function* () {
603
+ if (!this.datasource && !config) {
604
+ throw "No datasource created for query.";
605
+ }
606
+ config = config || (0, structures_1.basicQuery)(this.datasource._id);
607
+ return this._req(config, null, controllers.query.save);
608
+ });
609
+ }
610
+ // SCREEN
611
+ createScreen(config) {
612
+ return __awaiter(this, void 0, void 0, function* () {
613
+ config = config || (0, structures_1.basicScreen)();
614
+ return this._req(config, null, controllers.screen.save);
615
+ });
616
+ }
617
+ // LAYOUT
618
+ createLayout(config) {
619
+ return __awaiter(this, void 0, void 0, function* () {
620
+ config = config || (0, structures_1.basicLayout)();
621
+ return yield this._req(config, null, controllers.layout.save);
622
+ });
623
+ }
624
+ }
625
+ _TestConfiguration_setMultiTenancy = new WeakMap(), _TestConfiguration_setSelfHosted = new WeakMap();
626
+ 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"));