@budibase/server 2.6.19-alpha.5 → 2.6.19-alpha.50

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 (414) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/index.6ebb99b3.css +6 -0
  4. package/builder/assets/index.a7585108.js +1869 -0
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32529 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +45001 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24417 -0
  12. package/dist/query.js.map +7 -0
  13. package/jest.config.ts +3 -0
  14. package/nodemon.json +1 -1
  15. package/package.json +33 -15
  16. package/pm2.config.js +1 -1
  17. package/scripts/build.js +48 -0
  18. package/src/api/controllers/application.ts +21 -22
  19. package/src/api/controllers/automation.ts +37 -9
  20. package/src/api/controllers/datasource.ts +25 -15
  21. package/src/api/controllers/deploy/index.ts +1 -0
  22. package/src/api/controllers/plugin/index.ts +1 -1
  23. package/src/api/controllers/row/external.ts +39 -15
  24. package/src/api/controllers/row/index.ts +18 -24
  25. package/src/api/controllers/row/internal.ts +1 -1
  26. package/src/api/controllers/row/staticFormula.ts +6 -1
  27. package/src/api/controllers/row/utils.ts +12 -0
  28. package/src/api/controllers/static/index.ts +3 -3
  29. package/src/api/controllers/table/index.ts +3 -0
  30. package/src/api/controllers/table/internal.ts +2 -6
  31. package/src/api/controllers/table/utils.ts +32 -1
  32. package/src/api/controllers/view/index.ts +5 -5
  33. package/src/api/controllers/webhook.ts +33 -9
  34. package/src/api/routes/application.ts +5 -0
  35. package/src/api/routes/automation.ts +0 -1
  36. package/src/api/routes/datasource.ts +2 -2
  37. package/src/api/routes/static.ts +3 -1
  38. package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
  39. package/src/api/routes/tests/view.spec.js +4 -3
  40. package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
  41. package/src/app.ts +0 -1
  42. package/src/automations/actions.ts +8 -0
  43. package/src/automations/logging/index.ts +21 -0
  44. package/src/automations/steps/bash.ts +4 -0
  45. package/src/automations/steps/collect.ts +58 -0
  46. package/src/automations/steps/createRow.ts +4 -0
  47. package/src/automations/steps/delay.ts +1 -0
  48. package/src/automations/steps/deleteRow.ts +4 -0
  49. package/src/automations/steps/discord.ts +4 -0
  50. package/src/automations/steps/executeQuery.ts +4 -0
  51. package/src/automations/steps/executeScript.ts +4 -0
  52. package/src/automations/steps/filter.ts +1 -0
  53. package/src/automations/steps/loop.ts +1 -0
  54. package/src/automations/steps/make.ts +4 -0
  55. package/src/automations/steps/openai.ts +106 -0
  56. package/src/automations/steps/outgoingWebhook.ts +4 -0
  57. package/src/automations/steps/queryRows.ts +4 -0
  58. package/src/automations/steps/sendSmtpEmail.ts +4 -0
  59. package/src/automations/steps/serverLog.ts +4 -0
  60. package/src/automations/steps/slack.ts +4 -0
  61. package/src/automations/steps/updateRow.ts +4 -0
  62. package/src/automations/steps/zapier.ts +4 -0
  63. package/src/automations/tests/openai.spec.ts +86 -0
  64. package/src/automations/triggers.ts +3 -2
  65. package/src/constants/index.ts +17 -16
  66. package/src/db/inMemoryView.ts +1 -0
  67. package/src/db/linkedRows/index.ts +5 -3
  68. package/src/environment.ts +3 -0
  69. package/src/integration-test/postgres.spec.ts +5 -5
  70. package/src/integrations/airtable.ts +3 -1
  71. package/src/integrations/arangodb.ts +3 -1
  72. package/src/integrations/base/sqlTable.ts +0 -1
  73. package/src/integrations/couchdb.ts +3 -1
  74. package/src/integrations/dynamodb.ts +3 -1
  75. package/src/integrations/elasticsearch.ts +3 -1
  76. package/src/integrations/firebase.ts +3 -1
  77. package/src/integrations/googlesheets.ts +4 -4
  78. package/src/integrations/microsoftSqlServer.ts +4 -4
  79. package/src/integrations/mongodb.ts +3 -1
  80. package/src/integrations/mysql.ts +4 -4
  81. package/src/integrations/oracle.ts +4 -4
  82. package/src/integrations/postgres.ts +4 -4
  83. package/src/integrations/redis.ts +10 -2
  84. package/src/integrations/s3.ts +3 -1
  85. package/src/integrations/snowflake.ts +3 -1
  86. package/src/middleware/builder.ts +26 -18
  87. package/src/sdk/app/automations/index.ts +2 -0
  88. package/src/sdk/app/automations/utils.ts +7 -0
  89. package/src/sdk/plugins/plugins.ts +1 -1
  90. package/src/startup.ts +2 -0
  91. package/src/tests/utilities/TestConfiguration.ts +4 -2
  92. package/src/tests/utilities/structures.ts +42 -0
  93. package/src/threads/automation.ts +91 -23
  94. package/src/threads/index.ts +9 -3
  95. package/src/threads/utils.ts +2 -0
  96. package/src/utilities/fileSystem/app.ts +14 -4
  97. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  98. package/src/utilities/fileSystem/filesystem.ts +3 -1
  99. package/src/utilities/redis.ts +25 -3
  100. package/src/utilities/rowProcessor/index.ts +4 -1
  101. package/src/utilities/rowProcessor/map.ts +1 -1
  102. package/src/websockets/builder.ts +77 -0
  103. package/src/websockets/client.ts +2 -2
  104. package/src/websockets/grid.ts +44 -44
  105. package/src/websockets/index.ts +13 -6
  106. package/src/websockets/websocket.ts +207 -7
  107. package/tsconfig.build.json +9 -1
  108. package/tsconfig.json +1 -14
  109. package/builder/assets/index.07382a47.css +0 -6
  110. package/builder/assets/index.3d5c50fb.js +0 -1786
  111. package/dist/api/controllers/analytics.js +0 -46
  112. package/dist/api/controllers/apikeys.js +0 -72
  113. package/dist/api/controllers/application.js +0 -574
  114. package/dist/api/controllers/auth.js +0 -80
  115. package/dist/api/controllers/automation.js +0 -303
  116. package/dist/api/controllers/backup.js +0 -37
  117. package/dist/api/controllers/component.js +0 -59
  118. package/dist/api/controllers/datasource.js +0 -352
  119. package/dist/api/controllers/deploy/Deployment.js +0 -53
  120. package/dist/api/controllers/deploy/index.js +0 -198
  121. package/dist/api/controllers/dev.js +0 -146
  122. package/dist/api/controllers/integration.js +0 -28
  123. package/dist/api/controllers/layout.js +0 -49
  124. package/dist/api/controllers/metadata.js +0 -63
  125. package/dist/api/controllers/migrations.js +0 -29
  126. package/dist/api/controllers/ops.js +0 -40
  127. package/dist/api/controllers/permission.js +0 -162
  128. package/dist/api/controllers/plugin/file.js +0 -24
  129. package/dist/api/controllers/plugin/github.js +0 -69
  130. package/dist/api/controllers/plugin/index.js +0 -112
  131. package/dist/api/controllers/plugin/npm.js +0 -58
  132. package/dist/api/controllers/plugin/uploaders.js +0 -11
  133. package/dist/api/controllers/plugin/url.js +0 -24
  134. package/dist/api/controllers/plugin/utils.js +0 -27
  135. package/dist/api/controllers/public/applications.js +0 -146
  136. package/dist/api/controllers/public/mapping/applications.js +0 -29
  137. package/dist/api/controllers/public/mapping/index.js +0 -11
  138. package/dist/api/controllers/public/mapping/queries.js +0 -36
  139. package/dist/api/controllers/public/mapping/rows.js +0 -24
  140. package/dist/api/controllers/public/mapping/tables.js +0 -23
  141. package/dist/api/controllers/public/mapping/types.js +0 -2
  142. package/dist/api/controllers/public/mapping/users.js +0 -29
  143. package/dist/api/controllers/public/metrics.js +0 -113
  144. package/dist/api/controllers/public/queries.js +0 -58
  145. package/dist/api/controllers/public/rows.js +0 -120
  146. package/dist/api/controllers/public/tables.js +0 -95
  147. package/dist/api/controllers/public/users.js +0 -93
  148. package/dist/api/controllers/public/utils.js +0 -56
  149. package/dist/api/controllers/query/import/index.js +0 -87
  150. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  151. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  152. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  153. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  154. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  155. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  156. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  157. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  158. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  159. package/dist/api/controllers/query/index.js +0 -299
  160. package/dist/api/controllers/query/validation.js +0 -53
  161. package/dist/api/controllers/role.js +0 -109
  162. package/dist/api/controllers/routing.js +0 -105
  163. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  164. package/dist/api/controllers/row/external.js +0 -339
  165. package/dist/api/controllers/row/index.js +0 -203
  166. package/dist/api/controllers/row/internal.js +0 -509
  167. package/dist/api/controllers/row/internalSearch.js +0 -28
  168. package/dist/api/controllers/row/staticFormula.js +0 -165
  169. package/dist/api/controllers/row/utils.js +0 -183
  170. package/dist/api/controllers/screen.js +0 -110
  171. package/dist/api/controllers/script.js +0 -30
  172. package/dist/api/controllers/static/index.js +0 -268
  173. package/dist/api/controllers/table/bulkFormula.js +0 -173
  174. package/dist/api/controllers/table/external.js +0 -279
  175. package/dist/api/controllers/table/index.js +0 -179
  176. package/dist/api/controllers/table/internal.js +0 -197
  177. package/dist/api/controllers/table/utils.js +0 -379
  178. package/dist/api/controllers/templates.js +0 -56
  179. package/dist/api/controllers/user.js +0 -124
  180. package/dist/api/controllers/view/exporters.js +0 -46
  181. package/dist/api/controllers/view/index.js +0 -193
  182. package/dist/api/controllers/view/utils.js +0 -177
  183. package/dist/api/controllers/view/viewBuilder.js +0 -158
  184. package/dist/api/controllers/webhook.js +0 -134
  185. package/dist/api/index.js +0 -55
  186. package/dist/api/routes/analytics.js +0 -34
  187. package/dist/api/routes/apikeys.js +0 -37
  188. package/dist/api/routes/application.js +0 -48
  189. package/dist/api/routes/auth.js +0 -33
  190. package/dist/api/routes/automation.js +0 -50
  191. package/dist/api/routes/backup.js +0 -35
  192. package/dist/api/routes/component.js +0 -35
  193. package/dist/api/routes/datasource.js +0 -45
  194. package/dist/api/routes/deploy.js +0 -37
  195. package/dist/api/routes/dev.js +0 -49
  196. package/dist/api/routes/index.js +0 -75
  197. package/dist/api/routes/integration.js +0 -37
  198. package/dist/api/routes/layout.js +0 -37
  199. package/dist/api/routes/metadata.js +0 -40
  200. package/dist/api/routes/migrations.js +0 -36
  201. package/dist/api/routes/ops.js +0 -52
  202. package/dist/api/routes/permission.js +0 -44
  203. package/dist/api/routes/plugin.js +0 -39
  204. package/dist/api/routes/public/applications.js +0 -174
  205. package/dist/api/routes/public/index.js +0 -140
  206. package/dist/api/routes/public/metrics.js +0 -30
  207. package/dist/api/routes/public/middleware/mapper.js +0 -97
  208. package/dist/api/routes/public/queries.js +0 -72
  209. package/dist/api/routes/public/rows.js +0 -158
  210. package/dist/api/routes/public/tables.js +0 -152
  211. package/dist/api/routes/public/users.js +0 -135
  212. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  213. package/dist/api/routes/query.js +0 -47
  214. package/dist/api/routes/role.js +0 -40
  215. package/dist/api/routes/routing.js +0 -39
  216. package/dist/api/routes/row.js +0 -239
  217. package/dist/api/routes/screen.js +0 -39
  218. package/dist/api/routes/script.js +0 -35
  219. package/dist/api/routes/static.js +0 -80
  220. package/dist/api/routes/table.js +0 -163
  221. package/dist/api/routes/templates.js +0 -37
  222. package/dist/api/routes/user.js +0 -43
  223. package/dist/api/routes/utils/validators.js +0 -238
  224. package/dist/api/routes/view.js +0 -42
  225. package/dist/api/routes/webhook.js +0 -43
  226. package/dist/app.js +0 -132
  227. package/dist/automations/actions.js +0 -137
  228. package/dist/automations/automationUtils.js +0 -173
  229. package/dist/automations/bullboard.js +0 -71
  230. package/dist/automations/index.js +0 -43
  231. package/dist/automations/logging/index.js +0 -53
  232. package/dist/automations/steps/bash.js +0 -111
  233. package/dist/automations/steps/createRow.js +0 -108
  234. package/dist/automations/steps/delay.js +0 -53
  235. package/dist/automations/steps/deleteRow.js +0 -96
  236. package/dist/automations/steps/discord.js +0 -116
  237. package/dist/automations/steps/executeQuery.js +0 -134
  238. package/dist/automations/steps/executeScript.js +0 -106
  239. package/dist/automations/steps/filter.js +0 -112
  240. package/dist/automations/steps/loop.js +0 -54
  241. package/dist/automations/steps/make.js +0 -134
  242. package/dist/automations/steps/outgoingWebhook.js +0 -166
  243. package/dist/automations/steps/queryRows.js +0 -216
  244. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  245. package/dist/automations/steps/serverLog.js +0 -65
  246. package/dist/automations/steps/slack.js +0 -98
  247. package/dist/automations/steps/updateRow.js +0 -144
  248. package/dist/automations/steps/utils.js +0 -56
  249. package/dist/automations/steps/zapier.js +0 -130
  250. package/dist/automations/triggerInfo/app.js +0 -36
  251. package/dist/automations/triggerInfo/cron.js +0 -35
  252. package/dist/automations/triggerInfo/index.js +0 -40
  253. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  254. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  255. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  256. package/dist/automations/triggerInfo/webhook.js +0 -40
  257. package/dist/automations/triggers.js +0 -181
  258. package/dist/automations/utils.js +0 -275
  259. package/dist/constants/definitions.js +0 -2
  260. package/dist/constants/index.js +0 -181
  261. package/dist/constants/layouts.js +0 -148
  262. package/dist/constants/screens.js +0 -51
  263. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  264. package/dist/db/defaultData/employeeImport.js +0 -155
  265. package/dist/db/defaultData/expensesImport.js +0 -117
  266. package/dist/db/defaultData/inventoryImport.js +0 -109
  267. package/dist/db/defaultData/jobsImport.js +0 -152
  268. package/dist/db/dynamoClient.js +0 -124
  269. package/dist/db/inMemoryView.js +0 -62
  270. package/dist/db/index.js +0 -43
  271. package/dist/db/linkedRows/LinkController.js +0 -392
  272. package/dist/db/linkedRows/LinkDocument.js +0 -33
  273. package/dist/db/linkedRows/index.js +0 -206
  274. package/dist/db/linkedRows/linkUtils.js +0 -131
  275. package/dist/db/newid.js +0 -7
  276. package/dist/db/utils.js +0 -248
  277. package/dist/db/views/staticViews.js +0 -144
  278. package/dist/ddApm.js +0 -11
  279. package/dist/definitions/automations.js +0 -8
  280. package/dist/definitions/common.js +0 -2
  281. package/dist/definitions/datasource.js +0 -7
  282. package/dist/definitions/openapi.js +0 -6
  283. package/dist/environment.js +0 -109
  284. package/dist/events/AutomationEmitter.js +0 -53
  285. package/dist/events/BudibaseEmitter.js +0 -25
  286. package/dist/events/docUpdates/index.js +0 -17
  287. package/dist/events/docUpdates/processors.js +0 -18
  288. package/dist/events/docUpdates/syncUsers.js +0 -49
  289. package/dist/events/index.js +0 -11
  290. package/dist/events/utils.js +0 -43
  291. package/dist/integrations/airtable.js +0 -173
  292. package/dist/integrations/arangodb.js +0 -119
  293. package/dist/integrations/base/query.js +0 -32
  294. package/dist/integrations/base/sql.js +0 -600
  295. package/dist/integrations/base/sqlTable.js +0 -167
  296. package/dist/integrations/base/types.js +0 -2
  297. package/dist/integrations/couchdb.js +0 -140
  298. package/dist/integrations/dynamodb.js +0 -210
  299. package/dist/integrations/elasticsearch.js +0 -201
  300. package/dist/integrations/firebase.js +0 -189
  301. package/dist/integrations/googlesheets.js +0 -493
  302. package/dist/integrations/index.js +0 -138
  303. package/dist/integrations/microsoftSqlServer.js +0 -308
  304. package/dist/integrations/mongodb.js +0 -630
  305. package/dist/integrations/mysql.js +0 -291
  306. package/dist/integrations/oracle.js +0 -415
  307. package/dist/integrations/postgres.js +0 -335
  308. package/dist/integrations/queries/sql.js +0 -84
  309. package/dist/integrations/redis.js +0 -187
  310. package/dist/integrations/rest.js +0 -400
  311. package/dist/integrations/s3.js +0 -256
  312. package/dist/integrations/snowflake.js +0 -114
  313. package/dist/integrations/utils.js +0 -295
  314. package/dist/middleware/appInfo.js +0 -22
  315. package/dist/middleware/authorized.js +0 -112
  316. package/dist/middleware/builder.js +0 -93
  317. package/dist/middleware/currentapp.js +0 -103
  318. package/dist/middleware/joi-validator.js +0 -43
  319. package/dist/middleware/publicApi.js +0 -25
  320. package/dist/middleware/resourceId.js +0 -59
  321. package/dist/middleware/selfhost.js +0 -24
  322. package/dist/middleware/utils.js +0 -8
  323. package/dist/migrations/functions/appUrls.js +0 -42
  324. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  325. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  326. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  327. package/dist/migrations/functions/backfill/app/queries.js +0 -49
  328. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  329. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  330. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  331. package/dist/migrations/functions/backfill/app.js +0 -176
  332. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  333. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  334. package/dist/migrations/functions/backfill/global/users.js +0 -50
  335. package/dist/migrations/functions/backfill/global.js +0 -205
  336. package/dist/migrations/functions/backfill/index.js +0 -32
  337. package/dist/migrations/functions/backfill/installation.js +0 -80
  338. package/dist/migrations/functions/syncQuotas.js +0 -52
  339. package/dist/migrations/functions/tableSettings.js +0 -130
  340. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  341. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  342. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  343. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  344. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  345. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  346. package/dist/migrations/index.js +0 -111
  347. package/dist/migrations/tests/helpers.js +0 -72
  348. package/dist/migrations/tests/structures.js +0 -37
  349. package/dist/sdk/app/applications/index.js +0 -28
  350. package/dist/sdk/app/applications/sync.js +0 -164
  351. package/dist/sdk/app/applications/utils.js +0 -21
  352. package/dist/sdk/app/automations/index.js +0 -29
  353. package/dist/sdk/app/automations/webhook.js +0 -54
  354. package/dist/sdk/app/backups/constants.js +0 -6
  355. package/dist/sdk/app/backups/exports.js +0 -160
  356. package/dist/sdk/app/backups/imports.js +0 -170
  357. package/dist/sdk/app/backups/index.js +0 -29
  358. package/dist/sdk/app/backups/statistics.js +0 -73
  359. package/dist/sdk/app/datasources/datasources.js +0 -173
  360. package/dist/sdk/app/datasources/index.js +0 -27
  361. package/dist/sdk/app/queries/index.js +0 -27
  362. package/dist/sdk/app/queries/queries.js +0 -60
  363. package/dist/sdk/app/rows/attachments.js +0 -61
  364. package/dist/sdk/app/rows/index.js +0 -28
  365. package/dist/sdk/app/rows/rows.js +0 -30
  366. package/dist/sdk/app/tables/index.js +0 -65
  367. package/dist/sdk/index.js +0 -27
  368. package/dist/sdk/plugins/index.js +0 -27
  369. package/dist/sdk/plugins/plugins.js +0 -53
  370. package/dist/sdk/users/index.js +0 -27
  371. package/dist/sdk/users/utils.js +0 -87
  372. package/dist/sdk/utils/index.js +0 -29
  373. package/dist/startup.js +0 -158
  374. package/dist/threads/automation.js +0 -450
  375. package/dist/threads/definitions.js +0 -2
  376. package/dist/threads/index.js +0 -140
  377. package/dist/threads/query.js +0 -265
  378. package/dist/threads/utils.js +0 -120
  379. package/dist/tsconfig.build.tsbuildinfo +0 -1
  380. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  381. package/dist/utilities/budibaseDir.js +0 -5
  382. package/dist/utilities/centralPath.js +0 -27
  383. package/dist/utilities/csv.js +0 -33
  384. package/dist/utilities/fileSystem/app.js +0 -88
  385. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  386. package/dist/utilities/fileSystem/filesystem.js +0 -180
  387. package/dist/utilities/fileSystem/index.js +0 -21
  388. package/dist/utilities/fileSystem/plugin.js +0 -76
  389. package/dist/utilities/fileSystem/processor.js +0 -34
  390. package/dist/utilities/fileSystem/template.js +0 -47
  391. package/dist/utilities/global.js +0 -149
  392. package/dist/utilities/index.js +0 -143
  393. package/dist/utilities/redis.js +0 -117
  394. package/dist/utilities/retry.js +0 -30
  395. package/dist/utilities/routing/index.js +0 -39
  396. package/dist/utilities/rowProcessor/index.js +0 -282
  397. package/dist/utilities/rowProcessor/map.js +0 -116
  398. package/dist/utilities/rowProcessor/utils.js +0 -87
  399. package/dist/utilities/schema.js +0 -112
  400. package/dist/utilities/scriptRunner.js +0 -26
  401. package/dist/utilities/security.js +0 -57
  402. package/dist/utilities/statusCodes.js +0 -9
  403. package/dist/utilities/usageQuota/rows.js +0 -88
  404. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  405. package/dist/utilities/users.js +0 -57
  406. package/dist/utilities/workerRequests.js +0 -171
  407. package/dist/watch.js +0 -53
  408. package/dist/websockets/client.js +0 -14
  409. package/dist/websockets/grid.js +0 -60
  410. package/dist/websockets/index.js +0 -17
  411. package/dist/websockets/websocket.js +0 -78
  412. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  413. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  414. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,167 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const knex_1 = require("knex");
4
- const types_1 = require("@budibase/types");
5
- const utils_1 = require("../utils");
6
- const constants_1 = require("../../constants");
7
- function generateSchema(schema, table, tables, oldTable = null, renamed) {
8
- let primaryKey = table && table.primary ? table.primary[0] : null;
9
- const columns = Object.values(table.schema);
10
- // all columns in a junction table will be meta
11
- let metaCols = columns.filter(col => col.meta);
12
- let isJunction = metaCols.length === columns.length;
13
- // can't change primary once its set for now
14
- if (primaryKey && !oldTable && !isJunction) {
15
- schema.increments(primaryKey).primary();
16
- }
17
- else if (!oldTable && isJunction) {
18
- schema.primary(metaCols.map(col => col.name));
19
- }
20
- // check if any columns need added
21
- const foreignKeys = Object.values(table.schema).map(col => col.foreignKey);
22
- for (let [key, column] of Object.entries(table.schema)) {
23
- // skip things that are already correct
24
- const oldColumn = oldTable ? oldTable.schema[key] : null;
25
- if ((oldColumn && oldColumn.type) ||
26
- (primaryKey === key && !isJunction) ||
27
- (renamed === null || renamed === void 0 ? void 0 : renamed.updated) === key) {
28
- continue;
29
- }
30
- switch (column.type) {
31
- case constants_1.FieldTypes.STRING:
32
- case constants_1.FieldTypes.OPTIONS:
33
- case constants_1.FieldTypes.LONGFORM:
34
- case constants_1.FieldTypes.BARCODEQR:
35
- schema.text(key);
36
- break;
37
- case constants_1.FieldTypes.NUMBER:
38
- // if meta is specified then this is a junction table entry
39
- if (column.meta && column.meta.toKey && column.meta.toTable) {
40
- const { toKey, toTable } = column.meta;
41
- schema.integer(key).unsigned();
42
- schema.foreign(key).references(`${toTable}.${toKey}`);
43
- }
44
- else if (foreignKeys.indexOf(key) === -1) {
45
- schema.float(key);
46
- }
47
- break;
48
- case constants_1.FieldTypes.BOOLEAN:
49
- schema.boolean(key);
50
- break;
51
- case constants_1.FieldTypes.DATETIME:
52
- schema.datetime(key, {
53
- useTz: !column.ignoreTimezones,
54
- });
55
- break;
56
- case constants_1.FieldTypes.ARRAY:
57
- schema.json(key);
58
- break;
59
- case constants_1.FieldTypes.LINK:
60
- // this side of the relationship doesn't need any SQL work
61
- if (column.relationshipType !== constants_1.RelationshipTypes.MANY_TO_ONE &&
62
- column.relationshipType !== constants_1.RelationshipTypes.MANY_TO_MANY) {
63
- if (!column.foreignKey || !column.tableId) {
64
- throw "Invalid relationship schema";
65
- }
66
- const { tableName } = (0, utils_1.breakExternalTableId)(column.tableId);
67
- // @ts-ignore
68
- const relatedTable = tables[tableName];
69
- if (!relatedTable) {
70
- throw "Referenced table doesn't exist";
71
- }
72
- const relatedPrimary = relatedTable.primary[0];
73
- const externalType = relatedTable.schema[relatedPrimary].externalType;
74
- if (externalType) {
75
- schema.specificType(column.foreignKey, externalType);
76
- }
77
- else {
78
- schema.integer(column.foreignKey).unsigned();
79
- }
80
- schema
81
- .foreign(column.foreignKey)
82
- .references(`${tableName}.${relatedPrimary}`);
83
- }
84
- break;
85
- }
86
- }
87
- if (renamed) {
88
- schema.renameColumn(renamed.old, renamed.updated);
89
- }
90
- // need to check if any columns have been deleted
91
- if (oldTable) {
92
- const deletedColumns = Object.entries(oldTable.schema)
93
- .filter(([key, schema]) => schema.type !== constants_1.FieldTypes.LINK &&
94
- schema.type !== constants_1.FieldTypes.FORMULA &&
95
- table.schema[key] == null)
96
- .map(([key]) => key);
97
- deletedColumns.forEach(key => {
98
- if ((renamed === null || renamed === void 0 ? void 0 : renamed.old) === key) {
99
- return;
100
- }
101
- if (oldTable.constrained && oldTable.constrained.indexOf(key) !== -1) {
102
- schema.dropForeign(key);
103
- }
104
- schema.dropColumn(key);
105
- });
106
- }
107
- return schema;
108
- }
109
- function buildCreateTable(knex, table, tables) {
110
- return knex.createTable(table.name, schema => {
111
- generateSchema(schema, table, tables);
112
- });
113
- }
114
- function buildUpdateTable(knex, table, tables, oldTable, renamed) {
115
- return knex.alterTable(table.name, schema => {
116
- generateSchema(schema, table, tables, oldTable, renamed);
117
- });
118
- }
119
- function buildDeleteTable(knex, table) {
120
- return knex.dropTable(table.name);
121
- }
122
- class SqlTableQueryBuilder {
123
- // pass through client to get flavour of SQL
124
- constructor(client) {
125
- this.sqlClient = client;
126
- }
127
- getSqlClient() {
128
- return this.sqlClient;
129
- }
130
- /**
131
- * @param json the input JSON structure from which an SQL query will be built.
132
- * @return {string} the operation that was found in the JSON.
133
- */
134
- _operation(json) {
135
- return json.endpoint.operation;
136
- }
137
- _tableQuery(json) {
138
- var _a;
139
- let client = (0, knex_1.knex)({ client: this.sqlClient }).schema;
140
- if ((_a = json === null || json === void 0 ? void 0 : json.endpoint) === null || _a === void 0 ? void 0 : _a.schema) {
141
- client = client.withSchema(json.endpoint.schema);
142
- }
143
- let query;
144
- if (!json.table || !json.meta || !json.meta.tables) {
145
- throw "Cannot execute without table being specified";
146
- }
147
- switch (this._operation(json)) {
148
- case types_1.Operation.CREATE_TABLE:
149
- query = buildCreateTable(client, json.table, json.meta.tables);
150
- break;
151
- case types_1.Operation.UPDATE_TABLE:
152
- if (!json.meta || !json.meta.table) {
153
- throw "Must specify old table for update";
154
- }
155
- query = buildUpdateTable(client, json.table, json.meta.tables, json.meta.table, json.meta.renamed);
156
- break;
157
- case types_1.Operation.DELETE_TABLE:
158
- query = buildDeleteTable(client, json.table);
159
- break;
160
- default:
161
- throw "Table operation is of unknown type";
162
- }
163
- return query.toSQL();
164
- }
165
- }
166
- exports.default = SqlTableQueryBuilder;
167
- module.exports = SqlTableQueryBuilder;
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,140 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- const types_1 = require("@budibase/types");
13
- const backend_core_1 = require("@budibase/backend-core");
14
- const SCHEMA = {
15
- docs: "https://docs.couchdb.org/en/stable/",
16
- friendlyName: "CouchDB",
17
- type: "Non-relational",
18
- description: "Apache CouchDB is an open-source document-oriented NoSQL database, implemented in Erlang.",
19
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
20
- datasource: {
21
- url: {
22
- type: types_1.DatasourceFieldType.STRING,
23
- required: true,
24
- default: "http://localhost:5984",
25
- },
26
- database: {
27
- type: types_1.DatasourceFieldType.STRING,
28
- required: true,
29
- },
30
- },
31
- query: {
32
- create: {
33
- type: types_1.QueryType.JSON,
34
- },
35
- read: {
36
- type: types_1.QueryType.JSON,
37
- },
38
- update: {
39
- type: types_1.QueryType.JSON,
40
- },
41
- get: {
42
- type: types_1.QueryType.FIELDS,
43
- fields: {
44
- id: {
45
- type: types_1.DatasourceFieldType.STRING,
46
- required: true,
47
- },
48
- },
49
- },
50
- delete: {
51
- type: types_1.QueryType.FIELDS,
52
- fields: {
53
- id: {
54
- type: types_1.DatasourceFieldType.STRING,
55
- required: true,
56
- },
57
- },
58
- },
59
- },
60
- };
61
- class CouchDBIntegration {
62
- constructor(config) {
63
- this.client = backend_core_1.db.DatabaseWithConnection(config.database, config.url);
64
- }
65
- testConnection() {
66
- return __awaiter(this, void 0, void 0, function* () {
67
- const response = {
68
- connected: false,
69
- };
70
- try {
71
- const result = yield this.query("exists", "validation error", {});
72
- response.connected = result === true;
73
- }
74
- catch (e) {
75
- response.error = e.message;
76
- }
77
- return response;
78
- });
79
- }
80
- query(command, errorMsg, query) {
81
- return __awaiter(this, void 0, void 0, function* () {
82
- try {
83
- return yield this.client[command](query.id || query.json);
84
- }
85
- catch (err) {
86
- console.error(errorMsg, err);
87
- throw err;
88
- }
89
- });
90
- }
91
- parse(query) {
92
- return typeof query.json === "string" ? JSON.parse(query.json) : query.json;
93
- }
94
- create(query) {
95
- return __awaiter(this, void 0, void 0, function* () {
96
- const parsed = this.parse(query);
97
- return this.query("post", "Error writing to couchDB", { json: parsed });
98
- });
99
- }
100
- read(query) {
101
- return __awaiter(this, void 0, void 0, function* () {
102
- const parsed = this.parse(query);
103
- const result = yield this.query("allDocs", "Error querying couchDB", {
104
- json: Object.assign({ include_docs: true }, parsed),
105
- });
106
- return result.rows.map((row) => row.doc);
107
- });
108
- }
109
- update(query) {
110
- return __awaiter(this, void 0, void 0, function* () {
111
- const parsed = this.parse(query);
112
- if (!(parsed === null || parsed === void 0 ? void 0 : parsed._rev) && (parsed === null || parsed === void 0 ? void 0 : parsed._id)) {
113
- const oldDoc = yield this.get({ id: parsed._id });
114
- parsed._rev = oldDoc._rev;
115
- }
116
- return this.query("put", "Error updating couchDB document", {
117
- json: parsed,
118
- });
119
- });
120
- }
121
- get(query) {
122
- return __awaiter(this, void 0, void 0, function* () {
123
- return this.query("get", "Error retrieving couchDB document by ID", {
124
- id: query.id,
125
- });
126
- });
127
- }
128
- delete(query) {
129
- return __awaiter(this, void 0, void 0, function* () {
130
- const doc = yield this.query("get", "Cannot find doc to be deleted", query);
131
- return this.query("remove", "Error deleting couchDB document", {
132
- json: doc,
133
- });
134
- });
135
- }
136
- }
137
- exports.default = {
138
- schema: SCHEMA,
139
- integration: CouchDBIntegration,
140
- };
@@ -1,210 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- const types_1 = require("@budibase/types");
16
- const aws_sdk_1 = __importDefault(require("aws-sdk"));
17
- const dynamoClient_1 = require("../db/dynamoClient");
18
- const SCHEMA = {
19
- docs: "https://github.com/dabit3/dynamodb-documentclient-cheat-sheet",
20
- description: "Amazon DynamoDB is a key-value and document database that delivers single-digit millisecond performance at any scale.",
21
- friendlyName: "DynamoDB",
22
- type: "Non-relational",
23
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
24
- datasource: {
25
- region: {
26
- type: types_1.DatasourceFieldType.STRING,
27
- required: true,
28
- default: "us-east-1",
29
- },
30
- accessKeyId: {
31
- type: types_1.DatasourceFieldType.PASSWORD,
32
- required: true,
33
- },
34
- secretAccessKey: {
35
- type: types_1.DatasourceFieldType.PASSWORD,
36
- required: true,
37
- },
38
- endpoint: {
39
- type: types_1.DatasourceFieldType.STRING,
40
- required: false,
41
- default: "https://dynamodb.us-east-1.amazonaws.com",
42
- },
43
- },
44
- query: {
45
- create: {
46
- type: types_1.QueryType.FIELDS,
47
- customisable: true,
48
- fields: {
49
- table: {
50
- type: types_1.DatasourceFieldType.STRING,
51
- required: true,
52
- },
53
- },
54
- },
55
- read: {
56
- type: types_1.QueryType.FIELDS,
57
- customisable: true,
58
- readable: true,
59
- fields: {
60
- table: {
61
- type: types_1.DatasourceFieldType.STRING,
62
- required: true,
63
- },
64
- index: {
65
- type: types_1.DatasourceFieldType.STRING,
66
- },
67
- },
68
- },
69
- scan: {
70
- type: types_1.QueryType.FIELDS,
71
- customisable: true,
72
- readable: true,
73
- fields: {
74
- table: {
75
- type: types_1.DatasourceFieldType.STRING,
76
- required: true,
77
- },
78
- index: {
79
- type: types_1.DatasourceFieldType.STRING,
80
- },
81
- },
82
- },
83
- describe: {
84
- type: types_1.QueryType.FIELDS,
85
- customisable: true,
86
- readable: true,
87
- fields: {
88
- table: {
89
- type: types_1.DatasourceFieldType.STRING,
90
- required: true,
91
- },
92
- },
93
- },
94
- get: {
95
- type: types_1.QueryType.FIELDS,
96
- customisable: true,
97
- readable: true,
98
- fields: {
99
- table: {
100
- type: types_1.DatasourceFieldType.STRING,
101
- required: true,
102
- },
103
- },
104
- },
105
- update: {
106
- type: types_1.QueryType.FIELDS,
107
- customisable: true,
108
- fields: {
109
- table: {
110
- type: types_1.DatasourceFieldType.STRING,
111
- required: true,
112
- },
113
- },
114
- },
115
- delete: {
116
- type: types_1.QueryType.FIELDS,
117
- customisable: true,
118
- fields: {
119
- table: {
120
- type: types_1.DatasourceFieldType.STRING,
121
- required: true,
122
- },
123
- },
124
- },
125
- },
126
- };
127
- class DynamoDBIntegration {
128
- constructor(config) {
129
- var _a, _b;
130
- this.config = config;
131
- // User is using a local dynamoDB endpoint, don't auth with remote
132
- if ((_b = (_a = this.config) === null || _a === void 0 ? void 0 : _a.endpoint) === null || _b === void 0 ? void 0 : _b.includes("localhost")) {
133
- // @ts-ignore
134
- this.config = {};
135
- }
136
- this.config = Object.assign(Object.assign({}, this.config), { currentClockSkew: true, region: config.region || dynamoClient_1.AWS_REGION, endpoint: config.endpoint || undefined });
137
- this.client = new aws_sdk_1.default.DynamoDB.DocumentClient(this.config);
138
- }
139
- testConnection() {
140
- return __awaiter(this, void 0, void 0, function* () {
141
- const response = {
142
- connected: false,
143
- };
144
- try {
145
- const scanRes = yield new aws_sdk_1.default.DynamoDB(this.config).listTables().promise();
146
- response.connected = !!scanRes.$response;
147
- }
148
- catch (e) {
149
- response.error = e.message;
150
- }
151
- return response;
152
- });
153
- }
154
- create(query) {
155
- return __awaiter(this, void 0, void 0, function* () {
156
- const params = Object.assign({ TableName: query.table }, query.json);
157
- return this.client.put(params).promise();
158
- });
159
- }
160
- read(query) {
161
- return __awaiter(this, void 0, void 0, function* () {
162
- const params = Object.assign({ TableName: query.table, IndexName: query.index ? query.index : undefined }, query.json);
163
- const response = yield this.client.query(params).promise();
164
- if (response.Items) {
165
- return response.Items;
166
- }
167
- return response;
168
- });
169
- }
170
- scan(query) {
171
- return __awaiter(this, void 0, void 0, function* () {
172
- const params = Object.assign({ TableName: query.table, IndexName: query.index ? query.index : undefined }, query.json);
173
- const response = yield this.client.scan(params).promise();
174
- if (response.Items) {
175
- return response.Items;
176
- }
177
- return response;
178
- });
179
- }
180
- describe(query) {
181
- return __awaiter(this, void 0, void 0, function* () {
182
- const params = {
183
- TableName: query.table,
184
- };
185
- return new aws_sdk_1.default.DynamoDB(this.config).describeTable(params).promise();
186
- });
187
- }
188
- get(query) {
189
- return __awaiter(this, void 0, void 0, function* () {
190
- const params = Object.assign({ TableName: query.table }, query.json);
191
- return this.client.get(params).promise();
192
- });
193
- }
194
- update(query) {
195
- return __awaiter(this, void 0, void 0, function* () {
196
- const params = Object.assign({ TableName: query.table }, query.json);
197
- return this.client.update(params).promise();
198
- });
199
- }
200
- delete(query) {
201
- return __awaiter(this, void 0, void 0, function* () {
202
- const params = Object.assign({ TableName: query.table }, query.json);
203
- return this.client.delete(params).promise();
204
- });
205
- }
206
- }
207
- exports.default = {
208
- schema: SCHEMA,
209
- integration: DynamoDBIntegration,
210
- };