@budibase/server 2.2.12-alpha.6 → 2.2.12-alpha.60

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 (483) hide show
  1. package/__mocks__/node-fetch.ts +2 -0
  2. package/builder/assets/{bb-emblem.4e4717da.svg → bb-emblem.05f7ae7a.svg} +1 -1
  3. package/builder/assets/bg.c1563288.png +0 -0
  4. package/builder/assets/bulgaria.bd68393d.png +0 -0
  5. package/builder/assets/covanta.72c46c1e.png +0 -0
  6. package/builder/assets/index.426b225d.js +1798 -0
  7. package/builder/assets/index.f87b8d33.css +6 -0
  8. package/builder/assets/schnellecke.cf1837a8.png +0 -0
  9. package/builder/index.html +3 -3
  10. package/coverage/clover.xml +5112 -4923
  11. package/coverage/coverage-final.json +268 -264
  12. package/coverage/lcov-report/index.html +202 -157
  13. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +6 -6
  14. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +5 -5
  15. package/coverage/lcov-report/src/api/controllers/application.ts.html +185 -164
  16. package/coverage/lcov-report/src/api/controllers/auth.ts.html +9 -9
  17. package/coverage/lcov-report/src/api/controllers/automation.ts.html +24 -24
  18. package/coverage/lcov-report/src/api/controllers/backup.ts.html +6 -6
  19. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +15 -15
  20. package/coverage/lcov-report/src/api/controllers/component.ts.html +5 -5
  21. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +112 -88
  22. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +14 -14
  23. package/coverage/lcov-report/src/api/controllers/deploy/index.html +1 -1
  24. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +80 -80
  25. package/coverage/lcov-report/src/api/controllers/dev.ts.html +17 -17
  26. package/coverage/lcov-report/src/api/controllers/index.html +36 -36
  27. package/coverage/lcov-report/src/api/controllers/integration.ts.html +4 -4
  28. package/coverage/lcov-report/src/api/controllers/layout.ts.html +6 -6
  29. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +9 -9
  30. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +4 -4
  31. package/coverage/lcov-report/src/api/controllers/permission.ts.html +13 -13
  32. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +2 -2
  33. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +4 -4
  34. package/coverage/lcov-report/src/api/controllers/plugin/index.html +19 -19
  35. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +29 -29
  36. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +5 -5
  37. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +5 -5
  38. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +3 -3
  39. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +3 -3
  40. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +6 -6
  41. package/coverage/lcov-report/src/api/controllers/public/index.html +1 -1
  42. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +2 -2
  43. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +1 -1
  44. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +7 -7
  45. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +2 -2
  46. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +2 -2
  47. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +2 -2
  48. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +2 -2
  49. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +4 -4
  50. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +5 -5
  51. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +4 -4
  52. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +6 -6
  53. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +4 -4
  54. package/coverage/lcov-report/src/api/controllers/query/import/index.html +1 -1
  55. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +7 -7
  56. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +1 -1
  57. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +3 -3
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +5 -5
  59. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +7 -7
  60. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +1 -1
  61. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +9 -9
  62. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +13 -13
  63. package/coverage/lcov-report/src/api/controllers/query/index.html +7 -7
  64. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +89 -65
  65. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +9 -9
  66. package/coverage/lcov-report/src/api/controllers/role.ts.html +8 -8
  67. package/coverage/lcov-report/src/api/controllers/routing.ts.html +6 -6
  68. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +36 -18
  69. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +60 -30
  70. package/coverage/lcov-report/src/api/controllers/row/index.html +40 -40
  71. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +34 -34
  72. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +142 -70
  73. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +120 -120
  74. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +22 -22
  75. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +152 -38
  76. package/coverage/lcov-report/src/api/controllers/screen.ts.html +7 -7
  77. package/coverage/lcov-report/src/api/controllers/script.ts.html +2 -2
  78. package/coverage/lcov-report/src/api/controllers/static/index.html +1 -1
  79. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +39 -42
  80. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +52 -52
  81. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +43 -37
  82. package/coverage/lcov-report/src/api/controllers/table/index.html +34 -34
  83. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +155 -68
  84. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +47 -47
  85. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +66 -69
  86. package/coverage/lcov-report/src/api/controllers/templates.ts.html +7 -7
  87. package/coverage/lcov-report/src/api/controllers/user.ts.html +99 -75
  88. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +62 -17
  89. package/coverage/lcov-report/src/api/controllers/view/index.html +29 -29
  90. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +53 -92
  91. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +5 -5
  92. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +6 -6
  93. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +69 -63
  94. package/coverage/lcov-report/src/api/index.html +1 -1
  95. package/coverage/lcov-report/src/api/index.ts.html +27 -27
  96. package/coverage/lcov-report/src/api/routes/analytics.ts.html +7 -7
  97. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +8 -8
  98. package/coverage/lcov-report/src/api/routes/application.ts.html +10 -10
  99. package/coverage/lcov-report/src/api/routes/auth.ts.html +6 -6
  100. package/coverage/lcov-report/src/api/routes/automation.ts.html +11 -11
  101. package/coverage/lcov-report/src/api/routes/backup.ts.html +8 -8
  102. package/coverage/lcov-report/src/api/routes/cloud.ts.html +8 -8
  103. package/coverage/lcov-report/src/api/routes/component.ts.html +8 -8
  104. package/coverage/lcov-report/src/api/routes/datasource.ts.html +9 -9
  105. package/coverage/lcov-report/src/api/routes/deploy.ts.html +8 -8
  106. package/coverage/lcov-report/src/api/routes/dev.ts.html +13 -13
  107. package/coverage/lcov-report/src/api/routes/index.html +5 -5
  108. package/coverage/lcov-report/src/api/routes/index.ts.html +42 -36
  109. package/coverage/lcov-report/src/api/routes/integration.ts.html +8 -8
  110. package/coverage/lcov-report/src/api/routes/layout.ts.html +8 -8
  111. package/coverage/lcov-report/src/api/routes/metadata.ts.html +9 -9
  112. package/coverage/lcov-report/src/api/routes/migrations.ts.html +7 -7
  113. package/coverage/lcov-report/src/api/routes/permission.ts.html +9 -9
  114. package/coverage/lcov-report/src/api/routes/plugin.ts.html +8 -8
  115. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +14 -14
  116. package/coverage/lcov-report/src/api/routes/public/index.html +1 -1
  117. package/coverage/lcov-report/src/api/routes/public/index.ts.html +52 -52
  118. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +1 -1
  119. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +4 -4
  120. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +9 -9
  121. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +12 -12
  122. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +12 -12
  123. package/coverage/lcov-report/src/api/routes/public/tests/index.html +1 -1
  124. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +1 -1
  125. package/coverage/lcov-report/src/api/routes/public/users.ts.html +12 -12
  126. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +19 -19
  127. package/coverage/lcov-report/src/api/routes/public/utils/index.html +1 -1
  128. package/coverage/lcov-report/src/api/routes/query.ts.html +11 -11
  129. package/coverage/lcov-report/src/api/routes/role.ts.html +9 -9
  130. package/coverage/lcov-report/src/api/routes/routing.ts.html +8 -8
  131. package/coverage/lcov-report/src/api/routes/row.ts.html +12 -12
  132. package/coverage/lcov-report/src/api/routes/screen.ts.html +9 -9
  133. package/coverage/lcov-report/src/api/routes/script.ts.html +1 -1
  134. package/coverage/lcov-report/src/api/routes/static.ts.html +14 -14
  135. package/coverage/lcov-report/src/api/routes/table.ts.html +26 -95
  136. package/coverage/lcov-report/src/api/routes/templates.ts.html +8 -8
  137. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +1 -1
  138. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +1 -1
  139. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +1 -1
  140. package/coverage/lcov-report/src/api/routes/user.ts.html +9 -9
  141. package/coverage/lcov-report/src/api/routes/utils/index.html +1 -1
  142. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +43 -43
  143. package/coverage/lcov-report/src/api/routes/view.ts.html +10 -10
  144. package/coverage/lcov-report/src/api/routes/webhook.ts.html +10 -10
  145. package/coverage/lcov-report/src/app.ts.html +13 -7
  146. package/coverage/lcov-report/src/automations/actions.ts.html +27 -27
  147. package/coverage/lcov-report/src/automations/automationUtils.ts.html +59 -59
  148. package/coverage/lcov-report/src/automations/bullboard.ts.html +9 -9
  149. package/coverage/lcov-report/src/automations/index.html +30 -30
  150. package/coverage/lcov-report/src/automations/index.ts.html +10 -10
  151. package/coverage/lcov-report/src/automations/logging/index.html +1 -1
  152. package/coverage/lcov-report/src/automations/logging/index.ts.html +7 -7
  153. package/coverage/lcov-report/src/automations/steps/bash.ts.html +8 -8
  154. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +7 -7
  155. package/coverage/lcov-report/src/automations/steps/delay.ts.html +5 -5
  156. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +7 -7
  157. package/coverage/lcov-report/src/automations/steps/discord.ts.html +8 -8
  158. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +7 -7
  159. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +7 -7
  160. package/coverage/lcov-report/src/automations/steps/filter.ts.html +6 -6
  161. package/coverage/lcov-report/src/automations/steps/index.html +15 -15
  162. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +6 -6
  163. package/coverage/lcov-report/src/automations/steps/loop.ts.html +3 -3
  164. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +9 -9
  165. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +38 -38
  166. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +6 -6
  167. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +7 -7
  168. package/coverage/lcov-report/src/automations/steps/slack.ts.html +6 -6
  169. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +7 -7
  170. package/coverage/lcov-report/src/automations/steps/utils.ts.html +10 -10
  171. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +6 -6
  172. package/coverage/lcov-report/src/automations/tests/utilities/index.html +1 -1
  173. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +13 -13
  174. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +3 -3
  175. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +3 -3
  176. package/coverage/lcov-report/src/automations/triggerInfo/index.html +1 -1
  177. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +8 -8
  178. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +3 -3
  179. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +3 -3
  180. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +3 -3
  181. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +3 -3
  182. package/coverage/lcov-report/src/automations/triggers.ts.html +52 -37
  183. package/coverage/lcov-report/src/automations/utils.ts.html +52 -52
  184. package/coverage/lcov-report/src/constants/index.html +1 -1
  185. package/coverage/lcov-report/src/constants/index.ts.html +2 -2
  186. package/coverage/lcov-report/src/constants/layouts.ts.html +4 -4
  187. package/coverage/lcov-report/src/constants/screens.ts.html +3 -3
  188. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +22 -22
  189. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +2 -2
  190. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +2 -2
  191. package/coverage/lcov-report/src/db/defaultData/index.html +1 -1
  192. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +2 -2
  193. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +2 -2
  194. package/coverage/lcov-report/src/db/dynamoClient.ts.html +15 -15
  195. package/coverage/lcov-report/src/db/inMemoryView.ts.html +4 -4
  196. package/coverage/lcov-report/src/db/index.html +1 -1
  197. package/coverage/lcov-report/src/db/index.ts.html +9 -9
  198. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +18 -18
  199. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +4 -4
  200. package/coverage/lcov-report/src/db/linkedRows/index.html +1 -1
  201. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +27 -27
  202. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +13 -13
  203. package/coverage/lcov-report/src/db/newid.ts.html +4 -4
  204. package/coverage/lcov-report/src/db/utils.ts.html +40 -40
  205. package/coverage/lcov-report/src/definitions/automations.ts.html +6 -3
  206. package/coverage/lcov-report/src/definitions/index.html +5 -20
  207. package/coverage/lcov-report/src/environment.ts.html +10 -10
  208. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +8 -8
  209. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +5 -5
  210. package/coverage/lcov-report/src/events/index.html +1 -1
  211. package/coverage/lcov-report/src/events/index.ts.html +4 -4
  212. package/coverage/lcov-report/src/events/utils.ts.html +1 -1
  213. package/coverage/lcov-report/src/index.html +13 -13
  214. package/coverage/lcov-report/src/index.ts.html +5 -5
  215. package/coverage/lcov-report/src/integrations/airtable.ts.html +5 -5
  216. package/coverage/lcov-report/src/integrations/arangodb.ts.html +5 -5
  217. package/coverage/lcov-report/src/integrations/base/index.html +11 -11
  218. package/coverage/lcov-report/src/integrations/base/query.ts.html +14 -8
  219. package/coverage/lcov-report/src/integrations/base/sql.ts.html +12 -12
  220. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +8 -8
  221. package/coverage/lcov-report/src/integrations/base/utils.ts.html +5 -5
  222. package/coverage/lcov-report/src/integrations/couchdb.ts.html +113 -32
  223. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +9 -9
  224. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +26 -14
  225. package/coverage/lcov-report/src/integrations/firebase.ts.html +5 -5
  226. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +11 -11
  227. package/coverage/lcov-report/src/integrations/index.html +47 -47
  228. package/coverage/lcov-report/src/integrations/index.ts.html +49 -49
  229. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +8 -8
  230. package/coverage/lcov-report/src/integrations/mongodb.ts.html +417 -285
  231. package/coverage/lcov-report/src/integrations/mysql.ts.html +11 -11
  232. package/coverage/lcov-report/src/integrations/oracle.ts.html +13 -13
  233. package/coverage/lcov-report/src/integrations/postgres.ts.html +10 -10
  234. package/coverage/lcov-report/src/integrations/queries/index.html +19 -19
  235. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +15 -150
  236. package/coverage/lcov-report/src/integrations/redis.ts.html +5 -5
  237. package/coverage/lcov-report/src/integrations/rest.ts.html +36 -45
  238. package/coverage/lcov-report/src/integrations/s3.ts.html +6 -6
  239. package/coverage/lcov-report/src/integrations/snowflake.ts.html +5 -5
  240. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
  241. package/coverage/lcov-report/src/integrations/tests/index.html +1 -1
  242. package/coverage/lcov-report/src/integrations/utils.ts.html +18 -18
  243. package/coverage/lcov-report/src/middleware/appInfo.ts.html +5 -5
  244. package/coverage/lcov-report/src/middleware/authorized.ts.html +27 -27
  245. package/coverage/lcov-report/src/middleware/builder.ts.html +17 -17
  246. package/coverage/lcov-report/src/middleware/currentapp.ts.html +45 -42
  247. package/coverage/lcov-report/src/middleware/index.html +1 -1
  248. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +1 -1
  249. package/coverage/lcov-report/src/middleware/publicApi.ts.html +4 -4
  250. package/coverage/lcov-report/src/middleware/resourceId.ts.html +21 -21
  251. package/coverage/lcov-report/src/middleware/selfhost.ts.html +1 -1
  252. package/coverage/lcov-report/src/middleware/utils.ts.html +4 -4
  253. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +4 -4
  254. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +5 -5
  255. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +5 -5
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +1 -1
  257. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +5 -5
  258. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +7 -7
  259. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +5 -5
  260. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +5 -5
  261. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +4 -4
  262. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +19 -19
  263. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +6 -6
  264. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +1 -1
  265. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +7 -7
  266. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +6 -6
  267. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +15 -15
  268. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +1 -1
  269. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +5 -5
  270. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +8 -8
  271. package/coverage/lcov-report/src/migrations/functions/index.html +1 -1
  272. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +6 -6
  273. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +6 -6
  274. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +1 -1
  275. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +2 -2
  276. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +5 -5
  277. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +4 -4
  278. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +6 -6
  279. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +3 -3
  280. package/coverage/lcov-report/src/migrations/index.html +1 -1
  281. package/coverage/lcov-report/src/migrations/index.ts.html +32 -32
  282. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +1 -1
  283. package/coverage/lcov-report/src/migrations/tests/index.html +1 -1
  284. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +1 -1
  285. package/coverage/lcov-report/src/sdk/app/applications/index.html +1 -1
  286. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +4 -4
  287. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +22 -22
  288. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +9 -9
  289. package/coverage/lcov-report/src/sdk/app/automations/index.html +1 -1
  290. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +3 -3
  291. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +3 -3
  292. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +3 -3
  293. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +17 -17
  294. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +18 -18
  295. package/coverage/lcov-report/src/sdk/app/backups/index.html +1 -1
  296. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +5 -5
  297. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +7 -7
  298. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +493 -0
  299. package/coverage/lcov-report/src/sdk/app/datasources/index.html +131 -0
  300. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +100 -0
  301. package/coverage/lcov-report/src/sdk/app/queries/index.html +131 -0
  302. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +100 -0
  303. package/coverage/lcov-report/src/{definitions/datasource.ts.html → sdk/app/queries/queries.ts.html} +82 -82
  304. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +6 -6
  305. package/coverage/lcov-report/src/sdk/app/rows/index.html +1 -1
  306. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +4 -4
  307. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +4 -4
  308. package/coverage/lcov-report/src/sdk/app/tables/index.html +11 -11
  309. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +27 -18
  310. package/coverage/lcov-report/src/sdk/index.html +5 -5
  311. package/coverage/lcov-report/src/sdk/index.ts.html +23 -11
  312. package/coverage/lcov-report/src/sdk/users/index.html +1 -1
  313. package/coverage/lcov-report/src/sdk/users/index.ts.html +3 -3
  314. package/coverage/lcov-report/src/sdk/users/utils.ts.html +28 -28
  315. package/coverage/lcov-report/src/sdk/utils/index.html +116 -0
  316. package/coverage/lcov-report/src/sdk/utils/index.ts.html +133 -0
  317. package/coverage/lcov-report/src/startup.ts.html +34 -34
  318. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +134 -125
  319. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +15 -15
  320. package/coverage/lcov-report/src/tests/utilities/index.html +21 -21
  321. package/coverage/lcov-report/src/tests/utilities/index.ts.html +1 -1
  322. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +213 -24
  323. package/coverage/lcov-report/src/threads/automation.ts.html +216 -186
  324. package/coverage/lcov-report/src/threads/index.html +30 -30
  325. package/coverage/lcov-report/src/threads/index.ts.html +24 -24
  326. package/coverage/lcov-report/src/threads/query.ts.html +68 -29
  327. package/coverage/lcov-report/src/threads/utils.ts.html +9 -9
  328. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +2 -2
  329. package/coverage/lcov-report/src/utilities/centralPath.ts.html +11 -11
  330. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +9 -9
  331. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +1 -1
  332. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +27 -21
  333. package/coverage/lcov-report/src/utilities/fileSystem/index.html +21 -21
  334. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +1 -1
  335. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +5 -8
  336. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +1 -1
  337. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +3 -3
  338. package/coverage/lcov-report/src/utilities/global.ts.html +40 -40
  339. package/coverage/lcov-report/src/utilities/index.html +39 -39
  340. package/coverage/lcov-report/src/utilities/index.ts.html +12 -12
  341. package/coverage/lcov-report/src/utilities/redis.ts.html +12 -12
  342. package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
  343. package/coverage/lcov-report/src/utilities/routing/index.ts.html +4 -4
  344. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +1 -1
  345. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +50 -50
  346. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +3 -3
  347. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +14 -14
  348. package/coverage/lcov-report/src/utilities/{csvParser.ts.html → schema.ts.html} +173 -233
  349. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +5 -5
  350. package/coverage/lcov-report/src/utilities/security.ts.html +4 -4
  351. package/coverage/lcov-report/src/utilities/usageQuota/index.html +1 -1
  352. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +4 -4
  353. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +1 -1
  354. package/coverage/lcov-report/src/utilities/users.ts.html +4 -4
  355. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +38 -11
  356. package/coverage/lcov-report/src/watch.ts.html +7 -7
  357. package/coverage/lcov-report/src/websocket.ts.html +3 -3
  358. package/coverage/lcov.info +7897 -7537
  359. package/dist/api/controllers/application.js +73 -74
  360. package/dist/api/controllers/cloud.js +1 -1
  361. package/dist/api/controllers/datasource.js +24 -15
  362. package/dist/api/controllers/query/index.js +18 -11
  363. package/dist/api/controllers/row/ExternalRequest.js +12 -3
  364. package/dist/api/controllers/row/external.js +20 -13
  365. package/dist/api/controllers/row/internal.js +40 -15
  366. package/dist/api/controllers/row/utils.js +35 -3
  367. package/dist/api/controllers/static/index.js +38 -38
  368. package/dist/api/controllers/static/templates/BudibaseApp.svelte +0 -1
  369. package/dist/api/controllers/table/external.js +16 -35
  370. package/dist/api/controllers/table/index.js +44 -15
  371. package/dist/api/controllers/table/internal.js +4 -4
  372. package/dist/api/controllers/table/utils.js +9 -9
  373. package/dist/api/controllers/user.js +14 -6
  374. package/dist/api/controllers/view/exporters.js +22 -6
  375. package/dist/api/controllers/view/index.js +20 -56
  376. package/dist/api/controllers/webhook.js +45 -43
  377. package/dist/api/routes/index.js +2 -0
  378. package/dist/api/routes/row.js +2 -2
  379. package/dist/api/routes/table.js +6 -37
  380. package/dist/api/routes/utils/validators.js +1 -1
  381. package/dist/app.js +1 -0
  382. package/dist/automations/triggers.js +1 -0
  383. package/dist/definitions/datasource.js +0 -6
  384. package/dist/index.js +2 -2
  385. package/dist/integrations/base/query.js +7 -2
  386. package/dist/integrations/base/sqlTable.js +14 -14
  387. package/dist/integrations/couchdb.js +34 -8
  388. package/dist/integrations/dynamodb.js +8 -5
  389. package/dist/integrations/elasticsearch.js +7 -3
  390. package/dist/integrations/index.js +5 -5
  391. package/dist/integrations/mongodb.js +311 -271
  392. package/dist/integrations/mysql.js +2 -2
  393. package/dist/integrations/queries/sql.js +73 -100
  394. package/dist/integrations/rest.js +16 -18
  395. package/dist/middleware/currentapp.js +4 -2
  396. package/dist/package.json +7 -7
  397. package/dist/sdk/app/datasources/datasources.js +147 -0
  398. package/dist/sdk/app/datasources/index.js +27 -0
  399. package/dist/sdk/app/queries/index.js +27 -0
  400. package/dist/sdk/app/queries/queries.js +60 -0
  401. package/dist/sdk/app/tables/index.js +6 -2
  402. package/dist/sdk/index.js +4 -0
  403. package/dist/sdk/utils/index.js +29 -0
  404. package/dist/threads/automation.js +18 -7
  405. package/dist/threads/query.js +27 -13
  406. package/dist/tsconfig.build.tsbuildinfo +1 -1
  407. package/dist/utilities/fileSystem/filesystem.js +36 -34
  408. package/dist/utilities/fileSystem/plugin.js +17 -14
  409. package/dist/utilities/fileSystem/template.js +7 -4
  410. package/dist/utilities/schema.js +108 -0
  411. package/dist/utilities/workerRequests.js +2 -0
  412. package/package.json +8 -8
  413. package/scripts/dev/manage.js +1 -0
  414. package/src/api/controllers/application.ts +81 -74
  415. package/src/api/controllers/cloud.ts +1 -1
  416. package/src/api/controllers/datasource.ts +33 -25
  417. package/src/api/controllers/query/index.ts +47 -39
  418. package/src/api/controllers/row/ExternalRequest.ts +8 -2
  419. package/src/api/controllers/row/external.ts +24 -14
  420. package/src/api/controllers/row/internal.ts +42 -18
  421. package/src/api/controllers/row/utils.ts +40 -2
  422. package/src/api/controllers/static/index.ts +17 -18
  423. package/src/api/controllers/static/templates/BudibaseApp.svelte +0 -1
  424. package/src/api/controllers/table/external.ts +18 -16
  425. package/src/api/controllers/table/index.ts +46 -17
  426. package/src/api/controllers/table/internal.ts +4 -4
  427. package/src/api/controllers/table/utils.ts +12 -13
  428. package/src/api/controllers/user.ts +21 -13
  429. package/src/api/controllers/view/exporters.ts +20 -5
  430. package/src/api/controllers/view/index.ts +22 -35
  431. package/src/api/controllers/webhook.ts +48 -46
  432. package/src/api/routes/index.ts +2 -0
  433. package/src/api/routes/row.ts +1 -1
  434. package/src/api/routes/table.ts +15 -38
  435. package/src/api/routes/tests/datasource.spec.ts +35 -1
  436. package/src/api/routes/tests/misc.spec.js +4 -10
  437. package/src/api/routes/tests/table.spec.js +8 -30
  438. package/src/api/routes/tests/user.spec.js +20 -1
  439. package/src/api/routes/utils/validators.ts +1 -1
  440. package/src/app.ts +3 -1
  441. package/src/automations/tests/loop.spec.ts +45 -0
  442. package/src/automations/triggers.ts +6 -1
  443. package/src/definitions/automations.ts +1 -0
  444. package/src/definitions/datasource.ts +0 -41
  445. package/src/index.ts +1 -1
  446. package/src/integrations/base/query.ts +3 -1
  447. package/src/integrations/base/sqlTable.ts +1 -1
  448. package/src/integrations/couchdb.ts +41 -14
  449. package/src/integrations/dynamodb.ts +3 -3
  450. package/src/integrations/elasticsearch.ts +8 -4
  451. package/src/integrations/index.ts +4 -4
  452. package/src/integrations/mongodb.ts +315 -271
  453. package/src/integrations/mysql.ts +1 -1
  454. package/src/integrations/queries/sql.ts +5 -50
  455. package/src/integrations/rest.ts +16 -19
  456. package/src/integrations/tests/couchdb.spec.ts +33 -21
  457. package/src/integrations/tests/rest.spec.ts +4 -2
  458. package/src/middleware/currentapp.ts +3 -2
  459. package/src/migrations/functions/usageQuotas/tests/syncRows.spec.ts +10 -6
  460. package/src/sdk/app/datasources/datasources.ts +136 -0
  461. package/src/sdk/app/datasources/index.ts +5 -0
  462. package/src/sdk/app/queries/index.ts +5 -0
  463. package/src/sdk/app/queries/queries.ts +50 -0
  464. package/src/sdk/app/tables/index.ts +6 -3
  465. package/src/sdk/index.ts +4 -0
  466. package/src/sdk/utils/index.ts +16 -0
  467. package/src/tests/utilities/TestConfiguration.ts +15 -12
  468. package/src/tests/utilities/structures.ts +65 -2
  469. package/src/threads/automation.ts +18 -8
  470. package/src/threads/definitions.ts +3 -0
  471. package/src/threads/query.ts +28 -15
  472. package/src/utilities/fileSystem/filesystem.ts +6 -4
  473. package/src/utilities/fileSystem/plugin.ts +3 -4
  474. package/src/utilities/fileSystem/template.ts +2 -2
  475. package/src/utilities/schema.ts +141 -0
  476. package/src/utilities/workerRequests.ts +10 -1
  477. package/tsconfig.json +2 -1
  478. package/builder/assets/index.0b010a07.js +0 -1023
  479. package/builder/assets/index.fa480d5b.css +0 -6
  480. package/dist/utilities/csvParser.js +0 -152
  481. package/src/utilities/csvParser.ts +0 -161
  482. package/src/utilities/tests/__snapshots__/csvParser.spec.js.snap +0 -15
  483. package/src/utilities/tests/csvParser.spec.js +0 -112
@@ -12,11 +12,16 @@ import {
12
12
  FindOneAndUpdateOptions,
13
13
  UpdateOptions,
14
14
  OperationOptions,
15
+ MongoClientOptions,
15
16
  } from "mongodb"
17
+ import environment from "../environment"
16
18
 
17
19
  interface MongoDBConfig {
18
20
  connectionString: string
19
21
  db: string
22
+ tlsCertificateFile: string
23
+ tlsCertificateKeyFile: string
24
+ tlsCAFile: string
20
25
  }
21
26
 
22
27
  interface MongoDBQuery {
@@ -26,292 +31,331 @@ interface MongoDBQuery {
26
31
  }
27
32
  }
28
33
 
29
- const SCHEMA: Integration = {
30
- docs: "https://github.com/mongodb/node-mongodb-native",
31
- friendlyName: "MongoDB",
32
- type: "Non-relational",
33
- description:
34
- "MongoDB is a general purpose, document-based, distributed database built for modern application developers and for the cloud era.",
35
- datasource: {
36
- connectionString: {
37
- type: DatasourceFieldType.STRING,
38
- required: true,
39
- default: "mongodb://localhost:27017",
40
- },
41
- db: {
42
- type: DatasourceFieldType.STRING,
43
- required: true,
44
- },
45
- },
46
- query: {
47
- create: {
48
- type: QueryType.JSON,
49
- },
50
- read: {
51
- type: QueryType.JSON,
34
+ const getSchema = () => {
35
+ let schema = {
36
+ docs: "https://github.com/mongodb/node-mongodb-native",
37
+ friendlyName: "MongoDB",
38
+ type: "Non-relational",
39
+ description:
40
+ "MongoDB is a general purpose, document-based, distributed database built for modern application developers and for the cloud era.",
41
+ datasource: {
42
+ connectionString: {
43
+ type: DatasourceFieldType.STRING,
44
+ required: true,
45
+ default: "mongodb://localhost:27017",
46
+ display: "Connection string",
47
+ },
48
+ db: {
49
+ type: DatasourceFieldType.STRING,
50
+ required: true,
51
+ display: "DB",
52
+ },
52
53
  },
53
- update: {
54
- type: QueryType.JSON,
54
+ query: {
55
+ create: {
56
+ type: QueryType.JSON,
57
+ },
58
+ read: {
59
+ type: QueryType.JSON,
60
+ },
61
+ update: {
62
+ type: QueryType.JSON,
63
+ },
64
+ delete: {
65
+ type: QueryType.JSON,
66
+ },
67
+ aggregate: {
68
+ type: QueryType.JSON,
69
+ readable: true,
70
+ steps: [
71
+ {
72
+ key: "$addFields",
73
+ template: "{\n\t\n}",
74
+ },
75
+ {
76
+ key: "$bucket",
77
+ template: `{
78
+ "groupBy": "",
79
+ "boundaries": [],
80
+ "default": "",
81
+ "output": {}
82
+ }`,
83
+ },
84
+ {
85
+ key: "$bucketAuto",
86
+ template: `{
87
+ "groupBy": "",
88
+ "buckets": 1,
89
+ "output": {},
90
+ "granularity": "R5"
91
+ }`,
92
+ },
93
+ {
94
+ key: "$changeStream",
95
+ template: `{
96
+ "allChangesForCluster": true,
97
+ "fullDocument": "",
98
+ "fullDocumentBeforeChange": "",
99
+ "resumeAfter": 1,
100
+ "showExpandedEvents": true,
101
+ "startAfter": {},
102
+ "startAtOperationTime": ""
103
+ }`,
104
+ },
105
+ {
106
+ key: "$collStats",
107
+ template: `{
108
+ "latencyStats": { "histograms": true } },
109
+ "storageStats": { "scale": 1 } },
110
+ "count": {},
111
+ "queryExecStats": {}
112
+ }`,
113
+ },
114
+ {
115
+ key: "$count",
116
+ template: ``,
117
+ },
118
+ {
119
+ key: "$densify",
120
+ template: `{
121
+ "field": "",
122
+ "partitionByFields": [],
123
+ "range": {
124
+ "step": 1,
125
+ "unit": 1,
126
+ "bounds": "full"
127
+ }
128
+ }`,
129
+ },
130
+ {
131
+ key: "$documents",
132
+ template: `[]`,
133
+ },
134
+ {
135
+ key: "$facet",
136
+ template: `{\n\t\n}`,
137
+ },
138
+ {
139
+ key: "$fill",
140
+ template: `{
141
+ "partitionBy": "",
142
+ "partitionByFields": [],
143
+ "sortBy": {},
144
+ "output": {}
145
+ }`,
146
+ },
147
+ {
148
+ key: "$geoNear",
149
+ template: `{
150
+ "near": {
151
+ "type": "Point",
152
+ "coordinates": [
153
+ -73.98142, 40.71782
154
+ ]
55
155
  },
56
- delete: {
57
- type: QueryType.JSON,
156
+ "key": "location",
157
+ "distanceField": "dist.calculated",
158
+ "query": { "category": "Parks" }
159
+ }`,
160
+ },
161
+ {
162
+ key: "$graphLookup",
163
+ template: `{
164
+ "from": "",
165
+ "startWith": "",
166
+ "connectFromField": "",
167
+ "connectToField": "",
168
+ "as": "",
169
+ "maxDepth": 1,
170
+ "depthField": "",
171
+ "restrictSearchWithMatch": {}
172
+ }`,
173
+ },
174
+ {
175
+ key: "$group",
176
+ template: `{
177
+ "_id": ""
178
+ }`,
179
+ },
180
+ {
181
+ key: "$indexStats",
182
+ template: "{\n\t\n}",
183
+ },
184
+ {
185
+ key: "$limit",
186
+ template: `1`,
187
+ },
188
+ {
189
+ key: "$listLocalSessions",
190
+ template: `{\n\t\n}`,
191
+ },
192
+ {
193
+ key: "$listSessions",
194
+ template: `{\n\t\n}`,
195
+ },
196
+ {
197
+ key: "$lookup",
198
+ template: `{
199
+ "from": "",
200
+ "localField": "",
201
+ "foreignField": "",
202
+ "as": ""
203
+ }`,
204
+ },
205
+ {
206
+ key: "$match",
207
+ template: "{\n\t\n}",
208
+ },
209
+ {
210
+ key: "$merge",
211
+ template: `{
212
+ "into": {},
213
+ "on": "_id",
214
+ "whenMatched": "replace",
215
+ "whenNotMatched": "insert"
216
+ }`,
217
+ },
218
+ {
219
+ key: "$out",
220
+ template: `{
221
+ "db": "",
222
+ "coll": ""
223
+ }`,
224
+ },
225
+ {
226
+ key: "$planCacheStats",
227
+ template: "{\n\t\n}",
228
+ },
229
+ {
230
+ key: "$project",
231
+ template: "{\n\t\n}",
232
+ },
233
+ {
234
+ key: "$redact",
235
+ template: "",
236
+ },
237
+ {
238
+ key: "$replaceRoot",
239
+ template: `{ "newRoot": "" }`,
240
+ },
241
+ {
242
+ key: "$replaceWith",
243
+ template: ``,
244
+ },
245
+ {
246
+ key: "$sample",
247
+ template: `{ "size": 3 }`,
248
+ },
249
+ {
250
+ key: "$set",
251
+ template: "{\n\t\n}",
252
+ },
253
+ {
254
+ key: "$setWindowFields",
255
+ template: `{
256
+ "partitionBy": "",
257
+ "sortBy": {},
258
+ "output": {}
259
+ }`,
260
+ },
261
+ {
262
+ key: "$skip",
263
+ template: `1`,
264
+ },
265
+ {
266
+ key: "$sort",
267
+ template: "{\n\t\n}",
268
+ },
269
+ {
270
+ key: "$sortByCount",
271
+ template: "",
272
+ },
273
+ {
274
+ key: "$unionWith",
275
+ template: `{
276
+ "coll": "",
277
+ "pipeline": []
278
+ }`,
279
+ },
280
+ {
281
+ key: "$unset",
282
+ template: "",
283
+ },
284
+ {
285
+ key: "$unwind",
286
+ template: `{
287
+ "path": "",
288
+ "includeArrayIndex": "",
289
+ "preserveNullAndEmptyArrays": true
290
+ }`,
291
+ },
292
+ ],
293
+ },
58
294
  },
59
- aggregate: {
60
- type: QueryType.JSON,
61
- readable: true,
62
- steps: [
63
- {
64
- key: "$addFields",
65
- template: "{\n\t\n}",
66
- },
67
- {
68
- key: "$bucket",
69
- template: `{
70
- "groupBy": "",
71
- "boundaries": [],
72
- "default": "",
73
- "output": {}
74
- }`,
75
- },
76
- {
77
- key: "$bucketAuto",
78
- template: `{
79
- "groupBy": "",
80
- "buckets": 1,
81
- "output": {},
82
- "granularity": "R5"
83
- }`,
84
- },
85
- {
86
- key: "$changeStream",
87
- template: `{
88
- "allChangesForCluster": true,
89
- "fullDocument": "",
90
- "fullDocumentBeforeChange": "",
91
- "resumeAfter": 1,
92
- "showExpandedEvents": true,
93
- "startAfter": {},
94
- "startAtOperationTime": ""
95
- }`,
96
- },
97
- {
98
- key: "$collStats",
99
- template: `{
100
- "latencyStats": { "histograms": true } },
101
- "storageStats": { "scale": 1 } },
102
- "count": {},
103
- "queryExecStats": {}
104
- }`,
105
- },
106
- {
107
- key: "$count",
108
- template: ``,
295
+ extra: {
296
+ collection: {
297
+ displayName: "Collection",
298
+ type: DatasourceFieldType.STRING,
299
+ required: true,
300
+ },
301
+ actionType: {
302
+ displayName: "Query Type",
303
+ type: DatasourceFieldType.LIST,
304
+ required: true,
305
+ data: {
306
+ read: ["find", "findOne", "findOneAndUpdate", "count", "distinct"],
307
+ create: ["insertOne", "insertMany"],
308
+ update: ["updateOne", "updateMany"],
309
+ delete: ["deleteOne", "deleteMany"],
310
+ aggregate: ["json", "pipeline"],
109
311
  },
110
- {
111
- key: "$densify",
112
- template: `{
113
- "field": "",
114
- "partitionByFields": [],
115
- "range": {
116
- "step": 1,
117
- "unit": 1,
118
- "bounds": "full"
312
+ },
313
+ },
119
314
  }
120
- }`,
121
- },
122
- {
123
- key: "$documents",
124
- template: `[]`,
125
- },
126
- {
127
- key: "$facet",
128
- template: `{\n\t\n}`,
129
- },
130
- {
131
- key: "$fill",
132
- template: `{
133
- "partitionBy": "",
134
- "partitionByFields": [],
135
- "sortBy": {},
136
- "output": {}
137
- }`,
138
- },
139
- {
140
- key: "$geoNear",
141
- template: `{
142
- "near": {
143
- "type": "Point",
144
- "coordinates": [
145
- -73.98142, 40.71782
146
- ]
147
- },
148
- "key": "location",
149
- "distanceField": "dist.calculated",
150
- "query": { "category": "Parks" }
151
- }`,
152
- },
153
- {
154
- key: "$graphLookup",
155
- template: `{
156
- "from": "",
157
- "startWith": "",
158
- "connectFromField": "",
159
- "connectToField": "",
160
- "as": "",
161
- "maxDepth": 1,
162
- "depthField": "",
163
- "restrictSearchWithMatch": {}
164
- }`,
165
- },
166
- {
167
- key: "$group",
168
- template: `{
169
- "_id": ""
170
- }`,
171
- },
172
- {
173
- key: "$indexStats",
174
- template: "{\n\t\n}",
175
- },
176
- {
177
- key: "$limit",
178
- template: `1`,
179
- },
180
- {
181
- key: "$listLocalSessions",
182
- template: `{\n\t\n}`,
315
+ if (environment.SELF_HOSTED) {
316
+ schema.datasource = {
317
+ ...schema.datasource,
318
+ //@ts-ignore
319
+ tls: {
320
+ type: DatasourceFieldType.FIELD_GROUP,
321
+ display: "Configure SSL",
322
+ fields: {
323
+ tlsCertificateFile: {
324
+ type: DatasourceFieldType.STRING,
325
+ required: false,
326
+ display: "Certificate file path",
327
+ },
328
+ tlsCertificateKeyFile: {
329
+ type: DatasourceFieldType.STRING,
330
+ required: false,
331
+ display: "Certificate Key file path",
332
+ },
333
+ tlsCAFile: {
334
+ type: DatasourceFieldType.STRING,
335
+ required: false,
336
+ display: "CA file path",
337
+ },
183
338
  },
184
- {
185
- key: "$listSessions",
186
- template: `{\n\t\n}`,
187
- },
188
- {
189
- key: "$lookup",
190
- template: `{
191
- "from": "",
192
- "localField": "",
193
- "foreignField": "",
194
- "as": ""
195
- }`,
196
- },
197
- {
198
- key: "$match",
199
- template: "{\n\t\n}",
200
- },
201
- {
202
- key: "$merge",
203
- template: `{
204
- "into": {},
205
- "on": "_id",
206
- "whenMatched": "replace",
207
- "whenNotMatched": "insert"
208
- }`,
209
- },
210
- {
211
- key: "$out",
212
- template: `{
213
- "db": "",
214
- "coll": ""
215
- }`,
216
- },
217
- {
218
- key: "$planCacheStats",
219
- template: "{\n\t\n}",
220
- },
221
- {
222
- key: "$project",
223
- template: "{\n\t\n}",
224
- },
225
- {
226
- key: "$redact",
227
- template: "",
228
- },
229
- {
230
- key: "$replaceRoot",
231
- template: `{ "newRoot": "" }`,
232
- },
233
- {
234
- key: "$replaceWith",
235
- template: ``,
236
- },
237
- {
238
- key: "$sample",
239
- template: `{ "size": 3 }`,
240
- },
241
- {
242
- key: "$set",
243
- template: "{\n\t\n}",
244
- },
245
- {
246
- key: "$setWindowFields",
247
- template: `{
248
- "partitionBy": "",
249
- "sortBy": {},
250
- "output": {}
251
- }`,
252
- },
253
- {
254
- key: "$skip",
255
- template: `1`,
256
- },
257
- {
258
- key: "$sort",
259
- template: "{\n\t\n}",
260
- },
261
- {
262
- key: "$sortByCount",
263
- template: "",
264
- },
265
- {
266
- key: "$unionWith",
267
- template: `{
268
- "coll": "",
269
- "pipeline": []
270
- }`,
271
- },
272
- {
273
- key: "$unset",
274
- template: "",
275
- },
276
- {
277
- key: "$unwind",
278
- template: `{
279
- "path": "",
280
- "includeArrayIndex": "",
281
- "preserveNullAndEmptyArrays": true
282
- }`,
283
- },
284
- ],
285
- },
286
- },
287
- extra: {
288
- collection: {
289
- displayName: "Collection",
290
- type: DatasourceFieldType.STRING,
291
- required: true,
292
- },
293
- actionType: {
294
- displayName: "Query Type",
295
- type: DatasourceFieldType.LIST,
296
- required: true,
297
- data: {
298
- read: ["find", "findOne", "findOneAndUpdate", "count", "distinct"],
299
- create: ["insertOne", "insertMany"],
300
- update: ["updateOne", "updateMany"],
301
- delete: ["deleteOne", "deleteMany"],
302
- aggregate: ["json", "pipeline"],
303
339
  },
304
- },
305
- },
340
+ }
341
+ }
342
+ return schema
306
343
  }
307
344
 
345
+ const SCHEMA: Integration = getSchema()
346
+
308
347
  class MongoIntegration implements IntegrationBase {
309
348
  private config: MongoDBConfig
310
349
  private client: any
311
350
 
312
351
  constructor(config: MongoDBConfig) {
313
352
  this.config = config
314
- this.client = new MongoClient(config.connectionString)
353
+ const options: MongoClientOptions = {
354
+ tlsCertificateFile: config.tlsCertificateFile || undefined,
355
+ tlsCertificateKeyFile: config.tlsCertificateKeyFile || undefined,
356
+ tlsCAFile: config.tlsCAFile || undefined,
357
+ }
358
+ this.client = new MongoClient(config.connectionString, options)
315
359
  }
316
360
 
317
361
  async connect() {
@@ -16,7 +16,7 @@ import {
16
16
  finaliseExternalTables,
17
17
  } from "./utils"
18
18
  import dayjs from "dayjs"
19
- const { NUMBER_REGEX } = require("../utilities")
19
+ import { NUMBER_REGEX } from "../utilities"
20
20
  import Sql from "./base/sql"
21
21
  import { MySQLColumn } from "./base/types"
22
22
 
@@ -1,55 +1,10 @@
1
- import { findHBSBlocks, processStringSync } from "@budibase/string-templates"
1
+ import { findHBSBlocks } from "@budibase/string-templates"
2
2
  import { DatasourcePlus } from "@budibase/types"
3
+ import sdk from "../../sdk"
3
4
 
4
5
  const CONST_CHAR_REGEX = new RegExp("'[^']*'", "g")
5
6
 
6
- export function enrichQueryFields(
7
- fields: { [key: string]: any },
8
- parameters = {}
9
- ) {
10
- const enrichedQuery: { [key: string]: any } = Array.isArray(fields) ? [] : {}
11
- if (!fields || !parameters) {
12
- return enrichedQuery
13
- }
14
- // enrich the fields with dynamic parameters
15
- for (let key of Object.keys(fields)) {
16
- if (fields[key] == null) {
17
- continue
18
- }
19
- if (typeof fields[key] === "object") {
20
- // enrich nested fields object
21
- enrichedQuery[key] = enrichQueryFields(fields[key], parameters)
22
- } else if (typeof fields[key] === "string") {
23
- // enrich string value as normal
24
- enrichedQuery[key] = processStringSync(fields[key], parameters, {
25
- noEscaping: true,
26
- noHelpers: true,
27
- escapeNewlines: true,
28
- })
29
- } else {
30
- enrichedQuery[key] = fields[key]
31
- }
32
- }
33
- if (
34
- enrichedQuery.json ||
35
- enrichedQuery.customData ||
36
- enrichedQuery.requestBody
37
- ) {
38
- try {
39
- enrichedQuery.json = JSON.parse(
40
- enrichedQuery.json ||
41
- enrichedQuery.customData ||
42
- enrichedQuery.requestBody
43
- )
44
- } catch (err) {
45
- // no json found, ignore
46
- }
47
- delete enrichedQuery.customData
48
- }
49
- return enrichedQuery
50
- }
51
-
52
- export function interpolateSQL(
7
+ export async function interpolateSQL(
53
8
  fields: { [key: string]: any },
54
9
  parameters: { [key: string]: any },
55
10
  integration: DatasourcePlus
@@ -90,7 +45,7 @@ export function interpolateSQL(
90
45
  else if (listRegexMatch) {
91
46
  arrays.push(binding)
92
47
  // determine the length of the array
93
- const value = enrichQueryFields([binding], parameters)[0]
48
+ const value = (await sdk.queries.enrichContext([binding], parameters))[0]
94
49
  .split(",")
95
50
  .map((val: string) => val.trim())
96
51
  // build a string like ($1, $2, $3)
@@ -109,7 +64,7 @@ export function interpolateSQL(
109
64
  }
110
65
  // replicate the knex structure
111
66
  fields.sql = sql
112
- fields.bindings = enrichQueryFields(variables, parameters)
67
+ fields.bindings = await sdk.queries.enrichContext(variables, parameters)
113
68
  // check for arrays in the data
114
69
  let updated: string[] = []
115
70
  for (let i = 0; i < variables.length; i++) {