@budibase/server 2.6.22 → 2.6.24-alpha.0

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 (424) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/index.50121870.js +1869 -0
  4. package/builder/assets/index.a86e2071.css +6 -0
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32576 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +45065 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24462 -0
  12. package/dist/query.js.map +7 -0
  13. package/jest.config.ts +6 -3
  14. package/nodemon.json +8 -4
  15. package/package.json +35 -16
  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 +114 -49
  21. package/src/api/controllers/deploy/index.ts +1 -0
  22. package/src/api/controllers/integration.ts +3 -3
  23. package/src/api/controllers/plugin/index.ts +1 -1
  24. package/src/api/controllers/row/external.ts +39 -15
  25. package/src/api/controllers/row/index.ts +18 -24
  26. package/src/api/controllers/row/internal.ts +1 -1
  27. package/src/api/controllers/row/staticFormula.ts +6 -1
  28. package/src/api/controllers/row/utils.ts +12 -0
  29. package/src/api/controllers/static/index.ts +3 -3
  30. package/src/api/controllers/table/index.ts +3 -0
  31. package/src/api/controllers/table/internal.ts +2 -6
  32. package/src/api/controllers/table/utils.ts +32 -1
  33. package/src/api/controllers/view/index.ts +5 -5
  34. package/src/api/controllers/webhook.ts +33 -9
  35. package/src/api/routes/application.ts +5 -0
  36. package/src/api/routes/automation.ts +0 -1
  37. package/src/api/routes/datasource.ts +10 -0
  38. package/src/api/routes/static.ts +3 -1
  39. package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
  40. package/src/api/routes/tests/datasource.spec.ts +1 -1
  41. package/src/api/routes/tests/view.spec.js +4 -3
  42. package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
  43. package/src/app.ts +0 -1
  44. package/src/automations/actions.ts +8 -0
  45. package/src/automations/logging/index.ts +21 -0
  46. package/src/automations/steps/bash.ts +4 -0
  47. package/src/automations/steps/collect.ts +58 -0
  48. package/src/automations/steps/createRow.ts +4 -0
  49. package/src/automations/steps/delay.ts +1 -0
  50. package/src/automations/steps/deleteRow.ts +4 -0
  51. package/src/automations/steps/discord.ts +4 -0
  52. package/src/automations/steps/executeQuery.ts +4 -0
  53. package/src/automations/steps/executeScript.ts +4 -0
  54. package/src/automations/steps/filter.ts +1 -0
  55. package/src/automations/steps/loop.ts +1 -0
  56. package/src/automations/steps/make.ts +22 -1
  57. package/src/automations/steps/openai.ts +106 -0
  58. package/src/automations/steps/outgoingWebhook.ts +4 -0
  59. package/src/automations/steps/queryRows.ts +4 -0
  60. package/src/automations/steps/sendSmtpEmail.ts +4 -0
  61. package/src/automations/steps/serverLog.ts +4 -0
  62. package/src/automations/steps/slack.ts +4 -0
  63. package/src/automations/steps/updateRow.ts +4 -0
  64. package/src/automations/steps/zapier.ts +22 -1
  65. package/src/automations/tests/make.spec.ts +54 -0
  66. package/src/automations/tests/openai.spec.ts +86 -0
  67. package/src/automations/tests/zapier.spec.ts +56 -0
  68. package/src/automations/triggers.ts +3 -2
  69. package/src/constants/index.ts +17 -16
  70. package/src/db/dynamoClient.ts +1 -1
  71. package/src/db/inMemoryView.ts +1 -0
  72. package/src/db/linkedRows/index.ts +5 -3
  73. package/src/environment.ts +3 -0
  74. package/src/integration-test/postgres.spec.ts +47 -5
  75. package/src/integrations/airtable.ts +33 -4
  76. package/src/integrations/arangodb.ts +20 -2
  77. package/src/integrations/base/sqlTable.ts +0 -1
  78. package/src/integrations/couchdb.ts +20 -4
  79. package/src/integrations/dynamodb.ts +36 -5
  80. package/src/integrations/elasticsearch.ts +18 -1
  81. package/src/integrations/firebase.ts +17 -0
  82. package/src/integrations/googlesheets.ts +66 -5
  83. package/src/integrations/index.ts +12 -7
  84. package/src/integrations/microsoftSqlServer.ts +33 -1
  85. package/src/integrations/mongodb.ts +18 -0
  86. package/src/integrations/mysql.ts +53 -26
  87. package/src/integrations/oracle.ts +38 -6
  88. package/src/integrations/postgres.ts +47 -12
  89. package/src/integrations/redis.ts +35 -4
  90. package/src/integrations/s3.ts +21 -3
  91. package/src/integrations/snowflake.ts +25 -1
  92. package/src/integrations/tests/googlesheets.spec.ts +41 -9
  93. package/src/middleware/builder.ts +26 -18
  94. package/src/migrations/functions/backfill/app/queries.ts +1 -1
  95. package/src/sdk/app/automations/index.ts +2 -0
  96. package/src/sdk/app/automations/utils.ts +7 -0
  97. package/src/sdk/app/datasources/datasources.ts +7 -1
  98. package/src/sdk/plugins/plugins.ts +1 -1
  99. package/src/startup.ts +2 -0
  100. package/src/tests/utilities/TestConfiguration.ts +4 -2
  101. package/src/tests/utilities/structures.ts +42 -0
  102. package/src/threads/automation.ts +91 -23
  103. package/src/threads/index.ts +9 -3
  104. package/src/threads/utils.ts +2 -0
  105. package/src/utilities/fileSystem/app.ts +14 -4
  106. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  107. package/src/utilities/fileSystem/filesystem.ts +3 -1
  108. package/src/utilities/redis.ts +25 -3
  109. package/src/utilities/rowProcessor/index.ts +4 -1
  110. package/src/utilities/rowProcessor/map.ts +1 -1
  111. package/src/websockets/builder.ts +95 -0
  112. package/src/websockets/client.ts +2 -2
  113. package/src/websockets/grid.ts +44 -44
  114. package/src/websockets/index.ts +13 -6
  115. package/src/websockets/websocket.ts +211 -7
  116. package/tsconfig.build.json +9 -1
  117. package/tsconfig.json +1 -14
  118. package/builder/assets/index.86c992bf.css +0 -6
  119. package/builder/assets/index.c16c35ca.js +0 -1794
  120. package/dist/api/controllers/analytics.js +0 -46
  121. package/dist/api/controllers/apikeys.js +0 -72
  122. package/dist/api/controllers/application.js +0 -574
  123. package/dist/api/controllers/auth.js +0 -80
  124. package/dist/api/controllers/automation.js +0 -303
  125. package/dist/api/controllers/backup.js +0 -37
  126. package/dist/api/controllers/component.js +0 -59
  127. package/dist/api/controllers/datasource.js +0 -306
  128. package/dist/api/controllers/deploy/Deployment.js +0 -53
  129. package/dist/api/controllers/deploy/index.js +0 -198
  130. package/dist/api/controllers/dev.js +0 -146
  131. package/dist/api/controllers/integration.js +0 -28
  132. package/dist/api/controllers/layout.js +0 -49
  133. package/dist/api/controllers/metadata.js +0 -63
  134. package/dist/api/controllers/migrations.js +0 -29
  135. package/dist/api/controllers/ops.js +0 -40
  136. package/dist/api/controllers/permission.js +0 -162
  137. package/dist/api/controllers/plugin/file.js +0 -24
  138. package/dist/api/controllers/plugin/github.js +0 -69
  139. package/dist/api/controllers/plugin/index.js +0 -112
  140. package/dist/api/controllers/plugin/npm.js +0 -58
  141. package/dist/api/controllers/plugin/uploaders.js +0 -11
  142. package/dist/api/controllers/plugin/url.js +0 -24
  143. package/dist/api/controllers/plugin/utils.js +0 -27
  144. package/dist/api/controllers/public/applications.js +0 -146
  145. package/dist/api/controllers/public/mapping/applications.js +0 -29
  146. package/dist/api/controllers/public/mapping/index.js +0 -11
  147. package/dist/api/controllers/public/mapping/queries.js +0 -36
  148. package/dist/api/controllers/public/mapping/rows.js +0 -24
  149. package/dist/api/controllers/public/mapping/tables.js +0 -23
  150. package/dist/api/controllers/public/mapping/types.js +0 -2
  151. package/dist/api/controllers/public/mapping/users.js +0 -29
  152. package/dist/api/controllers/public/metrics.js +0 -113
  153. package/dist/api/controllers/public/queries.js +0 -58
  154. package/dist/api/controllers/public/rows.js +0 -120
  155. package/dist/api/controllers/public/tables.js +0 -95
  156. package/dist/api/controllers/public/users.js +0 -93
  157. package/dist/api/controllers/public/utils.js +0 -56
  158. package/dist/api/controllers/query/import/index.js +0 -87
  159. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  160. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  161. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  162. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  163. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  164. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  165. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  166. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  167. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  168. package/dist/api/controllers/query/index.js +0 -299
  169. package/dist/api/controllers/query/validation.js +0 -53
  170. package/dist/api/controllers/role.js +0 -109
  171. package/dist/api/controllers/routing.js +0 -105
  172. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  173. package/dist/api/controllers/row/external.js +0 -339
  174. package/dist/api/controllers/row/index.js +0 -203
  175. package/dist/api/controllers/row/internal.js +0 -509
  176. package/dist/api/controllers/row/internalSearch.js +0 -28
  177. package/dist/api/controllers/row/staticFormula.js +0 -165
  178. package/dist/api/controllers/row/utils.js +0 -183
  179. package/dist/api/controllers/screen.js +0 -110
  180. package/dist/api/controllers/script.js +0 -30
  181. package/dist/api/controllers/static/index.js +0 -268
  182. package/dist/api/controllers/table/bulkFormula.js +0 -173
  183. package/dist/api/controllers/table/external.js +0 -279
  184. package/dist/api/controllers/table/index.js +0 -179
  185. package/dist/api/controllers/table/internal.js +0 -197
  186. package/dist/api/controllers/table/utils.js +0 -379
  187. package/dist/api/controllers/templates.js +0 -56
  188. package/dist/api/controllers/user.js +0 -124
  189. package/dist/api/controllers/view/exporters.js +0 -46
  190. package/dist/api/controllers/view/index.js +0 -193
  191. package/dist/api/controllers/view/utils.js +0 -177
  192. package/dist/api/controllers/view/viewBuilder.js +0 -158
  193. package/dist/api/controllers/webhook.js +0 -134
  194. package/dist/api/index.js +0 -55
  195. package/dist/api/routes/analytics.js +0 -34
  196. package/dist/api/routes/apikeys.js +0 -37
  197. package/dist/api/routes/application.js +0 -48
  198. package/dist/api/routes/auth.js +0 -33
  199. package/dist/api/routes/automation.js +0 -50
  200. package/dist/api/routes/backup.js +0 -35
  201. package/dist/api/routes/component.js +0 -35
  202. package/dist/api/routes/datasource.js +0 -43
  203. package/dist/api/routes/deploy.js +0 -37
  204. package/dist/api/routes/dev.js +0 -49
  205. package/dist/api/routes/index.js +0 -75
  206. package/dist/api/routes/integration.js +0 -37
  207. package/dist/api/routes/layout.js +0 -37
  208. package/dist/api/routes/metadata.js +0 -40
  209. package/dist/api/routes/migrations.js +0 -36
  210. package/dist/api/routes/ops.js +0 -52
  211. package/dist/api/routes/permission.js +0 -44
  212. package/dist/api/routes/plugin.js +0 -39
  213. package/dist/api/routes/public/applications.js +0 -174
  214. package/dist/api/routes/public/index.js +0 -140
  215. package/dist/api/routes/public/metrics.js +0 -30
  216. package/dist/api/routes/public/middleware/mapper.js +0 -97
  217. package/dist/api/routes/public/queries.js +0 -72
  218. package/dist/api/routes/public/rows.js +0 -158
  219. package/dist/api/routes/public/tables.js +0 -152
  220. package/dist/api/routes/public/users.js +0 -135
  221. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  222. package/dist/api/routes/query.js +0 -47
  223. package/dist/api/routes/role.js +0 -40
  224. package/dist/api/routes/routing.js +0 -39
  225. package/dist/api/routes/row.js +0 -239
  226. package/dist/api/routes/screen.js +0 -39
  227. package/dist/api/routes/script.js +0 -35
  228. package/dist/api/routes/static.js +0 -80
  229. package/dist/api/routes/table.js +0 -163
  230. package/dist/api/routes/templates.js +0 -37
  231. package/dist/api/routes/user.js +0 -43
  232. package/dist/api/routes/utils/validators.js +0 -238
  233. package/dist/api/routes/view.js +0 -42
  234. package/dist/api/routes/webhook.js +0 -43
  235. package/dist/app.js +0 -132
  236. package/dist/automations/actions.js +0 -137
  237. package/dist/automations/automationUtils.js +0 -173
  238. package/dist/automations/bullboard.js +0 -71
  239. package/dist/automations/index.js +0 -43
  240. package/dist/automations/logging/index.js +0 -53
  241. package/dist/automations/steps/bash.js +0 -111
  242. package/dist/automations/steps/createRow.js +0 -108
  243. package/dist/automations/steps/delay.js +0 -53
  244. package/dist/automations/steps/deleteRow.js +0 -96
  245. package/dist/automations/steps/discord.js +0 -116
  246. package/dist/automations/steps/executeQuery.js +0 -134
  247. package/dist/automations/steps/executeScript.js +0 -106
  248. package/dist/automations/steps/filter.js +0 -112
  249. package/dist/automations/steps/loop.js +0 -54
  250. package/dist/automations/steps/make.js +0 -120
  251. package/dist/automations/steps/outgoingWebhook.js +0 -166
  252. package/dist/automations/steps/queryRows.js +0 -220
  253. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  254. package/dist/automations/steps/serverLog.js +0 -65
  255. package/dist/automations/steps/slack.js +0 -98
  256. package/dist/automations/steps/updateRow.js +0 -144
  257. package/dist/automations/steps/utils.js +0 -56
  258. package/dist/automations/steps/zapier.js +0 -117
  259. package/dist/automations/triggerInfo/app.js +0 -36
  260. package/dist/automations/triggerInfo/cron.js +0 -35
  261. package/dist/automations/triggerInfo/index.js +0 -40
  262. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  263. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  264. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  265. package/dist/automations/triggerInfo/webhook.js +0 -40
  266. package/dist/automations/triggers.js +0 -181
  267. package/dist/automations/utils.js +0 -275
  268. package/dist/constants/definitions.js +0 -2
  269. package/dist/constants/index.js +0 -181
  270. package/dist/constants/layouts.js +0 -148
  271. package/dist/constants/screens.js +0 -51
  272. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  273. package/dist/db/defaultData/employeeImport.js +0 -155
  274. package/dist/db/defaultData/expensesImport.js +0 -117
  275. package/dist/db/defaultData/inventoryImport.js +0 -109
  276. package/dist/db/defaultData/jobsImport.js +0 -152
  277. package/dist/db/dynamoClient.js +0 -124
  278. package/dist/db/inMemoryView.js +0 -62
  279. package/dist/db/index.js +0 -43
  280. package/dist/db/linkedRows/LinkController.js +0 -392
  281. package/dist/db/linkedRows/LinkDocument.js +0 -33
  282. package/dist/db/linkedRows/index.js +0 -206
  283. package/dist/db/linkedRows/linkUtils.js +0 -131
  284. package/dist/db/newid.js +0 -7
  285. package/dist/db/utils.js +0 -248
  286. package/dist/db/views/staticViews.js +0 -144
  287. package/dist/ddApm.js +0 -11
  288. package/dist/definitions/automations.js +0 -8
  289. package/dist/definitions/common.js +0 -2
  290. package/dist/definitions/datasource.js +0 -7
  291. package/dist/definitions/openapi.js +0 -6
  292. package/dist/environment.js +0 -109
  293. package/dist/events/AutomationEmitter.js +0 -53
  294. package/dist/events/BudibaseEmitter.js +0 -25
  295. package/dist/events/docUpdates/index.js +0 -17
  296. package/dist/events/docUpdates/processors.js +0 -18
  297. package/dist/events/docUpdates/syncUsers.js +0 -49
  298. package/dist/events/index.js +0 -11
  299. package/dist/events/utils.js +0 -43
  300. package/dist/integrations/airtable.js +0 -147
  301. package/dist/integrations/arangodb.js +0 -103
  302. package/dist/integrations/base/query.js +0 -32
  303. package/dist/integrations/base/sql.js +0 -600
  304. package/dist/integrations/base/sqlTable.js +0 -167
  305. package/dist/integrations/base/types.js +0 -2
  306. package/dist/integrations/couchdb.js +0 -125
  307. package/dist/integrations/dynamodb.js +0 -194
  308. package/dist/integrations/elasticsearch.js +0 -186
  309. package/dist/integrations/firebase.js +0 -174
  310. package/dist/integrations/googlesheets.js +0 -455
  311. package/dist/integrations/index.js +0 -135
  312. package/dist/integrations/microsoftSqlServer.js +0 -273
  313. package/dist/integrations/mongodb.js +0 -614
  314. package/dist/integrations/mysql.js +0 -256
  315. package/dist/integrations/oracle.js +0 -375
  316. package/dist/integrations/postgres.js +0 -300
  317. package/dist/integrations/queries/sql.js +0 -84
  318. package/dist/integrations/redis.js +0 -168
  319. package/dist/integrations/rest.js +0 -400
  320. package/dist/integrations/s3.js +0 -237
  321. package/dist/integrations/snowflake.js +0 -99
  322. package/dist/integrations/utils.js +0 -295
  323. package/dist/middleware/appInfo.js +0 -22
  324. package/dist/middleware/authorized.js +0 -112
  325. package/dist/middleware/builder.js +0 -93
  326. package/dist/middleware/currentapp.js +0 -103
  327. package/dist/middleware/joi-validator.js +0 -43
  328. package/dist/middleware/publicApi.js +0 -25
  329. package/dist/middleware/resourceId.js +0 -59
  330. package/dist/middleware/selfhost.js +0 -24
  331. package/dist/middleware/utils.js +0 -8
  332. package/dist/migrations/functions/appUrls.js +0 -42
  333. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  334. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  335. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  336. package/dist/migrations/functions/backfill/app/queries.js +0 -50
  337. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  338. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  339. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  340. package/dist/migrations/functions/backfill/app.js +0 -176
  341. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  342. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  343. package/dist/migrations/functions/backfill/global/users.js +0 -50
  344. package/dist/migrations/functions/backfill/global.js +0 -205
  345. package/dist/migrations/functions/backfill/index.js +0 -32
  346. package/dist/migrations/functions/backfill/installation.js +0 -80
  347. package/dist/migrations/functions/syncQuotas.js +0 -52
  348. package/dist/migrations/functions/tableSettings.js +0 -130
  349. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  350. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  351. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  352. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  353. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  354. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  355. package/dist/migrations/index.js +0 -111
  356. package/dist/migrations/tests/helpers.js +0 -72
  357. package/dist/migrations/tests/structures.js +0 -37
  358. package/dist/sdk/app/applications/index.js +0 -28
  359. package/dist/sdk/app/applications/sync.js +0 -164
  360. package/dist/sdk/app/applications/utils.js +0 -21
  361. package/dist/sdk/app/automations/index.js +0 -29
  362. package/dist/sdk/app/automations/webhook.js +0 -54
  363. package/dist/sdk/app/backups/constants.js +0 -6
  364. package/dist/sdk/app/backups/exports.js +0 -160
  365. package/dist/sdk/app/backups/imports.js +0 -170
  366. package/dist/sdk/app/backups/index.js +0 -29
  367. package/dist/sdk/app/backups/statistics.js +0 -73
  368. package/dist/sdk/app/datasources/datasources.js +0 -166
  369. package/dist/sdk/app/datasources/index.js +0 -27
  370. package/dist/sdk/app/queries/index.js +0 -27
  371. package/dist/sdk/app/queries/queries.js +0 -60
  372. package/dist/sdk/app/rows/attachments.js +0 -61
  373. package/dist/sdk/app/rows/index.js +0 -28
  374. package/dist/sdk/app/rows/rows.js +0 -30
  375. package/dist/sdk/app/tables/index.js +0 -65
  376. package/dist/sdk/index.js +0 -27
  377. package/dist/sdk/plugins/index.js +0 -27
  378. package/dist/sdk/plugins/plugins.js +0 -53
  379. package/dist/sdk/users/index.js +0 -27
  380. package/dist/sdk/users/utils.js +0 -94
  381. package/dist/sdk/utils/index.js +0 -29
  382. package/dist/startup.js +0 -158
  383. package/dist/threads/automation.js +0 -450
  384. package/dist/threads/definitions.js +0 -2
  385. package/dist/threads/index.js +0 -140
  386. package/dist/threads/query.js +0 -265
  387. package/dist/threads/utils.js +0 -120
  388. package/dist/tsconfig.build.tsbuildinfo +0 -1
  389. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  390. package/dist/utilities/budibaseDir.js +0 -5
  391. package/dist/utilities/centralPath.js +0 -27
  392. package/dist/utilities/csv.js +0 -33
  393. package/dist/utilities/fileSystem/app.js +0 -88
  394. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  395. package/dist/utilities/fileSystem/filesystem.js +0 -180
  396. package/dist/utilities/fileSystem/index.js +0 -21
  397. package/dist/utilities/fileSystem/plugin.js +0 -76
  398. package/dist/utilities/fileSystem/processor.js +0 -34
  399. package/dist/utilities/fileSystem/template.js +0 -47
  400. package/dist/utilities/global.js +0 -146
  401. package/dist/utilities/index.js +0 -143
  402. package/dist/utilities/redis.js +0 -117
  403. package/dist/utilities/retry.js +0 -30
  404. package/dist/utilities/routing/index.js +0 -39
  405. package/dist/utilities/rowProcessor/index.js +0 -282
  406. package/dist/utilities/rowProcessor/map.js +0 -116
  407. package/dist/utilities/rowProcessor/utils.js +0 -87
  408. package/dist/utilities/schema.js +0 -112
  409. package/dist/utilities/scriptRunner.js +0 -26
  410. package/dist/utilities/security.js +0 -57
  411. package/dist/utilities/statusCodes.js +0 -9
  412. package/dist/utilities/usageQuota/rows.js +0 -88
  413. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  414. package/dist/utilities/users.js +0 -57
  415. package/dist/utilities/workerRequests.js +0 -171
  416. package/dist/watch.js +0 -53
  417. package/dist/websockets/client.js +0 -14
  418. package/dist/websockets/grid.js +0 -60
  419. package/dist/websockets/index.js +0 -17
  420. package/dist/websockets/websocket.js +0 -78
  421. package/src/automations/tests/zapier.spec.js +0 -27
  422. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  423. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  424. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,256 +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 dayjs_1 = __importDefault(require("dayjs"));
18
- const utilities_1 = require("../utilities");
19
- const sql_1 = __importDefault(require("./base/sql"));
20
- const mysql = require("mysql2/promise");
21
- const SCHEMA = {
22
- docs: "https://github.com/sidorares/node-mysql2",
23
- plus: true,
24
- friendlyName: "MySQL",
25
- type: "Relational",
26
- description: "MySQL Database Service is a fully managed database service to deploy cloud-native applications. ",
27
- datasource: {
28
- host: {
29
- type: types_1.DatasourceFieldType.STRING,
30
- default: "localhost",
31
- required: true,
32
- },
33
- port: {
34
- type: types_1.DatasourceFieldType.NUMBER,
35
- default: 3306,
36
- required: false,
37
- },
38
- user: {
39
- type: types_1.DatasourceFieldType.STRING,
40
- default: "root",
41
- required: true,
42
- },
43
- password: {
44
- type: types_1.DatasourceFieldType.PASSWORD,
45
- default: "root",
46
- required: true,
47
- },
48
- database: {
49
- type: types_1.DatasourceFieldType.STRING,
50
- required: true,
51
- },
52
- ssl: {
53
- type: types_1.DatasourceFieldType.OBJECT,
54
- required: false,
55
- },
56
- rejectUnauthorized: {
57
- type: types_1.DatasourceFieldType.BOOLEAN,
58
- default: true,
59
- required: false,
60
- },
61
- },
62
- query: {
63
- create: {
64
- type: types_1.QueryType.SQL,
65
- },
66
- read: {
67
- type: types_1.QueryType.SQL,
68
- },
69
- update: {
70
- type: types_1.QueryType.SQL,
71
- },
72
- delete: {
73
- type: types_1.QueryType.SQL,
74
- },
75
- },
76
- };
77
- const TimezoneAwareDateTypes = ["timestamp"];
78
- function bindingTypeCoerce(bindings) {
79
- for (let i = 0; i < bindings.length; i++) {
80
- const binding = bindings[i];
81
- if (typeof binding !== "string") {
82
- continue;
83
- }
84
- const matches = binding.match(utilities_1.NUMBER_REGEX);
85
- // check if number first
86
- if (matches && matches[0] !== "" && !isNaN(Number(matches[0]))) {
87
- bindings[i] = parseFloat(binding);
88
- }
89
- // if not a number, see if it is a date - important to do in this order as any
90
- // integer will be considered a valid date
91
- else if (/^\d/.test(binding) &&
92
- (0, dayjs_1.default)(binding).isValid() &&
93
- !binding.includes(",")) {
94
- bindings[i] = (0, dayjs_1.default)(binding).toDate();
95
- }
96
- }
97
- return bindings;
98
- }
99
- class MySQLIntegration extends sql_1.default {
100
- constructor(config) {
101
- super(utils_1.SqlClient.MY_SQL);
102
- this.tables = {};
103
- this.schemaErrors = {};
104
- this.config = config;
105
- if (config.ssl && Object.keys(config.ssl).length === 0) {
106
- delete config.ssl;
107
- }
108
- // make sure this defaults to true
109
- if (config.rejectUnauthorized != null &&
110
- !config.rejectUnauthorized &&
111
- config.ssl) {
112
- config.ssl.rejectUnauthorized = config.rejectUnauthorized;
113
- }
114
- // @ts-ignore
115
- delete config.rejectUnauthorized;
116
- this.config = Object.assign(Object.assign({}, config), { multipleStatements: true, typeCast: function (field, next) {
117
- var _a;
118
- if (field.type == "DATETIME" ||
119
- field.type === "DATE" ||
120
- field.type === "TIMESTAMP" ||
121
- field.type === "LONGLONG") {
122
- return field.string();
123
- }
124
- if (field.type === "BIT" && field.length === 1) {
125
- return (_a = field.buffer()) === null || _a === void 0 ? void 0 : _a[0];
126
- }
127
- return next();
128
- } });
129
- }
130
- getBindingIdentifier() {
131
- return "?";
132
- }
133
- getStringConcat(parts) {
134
- return `concat(${parts.join(", ")})`;
135
- }
136
- connect() {
137
- return __awaiter(this, void 0, void 0, function* () {
138
- this.client = yield mysql.createConnection(this.config);
139
- });
140
- }
141
- disconnect() {
142
- return __awaiter(this, void 0, void 0, function* () {
143
- yield this.client.end();
144
- });
145
- }
146
- internalQuery(query, opts = {
147
- connect: true,
148
- disableCoercion: false,
149
- }) {
150
- return __awaiter(this, void 0, void 0, function* () {
151
- try {
152
- if (opts === null || opts === void 0 ? void 0 : opts.connect) {
153
- yield this.connect();
154
- }
155
- const baseBindings = query.bindings || [];
156
- const bindings = (opts === null || opts === void 0 ? void 0 : opts.disableCoercion)
157
- ? baseBindings
158
- : bindingTypeCoerce(baseBindings);
159
- // Node MySQL is callback based, so we must wrap our call in a promise
160
- const response = yield this.client.query(query.sql, bindings);
161
- return response[0];
162
- }
163
- finally {
164
- if (opts === null || opts === void 0 ? void 0 : opts.connect) {
165
- yield this.disconnect();
166
- }
167
- }
168
- });
169
- }
170
- buildSchema(datasourceId, entities) {
171
- return __awaiter(this, void 0, void 0, function* () {
172
- const tables = {};
173
- const database = this.config.database;
174
- yield this.connect();
175
- try {
176
- // get the tables first
177
- const tablesResp = yield this.internalQuery({ sql: "SHOW TABLES;" }, { connect: false });
178
- const tableNames = tablesResp.map((obj) => obj[`Tables_in_${database}`] ||
179
- obj[`Tables_in_${database.toLowerCase()}`]);
180
- for (let tableName of tableNames) {
181
- const primaryKeys = [];
182
- const schema = {};
183
- const descResp = yield this.internalQuery({ sql: `DESCRIBE \`${tableName}\`;` }, { connect: false });
184
- for (let column of descResp) {
185
- const columnName = column.Field;
186
- if (column.Key === "PRI" && primaryKeys.indexOf(column.Key) === -1) {
187
- primaryKeys.push(columnName);
188
- }
189
- const hasDefault = column.Default != null;
190
- const isAuto = typeof column.Extra === "string" &&
191
- (column.Extra === "auto_increment" ||
192
- column.Extra.toLowerCase().includes("generated"));
193
- const required = column.Null !== "YES";
194
- const constraints = {
195
- presence: required && !isAuto && !hasDefault,
196
- };
197
- schema[columnName] = Object.assign(Object.assign({ name: columnName, autocolumn: isAuto, constraints }, (0, utils_1.convertSqlType)(column.Type)), { externalType: column.Type });
198
- }
199
- if (!tables[tableName]) {
200
- tables[tableName] = {
201
- _id: (0, utils_1.buildExternalTableId)(datasourceId, tableName),
202
- primary: primaryKeys,
203
- name: tableName,
204
- schema,
205
- };
206
- }
207
- }
208
- }
209
- finally {
210
- yield this.disconnect();
211
- }
212
- const final = (0, utils_1.finaliseExternalTables)(tables, entities);
213
- this.tables = final.tables;
214
- this.schemaErrors = final.errors;
215
- });
216
- }
217
- create(query) {
218
- return __awaiter(this, void 0, void 0, function* () {
219
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
220
- return results.length ? results : [{ created: true }];
221
- });
222
- }
223
- read(query) {
224
- return __awaiter(this, void 0, void 0, function* () {
225
- return this.internalQuery((0, utils_1.getSqlQuery)(query));
226
- });
227
- }
228
- update(query) {
229
- return __awaiter(this, void 0, void 0, function* () {
230
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
231
- return results.length ? results : [{ updated: true }];
232
- });
233
- }
234
- delete(query) {
235
- return __awaiter(this, void 0, void 0, function* () {
236
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
237
- return results.length ? results : [{ deleted: true }];
238
- });
239
- }
240
- query(json) {
241
- return __awaiter(this, void 0, void 0, function* () {
242
- yield this.connect();
243
- try {
244
- const queryFn = (query) => this.internalQuery(query, { connect: false, disableCoercion: true });
245
- return yield this.queryWithReturning(json, queryFn);
246
- }
247
- finally {
248
- yield this.disconnect();
249
- }
250
- });
251
- }
252
- }
253
- exports.default = {
254
- schema: SCHEMA,
255
- integration: MySQLIntegration,
256
- };
@@ -1,375 +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 constants_1 = require("../constants");
19
- let oracledb;
20
- try {
21
- oracledb = require("oracledb");
22
- oracledb.outFormat = oracledb.OUT_FORMAT_OBJECT;
23
- }
24
- catch (err) {
25
- console.log("ORACLEDB is not installed");
26
- }
27
- const SCHEMA = {
28
- docs: "https://github.com/oracle/node-oracledb",
29
- plus: true,
30
- friendlyName: "Oracle",
31
- type: "Relational",
32
- description: "Oracle Database is an object-relational database management system developed by Oracle Corporation",
33
- datasource: {
34
- host: {
35
- type: types_1.DatasourceFieldType.STRING,
36
- default: "localhost",
37
- required: true,
38
- },
39
- port: {
40
- type: types_1.DatasourceFieldType.NUMBER,
41
- required: true,
42
- default: 1521,
43
- },
44
- database: {
45
- type: types_1.DatasourceFieldType.STRING,
46
- required: true,
47
- display: "Service Name",
48
- },
49
- user: {
50
- type: types_1.DatasourceFieldType.STRING,
51
- required: true,
52
- },
53
- password: {
54
- type: types_1.DatasourceFieldType.PASSWORD,
55
- required: true,
56
- },
57
- },
58
- query: {
59
- create: {
60
- type: types_1.QueryType.SQL,
61
- },
62
- read: {
63
- type: types_1.QueryType.SQL,
64
- },
65
- update: {
66
- type: types_1.QueryType.SQL,
67
- },
68
- delete: {
69
- type: types_1.QueryType.SQL,
70
- },
71
- },
72
- };
73
- const UNSUPPORTED_TYPES = ["BLOB", "CLOB", "NCLOB"];
74
- const OracleContraintTypes = {
75
- PRIMARY: "P",
76
- NOT_NULL_OR_CHECK: "C",
77
- FOREIGN_KEY: "R",
78
- UNIQUE: "U",
79
- };
80
- class OracleIntegration extends sql_1.default {
81
- constructor(config) {
82
- super(utils_1.SqlClient.ORACLE);
83
- this.index = 1;
84
- this.tables = {};
85
- this.schemaErrors = {};
86
- this.COLUMNS_SQL = `
87
- SELECT
88
- tabs.table_name,
89
- cols.column_name,
90
- cols.data_type,
91
- cols.data_default,
92
- cols.column_id,
93
- cons.constraint_name,
94
- cons.constraint_type,
95
- cons.r_constraint_name,
96
- cons.search_condition
97
- FROM
98
- user_tables tabs
99
- JOIN
100
- user_tab_columns cols
101
- ON tabs.table_name = cols.table_name
102
- LEFT JOIN
103
- user_cons_columns col_cons
104
- ON cols.column_name = col_cons.column_name
105
- AND cols.table_name = col_cons.table_name
106
- LEFT JOIN
107
- user_constraints cons
108
- ON col_cons.constraint_name = cons.constraint_name
109
- AND cons.table_name = cols.table_name
110
- WHERE
111
- (cons.status = 'ENABLED'
112
- OR cons.status IS NULL)
113
- `;
114
- this.getConnection = () => __awaiter(this, void 0, void 0, function* () {
115
- //connectString : "(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))(CONNECT_DATA =(SID= ORCL)))"
116
- const connectString = `${this.config.host}:${this.config.port || 1521}/${this.config.database}`;
117
- const attributes = {
118
- user: this.config.user,
119
- password: this.config.password,
120
- connectString,
121
- };
122
- return oracledb.getConnection(attributes);
123
- });
124
- this.config = config;
125
- }
126
- getBindingIdentifier() {
127
- return `:${this.index++}`;
128
- }
129
- getStringConcat(parts) {
130
- return parts.join(" || ");
131
- }
132
- static isInstalled() {
133
- return oracledb != null;
134
- }
135
- /**
136
- * Map the flat tabular columns and constraints data into a nested object
137
- */
138
- mapColumns(result) {
139
- const oracleTables = {};
140
- if (result.rows) {
141
- result.rows.forEach(row => {
142
- const tableName = row.TABLE_NAME;
143
- const columnName = row.COLUMN_NAME;
144
- const dataType = row.DATA_TYPE;
145
- const dataDefault = row.DATA_DEFAULT;
146
- const columnId = row.COLUMN_ID;
147
- const constraintName = row.CONSTRAINT_NAME;
148
- const constraintType = row.CONSTRAINT_TYPE;
149
- const relatedConstraintName = row.R_CONSTRAINT_NAME;
150
- const searchCondition = row.SEARCH_CONDITION;
151
- let table = oracleTables[tableName];
152
- if (!table) {
153
- table = {
154
- name: tableName,
155
- columns: {},
156
- };
157
- oracleTables[tableName] = table;
158
- }
159
- let column = table.columns[columnName];
160
- if (!column) {
161
- column = {
162
- name: columnName,
163
- type: dataType,
164
- default: dataDefault,
165
- id: columnId,
166
- constraints: {},
167
- };
168
- table.columns[columnName] = column;
169
- }
170
- if (constraintName && constraintType) {
171
- let constraint = column.constraints[constraintName];
172
- if (!constraint) {
173
- constraint = {
174
- name: constraintName,
175
- type: constraintType,
176
- relatedConstraintName: relatedConstraintName,
177
- searchCondition: searchCondition,
178
- };
179
- }
180
- column.constraints[constraintName] = constraint;
181
- }
182
- });
183
- }
184
- return oracleTables;
185
- }
186
- static isSupportedColumn(column) {
187
- return !UNSUPPORTED_TYPES.includes(column.type);
188
- }
189
- static isAutoColumn(column) {
190
- return !!(column.default && column.default.toLowerCase().includes("nextval"));
191
- }
192
- /**
193
- * No native boolean in oracle. Best we can do is to check if a manual 1 or 0 number constraint has been set up
194
- * This matches the default behaviour for generating DDL used in knex.
195
- */
196
- isBooleanType(column) {
197
- return (column.type.toLowerCase() === "number" &&
198
- Object.values(column.constraints).filter(c => {
199
- if (c.type === OracleContraintTypes.NOT_NULL_OR_CHECK &&
200
- c.searchCondition) {
201
- const condition = c.searchCondition
202
- .replace(/\s/g, "") // remove spaces
203
- .replace(/[']+/g, ""); // remove quotes
204
- if (condition.includes("in(0,1)") || condition.includes("in(1,0)")) {
205
- return true;
206
- }
207
- }
208
- return false;
209
- }).length > 0);
210
- }
211
- internalConvertType(column) {
212
- if (this.isBooleanType(column)) {
213
- return { type: constants_1.FieldTypes.BOOLEAN };
214
- }
215
- return (0, utils_1.convertSqlType)(column.type);
216
- }
217
- /**
218
- * Fetches the tables from the oracle table and assigns them to the datasource.
219
- * @param {*} datasourceId - datasourceId to fetch
220
- * @param entities - the tables that are to be built
221
- */
222
- buildSchema(datasourceId, entities) {
223
- return __awaiter(this, void 0, void 0, function* () {
224
- const columnsResponse = yield this.internalQuery({
225
- sql: this.COLUMNS_SQL,
226
- });
227
- const oracleTables = this.mapColumns(columnsResponse);
228
- const tables = {};
229
- // iterate each table
230
- Object.values(oracleTables).forEach(oracleTable => {
231
- let table = tables[oracleTable.name];
232
- if (!table) {
233
- table = {
234
- _id: (0, utils_1.buildExternalTableId)(datasourceId, oracleTable.name),
235
- primary: [],
236
- name: oracleTable.name,
237
- schema: {},
238
- };
239
- tables[oracleTable.name] = table;
240
- }
241
- // iterate each column on the table
242
- Object.values(oracleTable.columns)
243
- // remove columns that we can't read / save
244
- .filter(oracleColumn => OracleIntegration.isSupportedColumn(oracleColumn))
245
- // match the order of the columns in the db
246
- .sort((c1, c2) => c1.id - c2.id)
247
- .forEach(oracleColumn => {
248
- const columnName = oracleColumn.name;
249
- let fieldSchema = table.schema[columnName];
250
- if (!fieldSchema) {
251
- fieldSchema = Object.assign({ autocolumn: OracleIntegration.isAutoColumn(oracleColumn), name: columnName, constraints: {
252
- presence: false,
253
- } }, this.internalConvertType(oracleColumn));
254
- table.schema[columnName] = fieldSchema;
255
- }
256
- // iterate each constraint on the column
257
- Object.values(oracleColumn.constraints).forEach(oracleConstraint => {
258
- if (oracleConstraint.type === OracleContraintTypes.PRIMARY) {
259
- table.primary.push(columnName);
260
- }
261
- else if (oracleConstraint.type === OracleContraintTypes.NOT_NULL_OR_CHECK) {
262
- table.schema[columnName].constraints = {
263
- presence: true,
264
- };
265
- }
266
- });
267
- });
268
- });
269
- const final = (0, utils_1.finaliseExternalTables)(tables, entities);
270
- this.tables = final.tables;
271
- this.schemaErrors = final.errors;
272
- });
273
- }
274
- internalQuery(query) {
275
- return __awaiter(this, void 0, void 0, function* () {
276
- let connection;
277
- try {
278
- this.index = 1;
279
- connection = yield this.getConnection();
280
- const options = { autoCommit: true };
281
- const bindings = query.bindings || [];
282
- return yield connection.execute(query.sql, bindings, options);
283
- }
284
- finally {
285
- if (connection) {
286
- try {
287
- yield connection.close();
288
- }
289
- catch (err) {
290
- console.error(err);
291
- }
292
- }
293
- }
294
- });
295
- }
296
- create(query) {
297
- return __awaiter(this, void 0, void 0, function* () {
298
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
299
- return response.rows && response.rows.length
300
- ? response.rows
301
- : [{ created: true }];
302
- });
303
- }
304
- read(query) {
305
- return __awaiter(this, void 0, void 0, function* () {
306
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
307
- return response.rows ? response.rows : [];
308
- });
309
- }
310
- update(query) {
311
- return __awaiter(this, void 0, void 0, function* () {
312
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
313
- return response.rows && response.rows.length
314
- ? response.rows
315
- : [{ updated: true }];
316
- });
317
- }
318
- delete(query) {
319
- return __awaiter(this, void 0, void 0, function* () {
320
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
321
- return response.rows && response.rows.length
322
- ? response.rows
323
- : [{ deleted: true }];
324
- });
325
- }
326
- query(json) {
327
- var _a, _b, _c;
328
- return __awaiter(this, void 0, void 0, function* () {
329
- const operation = this._operation(json);
330
- const input = this._query(json, { disableReturning: true });
331
- if (Array.isArray(input)) {
332
- const responses = [];
333
- for (let query of input) {
334
- responses.push(yield this.internalQuery(query));
335
- }
336
- return responses;
337
- }
338
- else {
339
- // read the row to be deleted up front for the return
340
- let deletedRows;
341
- if (operation === types_1.Operation.DELETE) {
342
- const queryFn = (query) => this.internalQuery(query);
343
- deletedRows = yield this.getReturningRow(queryFn, json);
344
- }
345
- // run the query
346
- const response = yield this.internalQuery(input);
347
- // get the results or return the created / updated / deleted row
348
- if ((_a = deletedRows === null || deletedRows === void 0 ? void 0 : deletedRows.rows) === null || _a === void 0 ? void 0 : _a.length) {
349
- return deletedRows.rows;
350
- }
351
- else if ((_b = response.rows) === null || _b === void 0 ? void 0 : _b.length) {
352
- return response.rows;
353
- }
354
- else {
355
- // get the last row that was updated
356
- if (response.lastRowid &&
357
- ((_c = json.endpoint) === null || _c === void 0 ? void 0 : _c.entityId) &&
358
- operation !== types_1.Operation.DELETE) {
359
- const lastRow = yield this.internalQuery({
360
- sql: `SELECT * FROM \"${json.endpoint.entityId}\" WHERE ROWID = '${response.lastRowid}'`,
361
- });
362
- return lastRow.rows;
363
- }
364
- else {
365
- return [{ [operation.toLowerCase()]: true }];
366
- }
367
- }
368
- }
369
- });
370
- }
371
- }
372
- exports.default = {
373
- schema: SCHEMA,
374
- integration: OracleIntegration,
375
- };