@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,272 +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 promise_1 = __importDefault(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
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
28
- datasource: {
29
- host: {
30
- type: types_1.DatasourceFieldType.STRING,
31
- default: "localhost",
32
- required: true,
33
- },
34
- port: {
35
- type: types_1.DatasourceFieldType.NUMBER,
36
- default: 3306,
37
- required: false,
38
- },
39
- user: {
40
- type: types_1.DatasourceFieldType.STRING,
41
- default: "root",
42
- required: true,
43
- },
44
- password: {
45
- type: types_1.DatasourceFieldType.PASSWORD,
46
- default: "root",
47
- required: true,
48
- },
49
- database: {
50
- type: types_1.DatasourceFieldType.STRING,
51
- required: true,
52
- },
53
- ssl: {
54
- type: types_1.DatasourceFieldType.OBJECT,
55
- required: false,
56
- },
57
- rejectUnauthorized: {
58
- type: types_1.DatasourceFieldType.BOOLEAN,
59
- default: true,
60
- required: false,
61
- },
62
- },
63
- query: {
64
- create: {
65
- type: types_1.QueryType.SQL,
66
- },
67
- read: {
68
- type: types_1.QueryType.SQL,
69
- },
70
- update: {
71
- type: types_1.QueryType.SQL,
72
- },
73
- delete: {
74
- type: types_1.QueryType.SQL,
75
- },
76
- },
77
- };
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
- typeof config.ssl !== "string") {
113
- config.ssl.rejectUnauthorized = config.rejectUnauthorized;
114
- }
115
- // @ts-ignore
116
- delete config.rejectUnauthorized;
117
- this.config = Object.assign(Object.assign({}, config), { multipleStatements: true, typeCast: function (field, next) {
118
- var _a;
119
- if (field.type == "DATETIME" ||
120
- field.type === "DATE" ||
121
- field.type === "TIMESTAMP" ||
122
- field.type === "LONGLONG") {
123
- return field.string();
124
- }
125
- if (field.type === "BIT" && field.length === 1) {
126
- return (_a = field.buffer()) === null || _a === void 0 ? void 0 : _a[0];
127
- }
128
- return next();
129
- } });
130
- }
131
- testConnection() {
132
- return __awaiter(this, void 0, void 0, function* () {
133
- const response = {
134
- connected: false,
135
- };
136
- try {
137
- const [result] = yield this.internalQuery({ sql: "SELECT 1+1 AS checkRes" }, { connect: true });
138
- response.connected = (result === null || result === void 0 ? void 0 : result.checkRes) == 2;
139
- }
140
- catch (e) {
141
- response.error = e.message;
142
- }
143
- return response;
144
- });
145
- }
146
- getBindingIdentifier() {
147
- return "?";
148
- }
149
- getStringConcat(parts) {
150
- return `concat(${parts.join(", ")})`;
151
- }
152
- connect() {
153
- return __awaiter(this, void 0, void 0, function* () {
154
- this.client = yield promise_1.default.createConnection(this.config);
155
- });
156
- }
157
- disconnect() {
158
- return __awaiter(this, void 0, void 0, function* () {
159
- yield this.client.end();
160
- });
161
- }
162
- internalQuery(query, opts = {
163
- connect: true,
164
- disableCoercion: false,
165
- }) {
166
- return __awaiter(this, void 0, void 0, function* () {
167
- try {
168
- if (opts === null || opts === void 0 ? void 0 : opts.connect) {
169
- yield this.connect();
170
- }
171
- const baseBindings = query.bindings || [];
172
- const bindings = (opts === null || opts === void 0 ? void 0 : opts.disableCoercion)
173
- ? baseBindings
174
- : bindingTypeCoerce(baseBindings);
175
- // Node MySQL is callback based, so we must wrap our call in a promise
176
- const response = yield this.client.query(query.sql, bindings);
177
- return response[0];
178
- }
179
- finally {
180
- if ((opts === null || opts === void 0 ? void 0 : opts.connect) && this.client) {
181
- yield this.disconnect();
182
- }
183
- }
184
- });
185
- }
186
- buildSchema(datasourceId, entities) {
187
- return __awaiter(this, void 0, void 0, function* () {
188
- const tables = {};
189
- const database = this.config.database;
190
- yield this.connect();
191
- try {
192
- // get the tables first
193
- const tablesResp = yield this.internalQuery({ sql: "SHOW TABLES;" }, { connect: false });
194
- const tableNames = tablesResp.map((obj) => obj[`Tables_in_${database}`] ||
195
- obj[`Tables_in_${database.toLowerCase()}`]);
196
- for (let tableName of tableNames) {
197
- const primaryKeys = [];
198
- const schema = {};
199
- const descResp = yield this.internalQuery({ sql: `DESCRIBE \`${tableName}\`;` }, { connect: false });
200
- for (let column of descResp) {
201
- const columnName = column.Field;
202
- if (column.Key === "PRI" && primaryKeys.indexOf(column.Key) === -1) {
203
- primaryKeys.push(columnName);
204
- }
205
- const hasDefault = column.Default != null;
206
- const isAuto = typeof column.Extra === "string" &&
207
- (column.Extra === "auto_increment" ||
208
- column.Extra.toLowerCase().includes("generated"));
209
- const required = column.Null !== "YES";
210
- const constraints = {
211
- presence: required && !isAuto && !hasDefault,
212
- };
213
- schema[columnName] = Object.assign(Object.assign({ name: columnName, autocolumn: isAuto, constraints }, (0, utils_1.convertSqlType)(column.Type)), { externalType: column.Type });
214
- }
215
- if (!tables[tableName]) {
216
- tables[tableName] = {
217
- _id: (0, utils_1.buildExternalTableId)(datasourceId, tableName),
218
- primary: primaryKeys,
219
- name: tableName,
220
- schema,
221
- };
222
- }
223
- }
224
- }
225
- finally {
226
- yield this.disconnect();
227
- }
228
- const final = (0, utils_1.finaliseExternalTables)(tables, entities);
229
- this.tables = final.tables;
230
- this.schemaErrors = final.errors;
231
- });
232
- }
233
- create(query) {
234
- return __awaiter(this, void 0, void 0, function* () {
235
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
236
- return results.length ? results : [{ created: true }];
237
- });
238
- }
239
- read(query) {
240
- return __awaiter(this, void 0, void 0, function* () {
241
- return this.internalQuery((0, utils_1.getSqlQuery)(query));
242
- });
243
- }
244
- update(query) {
245
- return __awaiter(this, void 0, void 0, function* () {
246
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
247
- return results.length ? results : [{ updated: true }];
248
- });
249
- }
250
- delete(query) {
251
- return __awaiter(this, void 0, void 0, function* () {
252
- const results = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
253
- return results.length ? results : [{ deleted: true }];
254
- });
255
- }
256
- query(json) {
257
- return __awaiter(this, void 0, void 0, function* () {
258
- yield this.connect();
259
- try {
260
- const queryFn = (query) => this.internalQuery(query, { connect: false, disableCoercion: true });
261
- return yield this.queryWithReturning(json, queryFn);
262
- }
263
- finally {
264
- yield this.disconnect();
265
- }
266
- });
267
- }
268
- }
269
- exports.default = {
270
- schema: SCHEMA,
271
- integration: MySQLIntegration,
272
- };
@@ -1,404 +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
- features: [types_1.DatasourceFeature.CONNECTION_CHECKING],
34
- datasource: {
35
- host: {
36
- type: types_1.DatasourceFieldType.STRING,
37
- default: "localhost",
38
- required: true,
39
- },
40
- port: {
41
- type: types_1.DatasourceFieldType.NUMBER,
42
- required: true,
43
- default: 1521,
44
- },
45
- database: {
46
- type: types_1.DatasourceFieldType.STRING,
47
- required: true,
48
- display: "Service Name",
49
- },
50
- user: {
51
- type: types_1.DatasourceFieldType.STRING,
52
- required: true,
53
- },
54
- password: {
55
- type: types_1.DatasourceFieldType.PASSWORD,
56
- required: true,
57
- },
58
- },
59
- query: {
60
- create: {
61
- type: types_1.QueryType.SQL,
62
- },
63
- read: {
64
- type: types_1.QueryType.SQL,
65
- },
66
- update: {
67
- type: types_1.QueryType.SQL,
68
- },
69
- delete: {
70
- type: types_1.QueryType.SQL,
71
- },
72
- },
73
- };
74
- const UNSUPPORTED_TYPES = ["BLOB", "CLOB", "NCLOB"];
75
- const OracleContraintTypes = {
76
- PRIMARY: "P",
77
- NOT_NULL_OR_CHECK: "C",
78
- FOREIGN_KEY: "R",
79
- UNIQUE: "U",
80
- };
81
- class OracleIntegration extends sql_1.default {
82
- constructor(config) {
83
- super(utils_1.SqlClient.ORACLE);
84
- this.index = 1;
85
- this.tables = {};
86
- this.schemaErrors = {};
87
- this.COLUMNS_SQL = `
88
- SELECT
89
- tabs.table_name,
90
- cols.column_name,
91
- cols.data_type,
92
- cols.data_default,
93
- cols.column_id,
94
- cons.constraint_name,
95
- cons.constraint_type,
96
- cons.r_constraint_name,
97
- cons.search_condition
98
- FROM
99
- user_tables tabs
100
- JOIN
101
- user_tab_columns cols
102
- ON tabs.table_name = cols.table_name
103
- LEFT JOIN
104
- user_cons_columns col_cons
105
- ON cols.column_name = col_cons.column_name
106
- AND cols.table_name = col_cons.table_name
107
- LEFT JOIN
108
- user_constraints cons
109
- ON col_cons.constraint_name = cons.constraint_name
110
- AND cons.table_name = cols.table_name
111
- WHERE
112
- (cons.status = 'ENABLED'
113
- OR cons.status IS NULL)
114
- `;
115
- this.getConnection = () => __awaiter(this, void 0, void 0, function* () {
116
- //connectString : "(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))(CONNECT_DATA =(SID= ORCL)))"
117
- const connectString = `${this.config.host}:${this.config.port || 1521}/${this.config.database}`;
118
- const attributes = {
119
- user: this.config.user,
120
- password: this.config.password,
121
- connectString,
122
- };
123
- return oracledb.getConnection(attributes);
124
- });
125
- this.config = config;
126
- }
127
- getBindingIdentifier() {
128
- return `:${this.index++}`;
129
- }
130
- getStringConcat(parts) {
131
- return parts.join(" || ");
132
- }
133
- static isInstalled() {
134
- return oracledb != null;
135
- }
136
- /**
137
- * Map the flat tabular columns and constraints data into a nested object
138
- */
139
- mapColumns(result) {
140
- const oracleTables = {};
141
- if (result.rows) {
142
- result.rows.forEach(row => {
143
- const tableName = row.TABLE_NAME;
144
- const columnName = row.COLUMN_NAME;
145
- const dataType = row.DATA_TYPE;
146
- const dataDefault = row.DATA_DEFAULT;
147
- const columnId = row.COLUMN_ID;
148
- const constraintName = row.CONSTRAINT_NAME;
149
- const constraintType = row.CONSTRAINT_TYPE;
150
- const relatedConstraintName = row.R_CONSTRAINT_NAME;
151
- const searchCondition = row.SEARCH_CONDITION;
152
- let table = oracleTables[tableName];
153
- if (!table) {
154
- table = {
155
- name: tableName,
156
- columns: {},
157
- };
158
- oracleTables[tableName] = table;
159
- }
160
- let column = table.columns[columnName];
161
- if (!column) {
162
- column = {
163
- name: columnName,
164
- type: dataType,
165
- default: dataDefault,
166
- id: columnId,
167
- constraints: {},
168
- };
169
- table.columns[columnName] = column;
170
- }
171
- if (constraintName && constraintType) {
172
- let constraint = column.constraints[constraintName];
173
- if (!constraint) {
174
- constraint = {
175
- name: constraintName,
176
- type: constraintType,
177
- relatedConstraintName: relatedConstraintName,
178
- searchCondition: searchCondition,
179
- };
180
- }
181
- column.constraints[constraintName] = constraint;
182
- }
183
- });
184
- }
185
- return oracleTables;
186
- }
187
- static isSupportedColumn(column) {
188
- return !UNSUPPORTED_TYPES.includes(column.type);
189
- }
190
- static isAutoColumn(column) {
191
- return !!(column.default && column.default.toLowerCase().includes("nextval"));
192
- }
193
- /**
194
- * No native boolean in oracle. Best we can do is to check if a manual 1 or 0 number constraint has been set up
195
- * This matches the default behaviour for generating DDL used in knex.
196
- */
197
- isBooleanType(column) {
198
- return (column.type.toLowerCase() === "number" &&
199
- Object.values(column.constraints).filter(c => {
200
- if (c.type === OracleContraintTypes.NOT_NULL_OR_CHECK &&
201
- c.searchCondition) {
202
- const condition = c.searchCondition
203
- .replace(/\s/g, "") // remove spaces
204
- .replace(/[']+/g, ""); // remove quotes
205
- if (condition.includes("in(0,1)") || condition.includes("in(1,0)")) {
206
- return true;
207
- }
208
- }
209
- return false;
210
- }).length > 0);
211
- }
212
- internalConvertType(column) {
213
- if (this.isBooleanType(column)) {
214
- return { type: constants_1.FieldTypes.BOOLEAN };
215
- }
216
- return (0, utils_1.convertSqlType)(column.type);
217
- }
218
- /**
219
- * Fetches the tables from the oracle table and assigns them to the datasource.
220
- * @param {*} datasourceId - datasourceId to fetch
221
- * @param entities - the tables that are to be built
222
- */
223
- buildSchema(datasourceId, entities) {
224
- return __awaiter(this, void 0, void 0, function* () {
225
- const columnsResponse = yield this.internalQuery({
226
- sql: this.COLUMNS_SQL,
227
- });
228
- const oracleTables = this.mapColumns(columnsResponse);
229
- const tables = {};
230
- // iterate each table
231
- Object.values(oracleTables).forEach(oracleTable => {
232
- let table = tables[oracleTable.name];
233
- if (!table) {
234
- table = {
235
- _id: (0, utils_1.buildExternalTableId)(datasourceId, oracleTable.name),
236
- primary: [],
237
- name: oracleTable.name,
238
- schema: {},
239
- };
240
- tables[oracleTable.name] = table;
241
- }
242
- // iterate each column on the table
243
- Object.values(oracleTable.columns)
244
- // remove columns that we can't read / save
245
- .filter(oracleColumn => OracleIntegration.isSupportedColumn(oracleColumn))
246
- // match the order of the columns in the db
247
- .sort((c1, c2) => c1.id - c2.id)
248
- .forEach(oracleColumn => {
249
- const columnName = oracleColumn.name;
250
- let fieldSchema = table.schema[columnName];
251
- if (!fieldSchema) {
252
- fieldSchema = Object.assign({ autocolumn: OracleIntegration.isAutoColumn(oracleColumn), name: columnName, constraints: {
253
- presence: false,
254
- } }, this.internalConvertType(oracleColumn));
255
- table.schema[columnName] = fieldSchema;
256
- }
257
- // iterate each constraint on the column
258
- Object.values(oracleColumn.constraints).forEach(oracleConstraint => {
259
- if (oracleConstraint.type === OracleContraintTypes.PRIMARY) {
260
- table.primary.push(columnName);
261
- }
262
- else if (oracleConstraint.type === OracleContraintTypes.NOT_NULL_OR_CHECK) {
263
- table.schema[columnName].constraints = {
264
- presence: true,
265
- };
266
- }
267
- });
268
- });
269
- });
270
- const final = (0, utils_1.finaliseExternalTables)(tables, entities);
271
- this.tables = final.tables;
272
- this.schemaErrors = final.errors;
273
- });
274
- }
275
- testConnection() {
276
- return __awaiter(this, void 0, void 0, function* () {
277
- const response = {
278
- connected: false,
279
- };
280
- let connection;
281
- try {
282
- connection = yield this.getConnection();
283
- response.connected = true;
284
- }
285
- catch (err) {
286
- response.connected = false;
287
- response.error = err.message;
288
- }
289
- finally {
290
- if (connection) {
291
- try {
292
- yield connection.close();
293
- }
294
- catch (err) {
295
- response.connected = false;
296
- response.error = err.message;
297
- }
298
- }
299
- }
300
- return response;
301
- });
302
- }
303
- internalQuery(query) {
304
- return __awaiter(this, void 0, void 0, function* () {
305
- let connection;
306
- try {
307
- this.index = 1;
308
- connection = yield this.getConnection();
309
- const options = { autoCommit: true };
310
- const bindings = query.bindings || [];
311
- return yield connection.execute(query.sql, bindings, options);
312
- }
313
- finally {
314
- if (connection) {
315
- try {
316
- yield connection.close();
317
- }
318
- catch (err) {
319
- console.error(err);
320
- }
321
- }
322
- }
323
- });
324
- }
325
- create(query) {
326
- return __awaiter(this, void 0, void 0, function* () {
327
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
328
- return response.rows && response.rows.length
329
- ? response.rows
330
- : [{ created: true }];
331
- });
332
- }
333
- read(query) {
334
- return __awaiter(this, void 0, void 0, function* () {
335
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
336
- return response.rows ? response.rows : [];
337
- });
338
- }
339
- update(query) {
340
- return __awaiter(this, void 0, void 0, function* () {
341
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
342
- return response.rows && response.rows.length
343
- ? response.rows
344
- : [{ updated: true }];
345
- });
346
- }
347
- delete(query) {
348
- return __awaiter(this, void 0, void 0, function* () {
349
- const response = yield this.internalQuery((0, utils_1.getSqlQuery)(query));
350
- return response.rows && response.rows.length
351
- ? response.rows
352
- : [{ deleted: true }];
353
- });
354
- }
355
- query(json) {
356
- var _a, _b, _c;
357
- return __awaiter(this, void 0, void 0, function* () {
358
- const operation = this._operation(json);
359
- const input = this._query(json, { disableReturning: true });
360
- if (Array.isArray(input)) {
361
- const responses = [];
362
- for (let query of input) {
363
- responses.push(yield this.internalQuery(query));
364
- }
365
- return responses;
366
- }
367
- else {
368
- // read the row to be deleted up front for the return
369
- let deletedRows;
370
- if (operation === types_1.Operation.DELETE) {
371
- const queryFn = (query) => this.internalQuery(query);
372
- deletedRows = yield this.getReturningRow(queryFn, json);
373
- }
374
- // run the query
375
- const response = yield this.internalQuery(input);
376
- // get the results or return the created / updated / deleted row
377
- if ((_a = deletedRows === null || deletedRows === void 0 ? void 0 : deletedRows.rows) === null || _a === void 0 ? void 0 : _a.length) {
378
- return deletedRows.rows;
379
- }
380
- else if ((_b = response.rows) === null || _b === void 0 ? void 0 : _b.length) {
381
- return response.rows;
382
- }
383
- else {
384
- // get the last row that was updated
385
- if (response.lastRowid &&
386
- ((_c = json.endpoint) === null || _c === void 0 ? void 0 : _c.entityId) &&
387
- operation !== types_1.Operation.DELETE) {
388
- const lastRow = yield this.internalQuery({
389
- sql: `SELECT * FROM \"${json.endpoint.entityId}\" WHERE ROWID = '${response.lastRowid}'`,
390
- });
391
- return lastRow.rows;
392
- }
393
- else {
394
- return [{ [operation.toLowerCase()]: true }];
395
- }
396
- }
397
- }
398
- });
399
- }
400
- }
401
- exports.default = {
402
- schema: SCHEMA,
403
- integration: OracleIntegration,
404
- };