@budibase/server 2.3.17-alpha.1 → 2.3.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (463) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.2492f6c7.js → index.06e34d35.js} +364 -364
  3. package/builder/assets/{index.7e76c039.css → index.4488f38d.css} +1 -1
  4. package/builder/index.html +2 -2
  5. package/coverage/clover.xml +11771 -0
  6. package/coverage/coverage-final.json +284 -0
  7. package/coverage/lcov-report/base.css +224 -0
  8. package/coverage/lcov-report/block-navigation.js +87 -0
  9. package/coverage/lcov-report/favicon.png +0 -0
  10. package/coverage/lcov-report/index.html +1031 -0
  11. package/coverage/lcov-report/prettify.css +1 -0
  12. package/coverage/lcov-report/prettify.js +2 -0
  13. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  14. package/coverage/lcov-report/sorter.js +196 -0
  15. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +190 -0
  16. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +247 -0
  17. package/coverage/lcov-report/src/api/controllers/application.ts.html +1987 -0
  18. package/coverage/lcov-report/src/api/controllers/auth.ts.html +301 -0
  19. package/coverage/lcov-report/src/api/controllers/automation.ts.html +940 -0
  20. package/coverage/lcov-report/src/api/controllers/backup.ts.html +148 -0
  21. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +442 -0
  22. package/coverage/lcov-report/src/api/controllers/component.ts.html +259 -0
  23. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +1135 -0
  24. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +262 -0
  25. package/coverage/lcov-report/src/api/controllers/deploy/index.html +131 -0
  26. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +694 -0
  27. package/coverage/lcov-report/src/api/controllers/dev.ts.html +472 -0
  28. package/coverage/lcov-report/src/api/controllers/index.html +431 -0
  29. package/coverage/lcov-report/src/api/controllers/integration.ts.html +124 -0
  30. package/coverage/lcov-report/src/api/controllers/layout.ts.html +226 -0
  31. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +211 -0
  32. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +127 -0
  33. package/coverage/lcov-report/src/api/controllers/permission.ts.html +619 -0
  34. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +130 -0
  35. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +310 -0
  36. package/coverage/lcov-report/src/api/controllers/plugin/index.html +206 -0
  37. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +499 -0
  38. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +253 -0
  39. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +97 -0
  40. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +121 -0
  41. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +136 -0
  42. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +385 -0
  43. package/coverage/lcov-report/src/api/controllers/public/index.html +191 -0
  44. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +181 -0
  45. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +191 -0
  46. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +124 -0
  47. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +202 -0
  48. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +178 -0
  49. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +163 -0
  50. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +181 -0
  51. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +145 -0
  52. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +328 -0
  53. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +253 -0
  54. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +325 -0
  55. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +220 -0
  56. package/coverage/lcov-report/src/api/controllers/query/import/index.html +116 -0
  57. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +373 -0
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +131 -0
  59. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +379 -0
  60. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +157 -0
  61. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +403 -0
  62. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +146 -0
  63. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +586 -0
  64. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +712 -0
  65. package/coverage/lcov-report/src/api/controllers/query/index.html +131 -0
  66. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +1000 -0
  67. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +235 -0
  68. package/coverage/lcov-report/src/api/controllers/role.ts.html +397 -0
  69. package/coverage/lcov-report/src/api/controllers/routing.ts.html +370 -0
  70. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +2305 -0
  71. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +931 -0
  72. package/coverage/lcov-report/src/api/controllers/row/index.html +206 -0
  73. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +541 -0
  74. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +1609 -0
  75. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +1678 -0
  76. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +577 -0
  77. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +556 -0
  78. package/coverage/lcov-report/src/api/controllers/screen.ts.html +463 -0
  79. package/coverage/lcov-report/src/api/controllers/script.ts.html +121 -0
  80. package/coverage/lcov-report/src/api/controllers/static/index.html +116 -0
  81. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +679 -0
  82. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +649 -0
  83. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +1153 -0
  84. package/coverage/lcov-report/src/api/controllers/table/index.html +176 -0
  85. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +514 -0
  86. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +658 -0
  87. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +1273 -0
  88. package/coverage/lcov-report/src/api/controllers/templates.ts.html +214 -0
  89. package/coverage/lcov-report/src/api/controllers/user.ts.html +634 -0
  90. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +214 -0
  91. package/coverage/lcov-report/src/api/controllers/view/index.html +161 -0
  92. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +661 -0
  93. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +580 -0
  94. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +694 -0
  95. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +385 -0
  96. package/coverage/lcov-report/src/api/index.html +116 -0
  97. package/coverage/lcov-report/src/api/index.ts.html +352 -0
  98. package/coverage/lcov-report/src/api/routes/analytics.ts.html +112 -0
  99. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +121 -0
  100. package/coverage/lcov-report/src/api/routes/application.ts.html +256 -0
  101. package/coverage/lcov-report/src/api/routes/auth.ts.html +109 -0
  102. package/coverage/lcov-report/src/api/routes/automation.ts.html +346 -0
  103. package/coverage/lcov-report/src/api/routes/backup.ts.html +127 -0
  104. package/coverage/lcov-report/src/api/routes/cloud.ts.html +139 -0
  105. package/coverage/lcov-report/src/api/routes/component.ts.html +127 -0
  106. package/coverage/lcov-report/src/api/routes/datasource.ts.html +265 -0
  107. package/coverage/lcov-report/src/api/routes/deploy.ts.html +145 -0
  108. package/coverage/lcov-report/src/api/routes/dev.ts.html +199 -0
  109. package/coverage/lcov-report/src/api/routes/index.html +551 -0
  110. package/coverage/lcov-report/src/api/routes/index.ts.html +298 -0
  111. package/coverage/lcov-report/src/api/routes/integration.ts.html +133 -0
  112. package/coverage/lcov-report/src/api/routes/layout.ts.html +133 -0
  113. package/coverage/lcov-report/src/api/routes/metadata.ts.html +199 -0
  114. package/coverage/lcov-report/src/api/routes/migrations.ts.html +127 -0
  115. package/coverage/lcov-report/src/api/routes/permission.ts.html +208 -0
  116. package/coverage/lcov-report/src/api/routes/plugin.ts.html +151 -0
  117. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +673 -0
  118. package/coverage/lcov-report/src/api/routes/public/index.html +191 -0
  119. package/coverage/lcov-report/src/api/routes/public/index.ts.html +493 -0
  120. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +116 -0
  121. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +340 -0
  122. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +313 -0
  123. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +598 -0
  124. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +586 -0
  125. package/coverage/lcov-report/src/api/routes/public/tests/index.html +116 -0
  126. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +169 -0
  127. package/coverage/lcov-report/src/api/routes/public/users.ts.html +511 -0
  128. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +238 -0
  129. package/coverage/lcov-report/src/api/routes/public/utils/index.html +116 -0
  130. package/coverage/lcov-report/src/api/routes/query.ts.html +268 -0
  131. package/coverage/lcov-report/src/api/routes/role.ts.html +157 -0
  132. package/coverage/lcov-report/src/api/routes/routing.ts.html +127 -0
  133. package/coverage/lcov-report/src/api/routes/row.ts.html +883 -0
  134. package/coverage/lcov-report/src/api/routes/screen.ts.html +154 -0
  135. package/coverage/lcov-report/src/api/routes/script.ts.html +115 -0
  136. package/coverage/lcov-report/src/api/routes/static.ts.html +280 -0
  137. package/coverage/lcov-report/src/api/routes/table.ts.html +595 -0
  138. package/coverage/lcov-report/src/api/routes/templates.ts.html +133 -0
  139. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +550 -0
  140. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +131 -0
  141. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +367 -0
  142. package/coverage/lcov-report/src/api/routes/user.ts.html +238 -0
  143. package/coverage/lcov-report/src/api/routes/utils/index.html +116 -0
  144. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +805 -0
  145. package/coverage/lcov-report/src/api/routes/view.ts.html +187 -0
  146. package/coverage/lcov-report/src/api/routes/webhook.ts.html +166 -0
  147. package/coverage/lcov-report/src/app.ts.html +424 -0
  148. package/coverage/lcov-report/src/automations/actions.ts.html +316 -0
  149. package/coverage/lcov-report/src/automations/automationUtils.ts.html +562 -0
  150. package/coverage/lcov-report/src/automations/bullboard.ts.html +199 -0
  151. package/coverage/lcov-report/src/automations/index.html +191 -0
  152. package/coverage/lcov-report/src/automations/index.ts.html +163 -0
  153. package/coverage/lcov-report/src/automations/logging/index.html +116 -0
  154. package/coverage/lcov-report/src/automations/logging/index.ts.html +199 -0
  155. package/coverage/lcov-report/src/automations/steps/bash.ts.html +319 -0
  156. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +382 -0
  157. package/coverage/lcov-report/src/automations/steps/delay.ts.html +217 -0
  158. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +349 -0
  159. package/coverage/lcov-report/src/automations/steps/discord.ts.html +397 -0
  160. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +370 -0
  161. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +325 -0
  162. package/coverage/lcov-report/src/automations/steps/filter.ts.html +394 -0
  163. package/coverage/lcov-report/src/automations/steps/index.html +371 -0
  164. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +409 -0
  165. package/coverage/lcov-report/src/automations/steps/loop.ts.html +241 -0
  166. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +499 -0
  167. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +664 -0
  168. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +355 -0
  169. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +256 -0
  170. package/coverage/lcov-report/src/automations/steps/slack.ts.html +340 -0
  171. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +439 -0
  172. package/coverage/lcov-report/src/automations/steps/utils.ts.html +223 -0
  173. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +403 -0
  174. package/coverage/lcov-report/src/automations/tests/utilities/index.html +116 -0
  175. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +265 -0
  176. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +196 -0
  177. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +193 -0
  178. package/coverage/lcov-report/src/automations/triggerInfo/index.html +206 -0
  179. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +130 -0
  180. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +196 -0
  181. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +220 -0
  182. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +220 -0
  183. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +208 -0
  184. package/coverage/lcov-report/src/automations/triggers.ts.html +553 -0
  185. package/coverage/lcov-report/src/automations/utils.ts.html +886 -0
  186. package/coverage/lcov-report/src/constants/index.html +146 -0
  187. package/coverage/lcov-report/src/constants/index.ts.html +697 -0
  188. package/coverage/lcov-report/src/constants/layouts.ts.html +526 -0
  189. package/coverage/lcov-report/src/constants/screens.ts.html +229 -0
  190. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +2059 -0
  191. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +541 -0
  192. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +427 -0
  193. package/coverage/lcov-report/src/db/defaultData/index.html +176 -0
  194. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +403 -0
  195. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +559 -0
  196. package/coverage/lcov-report/src/db/dynamoClient.ts.html +526 -0
  197. package/coverage/lcov-report/src/db/inMemoryView.ts.html +250 -0
  198. package/coverage/lcov-report/src/db/index.html +176 -0
  199. package/coverage/lcov-report/src/db/index.ts.html +133 -0
  200. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +1417 -0
  201. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +265 -0
  202. package/coverage/lcov-report/src/db/linkedRows/index.html +161 -0
  203. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +736 -0
  204. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +460 -0
  205. package/coverage/lcov-report/src/db/newid.ts.html +100 -0
  206. package/coverage/lcov-report/src/db/utils.ts.html +913 -0
  207. package/coverage/lcov-report/src/definitions/automations.ts.html +184 -0
  208. package/coverage/lcov-report/src/definitions/index.html +116 -0
  209. package/coverage/lcov-report/src/environment.ts.html +472 -0
  210. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +259 -0
  211. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +172 -0
  212. package/coverage/lcov-report/src/events/index.html +161 -0
  213. package/coverage/lcov-report/src/events/index.ts.html +100 -0
  214. package/coverage/lcov-report/src/events/utils.ts.html +319 -0
  215. package/coverage/lcov-report/src/index.html +191 -0
  216. package/coverage/lcov-report/src/index.ts.html +133 -0
  217. package/coverage/lcov-report/src/integrations/airtable.ts.html +529 -0
  218. package/coverage/lcov-report/src/integrations/arangodb.ts.html +415 -0
  219. package/coverage/lcov-report/src/integrations/base/index.html +161 -0
  220. package/coverage/lcov-report/src/integrations/base/query.ts.html +139 -0
  221. package/coverage/lcov-report/src/integrations/base/sql.ts.html +2017 -0
  222. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +691 -0
  223. package/coverage/lcov-report/src/integrations/base/utils.ts.html +121 -0
  224. package/coverage/lcov-report/src/integrations/couchdb.ts.html +484 -0
  225. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +745 -0
  226. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +646 -0
  227. package/coverage/lcov-report/src/integrations/firebase.ts.html +646 -0
  228. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +1315 -0
  229. package/coverage/lcov-report/src/integrations/index.html +371 -0
  230. package/coverage/lcov-report/src/integrations/index.ts.html +460 -0
  231. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +1012 -0
  232. package/coverage/lcov-report/src/integrations/mongodb.ts.html +1999 -0
  233. package/coverage/lcov-report/src/integrations/mysql.ts.html +979 -0
  234. package/coverage/lcov-report/src/integrations/oracle.ts.html +1387 -0
  235. package/coverage/lcov-report/src/integrations/postgres.ts.html +1087 -0
  236. package/coverage/lcov-report/src/integrations/queries/index.html +116 -0
  237. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +328 -0
  238. package/coverage/lcov-report/src/integrations/redis.ts.html +550 -0
  239. package/coverage/lcov-report/src/integrations/rest.ts.html +1372 -0
  240. package/coverage/lcov-report/src/integrations/s3.ts.html +862 -0
  241. package/coverage/lcov-report/src/integrations/snowflake.ts.html +376 -0
  242. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +85 -0
  243. package/coverage/lcov-report/src/integrations/tests/index.html +116 -0
  244. package/coverage/lcov-report/src/integrations/utils.ts.html +1036 -0
  245. package/coverage/lcov-report/src/middleware/appInfo.ts.html +145 -0
  246. package/coverage/lcov-report/src/middleware/authorized.ts.html +472 -0
  247. package/coverage/lcov-report/src/middleware/builder.ts.html +361 -0
  248. package/coverage/lcov-report/src/middleware/currentapp.ts.html +508 -0
  249. package/coverage/lcov-report/src/middleware/index.html +236 -0
  250. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +205 -0
  251. package/coverage/lcov-report/src/middleware/publicApi.ts.html +148 -0
  252. package/coverage/lcov-report/src/middleware/resourceId.ts.html +283 -0
  253. package/coverage/lcov-report/src/middleware/selfhost.ts.html +121 -0
  254. package/coverage/lcov-report/src/middleware/utils.ts.html +112 -0
  255. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +166 -0
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +163 -0
  257. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +151 -0
  258. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +206 -0
  259. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +172 -0
  260. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +226 -0
  261. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +151 -0
  262. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +151 -0
  263. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +166 -0
  264. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +532 -0
  265. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +286 -0
  266. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +146 -0
  267. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +265 -0
  268. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +232 -0
  269. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +724 -0
  270. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +161 -0
  271. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +106 -0
  272. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +235 -0
  273. package/coverage/lcov-report/src/migrations/functions/index.html +161 -0
  274. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +130 -0
  275. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +520 -0
  276. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +161 -0
  277. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +94 -0
  278. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +127 -0
  279. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +115 -0
  280. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +169 -0
  281. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +124 -0
  282. package/coverage/lcov-report/src/migrations/index.html +116 -0
  283. package/coverage/lcov-report/src/migrations/index.ts.html +430 -0
  284. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +205 -0
  285. package/coverage/lcov-report/src/migrations/tests/index.html +131 -0
  286. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +283 -0
  287. package/coverage/lcov-report/src/sdk/app/applications/index.html +146 -0
  288. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +106 -0
  289. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +268 -0
  290. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +136 -0
  291. package/coverage/lcov-report/src/sdk/app/automations/index.html +131 -0
  292. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +100 -0
  293. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +214 -0
  294. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +91 -0
  295. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +604 -0
  296. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +640 -0
  297. package/coverage/lcov-report/src/sdk/app/backups/index.html +176 -0
  298. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +112 -0
  299. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +292 -0
  300. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +562 -0
  301. package/coverage/lcov-report/src/sdk/app/datasources/index.html +131 -0
  302. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +100 -0
  303. package/coverage/lcov-report/src/sdk/app/queries/index.html +131 -0
  304. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +100 -0
  305. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +235 -0
  306. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +265 -0
  307. package/coverage/lcov-report/src/sdk/app/rows/index.html +146 -0
  308. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +106 -0
  309. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +139 -0
  310. package/coverage/lcov-report/src/sdk/app/tables/index.html +116 -0
  311. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +274 -0
  312. package/coverage/lcov-report/src/sdk/index.html +116 -0
  313. package/coverage/lcov-report/src/sdk/index.ts.html +151 -0
  314. package/coverage/lcov-report/src/sdk/users/index.html +131 -0
  315. package/coverage/lcov-report/src/sdk/users/index.ts.html +100 -0
  316. package/coverage/lcov-report/src/sdk/users/utils.ts.html +277 -0
  317. package/coverage/lcov-report/src/sdk/utils/index.html +116 -0
  318. package/coverage/lcov-report/src/sdk/utils/index.ts.html +133 -0
  319. package/coverage/lcov-report/src/startup.ts.html +484 -0
  320. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +2032 -0
  321. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +127 -0
  322. package/coverage/lcov-report/src/tests/utilities/index.html +161 -0
  323. package/coverage/lcov-report/src/tests/utilities/index.ts.html +118 -0
  324. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +856 -0
  325. package/coverage/lcov-report/src/threads/automation.ts.html +1555 -0
  326. package/coverage/lcov-report/src/threads/index.html +161 -0
  327. package/coverage/lcov-report/src/threads/index.ts.html +418 -0
  328. package/coverage/lcov-report/src/threads/query.ts.html +1000 -0
  329. package/coverage/lcov-report/src/threads/utils.ts.html +373 -0
  330. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +94 -0
  331. package/coverage/lcov-report/src/utilities/centralPath.ts.html +151 -0
  332. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +343 -0
  333. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +547 -0
  334. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +601 -0
  335. package/coverage/lcov-report/src/utilities/fileSystem/index.html +206 -0
  336. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +100 -0
  337. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +277 -0
  338. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +142 -0
  339. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +193 -0
  340. package/coverage/lcov-report/src/utilities/global.ts.html +499 -0
  341. package/coverage/lcov-report/src/utilities/index.html +251 -0
  342. package/coverage/lcov-report/src/utilities/index.ts.html +487 -0
  343. package/coverage/lcov-report/src/utilities/redis.ts.html +343 -0
  344. package/coverage/lcov-report/src/utilities/routing/index.html +116 -0
  345. package/coverage/lcov-report/src/utilities/routing/index.ts.html +181 -0
  346. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +146 -0
  347. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +922 -0
  348. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +373 -0
  349. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +373 -0
  350. package/coverage/lcov-report/src/utilities/schema.ts.html +508 -0
  351. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +169 -0
  352. package/coverage/lcov-report/src/utilities/security.ts.html +280 -0
  353. package/coverage/lcov-report/src/utilities/usageQuota/index.html +131 -0
  354. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +325 -0
  355. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +139 -0
  356. package/coverage/lcov-report/src/utilities/users.ts.html +232 -0
  357. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +646 -0
  358. package/coverage/lcov-report/src/watch.ts.html +196 -0
  359. package/coverage/lcov-report/src/websocket.ts.html +163 -0
  360. package/coverage/lcov.info +21770 -0
  361. package/dist/api/controllers/query/index.js +0 -2
  362. package/dist/api/controllers/row/ExternalRequest.js +2 -4
  363. package/dist/api/controllers/row/external.js +1 -12
  364. package/dist/api/controllers/table/external.js +8 -8
  365. package/dist/api/routes/public/tests/utils.js +33 -0
  366. package/dist/app.js +1 -7
  367. package/dist/automations/steps/discord.js +29 -11
  368. package/dist/automations/steps/integromat.js +31 -13
  369. package/dist/automations/steps/slack.js +27 -9
  370. package/dist/automations/steps/zapier.js +32 -14
  371. package/dist/constants/index.js +24 -4
  372. package/dist/db/defaultData/datasource_bb_default.js +5 -6
  373. package/dist/db/linkedRows/LinkController.js +8 -9
  374. package/dist/integrations/base/sql.js +3 -10
  375. package/dist/package.json +6 -9
  376. package/dist/sdk/app/backups/exports.js +2 -8
  377. package/dist/sdk/app/datasources/datasources.js +0 -3
  378. package/dist/tsconfig.build.tsbuildinfo +1 -1
  379. package/jest.config.ts +11 -28
  380. package/package.json +7 -10
  381. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  382. package/src/api/controllers/query/index.ts +0 -2
  383. package/src/api/controllers/row/ExternalRequest.ts +2 -6
  384. package/src/api/controllers/row/external.ts +1 -13
  385. package/src/api/controllers/table/external.ts +2 -3
  386. package/src/api/routes/public/applications.ts +1 -0
  387. package/src/api/routes/public/tests/compare.spec.js +1 -1
  388. package/src/api/routes/public/tests/users.spec.js +1 -1
  389. package/src/api/routes/public/tests/utils.ts +8 -25
  390. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  391. package/src/api/routes/tests/analytics.spec.js +1 -4
  392. package/src/api/routes/tests/apikeys.spec.js +1 -1
  393. package/src/api/routes/tests/application.spec.ts +6 -20
  394. package/src/api/routes/tests/auth.spec.js +2 -2
  395. package/src/api/routes/tests/automation.spec.js +2 -6
  396. package/src/api/routes/tests/backup.spec.ts +13 -4
  397. package/src/api/routes/tests/{cloud.seq.spec.ts → cloud.spec.ts} +15 -11
  398. package/src/api/routes/tests/component.spec.js +1 -1
  399. package/src/api/routes/tests/datasource.spec.ts +3 -20
  400. package/src/api/routes/tests/dev.spec.js +1 -1
  401. package/src/api/routes/tests/integration.spec.js +1 -1
  402. package/src/api/routes/tests/layout.spec.js +1 -1
  403. package/src/api/routes/tests/metadata.spec.js +1 -1
  404. package/src/api/routes/tests/misc.spec.js +1 -1
  405. package/src/api/routes/tests/permissions.spec.js +1 -4
  406. package/src/api/routes/tests/{query.seq.spec.js → query.spec.js} +1 -22
  407. package/src/api/routes/tests/role.spec.js +1 -6
  408. package/src/api/routes/tests/routing.spec.js +1 -1
  409. package/src/api/routes/tests/row.spec.js +3 -11
  410. package/src/api/routes/tests/screen.spec.js +1 -1
  411. package/src/api/routes/tests/static.spec.js +1 -2
  412. package/src/api/routes/tests/table.spec.js +1 -1
  413. package/src/api/routes/tests/templates.spec.js +1 -1
  414. package/src/api/routes/tests/user.spec.js +12 -12
  415. package/src/api/routes/tests/utilities/TestFunctions.ts +2 -25
  416. package/src/api/routes/tests/utilities/index.ts +3 -5
  417. package/src/api/routes/tests/view.spec.js +1 -4
  418. package/src/api/routes/tests/webhook.spec.js +2 -11
  419. package/src/app.ts +1 -10
  420. package/src/automations/steps/discord.ts +27 -11
  421. package/src/automations/steps/integromat.ts +29 -13
  422. package/src/automations/steps/slack.ts +25 -9
  423. package/src/automations/steps/zapier.ts +30 -14
  424. package/src/automations/tests/automation.spec.js +4 -4
  425. package/src/automations/tests/bash.spec.js +1 -1
  426. package/src/automations/tests/discord.spec.js +1 -1
  427. package/src/automations/tests/executeQuery.spec.js +3 -2
  428. package/src/automations/tests/executeScript.spec.js +1 -1
  429. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  430. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  431. package/src/automations/tests/serverLog.spec.js +1 -1
  432. package/src/automations/tests/updateRow.spec.js +1 -1
  433. package/src/automations/tests/zapier.spec.js +1 -1
  434. package/src/constants/index.ts +23 -1
  435. package/src/db/defaultData/datasource_bb_default.ts +10 -6
  436. package/src/db/linkedRows/LinkController.ts +1 -2
  437. package/src/db/tests/linkController.spec.js +1 -4
  438. package/src/db/tests/linkTests.spec.js +1 -1
  439. package/src/integrations/base/sql.ts +5 -15
  440. package/src/integrations/oracle.ts +1 -1
  441. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  442. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  443. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  444. package/src/migrations/tests/index.spec.ts +20 -13
  445. package/src/sdk/app/backups/exports.ts +2 -8
  446. package/src/sdk/app/datasources/datasources.ts +0 -3
  447. package/src/tests/jestEnv.ts +6 -2
  448. package/src/tests/jestSetup.ts +7 -8
  449. package/src/tests/utilities/TestConfiguration.ts +50 -126
  450. package/src/tests/utilities/structures.ts +2 -16
  451. package/tsconfig.build.json +0 -1
  452. package/dist/ddApm.js +0 -11
  453. package/dist/elasticApm.js +0 -14
  454. package/dist/utilities/retry.js +0 -30
  455. package/jest-testcontainers-config.js +0 -8
  456. package/scripts/load/create-many-apps.js +0 -24
  457. package/scripts/load/create-many-rows.js +0 -30
  458. package/scripts/load/utils.js +0 -66
  459. package/src/api/routes/tests/environmentVariables.spec.ts +0 -144
  460. package/src/ddApm.ts +0 -7
  461. package/src/elasticApm.ts +0 -10
  462. package/src/integration-test/postgres.spec.ts +0 -752
  463. package/src/utilities/retry.ts +0 -18
@@ -1,4 +1,4 @@
1
- import { generator, mocks, structures } from "@budibase/backend-core/tests"
1
+ import { mocks } from "@budibase/backend-core/tests"
2
2
 
3
3
  // init the licensing mock
4
4
  import * as pro from "@budibase/pro"
@@ -10,7 +10,6 @@ mocks.licenses.useUnlimited()
10
10
  import { init as dbInit } from "../../db"
11
11
  dbInit()
12
12
  import env from "../../environment"
13
- import { env as coreEnv } from "@budibase/backend-core"
14
13
  import {
15
14
  basicTable,
16
15
  basicRow,
@@ -39,27 +38,17 @@ import { cleanup } from "../../utilities/fileSystem"
39
38
  import newid from "../../db/newid"
40
39
  import { generateUserMetadataID } from "../../db/utils"
41
40
  import { startup } from "../../startup"
42
- import supertest from "supertest"
43
- import {
44
- AuthToken,
45
- Database,
46
- Datasource,
47
- Row,
48
- SourceName,
49
- Table,
50
- } from "@budibase/types"
51
-
52
- type DefaultUserValues = {
53
- globalUserId: string
54
- email: string
55
- firstName: string
56
- lastName: string
57
- csrfToken: string
58
- }
41
+ const supertest = require("supertest")
42
+
43
+ const GLOBAL_USER_ID = "us_uuid1"
44
+ const EMAIL = "babs@babs.com"
45
+ const FIRSTNAME = "Barbara"
46
+ const LASTNAME = "Barbington"
47
+ const CSRF_TOKEN = "e3727778-7af0-4226-b5eb-f43cbe60a306"
59
48
 
60
49
  class TestConfiguration {
61
50
  server: any
62
- request: supertest.SuperTest<supertest.Test> | undefined
51
+ request: any
63
52
  started: boolean
64
53
  appId: string | null
65
54
  allApps: any[]
@@ -73,8 +62,6 @@ class TestConfiguration {
73
62
  linkedTable: any
74
63
  automation: any
75
64
  datasource: any
76
- tenantId: string | null
77
- defaultUserValues: DefaultUserValues
78
65
 
79
66
  constructor(openServer = true) {
80
67
  if (openServer) {
@@ -89,18 +76,6 @@ class TestConfiguration {
89
76
  }
90
77
  this.appId = null
91
78
  this.allApps = []
92
- this.tenantId = null
93
- this.defaultUserValues = this.populateDefaultUserValues()
94
- }
95
-
96
- populateDefaultUserValues(): DefaultUserValues {
97
- return {
98
- globalUserId: `us_${newid()}`,
99
- email: generator.email(),
100
- firstName: generator.first(),
101
- lastName: generator.last(),
102
- csrfToken: generator.hash(),
103
- }
104
79
  }
105
80
 
106
81
  getRequest() {
@@ -125,10 +100,10 @@ class TestConfiguration {
125
100
 
126
101
  getUserDetails() {
127
102
  return {
128
- globalId: this.defaultUserValues.globalUserId,
129
- email: this.defaultUserValues.email,
130
- firstName: this.defaultUserValues.firstName,
131
- lastName: this.defaultUserValues.lastName,
103
+ globalId: GLOBAL_USER_ID,
104
+ email: EMAIL,
105
+ firstName: FIRSTNAME,
106
+ lastName: LASTNAME,
132
107
  }
133
108
  }
134
109
 
@@ -136,9 +111,7 @@ class TestConfiguration {
136
111
  if (!appId) {
137
112
  appId = this.appId
138
113
  }
139
-
140
- const tenant = this.getTenantId()
141
- return tenancy.doInTenant(tenant, () => {
114
+ return tenancy.doInTenant(TENANT_ID, () => {
142
115
  // check if already in a context
143
116
  if (context.getAppId() == null && appId !== null) {
144
117
  return context.doInAppContext(appId, async () => {
@@ -154,11 +127,6 @@ class TestConfiguration {
154
127
 
155
128
  // use a new id as the name to avoid name collisions
156
129
  async init(appName = newid()) {
157
- this.defaultUserValues = this.populateDefaultUserValues()
158
- if (context.isMultiTenant()) {
159
- this.tenantId = structures.tenant.id()
160
- }
161
-
162
130
  if (!this.started) {
163
131
  await startup()
164
132
  }
@@ -181,30 +149,9 @@ class TestConfiguration {
181
149
  }
182
150
  }
183
151
 
184
- // MODES
185
- #setMultiTenancy = (value: boolean) => {
186
- env._set("MULTI_TENANCY", value)
187
- coreEnv._set("MULTI_TENANCY", value)
188
- }
189
-
190
- #setSelfHosted = (value: boolean) => {
191
- env._set("SELF_HOSTED", value)
192
- coreEnv._set("SELF_HOSTED", value)
193
- }
194
-
195
- modeCloud = () => {
196
- this.#setSelfHosted(false)
197
- this.#setMultiTenancy(true)
198
- }
199
-
200
- modeSelf = () => {
201
- this.#setSelfHosted(true)
202
- this.#setMultiTenancy(false)
203
- }
204
-
205
152
  // UTILS
206
153
 
207
- _req(body: any, params: any, controlFunc: any) {
154
+ async _req(body: any, params: any, controlFunc: any) {
208
155
  // create a fake request ctx
209
156
  const request: any = {}
210
157
  const appId = this.appId
@@ -212,7 +159,7 @@ class TestConfiguration {
212
159
  // fake cookies, we don't need them
213
160
  request.cookies = { set: () => {}, get: () => {} }
214
161
  request.config = { jwtSecret: env.JWT_SECRET }
215
- request.user = { appId, tenantId: this.getTenantId() }
162
+ request.user = { appId, tenantId: TENANT_ID }
216
163
  request.query = {}
217
164
  request.request = {
218
165
  body,
@@ -228,15 +175,15 @@ class TestConfiguration {
228
175
 
229
176
  // USER / AUTH
230
177
  async globalUser({
231
- id = this.defaultUserValues.globalUserId,
232
- firstName = this.defaultUserValues.firstName,
233
- lastName = this.defaultUserValues.lastName,
178
+ id = GLOBAL_USER_ID,
179
+ firstName = FIRSTNAME,
180
+ lastName = LASTNAME,
234
181
  builder = true,
235
182
  admin = false,
236
- email = this.defaultUserValues.email,
183
+ email = EMAIL,
237
184
  roles,
238
185
  }: any = {}) {
239
- return tenancy.doWithGlobalDB(this.getTenantId(), async (db: Database) => {
186
+ return tenancy.doWithGlobalDB(TENANT_ID, async (db: any) => {
240
187
  let existing
241
188
  try {
242
189
  existing = await db.get(id)
@@ -247,14 +194,14 @@ class TestConfiguration {
247
194
  _id: id,
248
195
  ...existing,
249
196
  roles: roles || {},
250
- tenantId: this.getTenantId(),
197
+ tenantId: TENANT_ID,
251
198
  firstName,
252
199
  lastName,
253
200
  }
254
201
  await sessions.createASession(id, {
255
202
  sessionId: "sessionid",
256
- tenantId: this.getTenantId(),
257
- csrfToken: this.defaultUserValues.csrfToken,
203
+ tenantId: TENANT_ID,
204
+ csrfToken: CSRF_TOKEN,
258
205
  })
259
206
  if (builder) {
260
207
  user.builder = { global: true }
@@ -268,31 +215,21 @@ class TestConfiguration {
268
215
  }
269
216
  const resp = await db.put(user)
270
217
  return {
271
- _rev: resp.rev,
218
+ _rev: resp._rev,
272
219
  ...user,
273
220
  }
274
221
  })
275
222
  }
276
223
 
277
224
  async createUser(
278
- user: {
279
- id?: string
280
- firstName?: string
281
- lastName?: string
282
- email?: string
283
- builder?: boolean
284
- admin?: boolean
285
- roles?: any
286
- } = {}
225
+ id = null,
226
+ firstName = FIRSTNAME,
227
+ lastName = LASTNAME,
228
+ email = EMAIL,
229
+ builder = true,
230
+ admin = false,
231
+ roles = {}
287
232
  ) {
288
- let { id, firstName, lastName, email, builder, admin, roles } = user
289
- firstName = firstName || this.defaultUserValues.firstName
290
- lastName = lastName || this.defaultUserValues.lastName
291
- email = email || this.defaultUserValues.email
292
- roles = roles || {}
293
- if (builder == null) {
294
- builder = true
295
- }
296
233
  const globalId = !id ? `us_${Math.random()}` : `us_${id}`
297
234
  const resp = await this.globalUser({
298
235
  id: globalId,
@@ -327,13 +264,13 @@ class TestConfiguration {
327
264
  }
328
265
  await sessions.createASession(userId, {
329
266
  sessionId: "sessionid",
330
- tenantId: this.getTenantId(),
267
+ tenantId: TENANT_ID,
331
268
  })
332
269
  // have to fake this
333
270
  const authObj = {
334
271
  userId,
335
272
  sessionId: "sessionid",
336
- tenantId: this.getTenantId(),
273
+ tenantId: TENANT_ID,
337
274
  }
338
275
  const app = {
339
276
  roleId: roleId,
@@ -356,11 +293,10 @@ class TestConfiguration {
356
293
  }
357
294
 
358
295
  defaultHeaders(extras = {}) {
359
- const tenantId = this.getTenantId()
360
- const authObj: AuthToken = {
361
- userId: this.defaultUserValues.globalUserId,
296
+ const authObj = {
297
+ userId: GLOBAL_USER_ID,
362
298
  sessionId: "sessionid",
363
- tenantId,
299
+ tenantId: TENANT_ID,
364
300
  }
365
301
  const app = {
366
302
  roleId: roles.BUILTIN_ROLE_IDS.ADMIN,
@@ -374,20 +310,15 @@ class TestConfiguration {
374
310
  `${constants.Cookie.Auth}=${authToken}`,
375
311
  `${constants.Cookie.CurrentApp}=${appToken}`,
376
312
  ],
377
- [constants.Header.CSRF_TOKEN]: this.defaultUserValues.csrfToken,
313
+ [constants.Header.CSRF_TOKEN]: CSRF_TOKEN,
378
314
  ...extras,
379
315
  }
380
-
381
316
  if (this.appId) {
382
317
  headers[constants.Header.APP_ID] = this.appId
383
318
  }
384
319
  return headers
385
320
  }
386
321
 
387
- getTenantId() {
388
- return this.tenantId || TENANT_ID
389
- }
390
-
391
322
  publicHeaders({ prodApp = true } = {}) {
392
323
  const appId = prodApp ? this.prodAppId : this.appId
393
324
 
@@ -397,16 +328,11 @@ class TestConfiguration {
397
328
  if (appId) {
398
329
  headers[constants.Header.APP_ID] = appId
399
330
  }
400
-
401
- if (this.tenantId) {
402
- headers[constants.Header.TENANT_ID] = this.tenantId
403
- }
404
-
405
331
  return headers
406
332
  }
407
333
 
408
334
  async roleHeaders({
409
- email = this.defaultUserValues.email,
335
+ email = EMAIL,
410
336
  roleId = roles.BUILTIN_ROLE_IDS.ADMIN,
411
337
  builder = false,
412
338
  prodApp = true,
@@ -416,8 +342,8 @@ class TestConfiguration {
416
342
 
417
343
  // API
418
344
 
419
- async generateApiKey(userId = this.defaultUserValues.globalUserId) {
420
- return tenancy.doWithGlobalDB(this.getTenantId(), async (db: any) => {
345
+ async generateApiKey(userId = GLOBAL_USER_ID) {
346
+ return tenancy.doWithGlobalDB(TENANT_ID, async (db: any) => {
421
347
  const id = dbCore.generateDevInfoID(userId)
422
348
  let devInfo
423
349
  try {
@@ -426,7 +352,7 @@ class TestConfiguration {
426
352
  devInfo = { _id: id, userId }
427
353
  }
428
354
  devInfo.apiKey = encryption.encrypt(
429
- `${this.getTenantId()}${dbCore.SEPARATOR}${newid()}`
355
+ `${TENANT_ID}${dbCore.SEPARATOR}${newid()}`
430
356
  )
431
357
  await db.put(devInfo)
432
358
  return devInfo.apiKey
@@ -482,13 +408,13 @@ class TestConfiguration {
482
408
 
483
409
  // TABLE
484
410
 
485
- async updateTable(config?: any): Promise<Table> {
411
+ async updateTable(config?: any) {
486
412
  config = config || basicTable()
487
413
  this.table = await this._req(config, null, controllers.table.save)
488
414
  return this.table
489
415
  }
490
416
 
491
- async createTable(config?: Table) {
417
+ async createTable(config?: any) {
492
418
  if (config != null && config._id) {
493
419
  delete config._id
494
420
  }
@@ -532,7 +458,7 @@ class TestConfiguration {
532
458
 
533
459
  // ROW
534
460
 
535
- async createRow(config?: Row): Promise<Row> {
461
+ async createRow(config: any = null) {
536
462
  if (!this.table) {
537
463
  throw "Test requires table to be configured."
538
464
  }
@@ -541,7 +467,7 @@ class TestConfiguration {
541
467
  return this._req(config, { tableId }, controllers.row.save)
542
468
  }
543
469
 
544
- async getRow(tableId: string, rowId: string): Promise<Row> {
470
+ async getRow(tableId: string, rowId: string) {
545
471
  return this._req(null, { tableId, rowId }, controllers.row.find)
546
472
  }
547
473
 
@@ -623,9 +549,7 @@ class TestConfiguration {
623
549
 
624
550
  // DATASOURCE
625
551
 
626
- async createDatasource(config?: {
627
- datasource: Datasource
628
- }): Promise<Datasource> {
552
+ async createDatasource(config?: any) {
629
553
  config = config || basicDatasource()
630
554
  const response = await this._req(config, null, controllers.datasource.save)
631
555
  this.datasource = response.datasource
@@ -646,7 +570,7 @@ class TestConfiguration {
646
570
  return this.createDatasource({
647
571
  datasource: {
648
572
  ...basicDatasource().datasource,
649
- source: SourceName.REST,
573
+ source: "REST",
650
574
  config: cfg || {},
651
575
  },
652
576
  })
@@ -655,7 +579,7 @@ class TestConfiguration {
655
579
  async dynamicVariableDatasource() {
656
580
  let datasource = await this.restDatasource()
657
581
  const basedOnQuery = await this.createQuery({
658
- ...basicQuery(datasource._id!),
582
+ ...basicQuery(datasource._id),
659
583
  fields: {
660
584
  path: "www.google.com",
661
585
  },
@@ -683,7 +607,7 @@ class TestConfiguration {
683
607
  datasource: any,
684
608
  fields: any,
685
609
  params: any,
686
- verb?: string
610
+ verb: string
687
611
  ) {
688
612
  return request
689
613
  .post(`/api/queries/preview`)
@@ -7,8 +7,6 @@ import {
7
7
  Automation,
8
8
  AutomationActionStepId,
9
9
  AutomationTriggerStepId,
10
- Datasource,
11
- SourceName,
12
10
  } from "@budibase/types"
13
11
 
14
12
  const { v4: uuidv4 } = require("uuid")
@@ -209,12 +207,12 @@ export function basicRole() {
209
207
  }
210
208
  }
211
209
 
212
- export function basicDatasource(): { datasource: Datasource } {
210
+ export function basicDatasource() {
213
211
  return {
214
212
  datasource: {
215
213
  type: "datasource",
216
214
  name: "Test",
217
- source: SourceName.POSTGRES,
215
+ source: "POSTGRES",
218
216
  config: {},
219
217
  },
220
218
  }
@@ -257,15 +255,3 @@ export function basicWebhook(automationId: string) {
257
255
  },
258
256
  }
259
257
  }
260
-
261
- export function basicEnvironmentVariable(
262
- name: string,
263
- prod: string,
264
- dev?: string
265
- ) {
266
- return {
267
- name,
268
- production: prod,
269
- development: dev || prod,
270
- }
271
- }
@@ -20,7 +20,6 @@
20
20
  "dist",
21
21
  "src/tests",
22
22
  "src/api/routes/tests/utilities",
23
- "src/api/routes/public/tests/utils.ts",
24
23
  "src/automations/tests/utilities",
25
24
  "**/*.spec.ts",
26
25
  "**/*.spec.js"
package/dist/ddApm.js DELETED
@@ -1,11 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const dd_trace_1 = __importDefault(require("dd-trace"));
7
- // enable APM if configured
8
- if (process.env.DD_APM_ENABLED) {
9
- console.log("Starting dd-trace");
10
- dd_trace_1.default.init();
11
- }
@@ -1,14 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const elastic_apm_node_1 = __importDefault(require("elastic-apm-node"));
7
- // enable APM if configured
8
- if (process.env.ELASTIC_APM_ENABLED) {
9
- console.log("Starting elastic-apm-node");
10
- elastic_apm_node_1.default.start({
11
- serviceName: process.env.SERVICE,
12
- environment: process.env.BUDIBASE_ENVIRONMENT,
13
- });
14
- }
@@ -1,30 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.retry = void 0;
13
- function retry(fn, maxTry = 5, retryCount = 1) {
14
- return __awaiter(this, void 0, void 0, function* () {
15
- const currRetry = typeof retryCount === "number" ? retryCount : 1;
16
- try {
17
- const result = yield fn();
18
- return result;
19
- }
20
- catch (e) {
21
- console.log(`Retry ${currRetry} failed.`);
22
- if (currRetry > maxTry) {
23
- console.log(`All ${maxTry} retry attempts exhausted`);
24
- throw e;
25
- }
26
- return retry(fn, maxTry, currRetry + 1);
27
- }
28
- });
29
- }
30
- exports.retry = retry;
@@ -1,8 +0,0 @@
1
- const { join } = require("path")
2
- require("dotenv").config({
3
- path: join(__dirname, "..", "..", "hosting", ".env"),
4
- })
5
-
6
- const jestTestcontainersConfigGenerator = require("../../jestTestcontainersConfigGenerator")
7
-
8
- module.exports = jestTestcontainersConfigGenerator()
@@ -1,24 +0,0 @@
1
- #!/bin/node
2
- const { createApp } = require("./utils")
3
-
4
- const APP_COUNT = 100
5
-
6
- if (!process.argv[2]) {
7
- console.error("Please specify an API key as script argument.")
8
- process.exit(-1)
9
- }
10
-
11
- async function run() {
12
- for (let i = 0; i < APP_COUNT; i++) {
13
- const app = await createApp(process.argv[2])
14
- console.log(`App created: ${app._id}`)
15
- }
16
- }
17
-
18
- run()
19
- .then(() => {
20
- console.log(`Finished creating ${APP_COUNT} apps.`)
21
- })
22
- .catch(err => {
23
- console.error(err)
24
- })
@@ -1,30 +0,0 @@
1
- #!/bin/node
2
- const { createApp, getTable, createRow } = require("./utils")
3
-
4
- const ROW_COUNT = 1000
5
-
6
- if (!process.argv[2]) {
7
- console.error("Please specify an API key as script argument.")
8
- process.exit(-1)
9
- }
10
-
11
- async function run() {
12
- const apiKey = process.argv[2]
13
- const app = await createApp(apiKey)
14
- console.log(`App created: ${app._id}`)
15
- const table = await getTable(apiKey, app._id)
16
- console.log(`Table found: ${table.name}`)
17
- const promises = []
18
- for (let i = 0; i < ROW_COUNT; i++) {
19
- promises.push(await createRow(apiKey, app._id, table))
20
- }
21
- await Promise.all(promises)
22
- }
23
-
24
- run()
25
- .then(() => {
26
- console.log(`Finished creating ${ROW_COUNT} rows.`)
27
- })
28
- .catch(err => {
29
- console.error(err)
30
- })
@@ -1,66 +0,0 @@
1
- const fetch = require("node-fetch")
2
- const uuid = require("uuid/v4")
3
-
4
- const URL_APP = "http://localhost:10000/api/public/v1/applications"
5
- const URL_TABLE = "http://localhost:10000/api/public/v1/tables/search"
6
-
7
- async function request(apiKey, url, method, body, appId = undefined) {
8
- const headers = {
9
- "x-budibase-api-key": apiKey,
10
- "Content-Type": "application/json",
11
- }
12
- if (appId) {
13
- headers["x-budibase-app-id"] = appId
14
- }
15
- const res = await fetch(url, {
16
- method,
17
- headers,
18
- body: JSON.stringify(body),
19
- })
20
- if (res.status !== 200) {
21
- throw new Error(await res.text())
22
- }
23
- return res
24
- }
25
-
26
- exports.createApp = async apiKey => {
27
- const name = uuid().replace(/-/g, "")
28
- const body = {
29
- name,
30
- url: `/${name}`,
31
- useTemplate: "true",
32
- templateKey: "app/school-admin-panel",
33
- templateName: "School Admin Panel",
34
- }
35
- const res = await request(apiKey, URL_APP, "POST", body)
36
- const json = await res.json()
37
- return json.data
38
- }
39
-
40
- exports.getTable = async (apiKey, appId) => {
41
- const res = await request(apiKey, URL_TABLE, "POST", {}, appId)
42
- const json = await res.json()
43
- return json.data[0]
44
- }
45
-
46
- exports.createRow = async (apiKey, appId, table) => {
47
- const body = {}
48
- for (let [key, schema] of Object.entries(table.schema)) {
49
- let fake
50
- switch (schema.type) {
51
- default:
52
- case "string":
53
- fake = schema.constraints.inclusion
54
- ? schema.constraints.inclusion[0]
55
- : "a"
56
- break
57
- case "number":
58
- fake = 1
59
- break
60
- }
61
- body[key] = fake
62
- }
63
- const url = `http://localhost:10000/api/public/v1/tables/${table._id}/rows`
64
- const res = await request(apiKey, url, "POST", body, appId)
65
- return (await res.json()).data
66
- }