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

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