@budibase/server 2.2.12-alpha.5 → 2.2.13

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 (464) hide show
  1. package/__mocks__/aws-sdk.ts +0 -19
  2. package/__mocks__/node-fetch.ts +0 -78
  3. package/builder/assets/{index.fa480d5b.css → index.9cb087df.css} +2 -2
  4. package/builder/assets/{index.d930bfc5.js → index.ef02c146.js} +369 -372
  5. package/builder/index.html +2 -2
  6. package/coverage/clover.xml +5094 -5122
  7. package/coverage/coverage-final.json +265 -268
  8. package/coverage/lcov-report/index.html +215 -215
  9. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +7 -7
  10. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +5 -5
  11. package/coverage/lcov-report/src/api/controllers/application.ts.html +183 -258
  12. package/coverage/lcov-report/src/api/controllers/auth.ts.html +11 -11
  13. package/coverage/lcov-report/src/api/controllers/automation.ts.html +51 -51
  14. package/coverage/lcov-report/src/api/controllers/backup.ts.html +6 -6
  15. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +79 -91
  16. package/coverage/lcov-report/src/api/controllers/component.ts.html +5 -5
  17. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +30 -30
  18. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +14 -17
  19. package/coverage/lcov-report/src/api/controllers/deploy/index.html +19 -19
  20. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +195 -141
  21. package/coverage/lcov-report/src/api/controllers/dev.ts.html +18 -18
  22. package/coverage/lcov-report/src/api/controllers/index.html +51 -51
  23. package/coverage/lcov-report/src/api/controllers/integration.ts.html +4 -4
  24. package/coverage/lcov-report/src/api/controllers/layout.ts.html +6 -6
  25. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +9 -9
  26. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +4 -4
  27. package/coverage/lcov-report/src/api/controllers/permission.ts.html +13 -13
  28. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +19 -19
  29. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +63 -63
  30. package/coverage/lcov-report/src/api/controllers/plugin/index.html +72 -72
  31. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +135 -150
  32. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +55 -55
  33. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +11 -11
  34. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +18 -18
  35. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +20 -20
  36. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +16 -67
  37. package/coverage/lcov-report/src/api/controllers/public/index.html +15 -15
  38. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +2 -2
  39. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +1 -1
  40. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +7 -7
  41. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +2 -2
  42. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +2 -2
  43. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +2 -2
  44. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +2 -2
  45. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +6 -6
  46. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +10 -10
  47. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +9 -9
  48. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +11 -11
  49. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +6 -6
  50. package/coverage/lcov-report/src/api/controllers/query/import/index.html +1 -1
  51. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +8 -8
  52. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +1 -1
  53. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +8 -8
  54. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +5 -5
  55. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +8 -8
  56. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +1 -1
  57. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +10 -10
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +14 -14
  59. package/coverage/lcov-report/src/api/controllers/query/index.html +19 -19
  60. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +60 -60
  61. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +9 -9
  62. package/coverage/lcov-report/src/api/controllers/role.ts.html +8 -8
  63. package/coverage/lcov-report/src/api/controllers/routing.ts.html +6 -6
  64. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +15 -12
  65. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +20 -20
  66. package/coverage/lcov-report/src/api/controllers/row/index.html +1 -1
  67. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +14 -14
  68. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +52 -55
  69. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +9 -9
  70. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +12 -21
  71. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +14 -17
  72. package/coverage/lcov-report/src/api/controllers/screen.ts.html +26 -26
  73. package/coverage/lcov-report/src/api/controllers/script.ts.html +18 -18
  74. package/coverage/lcov-report/src/api/controllers/static/index.html +11 -11
  75. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +44 -32
  76. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +10 -10
  77. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +14 -14
  78. package/coverage/lcov-report/src/api/controllers/table/index.html +19 -19
  79. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +14 -14
  80. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +17 -17
  81. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +70 -52
  82. package/coverage/lcov-report/src/api/controllers/templates.ts.html +7 -7
  83. package/coverage/lcov-report/src/api/controllers/user.ts.html +119 -119
  84. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +4 -4
  85. package/coverage/lcov-report/src/api/controllers/view/index.html +24 -24
  86. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +77 -59
  87. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +22 -22
  88. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +69 -51
  89. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +14 -14
  90. package/coverage/lcov-report/src/api/index.html +1 -1
  91. package/coverage/lcov-report/src/api/index.ts.html +33 -33
  92. package/coverage/lcov-report/src/api/routes/analytics.ts.html +7 -7
  93. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +8 -8
  94. package/coverage/lcov-report/src/api/routes/application.ts.html +11 -44
  95. package/coverage/lcov-report/src/api/routes/auth.ts.html +6 -6
  96. package/coverage/lcov-report/src/api/routes/automation.ts.html +11 -11
  97. package/coverage/lcov-report/src/api/routes/backup.ts.html +8 -8
  98. package/coverage/lcov-report/src/api/routes/cloud.ts.html +8 -8
  99. package/coverage/lcov-report/src/api/routes/component.ts.html +8 -8
  100. package/coverage/lcov-report/src/api/routes/datasource.ts.html +9 -9
  101. package/coverage/lcov-report/src/api/routes/deploy.ts.html +11 -8
  102. package/coverage/lcov-report/src/api/routes/dev.ts.html +13 -13
  103. package/coverage/lcov-report/src/api/routes/index.html +7 -7
  104. package/coverage/lcov-report/src/api/routes/index.ts.html +37 -40
  105. package/coverage/lcov-report/src/api/routes/integration.ts.html +8 -8
  106. package/coverage/lcov-report/src/api/routes/layout.ts.html +8 -8
  107. package/coverage/lcov-report/src/api/routes/metadata.ts.html +9 -9
  108. package/coverage/lcov-report/src/api/routes/migrations.ts.html +7 -7
  109. package/coverage/lcov-report/src/api/routes/permission.ts.html +9 -9
  110. package/coverage/lcov-report/src/api/routes/plugin.ts.html +8 -8
  111. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +14 -146
  112. package/coverage/lcov-report/src/api/routes/public/index.html +7 -7
  113. package/coverage/lcov-report/src/api/routes/public/index.ts.html +52 -52
  114. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +15 -15
  115. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +16 -28
  116. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +9 -9
  117. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +12 -12
  118. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +12 -12
  119. package/coverage/lcov-report/src/api/routes/public/tests/index.html +1 -1
  120. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +1 -1
  121. package/coverage/lcov-report/src/api/routes/public/users.ts.html +12 -12
  122. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +19 -19
  123. package/coverage/lcov-report/src/api/routes/public/utils/index.html +1 -1
  124. package/coverage/lcov-report/src/api/routes/query.ts.html +11 -11
  125. package/coverage/lcov-report/src/api/routes/role.ts.html +9 -9
  126. package/coverage/lcov-report/src/api/routes/routing.ts.html +8 -8
  127. package/coverage/lcov-report/src/api/routes/row.ts.html +11 -11
  128. package/coverage/lcov-report/src/api/routes/screen.ts.html +9 -9
  129. package/coverage/lcov-report/src/api/routes/script.ts.html +1 -1
  130. package/coverage/lcov-report/src/api/routes/static.ts.html +14 -14
  131. package/coverage/lcov-report/src/api/routes/table.ts.html +11 -11
  132. package/coverage/lcov-report/src/api/routes/templates.ts.html +8 -8
  133. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +15 -15
  134. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +1 -1
  135. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +24 -24
  136. package/coverage/lcov-report/src/api/routes/user.ts.html +9 -9
  137. package/coverage/lcov-report/src/api/routes/utils/index.html +1 -1
  138. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +42 -42
  139. package/coverage/lcov-report/src/api/routes/view.ts.html +10 -10
  140. package/coverage/lcov-report/src/api/routes/webhook.ts.html +10 -10
  141. package/coverage/lcov-report/src/app.ts.html +32 -32
  142. package/coverage/lcov-report/src/automations/actions.ts.html +25 -25
  143. package/coverage/lcov-report/src/automations/automationUtils.ts.html +19 -91
  144. package/coverage/lcov-report/src/automations/bullboard.ts.html +11 -11
  145. package/coverage/lcov-report/src/automations/index.html +19 -19
  146. package/coverage/lcov-report/src/automations/index.ts.html +13 -13
  147. package/coverage/lcov-report/src/automations/logging/index.html +1 -1
  148. package/coverage/lcov-report/src/automations/logging/index.ts.html +11 -11
  149. package/coverage/lcov-report/src/automations/steps/bash.ts.html +34 -34
  150. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +7 -7
  151. package/coverage/lcov-report/src/automations/steps/delay.ts.html +5 -5
  152. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +7 -7
  153. package/coverage/lcov-report/src/automations/steps/discord.ts.html +33 -33
  154. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +35 -35
  155. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +31 -31
  156. package/coverage/lcov-report/src/automations/steps/filter.ts.html +6 -6
  157. package/coverage/lcov-report/src/automations/steps/index.html +83 -83
  158. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +6 -6
  159. package/coverage/lcov-report/src/automations/steps/loop.ts.html +3 -3
  160. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +14 -14
  161. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +17 -17
  162. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +28 -28
  163. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +18 -18
  164. package/coverage/lcov-report/src/automations/steps/slack.ts.html +6 -6
  165. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +7 -7
  166. package/coverage/lcov-report/src/automations/steps/utils.ts.html +16 -16
  167. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +22 -22
  168. package/coverage/lcov-report/src/automations/tests/utilities/index.html +5 -5
  169. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +26 -26
  170. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +3 -3
  171. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +3 -3
  172. package/coverage/lcov-report/src/automations/triggerInfo/index.html +1 -1
  173. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +8 -8
  174. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +3 -3
  175. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +3 -3
  176. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +3 -3
  177. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +3 -3
  178. package/coverage/lcov-report/src/automations/triggers.ts.html +21 -21
  179. package/coverage/lcov-report/src/automations/utils.ts.html +56 -56
  180. package/coverage/lcov-report/src/constants/index.html +1 -1
  181. package/coverage/lcov-report/src/constants/index.ts.html +92 -92
  182. package/coverage/lcov-report/src/constants/layouts.ts.html +4 -4
  183. package/coverage/lcov-report/src/constants/screens.ts.html +5 -5
  184. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +23 -23
  185. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +2 -2
  186. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +2 -2
  187. package/coverage/lcov-report/src/db/defaultData/index.html +1 -1
  188. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +2 -2
  189. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +2 -2
  190. package/coverage/lcov-report/src/db/dynamoClient.ts.html +16 -16
  191. package/coverage/lcov-report/src/db/inMemoryView.ts.html +5 -5
  192. package/coverage/lcov-report/src/db/index.html +19 -19
  193. package/coverage/lcov-report/src/db/index.ts.html +9 -9
  194. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +8 -8
  195. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +4 -4
  196. package/coverage/lcov-report/src/db/linkedRows/index.html +1 -1
  197. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +15 -15
  198. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +12 -12
  199. package/coverage/lcov-report/src/db/newid.ts.html +4 -4
  200. package/coverage/lcov-report/src/db/utils.ts.html +80 -80
  201. package/coverage/lcov-report/src/definitions/automations.ts.html +4 -4
  202. package/coverage/lcov-report/src/definitions/datasource.ts.html +4 -4
  203. package/coverage/lcov-report/src/definitions/index.html +1 -1
  204. package/coverage/lcov-report/src/environment.ts.html +28 -40
  205. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +6 -6
  206. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +5 -5
  207. package/coverage/lcov-report/src/events/index.html +1 -1
  208. package/coverage/lcov-report/src/events/index.ts.html +4 -4
  209. package/coverage/lcov-report/src/events/utils.ts.html +3 -3
  210. package/coverage/lcov-report/src/index.html +25 -25
  211. package/coverage/lcov-report/src/index.ts.html +1 -1
  212. package/coverage/lcov-report/src/integrations/airtable.ts.html +5 -5
  213. package/coverage/lcov-report/src/integrations/arangodb.ts.html +5 -5
  214. package/coverage/lcov-report/src/integrations/base/index.html +1 -1
  215. package/coverage/lcov-report/src/integrations/base/query.ts.html +3 -3
  216. package/coverage/lcov-report/src/integrations/base/sql.ts.html +14 -14
  217. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +8 -8
  218. package/coverage/lcov-report/src/integrations/base/utils.ts.html +3 -3
  219. package/coverage/lcov-report/src/integrations/couchdb.ts.html +5 -5
  220. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +6 -6
  221. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +5 -5
  222. package/coverage/lcov-report/src/integrations/firebase.ts.html +5 -5
  223. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +12 -12
  224. package/coverage/lcov-report/src/integrations/index.html +5 -5
  225. package/coverage/lcov-report/src/integrations/index.ts.html +47 -35
  226. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +8 -8
  227. package/coverage/lcov-report/src/integrations/mongodb.ts.html +5 -5
  228. package/coverage/lcov-report/src/integrations/mysql.ts.html +10 -10
  229. package/coverage/lcov-report/src/integrations/oracle.ts.html +13 -13
  230. package/coverage/lcov-report/src/integrations/postgres.ts.html +42 -42
  231. package/coverage/lcov-report/src/integrations/queries/index.html +1 -1
  232. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +13 -13
  233. package/coverage/lcov-report/src/integrations/redis.ts.html +5 -5
  234. package/coverage/lcov-report/src/integrations/rest.ts.html +16 -16
  235. package/coverage/lcov-report/src/integrations/s3.ts.html +6 -6
  236. package/coverage/lcov-report/src/integrations/snowflake.ts.html +5 -5
  237. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
  238. package/coverage/lcov-report/src/integrations/tests/index.html +1 -1
  239. package/coverage/lcov-report/src/integrations/utils.ts.html +36 -36
  240. package/coverage/lcov-report/src/middleware/appInfo.ts.html +7 -7
  241. package/coverage/lcov-report/src/middleware/authorized.ts.html +28 -28
  242. package/coverage/lcov-report/src/middleware/builder.ts.html +17 -17
  243. package/coverage/lcov-report/src/middleware/currentapp.ts.html +39 -39
  244. package/coverage/lcov-report/src/middleware/index.html +1 -1
  245. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +1 -1
  246. package/coverage/lcov-report/src/middleware/publicApi.ts.html +4 -4
  247. package/coverage/lcov-report/src/middleware/resourceId.ts.html +22 -22
  248. package/coverage/lcov-report/src/middleware/selfhost.ts.html +1 -1
  249. package/coverage/lcov-report/src/middleware/utils.ts.html +4 -4
  250. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +4 -4
  251. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +5 -5
  252. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +5 -5
  253. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +1 -1
  254. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +5 -5
  255. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +7 -7
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +5 -5
  257. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +5 -5
  258. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +4 -4
  259. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +19 -19
  260. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +10 -13
  261. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +1 -1
  262. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +7 -7
  263. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +6 -6
  264. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +15 -15
  265. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +1 -1
  266. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +5 -5
  267. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +8 -8
  268. package/coverage/lcov-report/src/migrations/functions/index.html +1 -1
  269. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +6 -6
  270. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +6 -6
  271. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +1 -1
  272. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +2 -2
  273. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +5 -5
  274. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +4 -4
  275. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +6 -6
  276. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +3 -3
  277. package/coverage/lcov-report/src/migrations/index.html +1 -1
  278. package/coverage/lcov-report/src/migrations/index.ts.html +32 -32
  279. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +1 -1
  280. package/coverage/lcov-report/src/migrations/tests/index.html +1 -1
  281. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +1 -1
  282. package/coverage/lcov-report/src/sdk/app/applications/index.html +15 -15
  283. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +4 -4
  284. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +34 -34
  285. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +9 -9
  286. package/coverage/lcov-report/src/sdk/app/automations/index.html +1 -1
  287. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +3 -3
  288. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +6 -6
  289. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +3 -3
  290. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +17 -17
  291. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +53 -41
  292. package/coverage/lcov-report/src/sdk/app/backups/index.html +28 -28
  293. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +5 -5
  294. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +73 -73
  295. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +6 -6
  296. package/coverage/lcov-report/src/sdk/app/rows/index.html +1 -1
  297. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +4 -4
  298. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +4 -4
  299. package/coverage/lcov-report/src/sdk/app/tables/index.html +1 -1
  300. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +5 -5
  301. package/coverage/lcov-report/src/sdk/index.html +1 -1
  302. package/coverage/lcov-report/src/sdk/index.ts.html +9 -9
  303. package/coverage/lcov-report/src/sdk/users/index.html +5 -5
  304. package/coverage/lcov-report/src/sdk/users/index.ts.html +3 -3
  305. package/coverage/lcov-report/src/sdk/users/utils.ts.html +34 -34
  306. package/coverage/lcov-report/src/startup.ts.html +42 -42
  307. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +125 -182
  308. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +15 -15
  309. package/coverage/lcov-report/src/tests/utilities/index.html +15 -15
  310. package/coverage/lcov-report/src/tests/utilities/index.ts.html +1 -1
  311. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +30 -30
  312. package/coverage/lcov-report/src/threads/automation.ts.html +103 -34
  313. package/coverage/lcov-report/src/threads/index.html +19 -19
  314. package/coverage/lcov-report/src/threads/index.ts.html +25 -25
  315. package/coverage/lcov-report/src/threads/query.ts.html +71 -71
  316. package/coverage/lcov-report/src/threads/utils.ts.html +18 -18
  317. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +3 -3
  318. package/coverage/lcov-report/src/utilities/centralPath.ts.html +4 -4
  319. package/coverage/lcov-report/src/utilities/csvParser.ts.html +8 -8
  320. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +12 -12
  321. package/coverage/lcov-report/src/utilities/fileSystem/index.html +19 -79
  322. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +1049 -20
  323. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +1 -1
  324. package/coverage/lcov-report/src/utilities/global.ts.html +43 -43
  325. package/coverage/lcov-report/src/utilities/index.html +63 -48
  326. package/coverage/lcov-report/src/utilities/index.ts.html +168 -36
  327. package/coverage/lcov-report/src/utilities/plugins.ts.html +151 -0
  328. package/coverage/lcov-report/src/utilities/redis.ts.html +32 -32
  329. package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
  330. package/coverage/lcov-report/src/utilities/routing/index.ts.html +5 -5
  331. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +28 -28
  332. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +33 -60
  333. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +3 -3
  334. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +38 -38
  335. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +32 -32
  336. package/coverage/lcov-report/src/utilities/security.ts.html +6 -6
  337. package/coverage/lcov-report/src/utilities/statusCodes.ts.html +1 -1
  338. package/coverage/lcov-report/src/utilities/usageQuota/index.html +1 -1
  339. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +35 -35
  340. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +1 -1
  341. package/coverage/lcov-report/src/utilities/users.ts.html +6 -6
  342. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +56 -56
  343. package/coverage/lcov-report/src/watch.ts.html +9 -9
  344. package/coverage/lcov-report/src/websocket.ts.html +15 -15
  345. package/coverage/lcov.info +7320 -7367
  346. package/dist/api/controllers/application.js +35 -47
  347. package/dist/api/controllers/cloud.js +2 -6
  348. package/dist/api/controllers/deploy/index.js +60 -43
  349. package/dist/api/controllers/plugin/index.js +6 -6
  350. package/dist/api/controllers/public/applications.js +1 -22
  351. package/dist/api/controllers/row/ExternalRequest.js +1 -0
  352. package/dist/api/controllers/row/internal.js +12 -12
  353. package/dist/api/controllers/row/staticFormula.js +1 -1
  354. package/dist/api/controllers/static/index.js +11 -8
  355. package/dist/api/controllers/table/utils.js +2 -1
  356. package/dist/api/controllers/view/index.js +6 -5
  357. package/dist/api/controllers/view/viewBuilder.js +8 -2
  358. package/dist/api/routes/application.js +0 -3
  359. package/dist/api/routes/deploy.js +2 -1
  360. package/dist/api/routes/public/applications.js +0 -37
  361. package/dist/api/routes/public/middleware/mapper.js +0 -3
  362. package/dist/api/routes/tests/utilities/TestFunctions.js +167 -0
  363. package/dist/api/routes/tests/utilities/index.js +131 -0
  364. package/dist/automations/automationUtils.js +1 -26
  365. package/dist/automations/tests/utilities/index.js +81 -0
  366. package/dist/environment.js +1 -5
  367. package/dist/integrations/googlesheets.js +1 -1
  368. package/dist/integrations/index.js +2 -1
  369. package/dist/migrations/functions/backfill/global/configs.js +4 -4
  370. package/dist/package.json +7 -9
  371. package/dist/sdk/app/backups/imports.js +6 -2
  372. package/dist/tests/utilities/TestConfiguration.js +562 -0
  373. package/dist/tests/utilities/controllers.js +40 -0
  374. package/dist/tests/utilities/structures.js +168 -0
  375. package/dist/threads/automation.js +28 -4
  376. package/dist/tsconfig.build.tsbuildinfo +1 -1
  377. package/dist/utilities/fileSystem/clientLibrary.js +3 -3
  378. package/dist/utilities/fileSystem/index.js +342 -18
  379. package/dist/utilities/index.js +44 -1
  380. package/dist/utilities/plugins.js +26 -0
  381. package/dist/utilities/rowProcessor/index.js +4 -12
  382. package/package.json +8 -10
  383. package/scripts/dev/manage.js +16 -0
  384. package/specs/openapi.json +0 -84
  385. package/specs/openapi.yaml +0 -53
  386. package/specs/resources/application.js +0 -19
  387. package/src/api/controllers/application.ts +36 -61
  388. package/src/api/controllers/auth.ts +2 -2
  389. package/src/api/controllers/cloud.ts +6 -10
  390. package/src/api/controllers/deploy/Deployment.ts +0 -1
  391. package/src/api/controllers/deploy/index.ts +58 -40
  392. package/src/api/controllers/plugin/index.ts +9 -14
  393. package/src/api/controllers/public/applications.ts +0 -17
  394. package/src/api/controllers/row/ExternalRequest.ts +1 -0
  395. package/src/api/controllers/row/internal.ts +23 -24
  396. package/src/api/controllers/row/staticFormula.ts +2 -5
  397. package/src/api/controllers/row/utils.ts +1 -2
  398. package/src/api/controllers/static/index.ts +10 -6
  399. package/src/api/controllers/table/utils.ts +7 -1
  400. package/src/api/controllers/view/index.ts +11 -5
  401. package/src/api/controllers/view/viewBuilder.ts +14 -8
  402. package/src/api/routes/application.ts +0 -11
  403. package/src/api/routes/deploy.ts +1 -0
  404. package/src/api/routes/index.ts +3 -4
  405. package/src/api/routes/public/applications.ts +0 -44
  406. package/src/api/routes/public/middleware/mapper.ts +0 -4
  407. package/src/api/routes/tests/__snapshots__/{datasource.spec.ts.snap → datasource.spec.js.snap} +0 -0
  408. package/src/api/routes/tests/{application.spec.ts → application.spec.js} +18 -94
  409. package/src/api/routes/tests/{backup.spec.ts → backup.spec.js} +6 -17
  410. package/src/api/routes/tests/{datasource.spec.ts → datasource.spec.js} +15 -23
  411. package/src/api/routes/tests/deployment.spec.ts +25 -0
  412. package/src/api/routes/tests/permissions.spec.js +1 -1
  413. package/src/api/routes/tests/routing.spec.js +2 -1
  414. package/src/api/routes/tests/row.spec.js +2 -4
  415. package/src/api/routes/tests/static.spec.js +17 -2
  416. package/src/api/routes/tests/table.spec.js +2 -8
  417. package/src/api/routes/tests/user.spec.js +0 -86
  418. package/src/api/routes/tests/utilities/index.ts +2 -2
  419. package/src/api/routes/tests/webhook.spec.js +1 -1
  420. package/src/automations/automationUtils.ts +0 -24
  421. package/src/automations/tests/utilities/index.ts +2 -2
  422. package/src/automations/unitTests/automationUtils.spec.js +17 -0
  423. package/src/definitions/openapi.ts +0 -10
  424. package/src/environment.ts +1 -5
  425. package/src/integrations/googlesheets.ts +1 -1
  426. package/src/integrations/index.ts +5 -1
  427. package/src/migrations/functions/backfill/global/configs.ts +4 -5
  428. package/src/sdk/app/backups/imports.ts +6 -2
  429. package/src/sdk/tests/attachments.spec.ts +4 -1
  430. package/src/tests/jestSetup.ts +1 -4
  431. package/src/tests/utilities/TestConfiguration.ts +4 -23
  432. package/src/threads/automation.ts +27 -4
  433. package/src/utilities/fileSystem/clientLibrary.ts +1 -1
  434. package/src/utilities/fileSystem/index.ts +348 -5
  435. package/src/utilities/index.ts +45 -1
  436. package/src/utilities/plugins.ts +22 -0
  437. package/src/utilities/rowProcessor/index.ts +8 -17
  438. package/tsconfig.build.json +0 -2
  439. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  440. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -595
  441. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -280
  442. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  443. package/dist/utilities/fileSystem/app.js +0 -97
  444. package/dist/utilities/fileSystem/filesystem.js +0 -182
  445. package/dist/utilities/fileSystem/plugin.js +0 -63
  446. package/dist/utilities/fileSystem/template.js +0 -44
  447. package/src/api/routes/tests/cloud.spec.ts +0 -65
  448. package/src/api/routes/tests/data/budibase-component-1.0.1.tgz +0 -0
  449. package/src/api/routes/tests/data/comment-box-1.0.2.tar.gz +0 -0
  450. package/src/api/routes/tests/data/export-test.tar.gz +0 -0
  451. package/src/api/routes/tests/plugin.spec.ts +0 -179
  452. package/src/automations/tests/bash.spec.js +0 -34
  453. package/src/automations/tests/discord.spec.js +0 -27
  454. package/src/automations/tests/executeQuery.spec.js +0 -49
  455. package/src/automations/tests/executeScript.spec.js +0 -48
  456. package/src/automations/tests/sendSmtpEmail.spec.js +0 -71
  457. package/src/automations/tests/serverLog.spec.js +0 -22
  458. package/src/automations/tests/zapier.spec.js +0 -27
  459. package/src/automations/unitTests/automationUtils.spec.ts +0 -65
  460. package/src/utilities/fileSystem/app.ts +0 -86
  461. package/src/utilities/fileSystem/filesystem.ts +0 -170
  462. package/src/utilities/fileSystem/plugin.ts +0 -65
  463. package/src/utilities/fileSystem/template.ts +0 -36
  464. package/src/utilities/rowProcessor/tests/utils.spec.ts +0 -57
@@ -0,0 +1,562 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
+ return new (P || (P = Promise))(function (resolve, reject) {
28
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
32
+ });
33
+ };
34
+ var __importDefault = (this && this.__importDefault) || function (mod) {
35
+ return (mod && mod.__esModule) ? mod : { "default": mod };
36
+ };
37
+ const db_1 = require("../../db");
38
+ (0, db_1.init)();
39
+ const environment_1 = __importDefault(require("../../environment"));
40
+ const structures_1 = require("./structures");
41
+ const backend_core_1 = require("@budibase/backend-core");
42
+ const controllers = __importStar(require("./controllers"));
43
+ const fileSystem_1 = require("../../utilities/fileSystem");
44
+ const newid_1 = __importDefault(require("../../db/newid"));
45
+ const utils_1 = require("../../db/utils");
46
+ const startup_1 = require("../../startup");
47
+ const supertest = require("supertest");
48
+ const GLOBAL_USER_ID = "us_uuid1";
49
+ const EMAIL = "babs@babs.com";
50
+ const FIRSTNAME = "Barbara";
51
+ const LASTNAME = "Barbington";
52
+ const CSRF_TOKEN = "e3727778-7af0-4226-b5eb-f43cbe60a306";
53
+ class TestConfiguration {
54
+ constructor(openServer = true) {
55
+ if (openServer) {
56
+ // use a random port because it doesn't matter
57
+ environment_1.default.PORT = "0";
58
+ this.server = require("../../app");
59
+ // we need the request for logging in, involves cookies, hard to fake
60
+ this.request = supertest(this.server);
61
+ this.started = true;
62
+ }
63
+ else {
64
+ this.started = false;
65
+ }
66
+ this.appId = null;
67
+ this.allApps = [];
68
+ }
69
+ getRequest() {
70
+ return this.request;
71
+ }
72
+ getApp() {
73
+ return this.app;
74
+ }
75
+ getProdApp() {
76
+ return this.prodApp;
77
+ }
78
+ getAppId() {
79
+ return this.appId;
80
+ }
81
+ getProdAppId() {
82
+ return this.prodAppId;
83
+ }
84
+ getUserDetails() {
85
+ return {
86
+ globalId: GLOBAL_USER_ID,
87
+ email: EMAIL,
88
+ firstName: FIRSTNAME,
89
+ lastName: LASTNAME,
90
+ };
91
+ }
92
+ doInContext(appId, task) {
93
+ return __awaiter(this, void 0, void 0, function* () {
94
+ if (!appId) {
95
+ appId = this.appId;
96
+ }
97
+ return backend_core_1.tenancy.doInTenant(structures_1.TENANT_ID, () => {
98
+ // check if already in a context
99
+ if (backend_core_1.context.getAppId() == null && appId !== null) {
100
+ return backend_core_1.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
101
+ return task();
102
+ }));
103
+ }
104
+ else {
105
+ return task();
106
+ }
107
+ });
108
+ });
109
+ }
110
+ // SETUP / TEARDOWN
111
+ // use a new id as the name to avoid name collisions
112
+ init(appName = (0, newid_1.default)()) {
113
+ return __awaiter(this, void 0, void 0, function* () {
114
+ if (!this.started) {
115
+ yield (0, startup_1.startup)();
116
+ }
117
+ this.user = yield this.globalUser();
118
+ this.globalUserId = this.user._id;
119
+ this.userMetadataId = (0, utils_1.generateUserMetadataID)(this.globalUserId);
120
+ return this.createApp(appName);
121
+ });
122
+ }
123
+ end() {
124
+ if (!this) {
125
+ return;
126
+ }
127
+ if (this.server) {
128
+ this.server.close();
129
+ }
130
+ if (this.allApps) {
131
+ (0, fileSystem_1.cleanup)(this.allApps.map(app => app.appId));
132
+ }
133
+ }
134
+ // UTILS
135
+ _req(body, params, controlFunc) {
136
+ return __awaiter(this, void 0, void 0, function* () {
137
+ // create a fake request ctx
138
+ const request = {};
139
+ const appId = this.appId;
140
+ request.appId = appId;
141
+ // fake cookies, we don't need them
142
+ request.cookies = { set: () => { }, get: () => { } };
143
+ request.config = { jwtSecret: environment_1.default.JWT_SECRET };
144
+ request.user = { appId, tenantId: structures_1.TENANT_ID };
145
+ request.query = {};
146
+ request.request = {
147
+ body,
148
+ };
149
+ if (params) {
150
+ request.params = params;
151
+ }
152
+ return this.doInContext(appId, () => __awaiter(this, void 0, void 0, function* () {
153
+ yield controlFunc(request);
154
+ return request.body;
155
+ }));
156
+ });
157
+ }
158
+ // USER / AUTH
159
+ globalUser({ id = GLOBAL_USER_ID, firstName = FIRSTNAME, lastName = LASTNAME, builder = true, admin = false, email = EMAIL, roles, } = {}) {
160
+ return __awaiter(this, void 0, void 0, function* () {
161
+ return backend_core_1.tenancy.doWithGlobalDB(structures_1.TENANT_ID, (db) => __awaiter(this, void 0, void 0, function* () {
162
+ let existing;
163
+ try {
164
+ existing = yield db.get(id);
165
+ }
166
+ catch (err) {
167
+ existing = { email };
168
+ }
169
+ const user = Object.assign(Object.assign({ _id: id }, existing), { roles: roles || {}, tenantId: structures_1.TENANT_ID, firstName,
170
+ lastName });
171
+ yield backend_core_1.sessions.createASession(id, {
172
+ sessionId: "sessionid",
173
+ tenantId: structures_1.TENANT_ID,
174
+ csrfToken: CSRF_TOKEN,
175
+ });
176
+ if (builder) {
177
+ user.builder = { global: true };
178
+ }
179
+ else {
180
+ user.builder = { global: false };
181
+ }
182
+ if (admin) {
183
+ user.admin = { global: true };
184
+ }
185
+ else {
186
+ user.admin = { global: false };
187
+ }
188
+ const resp = yield db.put(user);
189
+ return Object.assign({ _rev: resp._rev }, user);
190
+ }));
191
+ });
192
+ }
193
+ createUser(id = null, firstName = FIRSTNAME, lastName = LASTNAME, email = EMAIL, builder = true, admin = false, roles = {}) {
194
+ return __awaiter(this, void 0, void 0, function* () {
195
+ const globalId = !id ? `us_${Math.random()}` : `us_${id}`;
196
+ const resp = yield this.globalUser({
197
+ id: globalId,
198
+ firstName,
199
+ lastName,
200
+ email,
201
+ builder,
202
+ admin,
203
+ roles,
204
+ });
205
+ yield backend_core_1.cache.user.invalidateUser(globalId);
206
+ return Object.assign(Object.assign({}, resp), { globalId });
207
+ });
208
+ }
209
+ login({ roleId, userId, builder, prodApp = false } = {}) {
210
+ return __awaiter(this, void 0, void 0, function* () {
211
+ const appId = prodApp ? this.prodAppId : this.appId;
212
+ return backend_core_1.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
213
+ userId = !userId ? `us_uuid1` : userId;
214
+ if (!this.request) {
215
+ throw "Server has not been opened, cannot login.";
216
+ }
217
+ // make sure the user exists in the global DB
218
+ if (roleId !== backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC) {
219
+ yield this.globalUser({
220
+ id: userId,
221
+ builder,
222
+ roles: { [this.prodAppId]: roleId },
223
+ });
224
+ }
225
+ yield backend_core_1.sessions.createASession(userId, {
226
+ sessionId: "sessionid",
227
+ tenantId: structures_1.TENANT_ID,
228
+ });
229
+ // have to fake this
230
+ const authObj = {
231
+ userId,
232
+ sessionId: "sessionid",
233
+ tenantId: structures_1.TENANT_ID,
234
+ };
235
+ const app = {
236
+ roleId: roleId,
237
+ appId,
238
+ };
239
+ const authToken = backend_core_1.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
240
+ const appToken = backend_core_1.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
241
+ // returning necessary request headers
242
+ yield backend_core_1.cache.user.invalidateUser(userId);
243
+ return {
244
+ Accept: "application/json",
245
+ Cookie: [
246
+ `${backend_core_1.constants.Cookie.Auth}=${authToken}`,
247
+ `${backend_core_1.constants.Cookie.CurrentApp}=${appToken}`,
248
+ ],
249
+ [backend_core_1.constants.Header.APP_ID]: appId,
250
+ };
251
+ }));
252
+ });
253
+ }
254
+ defaultHeaders(extras = {}) {
255
+ const authObj = {
256
+ userId: GLOBAL_USER_ID,
257
+ sessionId: "sessionid",
258
+ tenantId: structures_1.TENANT_ID,
259
+ };
260
+ const app = {
261
+ roleId: backend_core_1.roles.BUILTIN_ROLE_IDS.ADMIN,
262
+ appId: this.appId,
263
+ };
264
+ const authToken = backend_core_1.auth.jwt.sign(authObj, environment_1.default.JWT_SECRET);
265
+ const appToken = backend_core_1.auth.jwt.sign(app, environment_1.default.JWT_SECRET);
266
+ const headers = Object.assign({ Accept: "application/json", Cookie: [
267
+ `${backend_core_1.constants.Cookie.Auth}=${authToken}`,
268
+ `${backend_core_1.constants.Cookie.CurrentApp}=${appToken}`,
269
+ ], [backend_core_1.constants.Header.CSRF_TOKEN]: CSRF_TOKEN }, extras);
270
+ if (this.appId) {
271
+ headers[backend_core_1.constants.Header.APP_ID] = this.appId;
272
+ }
273
+ return headers;
274
+ }
275
+ publicHeaders({ prodApp = true } = {}) {
276
+ const appId = prodApp ? this.prodAppId : this.appId;
277
+ const headers = {
278
+ Accept: "application/json",
279
+ };
280
+ if (appId) {
281
+ headers[backend_core_1.constants.Header.APP_ID] = appId;
282
+ }
283
+ return headers;
284
+ }
285
+ roleHeaders({ email = EMAIL, roleId = backend_core_1.roles.BUILTIN_ROLE_IDS.ADMIN, builder = false, prodApp = true, } = {}) {
286
+ return __awaiter(this, void 0, void 0, function* () {
287
+ return this.login({ email, roleId, builder, prodApp });
288
+ });
289
+ }
290
+ // API
291
+ generateApiKey(userId = GLOBAL_USER_ID) {
292
+ return __awaiter(this, void 0, void 0, function* () {
293
+ return backend_core_1.tenancy.doWithGlobalDB(structures_1.TENANT_ID, (db) => __awaiter(this, void 0, void 0, function* () {
294
+ const id = backend_core_1.db.generateDevInfoID(userId);
295
+ let devInfo;
296
+ try {
297
+ devInfo = yield db.get(id);
298
+ }
299
+ catch (err) {
300
+ devInfo = { _id: id, userId };
301
+ }
302
+ devInfo.apiKey = backend_core_1.encryption.encrypt(`${structures_1.TENANT_ID}${backend_core_1.db.SEPARATOR}${(0, newid_1.default)()}`);
303
+ yield db.put(devInfo);
304
+ return devInfo.apiKey;
305
+ }));
306
+ });
307
+ }
308
+ // APP
309
+ createApp(appName) {
310
+ return __awaiter(this, void 0, void 0, function* () {
311
+ // create dev app
312
+ // clear any old app
313
+ this.appId = null;
314
+ // @ts-ignore
315
+ yield backend_core_1.context.updateAppId(null);
316
+ this.app = yield this._req({ name: appName }, null, controllers.app.create);
317
+ this.appId = this.app.appId;
318
+ // @ts-ignore
319
+ yield backend_core_1.context.updateAppId(this.appId);
320
+ // create production app
321
+ this.prodApp = yield this.deploy();
322
+ this.allApps.push(this.prodApp);
323
+ this.allApps.push(this.app);
324
+ return this.app;
325
+ });
326
+ }
327
+ deploy() {
328
+ return __awaiter(this, void 0, void 0, function* () {
329
+ yield this._req(null, null, controllers.deploy.deployApp);
330
+ // @ts-ignore
331
+ const prodAppId = this.getAppId().replace("_dev", "");
332
+ this.prodAppId = prodAppId;
333
+ return backend_core_1.context.doInAppContext(prodAppId, () => __awaiter(this, void 0, void 0, function* () {
334
+ const db = backend_core_1.context.getProdAppDB();
335
+ return yield db.get(backend_core_1.db.DocumentType.APP_METADATA);
336
+ }));
337
+ });
338
+ }
339
+ // TABLE
340
+ updateTable(config) {
341
+ return __awaiter(this, void 0, void 0, function* () {
342
+ config = config || (0, structures_1.basicTable)();
343
+ this.table = yield this._req(config, null, controllers.table.save);
344
+ return this.table;
345
+ });
346
+ }
347
+ createTable(config) {
348
+ return __awaiter(this, void 0, void 0, function* () {
349
+ if (config != null && config._id) {
350
+ delete config._id;
351
+ }
352
+ return this.updateTable(config);
353
+ });
354
+ }
355
+ getTable(tableId) {
356
+ return __awaiter(this, void 0, void 0, function* () {
357
+ tableId = tableId || this.table._id;
358
+ return this._req(null, { tableId }, controllers.table.find);
359
+ });
360
+ }
361
+ createLinkedTable(relationshipType, links = ["link"]) {
362
+ return __awaiter(this, void 0, void 0, function* () {
363
+ if (!this.table) {
364
+ throw "Must have created a table first.";
365
+ }
366
+ const tableConfig = (0, structures_1.basicTable)();
367
+ tableConfig.primaryDisplay = "name";
368
+ for (let link of links) {
369
+ tableConfig.schema[link] = {
370
+ type: "link",
371
+ fieldName: link,
372
+ tableId: this.table._id,
373
+ name: link,
374
+ };
375
+ if (relationshipType) {
376
+ tableConfig.schema[link].relationshipType = relationshipType;
377
+ }
378
+ }
379
+ const linkedTable = yield this.createTable(tableConfig);
380
+ this.linkedTable = linkedTable;
381
+ return linkedTable;
382
+ });
383
+ }
384
+ createAttachmentTable() {
385
+ return __awaiter(this, void 0, void 0, function* () {
386
+ const table = (0, structures_1.basicTable)();
387
+ table.schema.attachment = {
388
+ type: "attachment",
389
+ };
390
+ return this.createTable(table);
391
+ });
392
+ }
393
+ // ROW
394
+ createRow(config = null) {
395
+ return __awaiter(this, void 0, void 0, function* () {
396
+ if (!this.table) {
397
+ throw "Test requires table to be configured.";
398
+ }
399
+ const tableId = (config && config.tableId) || this.table._id;
400
+ config = config || (0, structures_1.basicRow)(tableId);
401
+ return this._req(config, { tableId }, controllers.row.save);
402
+ });
403
+ }
404
+ getRow(tableId, rowId) {
405
+ return __awaiter(this, void 0, void 0, function* () {
406
+ return this._req(null, { tableId, rowId }, controllers.row.find);
407
+ });
408
+ }
409
+ getRows(tableId) {
410
+ return __awaiter(this, void 0, void 0, function* () {
411
+ if (!tableId && this.table) {
412
+ tableId = this.table._id;
413
+ }
414
+ return this._req(null, { tableId }, controllers.row.fetch);
415
+ });
416
+ }
417
+ // ROLE
418
+ createRole(config) {
419
+ return __awaiter(this, void 0, void 0, function* () {
420
+ config = config || (0, structures_1.basicRole)();
421
+ return this._req(config, null, controllers.role.save);
422
+ });
423
+ }
424
+ addPermission(roleId, resourceId, level = "read") {
425
+ return __awaiter(this, void 0, void 0, function* () {
426
+ return this._req(null, {
427
+ roleId,
428
+ resourceId,
429
+ level,
430
+ }, controllers.perms.addPermission);
431
+ });
432
+ }
433
+ // VIEW
434
+ createView(config) {
435
+ return __awaiter(this, void 0, void 0, function* () {
436
+ if (!this.table) {
437
+ throw "Test requires table to be configured.";
438
+ }
439
+ const view = config || {
440
+ tableId: this.table._id,
441
+ name: "ViewTest",
442
+ };
443
+ return this._req(view, null, controllers.view.save);
444
+ });
445
+ }
446
+ // AUTOMATION
447
+ createAutomation(config) {
448
+ return __awaiter(this, void 0, void 0, function* () {
449
+ config = config || (0, structures_1.basicAutomation)();
450
+ if (config._rev) {
451
+ delete config._rev;
452
+ }
453
+ this.automation = (yield this._req(config, null, controllers.automation.create)).automation;
454
+ return this.automation;
455
+ });
456
+ }
457
+ getAllAutomations() {
458
+ return __awaiter(this, void 0, void 0, function* () {
459
+ return this._req(null, null, controllers.automation.fetch);
460
+ });
461
+ }
462
+ deleteAutomation(automation) {
463
+ return __awaiter(this, void 0, void 0, function* () {
464
+ automation = automation || this.automation;
465
+ if (!automation) {
466
+ return;
467
+ }
468
+ return this._req(null, { id: automation._id, rev: automation._rev }, controllers.automation.destroy);
469
+ });
470
+ }
471
+ createWebhook(config) {
472
+ return __awaiter(this, void 0, void 0, function* () {
473
+ if (!this.automation) {
474
+ throw "Must create an automation before creating webhook.";
475
+ }
476
+ config = config || (0, structures_1.basicWebhook)(this.automation._id);
477
+ return (yield this._req(config, null, controllers.webhook.save)).webhook;
478
+ });
479
+ }
480
+ // DATASOURCE
481
+ createDatasource(config) {
482
+ return __awaiter(this, void 0, void 0, function* () {
483
+ config = config || (0, structures_1.basicDatasource)();
484
+ const response = yield this._req(config, null, controllers.datasource.save);
485
+ this.datasource = response.datasource;
486
+ return this.datasource;
487
+ });
488
+ }
489
+ updateDatasource(datasource) {
490
+ return __awaiter(this, void 0, void 0, function* () {
491
+ const response = yield this._req(datasource, { datasourceId: datasource._id }, controllers.datasource.update);
492
+ this.datasource = response.datasource;
493
+ return this.datasource;
494
+ });
495
+ }
496
+ restDatasource(cfg) {
497
+ return __awaiter(this, void 0, void 0, function* () {
498
+ return this.createDatasource({
499
+ datasource: Object.assign(Object.assign({}, (0, structures_1.basicDatasource)().datasource), { source: "REST", config: cfg || {} }),
500
+ });
501
+ });
502
+ }
503
+ dynamicVariableDatasource() {
504
+ return __awaiter(this, void 0, void 0, function* () {
505
+ let datasource = yield this.restDatasource();
506
+ const basedOnQuery = yield this.createQuery(Object.assign(Object.assign({}, (0, structures_1.basicQuery)(datasource._id)), { fields: {
507
+ path: "www.google.com",
508
+ } }));
509
+ datasource = yield this.updateDatasource(Object.assign(Object.assign({}, datasource), { config: {
510
+ dynamicVariables: [
511
+ {
512
+ queryId: basedOnQuery._id,
513
+ name: "variable3",
514
+ value: "{{ data.0.[value] }}",
515
+ },
516
+ ],
517
+ } }));
518
+ return { datasource, query: basedOnQuery };
519
+ });
520
+ }
521
+ // QUERY
522
+ previewQuery(request, config, datasource, fields, params, verb) {
523
+ return __awaiter(this, void 0, void 0, function* () {
524
+ return request
525
+ .post(`/api/queries/preview`)
526
+ .send({
527
+ datasourceId: datasource._id,
528
+ parameters: params || {},
529
+ fields,
530
+ queryVerb: verb || "read",
531
+ name: datasource.name,
532
+ })
533
+ .set(config.defaultHeaders())
534
+ .expect("Content-Type", /json/)
535
+ .expect(200);
536
+ });
537
+ }
538
+ createQuery(config) {
539
+ return __awaiter(this, void 0, void 0, function* () {
540
+ if (!this.datasource && !config) {
541
+ throw "No datasource created for query.";
542
+ }
543
+ config = config || (0, structures_1.basicQuery)(this.datasource._id);
544
+ return this._req(config, null, controllers.query.save);
545
+ });
546
+ }
547
+ // SCREEN
548
+ createScreen(config) {
549
+ return __awaiter(this, void 0, void 0, function* () {
550
+ config = config || (0, structures_1.basicScreen)();
551
+ return this._req(config, null, controllers.screen.save);
552
+ });
553
+ }
554
+ // LAYOUT
555
+ createLayout(config) {
556
+ return __awaiter(this, void 0, void 0, function* () {
557
+ config = config || (0, structures_1.basicLayout)();
558
+ return yield this._req(config, null, controllers.layout.save);
559
+ });
560
+ }
561
+ }
562
+ 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"));