@budibase/server 2.6.19-alpha.3 → 2.6.19-alpha.31

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 (404) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/{index.71388c79.js → index.3dd3d237.js} +435 -428
  4. package/builder/assets/{index.07382a47.css → index.8469b14c.css} +2 -2
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32436 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +44735 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24367 -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 +32 -13
  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 +20 -0
  21. package/src/api/controllers/row/index.ts +15 -22
  22. package/src/api/controllers/row/internal.ts +1 -1
  23. package/src/api/controllers/row/utils.ts +12 -0
  24. package/src/api/controllers/static/index.ts +3 -3
  25. package/src/api/controllers/table/index.ts +3 -0
  26. package/src/api/controllers/table/internal.ts +2 -6
  27. package/src/api/controllers/table/utils.ts +32 -1
  28. package/src/api/controllers/view/index.ts +5 -5
  29. package/src/api/controllers/webhook.ts +33 -9
  30. package/src/api/routes/application.ts +5 -0
  31. package/src/api/routes/automation.ts +0 -1
  32. package/src/api/routes/datasource.ts +5 -0
  33. package/src/api/routes/static.ts +3 -1
  34. package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
  35. package/src/api/routes/tests/datasource.spec.ts +1 -1
  36. package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
  37. package/src/app.ts +0 -1
  38. package/src/automations/actions.ts +8 -0
  39. package/src/automations/logging/index.ts +21 -0
  40. package/src/automations/steps/bash.ts +4 -0
  41. package/src/automations/steps/collect.ts +58 -0
  42. package/src/automations/steps/createRow.ts +4 -0
  43. package/src/automations/steps/delay.ts +1 -0
  44. package/src/automations/steps/deleteRow.ts +4 -0
  45. package/src/automations/steps/discord.ts +4 -0
  46. package/src/automations/steps/executeQuery.ts +4 -0
  47. package/src/automations/steps/executeScript.ts +4 -0
  48. package/src/automations/steps/filter.ts +1 -0
  49. package/src/automations/steps/loop.ts +1 -0
  50. package/src/automations/steps/make.ts +4 -0
  51. package/src/automations/steps/openai.ts +106 -0
  52. package/src/automations/steps/outgoingWebhook.ts +4 -0
  53. package/src/automations/steps/queryRows.ts +4 -0
  54. package/src/automations/steps/sendSmtpEmail.ts +4 -0
  55. package/src/automations/steps/serverLog.ts +4 -0
  56. package/src/automations/steps/slack.ts +4 -0
  57. package/src/automations/steps/updateRow.ts +4 -0
  58. package/src/automations/steps/zapier.ts +4 -0
  59. package/src/automations/tests/openai.spec.ts +86 -0
  60. package/src/automations/triggers.ts +3 -2
  61. package/src/constants/index.ts +17 -16
  62. package/src/db/inMemoryView.ts +1 -0
  63. package/src/environment.ts +3 -0
  64. package/src/integration-test/postgres.spec.ts +47 -4
  65. package/src/integrations/airtable.ts +3 -1
  66. package/src/integrations/arangodb.ts +3 -1
  67. package/src/integrations/base/sqlTable.ts +0 -1
  68. package/src/integrations/couchdb.ts +3 -1
  69. package/src/integrations/dynamodb.ts +3 -1
  70. package/src/integrations/elasticsearch.ts +3 -1
  71. package/src/integrations/firebase.ts +3 -1
  72. package/src/integrations/googlesheets.ts +11 -3
  73. package/src/integrations/microsoftSqlServer.ts +18 -2
  74. package/src/integrations/mongodb.ts +3 -1
  75. package/src/integrations/mysql.ts +27 -11
  76. package/src/integrations/oracle.ts +11 -1
  77. package/src/integrations/postgres.ts +15 -1
  78. package/src/integrations/redis.ts +3 -1
  79. package/src/integrations/s3.ts +3 -1
  80. package/src/integrations/snowflake.ts +3 -1
  81. package/src/integrations/tests/googlesheets.spec.ts +41 -9
  82. package/src/middleware/builder.ts +4 -5
  83. package/src/sdk/app/automations/index.ts +2 -0
  84. package/src/sdk/app/automations/utils.ts +7 -0
  85. package/src/startup.ts +2 -0
  86. package/src/tests/utilities/TestConfiguration.ts +4 -2
  87. package/src/tests/utilities/structures.ts +42 -0
  88. package/src/threads/automation.ts +78 -22
  89. package/src/threads/index.ts +9 -3
  90. package/src/threads/utils.ts +2 -0
  91. package/src/utilities/fileSystem/app.ts +1 -1
  92. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  93. package/src/utilities/fileSystem/filesystem.ts +3 -1
  94. package/src/utilities/redis.ts +19 -2
  95. package/src/websockets/builder.ts +69 -0
  96. package/src/websockets/grid.ts +25 -7
  97. package/src/websockets/index.ts +5 -2
  98. package/src/websockets/websocket.ts +20 -4
  99. package/tsconfig.build.json +9 -1
  100. package/tsconfig.json +1 -14
  101. package/dist/api/controllers/analytics.js +0 -46
  102. package/dist/api/controllers/apikeys.js +0 -72
  103. package/dist/api/controllers/application.js +0 -574
  104. package/dist/api/controllers/auth.js +0 -80
  105. package/dist/api/controllers/automation.js +0 -303
  106. package/dist/api/controllers/backup.js +0 -37
  107. package/dist/api/controllers/component.js +0 -59
  108. package/dist/api/controllers/datasource.js +0 -337
  109. package/dist/api/controllers/deploy/Deployment.js +0 -53
  110. package/dist/api/controllers/deploy/index.js +0 -198
  111. package/dist/api/controllers/dev.js +0 -146
  112. package/dist/api/controllers/integration.js +0 -28
  113. package/dist/api/controllers/layout.js +0 -49
  114. package/dist/api/controllers/metadata.js +0 -63
  115. package/dist/api/controllers/migrations.js +0 -29
  116. package/dist/api/controllers/ops.js +0 -40
  117. package/dist/api/controllers/permission.js +0 -162
  118. package/dist/api/controllers/plugin/file.js +0 -24
  119. package/dist/api/controllers/plugin/github.js +0 -69
  120. package/dist/api/controllers/plugin/index.js +0 -112
  121. package/dist/api/controllers/plugin/npm.js +0 -58
  122. package/dist/api/controllers/plugin/uploaders.js +0 -11
  123. package/dist/api/controllers/plugin/url.js +0 -24
  124. package/dist/api/controllers/plugin/utils.js +0 -27
  125. package/dist/api/controllers/public/applications.js +0 -146
  126. package/dist/api/controllers/public/mapping/applications.js +0 -29
  127. package/dist/api/controllers/public/mapping/index.js +0 -11
  128. package/dist/api/controllers/public/mapping/queries.js +0 -36
  129. package/dist/api/controllers/public/mapping/rows.js +0 -24
  130. package/dist/api/controllers/public/mapping/tables.js +0 -23
  131. package/dist/api/controllers/public/mapping/types.js +0 -2
  132. package/dist/api/controllers/public/mapping/users.js +0 -29
  133. package/dist/api/controllers/public/metrics.js +0 -113
  134. package/dist/api/controllers/public/queries.js +0 -58
  135. package/dist/api/controllers/public/rows.js +0 -120
  136. package/dist/api/controllers/public/tables.js +0 -95
  137. package/dist/api/controllers/public/users.js +0 -93
  138. package/dist/api/controllers/public/utils.js +0 -56
  139. package/dist/api/controllers/query/import/index.js +0 -87
  140. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  141. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  142. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  143. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  144. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  145. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  146. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  147. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  148. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  149. package/dist/api/controllers/query/index.js +0 -299
  150. package/dist/api/controllers/query/validation.js +0 -53
  151. package/dist/api/controllers/role.js +0 -109
  152. package/dist/api/controllers/routing.js +0 -105
  153. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  154. package/dist/api/controllers/row/external.js +0 -339
  155. package/dist/api/controllers/row/index.js +0 -203
  156. package/dist/api/controllers/row/internal.js +0 -509
  157. package/dist/api/controllers/row/internalSearch.js +0 -28
  158. package/dist/api/controllers/row/staticFormula.js +0 -165
  159. package/dist/api/controllers/row/utils.js +0 -183
  160. package/dist/api/controllers/screen.js +0 -110
  161. package/dist/api/controllers/script.js +0 -30
  162. package/dist/api/controllers/static/index.js +0 -268
  163. package/dist/api/controllers/table/bulkFormula.js +0 -173
  164. package/dist/api/controllers/table/external.js +0 -279
  165. package/dist/api/controllers/table/index.js +0 -179
  166. package/dist/api/controllers/table/internal.js +0 -197
  167. package/dist/api/controllers/table/utils.js +0 -379
  168. package/dist/api/controllers/templates.js +0 -56
  169. package/dist/api/controllers/user.js +0 -124
  170. package/dist/api/controllers/view/exporters.js +0 -46
  171. package/dist/api/controllers/view/index.js +0 -193
  172. package/dist/api/controllers/view/utils.js +0 -177
  173. package/dist/api/controllers/view/viewBuilder.js +0 -158
  174. package/dist/api/controllers/webhook.js +0 -134
  175. package/dist/api/index.js +0 -55
  176. package/dist/api/routes/analytics.js +0 -34
  177. package/dist/api/routes/apikeys.js +0 -37
  178. package/dist/api/routes/application.js +0 -48
  179. package/dist/api/routes/auth.js +0 -33
  180. package/dist/api/routes/automation.js +0 -50
  181. package/dist/api/routes/backup.js +0 -35
  182. package/dist/api/routes/component.js +0 -35
  183. package/dist/api/routes/datasource.js +0 -44
  184. package/dist/api/routes/deploy.js +0 -37
  185. package/dist/api/routes/dev.js +0 -49
  186. package/dist/api/routes/index.js +0 -75
  187. package/dist/api/routes/integration.js +0 -37
  188. package/dist/api/routes/layout.js +0 -37
  189. package/dist/api/routes/metadata.js +0 -40
  190. package/dist/api/routes/migrations.js +0 -36
  191. package/dist/api/routes/ops.js +0 -52
  192. package/dist/api/routes/permission.js +0 -44
  193. package/dist/api/routes/plugin.js +0 -39
  194. package/dist/api/routes/public/applications.js +0 -174
  195. package/dist/api/routes/public/index.js +0 -140
  196. package/dist/api/routes/public/metrics.js +0 -30
  197. package/dist/api/routes/public/middleware/mapper.js +0 -97
  198. package/dist/api/routes/public/queries.js +0 -72
  199. package/dist/api/routes/public/rows.js +0 -158
  200. package/dist/api/routes/public/tables.js +0 -152
  201. package/dist/api/routes/public/users.js +0 -135
  202. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  203. package/dist/api/routes/query.js +0 -47
  204. package/dist/api/routes/role.js +0 -40
  205. package/dist/api/routes/routing.js +0 -39
  206. package/dist/api/routes/row.js +0 -239
  207. package/dist/api/routes/screen.js +0 -39
  208. package/dist/api/routes/script.js +0 -35
  209. package/dist/api/routes/static.js +0 -80
  210. package/dist/api/routes/table.js +0 -163
  211. package/dist/api/routes/templates.js +0 -37
  212. package/dist/api/routes/user.js +0 -43
  213. package/dist/api/routes/utils/validators.js +0 -238
  214. package/dist/api/routes/view.js +0 -42
  215. package/dist/api/routes/webhook.js +0 -43
  216. package/dist/app.js +0 -132
  217. package/dist/automations/actions.js +0 -137
  218. package/dist/automations/automationUtils.js +0 -173
  219. package/dist/automations/bullboard.js +0 -71
  220. package/dist/automations/index.js +0 -43
  221. package/dist/automations/logging/index.js +0 -53
  222. package/dist/automations/steps/bash.js +0 -111
  223. package/dist/automations/steps/createRow.js +0 -108
  224. package/dist/automations/steps/delay.js +0 -53
  225. package/dist/automations/steps/deleteRow.js +0 -96
  226. package/dist/automations/steps/discord.js +0 -116
  227. package/dist/automations/steps/executeQuery.js +0 -134
  228. package/dist/automations/steps/executeScript.js +0 -106
  229. package/dist/automations/steps/filter.js +0 -112
  230. package/dist/automations/steps/loop.js +0 -54
  231. package/dist/automations/steps/make.js +0 -134
  232. package/dist/automations/steps/outgoingWebhook.js +0 -166
  233. package/dist/automations/steps/queryRows.js +0 -216
  234. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  235. package/dist/automations/steps/serverLog.js +0 -65
  236. package/dist/automations/steps/slack.js +0 -98
  237. package/dist/automations/steps/updateRow.js +0 -144
  238. package/dist/automations/steps/utils.js +0 -56
  239. package/dist/automations/steps/zapier.js +0 -130
  240. package/dist/automations/triggerInfo/app.js +0 -36
  241. package/dist/automations/triggerInfo/cron.js +0 -35
  242. package/dist/automations/triggerInfo/index.js +0 -40
  243. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  244. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  245. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  246. package/dist/automations/triggerInfo/webhook.js +0 -40
  247. package/dist/automations/triggers.js +0 -181
  248. package/dist/automations/utils.js +0 -275
  249. package/dist/constants/definitions.js +0 -2
  250. package/dist/constants/index.js +0 -181
  251. package/dist/constants/layouts.js +0 -148
  252. package/dist/constants/screens.js +0 -51
  253. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  254. package/dist/db/defaultData/employeeImport.js +0 -155
  255. package/dist/db/defaultData/expensesImport.js +0 -117
  256. package/dist/db/defaultData/inventoryImport.js +0 -109
  257. package/dist/db/defaultData/jobsImport.js +0 -152
  258. package/dist/db/dynamoClient.js +0 -124
  259. package/dist/db/inMemoryView.js +0 -62
  260. package/dist/db/index.js +0 -43
  261. package/dist/db/linkedRows/LinkController.js +0 -392
  262. package/dist/db/linkedRows/LinkDocument.js +0 -33
  263. package/dist/db/linkedRows/index.js +0 -206
  264. package/dist/db/linkedRows/linkUtils.js +0 -131
  265. package/dist/db/newid.js +0 -7
  266. package/dist/db/utils.js +0 -248
  267. package/dist/db/views/staticViews.js +0 -144
  268. package/dist/ddApm.js +0 -11
  269. package/dist/definitions/automations.js +0 -8
  270. package/dist/definitions/common.js +0 -2
  271. package/dist/definitions/datasource.js +0 -7
  272. package/dist/definitions/openapi.js +0 -6
  273. package/dist/environment.js +0 -109
  274. package/dist/events/AutomationEmitter.js +0 -53
  275. package/dist/events/BudibaseEmitter.js +0 -25
  276. package/dist/events/docUpdates/index.js +0 -17
  277. package/dist/events/docUpdates/processors.js +0 -18
  278. package/dist/events/docUpdates/syncUsers.js +0 -49
  279. package/dist/events/index.js +0 -11
  280. package/dist/events/utils.js +0 -43
  281. package/dist/integrations/airtable.js +0 -173
  282. package/dist/integrations/arangodb.js +0 -119
  283. package/dist/integrations/base/query.js +0 -32
  284. package/dist/integrations/base/sql.js +0 -600
  285. package/dist/integrations/base/sqlTable.js +0 -167
  286. package/dist/integrations/base/types.js +0 -2
  287. package/dist/integrations/couchdb.js +0 -140
  288. package/dist/integrations/dynamodb.js +0 -210
  289. package/dist/integrations/elasticsearch.js +0 -201
  290. package/dist/integrations/firebase.js +0 -189
  291. package/dist/integrations/googlesheets.js +0 -484
  292. package/dist/integrations/index.js +0 -138
  293. package/dist/integrations/microsoftSqlServer.js +0 -289
  294. package/dist/integrations/mongodb.js +0 -630
  295. package/dist/integrations/mysql.js +0 -272
  296. package/dist/integrations/oracle.js +0 -404
  297. package/dist/integrations/postgres.js +0 -320
  298. package/dist/integrations/queries/sql.js +0 -84
  299. package/dist/integrations/redis.js +0 -187
  300. package/dist/integrations/rest.js +0 -400
  301. package/dist/integrations/s3.js +0 -256
  302. package/dist/integrations/snowflake.js +0 -114
  303. package/dist/integrations/utils.js +0 -295
  304. package/dist/middleware/appInfo.js +0 -22
  305. package/dist/middleware/authorized.js +0 -112
  306. package/dist/middleware/builder.js +0 -93
  307. package/dist/middleware/currentapp.js +0 -103
  308. package/dist/middleware/joi-validator.js +0 -43
  309. package/dist/middleware/publicApi.js +0 -25
  310. package/dist/middleware/resourceId.js +0 -59
  311. package/dist/middleware/selfhost.js +0 -24
  312. package/dist/middleware/utils.js +0 -8
  313. package/dist/migrations/functions/appUrls.js +0 -42
  314. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  315. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  316. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  317. package/dist/migrations/functions/backfill/app/queries.js +0 -49
  318. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  319. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  320. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  321. package/dist/migrations/functions/backfill/app.js +0 -176
  322. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  323. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  324. package/dist/migrations/functions/backfill/global/users.js +0 -50
  325. package/dist/migrations/functions/backfill/global.js +0 -205
  326. package/dist/migrations/functions/backfill/index.js +0 -32
  327. package/dist/migrations/functions/backfill/installation.js +0 -80
  328. package/dist/migrations/functions/syncQuotas.js +0 -52
  329. package/dist/migrations/functions/tableSettings.js +0 -130
  330. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  331. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  332. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  333. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  334. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  335. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  336. package/dist/migrations/index.js +0 -111
  337. package/dist/migrations/tests/helpers.js +0 -72
  338. package/dist/migrations/tests/structures.js +0 -37
  339. package/dist/sdk/app/applications/index.js +0 -28
  340. package/dist/sdk/app/applications/sync.js +0 -164
  341. package/dist/sdk/app/applications/utils.js +0 -21
  342. package/dist/sdk/app/automations/index.js +0 -29
  343. package/dist/sdk/app/automations/webhook.js +0 -54
  344. package/dist/sdk/app/backups/constants.js +0 -6
  345. package/dist/sdk/app/backups/exports.js +0 -160
  346. package/dist/sdk/app/backups/imports.js +0 -170
  347. package/dist/sdk/app/backups/index.js +0 -29
  348. package/dist/sdk/app/backups/statistics.js +0 -73
  349. package/dist/sdk/app/datasources/datasources.js +0 -173
  350. package/dist/sdk/app/datasources/index.js +0 -27
  351. package/dist/sdk/app/queries/index.js +0 -27
  352. package/dist/sdk/app/queries/queries.js +0 -60
  353. package/dist/sdk/app/rows/attachments.js +0 -61
  354. package/dist/sdk/app/rows/index.js +0 -28
  355. package/dist/sdk/app/rows/rows.js +0 -30
  356. package/dist/sdk/app/tables/index.js +0 -65
  357. package/dist/sdk/index.js +0 -27
  358. package/dist/sdk/plugins/index.js +0 -27
  359. package/dist/sdk/plugins/plugins.js +0 -53
  360. package/dist/sdk/users/index.js +0 -27
  361. package/dist/sdk/users/utils.js +0 -87
  362. package/dist/sdk/utils/index.js +0 -29
  363. package/dist/startup.js +0 -158
  364. package/dist/threads/automation.js +0 -450
  365. package/dist/threads/definitions.js +0 -2
  366. package/dist/threads/index.js +0 -140
  367. package/dist/threads/query.js +0 -265
  368. package/dist/threads/utils.js +0 -120
  369. package/dist/tsconfig.build.tsbuildinfo +0 -1
  370. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  371. package/dist/utilities/budibaseDir.js +0 -5
  372. package/dist/utilities/centralPath.js +0 -27
  373. package/dist/utilities/csv.js +0 -33
  374. package/dist/utilities/fileSystem/app.js +0 -88
  375. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  376. package/dist/utilities/fileSystem/filesystem.js +0 -180
  377. package/dist/utilities/fileSystem/index.js +0 -21
  378. package/dist/utilities/fileSystem/plugin.js +0 -76
  379. package/dist/utilities/fileSystem/processor.js +0 -34
  380. package/dist/utilities/fileSystem/template.js +0 -47
  381. package/dist/utilities/global.js +0 -149
  382. package/dist/utilities/index.js +0 -143
  383. package/dist/utilities/redis.js +0 -117
  384. package/dist/utilities/retry.js +0 -30
  385. package/dist/utilities/routing/index.js +0 -39
  386. package/dist/utilities/rowProcessor/index.js +0 -282
  387. package/dist/utilities/rowProcessor/map.js +0 -116
  388. package/dist/utilities/rowProcessor/utils.js +0 -87
  389. package/dist/utilities/schema.js +0 -112
  390. package/dist/utilities/scriptRunner.js +0 -26
  391. package/dist/utilities/security.js +0 -57
  392. package/dist/utilities/statusCodes.js +0 -9
  393. package/dist/utilities/usageQuota/rows.js +0 -88
  394. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  395. package/dist/utilities/users.js +0 -57
  396. package/dist/utilities/workerRequests.js +0 -171
  397. package/dist/watch.js +0 -53
  398. package/dist/websockets/client.js +0 -14
  399. package/dist/websockets/grid.js +0 -60
  400. package/dist/websockets/index.js +0 -17
  401. package/dist/websockets/websocket.js +0 -78
  402. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  403. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  404. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,320 +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 utils_1 = require("./utils");
17
- const sql_1 = __importDefault(require("./base/sql"));
18
- const utilities_1 = require("../utilities");
19
- const pg_1 = require("pg");
20
- // Return "date" and "timestamp" types as plain strings.
21
- // This lets us reference the original stored timezone.
22
- // types is undefined when running in a test env for some reason.
23
- if (pg_1.types) {
24
- pg_1.types.setTypeParser(1114, (val) => val); // timestamp
25
- pg_1.types.setTypeParser(1082, (val) => val); // date
26
- pg_1.types.setTypeParser(1184, (val) => val); // timestampz
27
- }
28
- const JSON_REGEX = /'{.*}'::json/s;
29
- const SCHEMA = {
30
- docs: "https://node-postgres.com",
31
- plus: true,
32
- friendlyName: "PostgreSQL",
33
- type: "Relational",
34
- description: "PostgreSQL, also known as Postgres, is a free and open-source relational database management system emphasizing extensibility and SQL compliance.",
35
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
36
- datasource: {
37
- host: {
38
- type: types_1.DatasourceFieldType.STRING,
39
- default: "localhost",
40
- required: true,
41
- },
42
- port: {
43
- type: types_1.DatasourceFieldType.NUMBER,
44
- required: true,
45
- default: 5432,
46
- },
47
- database: {
48
- type: types_1.DatasourceFieldType.STRING,
49
- default: "postgres",
50
- required: true,
51
- },
52
- user: {
53
- type: types_1.DatasourceFieldType.STRING,
54
- default: "root",
55
- required: true,
56
- },
57
- password: {
58
- type: types_1.DatasourceFieldType.PASSWORD,
59
- default: "root",
60
- required: true,
61
- },
62
- schema: {
63
- type: types_1.DatasourceFieldType.STRING,
64
- default: "public",
65
- required: true,
66
- },
67
- ssl: {
68
- type: types_1.DatasourceFieldType.BOOLEAN,
69
- default: false,
70
- required: false,
71
- },
72
- rejectUnauthorized: {
73
- type: types_1.DatasourceFieldType.BOOLEAN,
74
- default: false,
75
- required: false,
76
- },
77
- ca: {
78
- type: types_1.DatasourceFieldType.LONGFORM,
79
- default: false,
80
- required: false,
81
- },
82
- },
83
- query: {
84
- create: {
85
- type: types_1.QueryType.SQL,
86
- },
87
- read: {
88
- type: types_1.QueryType.SQL,
89
- },
90
- update: {
91
- type: types_1.QueryType.SQL,
92
- },
93
- delete: {
94
- type: types_1.QueryType.SQL,
95
- },
96
- },
97
- };
98
- class PostgresIntegration extends sql_1.default {
99
- constructor(config) {
100
- super(utils_1.SqlClient.POSTGRES);
101
- this.index = 1;
102
- this.tables = {};
103
- this.schemaErrors = {};
104
- this.PRIMARY_KEYS_SQL = () => `
105
- SELECT pg_namespace.nspname table_schema
106
- , pg_class.relname table_name
107
- , pg_attribute.attname primary_key
108
- FROM pg_class
109
- JOIN pg_index ON pg_class.oid = pg_index.indrelid AND pg_index.indisprimary
110
- JOIN pg_attribute ON pg_attribute.attrelid = pg_class.oid AND pg_attribute.attnum = ANY(pg_index.indkey)
111
- JOIN pg_namespace ON pg_namespace.oid = pg_class.relnamespace
112
- WHERE pg_namespace.nspname = '${this.config.schema}';
113
- `;
114
- this.config = config;
115
- let newConfig = Object.assign(Object.assign({}, this.config), { ssl: this.config.ssl
116
- ? {
117
- rejectUnauthorized: this.config.rejectUnauthorized,
118
- ca: this.config.ca,
119
- }
120
- : undefined });
121
- this.client = new pg_1.Client(newConfig);
122
- this.open = false;
123
- }
124
- testConnection() {
125
- return __awaiter(this, void 0, void 0, function* () {
126
- const response = {
127
- connected: false,
128
- };
129
- try {
130
- yield this.openConnection();
131
- response.connected = true;
132
- }
133
- catch (e) {
134
- response.error = e.message;
135
- }
136
- finally {
137
- yield this.closeConnection();
138
- }
139
- return response;
140
- });
141
- }
142
- getBindingIdentifier() {
143
- return `$${this.index++}`;
144
- }
145
- getStringConcat(parts) {
146
- return parts.join(" || ");
147
- }
148
- openConnection() {
149
- return __awaiter(this, void 0, void 0, function* () {
150
- yield this.client.connect();
151
- if (!this.config.schema) {
152
- this.config.schema = "public";
153
- }
154
- yield this.client.query(`SET search_path TO ${this.config.schema}`);
155
- this.COLUMNS_SQL = `select * from information_schema.columns where table_schema = '${this.config.schema}'`;
156
- this.open = true;
157
- });
158
- }
159
- closeConnection() {
160
- const pg = this;
161
- return new Promise((resolve, reject) => {
162
- this.client.end((err) => {
163
- pg.open = false;
164
- if (err) {
165
- reject(err);
166
- }
167
- else {
168
- resolve();
169
- }
170
- });
171
- });
172
- }
173
- internalQuery(query, close = true) {
174
- return __awaiter(this, void 0, void 0, function* () {
175
- if (!this.open) {
176
- yield this.openConnection();
177
- }
178
- const client = this.client;
179
- this.index = 1;
180
- // need to handle a specific issue with json data types in postgres,
181
- // new lines inside the JSON data will break it
182
- if (query && query.sql) {
183
- const matches = query.sql.match(JSON_REGEX);
184
- if (matches && matches.length > 0) {
185
- for (let match of matches) {
186
- const escaped = (0, utilities_1.escapeDangerousCharacters)(match);
187
- query.sql = query.sql.replace(match, escaped);
188
- }
189
- }
190
- }
191
- try {
192
- return yield client.query(query.sql, query.bindings || []);
193
- }
194
- catch (err) {
195
- yield this.closeConnection();
196
- // @ts-ignore
197
- throw new Error(err);
198
- }
199
- finally {
200
- if (close) {
201
- yield this.closeConnection();
202
- }
203
- }
204
- });
205
- }
206
- /**
207
- * Fetches the tables from the postgres table and assigns them to the datasource.
208
- * @param {*} datasourceId - datasourceId to fetch
209
- * @param entities - the tables that are to be built
210
- */
211
- buildSchema(datasourceId, entities) {
212
- return __awaiter(this, void 0, void 0, function* () {
213
- let tableKeys = {};
214
- yield this.openConnection();
215
- try {
216
- const primaryKeysResponse = yield this.client.query(this.PRIMARY_KEYS_SQL());
217
- for (let table of primaryKeysResponse.rows) {
218
- const tableName = table.table_name;
219
- if (!tableKeys[tableName]) {
220
- tableKeys[tableName] = [];
221
- }
222
- const key = table.column_name || table.primary_key;
223
- // only add the unique keys
224
- if (key && tableKeys[tableName].indexOf(key) === -1) {
225
- tableKeys[tableName].push(key);
226
- }
227
- }
228
- }
229
- catch (err) {
230
- tableKeys = {};
231
- }
232
- try {
233
- const columnsResponse = yield this.client.query(this.COLUMNS_SQL);
234
- const tables = {};
235
- for (let column of columnsResponse.rows) {
236
- const tableName = column.table_name;
237
- const columnName = column.column_name;
238
- // table key doesn't exist yet
239
- if (!tables[tableName] || !tables[tableName].schema) {
240
- tables[tableName] = {
241
- _id: (0, utils_1.buildExternalTableId)(datasourceId, tableName),
242
- primary: tableKeys[tableName] || [],
243
- name: tableName,
244
- schema: {},
245
- };
246
- }
247
- const identity = !!(column.identity_generation ||
248
- column.identity_start ||
249
- column.identity_increment);
250
- const hasDefault = column.column_default != null;
251
- const hasNextVal = typeof column.column_default === "string" &&
252
- column.column_default.startsWith("nextval");
253
- const isGenerated = column.is_generated && column.is_generated !== "NEVER";
254
- const isAuto = hasNextVal || identity || isGenerated;
255
- const required = column.is_nullable === "NO";
256
- const constraints = {
257
- presence: required && !hasDefault && !isGenerated,
258
- };
259
- tables[tableName].schema[columnName] = Object.assign(Object.assign({ autocolumn: isAuto, name: columnName, constraints }, (0, utils_1.convertSqlType)(column.data_type)), { externalType: column.data_type });
260
- }
261
- const final = (0, utils_1.finaliseExternalTables)(tables, entities);
262
- this.tables = final.tables;
263
- this.schemaErrors = final.errors;
264
- }
265
- catch (err) {
266
- // @ts-ignore
267
- throw new Error(err);
268
- }
269
- finally {
270
- yield this.closeConnection();
271
- }
272
- });
273
- }
274
- create(query) {
275
- return __awaiter(this, void 0, void 0, function* () {
276
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
277
- return response.rows.length ? response.rows : [{ created: true }];
278
- });
279
- }
280
- read(query) {
281
- return __awaiter(this, void 0, void 0, function* () {
282
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
283
- return response.rows;
284
- });
285
- }
286
- update(query) {
287
- return __awaiter(this, void 0, void 0, function* () {
288
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
289
- return response.rows.length ? response.rows : [{ updated: true }];
290
- });
291
- }
292
- delete(query) {
293
- return __awaiter(this, void 0, void 0, function* () {
294
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
295
- return response.rows.length ? response.rows : [{ deleted: true }];
296
- });
297
- }
298
- query(json) {
299
- return __awaiter(this, void 0, void 0, function* () {
300
- const operation = this._operation(json).toLowerCase();
301
- const input = this._query(json);
302
- if (Array.isArray(input)) {
303
- const responses = [];
304
- for (let query of input) {
305
- responses.push(yield this.internalQuery(query, false));
306
- }
307
- yield this.closeConnection();
308
- return responses;
309
- }
310
- else {
311
- const response = yield this.internalQuery(input);
312
- return response.rows.length ? response.rows : [{ [operation]: true }];
313
- }
314
- });
315
- }
316
- }
317
- exports.default = {
318
- schema: SCHEMA,
319
- integration: PostgresIntegration,
320
- };
@@ -1,84 +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
- exports.interpolateSQL = void 0;
16
- const string_templates_1 = require("@budibase/string-templates");
17
- const sdk_1 = __importDefault(require("../../sdk"));
18
- const CONST_CHAR_REGEX = new RegExp("'[^']*'", "g");
19
- function interpolateSQL(fields, parameters, integration) {
20
- return __awaiter(this, void 0, void 0, function* () {
21
- let sql = fields.sql;
22
- if (!sql || typeof sql !== "string") {
23
- return fields;
24
- }
25
- const bindings = (0, string_templates_1.findHBSBlocks)(sql);
26
- let variables = [], arrays = [];
27
- for (let binding of bindings) {
28
- // look for array/list operations in the SQL statement, which will need handled later
29
- const listRegexMatch = sql.match(new RegExp(`(in|IN|In|iN)( )+[(]?${binding}[)]?`));
30
- // check if the variable was used as part of a string concat e.g. 'Hello {{binding}}'
31
- // start by finding all the instances of const character strings
32
- const charConstMatch = sql.match(CONST_CHAR_REGEX) || [];
33
- // now look within them to see if a binding is used
34
- const charConstBindingMatch = charConstMatch.find((string) => string.match(new RegExp(`'[^']*${binding}[^']*'`)));
35
- if (charConstBindingMatch) {
36
- let [part1, part2] = charConstBindingMatch.split(binding);
37
- part1 = `'${part1.substring(1)}'`;
38
- part2 = `'${part2.substring(0, part2.length - 1)}'`;
39
- sql = sql.replace(charConstBindingMatch, integration.getStringConcat([
40
- part1,
41
- integration.getBindingIdentifier(),
42
- part2,
43
- ]));
44
- }
45
- // generate SQL parameterised array
46
- else if (listRegexMatch) {
47
- arrays.push(binding);
48
- // determine the length of the array
49
- const value = (yield sdk_1.default.queries.enrichContext([binding], parameters))[0]
50
- .split(",")
51
- .map((val) => val.trim());
52
- // build a string like ($1, $2, $3)
53
- let replacement = `${Array.apply(null, Array(value.length))
54
- .map(() => integration.getBindingIdentifier())
55
- .join(",")}`;
56
- // check if parentheses are needed
57
- if (!listRegexMatch[0].includes(`(${binding})`)) {
58
- replacement = `(${replacement})`;
59
- }
60
- sql = sql.replace(binding, replacement);
61
- }
62
- else {
63
- sql = sql.replace(binding, integration.getBindingIdentifier());
64
- }
65
- variables.push(binding);
66
- }
67
- // replicate the knex structure
68
- fields.sql = sql;
69
- fields.bindings = yield sdk_1.default.queries.enrichContext(variables, parameters);
70
- // check for arrays in the data
71
- let updated = [];
72
- for (let i = 0; i < variables.length; i++) {
73
- if (arrays.includes(variables[i])) {
74
- updated = updated.concat(fields.bindings[i].split(",").map((val) => val.trim()));
75
- }
76
- else {
77
- updated.push(fields.bindings[i]);
78
- }
79
- }
80
- fields.bindings = updated;
81
- return fields;
82
- });
83
- }
84
- exports.interpolateSQL = interpolateSQL;
@@ -1,187 +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 ioredis_1 = __importDefault(require("ioredis"));
17
- const SCHEMA = {
18
- docs: "https://redis.io/docs/",
19
- description: "Redis is a caching tool, providing powerful key-value store capabilities.",
20
- friendlyName: "Redis",
21
- type: "Non-relational",
22
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
23
- datasource: {
24
- host: {
25
- type: "string",
26
- required: true,
27
- default: "localhost",
28
- },
29
- port: {
30
- type: "number",
31
- required: true,
32
- default: 6379,
33
- },
34
- username: {
35
- type: "string",
36
- required: false,
37
- },
38
- password: {
39
- type: "password",
40
- required: false,
41
- },
42
- db: {
43
- type: "number",
44
- required: false,
45
- display: "DB",
46
- default: 0,
47
- },
48
- },
49
- query: {
50
- create: {
51
- type: types_1.QueryType.FIELDS,
52
- fields: {
53
- key: {
54
- type: types_1.DatasourceFieldType.STRING,
55
- required: true,
56
- },
57
- value: {
58
- type: types_1.DatasourceFieldType.STRING,
59
- required: true,
60
- },
61
- ttl: {
62
- type: types_1.DatasourceFieldType.NUMBER,
63
- },
64
- },
65
- },
66
- read: {
67
- readable: true,
68
- type: types_1.QueryType.FIELDS,
69
- fields: {
70
- key: {
71
- type: types_1.DatasourceFieldType.STRING,
72
- required: true,
73
- },
74
- },
75
- },
76
- delete: {
77
- type: types_1.QueryType.FIELDS,
78
- fields: {
79
- key: {
80
- type: types_1.DatasourceFieldType.STRING,
81
- required: true,
82
- },
83
- },
84
- },
85
- command: {
86
- readable: true,
87
- displayName: "Redis Command",
88
- type: types_1.QueryType.JSON,
89
- },
90
- },
91
- };
92
- class RedisIntegration {
93
- constructor(config) {
94
- this.config = config;
95
- this.client = new ioredis_1.default({
96
- host: this.config.host,
97
- port: this.config.port,
98
- username: this.config.username,
99
- password: this.config.password,
100
- db: this.config.db,
101
- });
102
- }
103
- testConnection() {
104
- return __awaiter(this, void 0, void 0, function* () {
105
- const response = {
106
- connected: false,
107
- };
108
- try {
109
- yield this.client.ping();
110
- response.connected = true;
111
- }
112
- catch (e) {
113
- response.error = e.message;
114
- }
115
- finally {
116
- yield this.disconnect();
117
- }
118
- return response;
119
- });
120
- }
121
- disconnect() {
122
- return __awaiter(this, void 0, void 0, function* () {
123
- return this.client.quit();
124
- });
125
- }
126
- redisContext(query) {
127
- return __awaiter(this, void 0, void 0, function* () {
128
- try {
129
- return yield query();
130
- }
131
- catch (err) {
132
- throw new Error(`Redis error: ${err}`);
133
- }
134
- finally {
135
- yield this.disconnect();
136
- }
137
- });
138
- }
139
- create(query) {
140
- return __awaiter(this, void 0, void 0, function* () {
141
- return this.redisContext(() => __awaiter(this, void 0, void 0, function* () {
142
- const response = yield this.client.set(query.key, query.value);
143
- if (query.ttl) {
144
- yield this.client.expire(query.key, query.ttl);
145
- }
146
- return response;
147
- }));
148
- });
149
- }
150
- read(query) {
151
- return __awaiter(this, void 0, void 0, function* () {
152
- return this.redisContext(() => __awaiter(this, void 0, void 0, function* () {
153
- return yield this.client.get(query.key);
154
- }));
155
- });
156
- }
157
- delete(query) {
158
- return __awaiter(this, void 0, void 0, function* () {
159
- return this.redisContext(() => __awaiter(this, void 0, void 0, function* () {
160
- return yield this.client.del(query.key);
161
- }));
162
- });
163
- }
164
- command(query) {
165
- return __awaiter(this, void 0, void 0, function* () {
166
- return this.redisContext(() => __awaiter(this, void 0, void 0, function* () {
167
- // commands split line by line
168
- const commands = query.json.trim().split("\n");
169
- let pipelineCommands = [];
170
- // process each command separately
171
- for (let command of commands) {
172
- const tokenised = command.trim().split(" ");
173
- // Pipeline only accepts lower case commands
174
- tokenised[0] = tokenised[0].toLowerCase();
175
- pipelineCommands.push(tokenised);
176
- }
177
- const pipeline = this.client.pipeline(pipelineCommands);
178
- const result = yield pipeline.exec();
179
- return result.map((output) => output[1]);
180
- }));
181
- });
182
- }
183
- }
184
- exports.default = {
185
- schema: SCHEMA,
186
- integration: RedisIntegration,
187
- };