@budibase/server 2.6.23 → 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 +22 -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 -102
  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,144 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.createAllSearchIndex = exports.createRoutingView = exports.createLinkView = void 0;
13
- const backend_core_1 = require("@budibase/backend-core");
14
- const utils_1 = require("../utils");
15
- const types_1 = require("@budibase/types");
16
- const SCREEN_PREFIX = utils_1.DocumentType.SCREEN + utils_1.SEPARATOR;
17
- /**************************************************
18
- * INFORMATION *
19
- * This file exists purely to keep views separate *
20
- * from the rest of the codebase, the reason *
21
- * being that they affect coverage and any *
22
- * functions written in this file cannot import *
23
- * or make use of any constants/variables that *
24
- * aren't defined as part of the map function *
25
- * itself. *
26
- **************************************************/
27
- /**
28
- * Creates the link view for the instance, this will overwrite the existing one, but this should only
29
- * be called if it is found that the view does not exist.
30
- * @returns {Promise<void>} The view now exists, please note that the next view of this query will actually build it,
31
- * so it may be slow.
32
- */
33
- function createLinkView() {
34
- return __awaiter(this, void 0, void 0, function* () {
35
- const db = backend_core_1.context.getAppDB();
36
- const designDoc = yield db.get("_design/database");
37
- const view = {
38
- map: function (doc) {
39
- // everything in this must remain constant as its going to Pouch, no external variables
40
- if (doc.type === "link") {
41
- let doc1 = doc.doc1;
42
- let doc2 = doc.doc2;
43
- // eslint-disable-next-line no-undef
44
- // @ts-ignore
45
- emit([doc1.tableId, doc1.rowId], {
46
- id: doc2.rowId,
47
- thisId: doc1.rowId,
48
- fieldName: doc1.fieldName,
49
- });
50
- // if linking to same table can't emit twice
51
- if (doc1.tableId !== doc2.tableId) {
52
- // eslint-disable-next-line no-undef
53
- // @ts-ignore
54
- emit([doc2.tableId, doc2.rowId], {
55
- id: doc1.rowId,
56
- thisId: doc2.rowId,
57
- fieldName: doc2.fieldName,
58
- });
59
- }
60
- }
61
- }.toString(),
62
- };
63
- designDoc.views = Object.assign(Object.assign({}, designDoc.views), { [utils_1.ViewName.LINK]: view });
64
- yield db.put(designDoc);
65
- });
66
- }
67
- exports.createLinkView = createLinkView;
68
- function createRoutingView() {
69
- return __awaiter(this, void 0, void 0, function* () {
70
- const db = backend_core_1.context.getAppDB();
71
- const designDoc = yield db.get("_design/database");
72
- const view = {
73
- // if using variables in a map function need to inject them before use
74
- map: `function(doc) {
75
- if (doc._id.startsWith("${SCREEN_PREFIX}")) {
76
- emit(doc._id, {
77
- id: doc._id,
78
- routing: doc.routing,
79
- })
80
- }
81
- }`,
82
- };
83
- designDoc.views = Object.assign(Object.assign({}, designDoc.views), { [utils_1.ViewName.ROUTING]: view });
84
- yield db.put(designDoc);
85
- });
86
- }
87
- exports.createRoutingView = createRoutingView;
88
- function searchIndex(indexName, fnString) {
89
- return __awaiter(this, void 0, void 0, function* () {
90
- const db = backend_core_1.context.getAppDB();
91
- const designDoc = yield db.get("_design/database");
92
- designDoc.indexes = {
93
- [indexName]: {
94
- index: fnString,
95
- analyzer: "keyword",
96
- },
97
- };
98
- yield db.put(designDoc);
99
- });
100
- }
101
- function createAllSearchIndex() {
102
- return __awaiter(this, void 0, void 0, function* () {
103
- yield searchIndex(types_1.SearchIndex.ROWS, function (doc) {
104
- function idx(input, prev) {
105
- for (let key of Object.keys(input)) {
106
- let idxKey = prev != null ? `${prev}.${key}` : key;
107
- idxKey = idxKey.replace(/ /g, "_");
108
- if (Array.isArray(input[key])) {
109
- for (let val of input[key]) {
110
- if (typeof val !== "object") {
111
- // eslint-disable-next-line no-undef
112
- // @ts-ignore
113
- index(idxKey, val, { store: true });
114
- }
115
- }
116
- }
117
- else if (key === "_id" || key === "_rev" || input[key] == null) {
118
- continue;
119
- }
120
- if (typeof input[key] === "string") {
121
- // eslint-disable-next-line no-undef
122
- // @ts-ignore
123
- index(idxKey, input[key].toLowerCase(), { store: true });
124
- }
125
- else if (typeof input[key] !== "object") {
126
- // eslint-disable-next-line no-undef
127
- // @ts-ignore
128
- index(idxKey, input[key], { store: true });
129
- }
130
- else {
131
- idx(input[key], idxKey);
132
- }
133
- }
134
- }
135
- if (doc._id.startsWith("ro_")) {
136
- // eslint-disable-next-line no-undef
137
- // @ts-ignore
138
- index("default", doc._id);
139
- idx(doc);
140
- }
141
- }.toString());
142
- });
143
- }
144
- exports.createAllSearchIndex = createAllSearchIndex;
package/dist/ddApm.js DELETED
@@ -1,11 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const dd_trace_1 = __importDefault(require("dd-trace"));
7
- // enable APM if configured
8
- if (process.env.DD_APM_ENABLED) {
9
- console.log("Starting dd-trace");
10
- dd_trace_1.default.init();
11
- }
@@ -1,8 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LoopStepType = void 0;
4
- var LoopStepType;
5
- (function (LoopStepType) {
6
- LoopStepType["ARRAY"] = "Array";
7
- LoopStepType["STRING"] = "String";
8
- })(LoopStepType = exports.LoopStepType || (exports.LoopStepType = {}));
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,7 +0,0 @@
1
- "use strict";
2
- /********************************************
3
- * This file contains structures which are *
4
- * internal to the server and don't need to *
5
- * be exposed for use by other services. *
6
- ********************************************/
7
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,6 +0,0 @@
1
- "use strict";
2
- /**
3
- * This file was auto-generated by openapi-typescript.
4
- * Do not make direct changes to the file.
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,109 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const path_1 = require("path");
4
- function isTest() {
5
- return isCypress() || isJest();
6
- }
7
- function isJest() {
8
- return (process.env.NODE_ENV === "jest" ||
9
- (process.env.JEST_WORKER_ID != null &&
10
- process.env.JEST_WORKER_ID !== "null"));
11
- }
12
- function isDev() {
13
- return process.env.NODE_ENV !== "production";
14
- }
15
- function isCypress() {
16
- return process.env.NODE_ENV === "cypress";
17
- }
18
- let LOADED = false;
19
- if (!LOADED && isDev() && !isTest()) {
20
- require("dotenv").config({
21
- path: (0, path_1.join)(__dirname, "..", ".env"),
22
- });
23
- LOADED = true;
24
- }
25
- function parseIntSafe(number) {
26
- if (number) {
27
- return parseInt(number);
28
- }
29
- }
30
- const environment = {
31
- // important - prefer app port to generic port
32
- PORT: process.env.APP_PORT || process.env.PORT,
33
- COUCH_DB_URL: process.env.COUCH_DB_URL,
34
- MINIO_URL: process.env.MINIO_URL,
35
- WORKER_URL: process.env.WORKER_URL,
36
- AWS_REGION: process.env.AWS_REGION,
37
- MINIO_ACCESS_KEY: process.env.MINIO_ACCESS_KEY,
38
- MINIO_SECRET_KEY: process.env.MINIO_SECRET_KEY,
39
- REDIS_URL: process.env.REDIS_URL,
40
- REDIS_PASSWORD: process.env.REDIS_PASSWORD,
41
- REDIS_CLUSTERED: process.env.REDIS_CLUSTERED,
42
- HTTP_MIGRATIONS: process.env.HTTP_MIGRATIONS,
43
- API_REQ_LIMIT_PER_SEC: process.env.API_REQ_LIMIT_PER_SEC,
44
- GOOGLE_CLIENT_ID: process.env.GOOGLE_CLIENT_ID,
45
- GOOGLE_CLIENT_SECRET: process.env.GOOGLE_CLIENT_SECRET,
46
- // environment
47
- NODE_ENV: process.env.NODE_ENV,
48
- JEST_WORKER_ID: process.env.JEST_WORKER_ID,
49
- BUDIBASE_ENVIRONMENT: process.env.BUDIBASE_ENVIRONMENT,
50
- DISABLE_ACCOUNT_PORTAL: process.env.DISABLE_ACCOUNT_PORTAL,
51
- TEMPLATE_REPOSITORY: process.env.TEMPLATE_REPOSITORY || "app",
52
- DISABLE_AUTO_PROD_APP_SYNC: process.env.DISABLE_AUTO_PROD_APP_SYNC,
53
- SESSION_UPDATE_PERIOD: process.env.SESSION_UPDATE_PERIOD,
54
- // minor
55
- SALT_ROUNDS: process.env.SALT_ROUNDS,
56
- LOGGER: process.env.LOGGER,
57
- ACCOUNT_PORTAL_URL: process.env.ACCOUNT_PORTAL_URL,
58
- AUTOMATION_MAX_ITERATIONS: parseIntSafe(process.env.AUTOMATION_MAX_ITERATIONS) || 200,
59
- SENDGRID_API_KEY: process.env.SENDGRID_API_KEY,
60
- DYNAMO_ENDPOINT: process.env.DYNAMO_ENDPOINT,
61
- QUERY_THREAD_TIMEOUT: parseIntSafe(process.env.QUERY_THREAD_TIMEOUT),
62
- SQL_MAX_ROWS: process.env.SQL_MAX_ROWS,
63
- BB_ADMIN_USER_EMAIL: process.env.BB_ADMIN_USER_EMAIL,
64
- BB_ADMIN_USER_PASSWORD: process.env.BB_ADMIN_USER_PASSWORD,
65
- PLUGINS_DIR: process.env.PLUGINS_DIR || "/plugins",
66
- // flags
67
- ALLOW_DEV_AUTOMATIONS: process.env.ALLOW_DEV_AUTOMATIONS,
68
- DISABLE_THREADING: process.env.DISABLE_THREADING,
69
- DISABLE_AUTOMATION_LOGS: process.env.DISABLE_AUTOMATION_LOGS,
70
- MULTI_TENANCY: process.env.MULTI_TENANCY,
71
- ENABLE_ANALYTICS: process.env.ENABLE_ANALYTICS,
72
- SELF_HOSTED: process.env.SELF_HOSTED,
73
- HTTP_MB_LIMIT: process.env.HTTP_MB_LIMIT,
74
- // old
75
- CLIENT_ID: process.env.CLIENT_ID,
76
- _set(key, value) {
77
- process.env[key] = value;
78
- // @ts-ignore
79
- environment[key] = value;
80
- },
81
- isTest,
82
- isJest,
83
- isCypress,
84
- isDev,
85
- isProd: () => {
86
- return !isDev();
87
- },
88
- isInThread: () => {
89
- return process.env.FORKED_PROCESS;
90
- },
91
- };
92
- // threading can cause memory issues with node-ts in development
93
- if (isDev() && environment.DISABLE_THREADING == null) {
94
- environment._set("DISABLE_THREADING", "1");
95
- }
96
- // clean up any environment variable edge cases
97
- for (let [key, value] of Object.entries(environment)) {
98
- // handle the edge case of "0" to disable an environment variable
99
- if (value === "0") {
100
- // @ts-ignore
101
- environment[key] = 0;
102
- }
103
- // handle the edge case of "false" to disable an environment variable
104
- if (value === "false") {
105
- // @ts-ignore
106
- environment[key] = 0;
107
- }
108
- }
109
- exports.default = environment;
@@ -1,53 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const utils_1 = require("./utils");
7
- const index_1 = __importDefault(require("./index"));
8
- const environment_1 = __importDefault(require("../environment"));
9
- // max number of automations that can chain on top of each other
10
- // TODO: in future make this configurable at the automation level
11
- const MAX_AUTOMATION_CHAIN = environment_1.default.SELF_HOSTED ? 5 : 0;
12
- /**
13
- * Special emitter which takes the count of automation runs which have occurred and blocks an
14
- * automation from running if it has reached the maximum number of chained automations runs.
15
- * This essentially "fakes" the normal emitter to add some functionality in-between to stop automations
16
- * from getting stuck endlessly chaining.
17
- */
18
- class AutomationEmitter {
19
- constructor(chainCount) {
20
- this.chainCount = chainCount;
21
- this.metadata = {
22
- automationChainCount: chainCount,
23
- };
24
- }
25
- emitRow(eventName, appId, row, table) {
26
- // don't emit even if we've reached max automation chain
27
- if (this.chainCount >= MAX_AUTOMATION_CHAIN) {
28
- return;
29
- }
30
- (0, utils_1.rowEmission)({
31
- emitter: index_1.default,
32
- eventName,
33
- appId,
34
- row,
35
- table,
36
- metadata: this.metadata,
37
- });
38
- }
39
- emitTable(eventName, appId, table) {
40
- // don't emit even if we've reached max automation chain
41
- if (this.chainCount > MAX_AUTOMATION_CHAIN) {
42
- return;
43
- }
44
- (0, utils_1.tableEmission)({
45
- emitter: index_1.default,
46
- eventName,
47
- appId,
48
- table,
49
- metadata: this.metadata,
50
- });
51
- }
52
- }
53
- exports.default = AutomationEmitter;
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const events_1 = require("events");
4
- const utils_1 = require("./utils");
5
- /**
6
- * keeping event emitter in one central location as it might be used for things other than
7
- * automations (what it was for originally) - having a central emitter will be useful in the
8
- * future.
9
- */
10
- /**
11
- * Extending the standard emitter to some syntactic sugar and standardisation to the emitted event.
12
- * This is specifically quite important for template strings used in automations.
13
- */
14
- class BudibaseEmitter extends events_1.EventEmitter {
15
- emitRow(eventName, appId, row, table) {
16
- (0, utils_1.rowEmission)({ emitter: this, eventName, appId, row, table });
17
- }
18
- emitTable(eventName, appId, table) {
19
- (0, utils_1.tableEmission)({ emitter: this, eventName, appId, table });
20
- }
21
- emitPort(portNumber) {
22
- this.emit("internal:port", portNumber);
23
- }
24
- }
25
- exports.default = BudibaseEmitter;
@@ -1,17 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./processors"), exports);
@@ -1,18 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.init = void 0;
7
- const syncUsers_1 = __importDefault(require("./syncUsers"));
8
- const backend_core_1 = require("@budibase/backend-core");
9
- let started = false;
10
- function init(updateCb) {
11
- if (started) {
12
- return;
13
- }
14
- const processors = [(0, syncUsers_1.default)(updateCb)];
15
- backend_core_1.docUpdates.init(processors);
16
- started = true;
17
- }
18
- exports.init = init;
@@ -1,49 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- const backend_core_1 = require("@budibase/backend-core");
13
- const pro_1 = require("@budibase/pro");
14
- const types_1 = require("@budibase/types");
15
- const sync_1 = require("../../sdk/app/applications/sync");
16
- function process(updateCb) {
17
- const processor = (update) => __awaiter(this, void 0, void 0, function* () {
18
- var _a;
19
- try {
20
- const docId = update.id;
21
- const isGroup = docId.startsWith(backend_core_1.constants.DocumentType.GROUP);
22
- let userIds;
23
- if (isGroup) {
24
- const group = yield pro_1.sdk.groups.get(docId);
25
- userIds = ((_a = group.users) === null || _a === void 0 ? void 0 : _a.map(user => user._id)) || [];
26
- }
27
- else {
28
- userIds = [docId];
29
- }
30
- if (userIds.length > 0) {
31
- yield (0, sync_1.syncUsersToAllApps)(userIds);
32
- }
33
- if (updateCb) {
34
- updateCb(docId);
35
- }
36
- }
37
- catch (err) {
38
- // if something not found - no changes to perform
39
- if ((err === null || err === void 0 ? void 0 : err.status) === 404) {
40
- return;
41
- }
42
- else {
43
- backend_core_1.logging.logAlert("Failed to perform user/group app sync", err);
44
- }
45
- }
46
- });
47
- return { events: types_1.UserGroupSyncEvents, processor };
48
- }
49
- exports.default = process;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.init = void 0;
7
- const BudibaseEmitter_1 = __importDefault(require("./BudibaseEmitter"));
8
- const emitter = new BudibaseEmitter_1.default();
9
- var docUpdates_1 = require("./docUpdates");
10
- Object.defineProperty(exports, "init", { enumerable: true, get: function () { return docUpdates_1.init; } });
11
- exports.default = emitter;
@@ -1,43 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.tableEmission = exports.rowEmission = void 0;
4
- function rowEmission({ emitter, eventName, appId, row, table, metadata, }) {
5
- let event = {
6
- row,
7
- appId,
8
- tableId: row === null || row === void 0 ? void 0 : row.tableId,
9
- };
10
- if (table) {
11
- event.table = table;
12
- }
13
- event.id = row === null || row === void 0 ? void 0 : row._id;
14
- if (row === null || row === void 0 ? void 0 : row._rev) {
15
- event.revision = row._rev;
16
- }
17
- if (metadata) {
18
- event.metadata = metadata;
19
- }
20
- emitter.emit(eventName, event);
21
- }
22
- exports.rowEmission = rowEmission;
23
- function tableEmission({ emitter, eventName, appId, table, metadata, }) {
24
- const tableId = table === null || table === void 0 ? void 0 : table._id;
25
- const inputTable = table;
26
- if (inputTable) {
27
- inputTable.tableId = tableId;
28
- }
29
- let event = {
30
- table: inputTable,
31
- appId,
32
- tableId: tableId,
33
- };
34
- event.id = tableId;
35
- if (table === null || table === void 0 ? void 0 : table._rev) {
36
- event.revision = table._rev;
37
- }
38
- if (metadata) {
39
- event.metadata = metadata;
40
- }
41
- emitter.emit(eventName, event);
42
- }
43
- exports.tableEmission = tableEmission;
@@ -1,147 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- const types_1 = require("@budibase/types");
13
- const Airtable = require("airtable");
14
- const SCHEMA = {
15
- docs: "https://airtable.com/api",
16
- description: "Airtable is a spreadsheet-database hybrid, with the features of a database but applied to a spreadsheet.",
17
- friendlyName: "Airtable",
18
- type: "Spreadsheet",
19
- datasource: {
20
- apiKey: {
21
- type: types_1.DatasourceFieldType.PASSWORD,
22
- default: "enter api key",
23
- required: true,
24
- },
25
- base: {
26
- type: types_1.DatasourceFieldType.STRING,
27
- default: "mybase",
28
- required: true,
29
- },
30
- },
31
- query: {
32
- create: {
33
- type: types_1.QueryType.FIELDS,
34
- customisable: true,
35
- fields: {
36
- table: {
37
- type: types_1.DatasourceFieldType.STRING,
38
- required: true,
39
- },
40
- },
41
- },
42
- read: {
43
- type: types_1.QueryType.FIELDS,
44
- fields: {
45
- table: {
46
- type: types_1.DatasourceFieldType.STRING,
47
- required: true,
48
- },
49
- view: {
50
- type: types_1.DatasourceFieldType.STRING,
51
- required: true,
52
- },
53
- numRecords: {
54
- type: types_1.DatasourceFieldType.NUMBER,
55
- default: 10,
56
- },
57
- },
58
- },
59
- update: {
60
- type: types_1.QueryType.FIELDS,
61
- customisable: true,
62
- fields: {
63
- id: {
64
- display: "Record ID",
65
- type: types_1.DatasourceFieldType.STRING,
66
- required: true,
67
- },
68
- table: {
69
- type: types_1.DatasourceFieldType.STRING,
70
- required: true,
71
- },
72
- },
73
- },
74
- delete: {
75
- type: types_1.QueryType.JSON,
76
- },
77
- },
78
- };
79
- class AirtableIntegration {
80
- constructor(config) {
81
- this.config = config;
82
- this.client = new Airtable(config).base(config.base);
83
- }
84
- create(query) {
85
- return __awaiter(this, void 0, void 0, function* () {
86
- const { table, json } = query;
87
- try {
88
- return yield this.client(table).create([
89
- {
90
- fields: json,
91
- },
92
- ]);
93
- }
94
- catch (err) {
95
- console.error("Error writing to airtable", err);
96
- throw err;
97
- }
98
- });
99
- }
100
- read(query) {
101
- return __awaiter(this, void 0, void 0, function* () {
102
- try {
103
- const records = yield this.client(query.table)
104
- .select({ maxRecords: query.numRecords || 10, view: query.view })
105
- .firstPage();
106
- // @ts-ignore
107
- return records.map(({ fields }) => fields);
108
- }
109
- catch (err) {
110
- console.error("Error writing to airtable", err);
111
- return [];
112
- }
113
- });
114
- }
115
- update(query) {
116
- return __awaiter(this, void 0, void 0, function* () {
117
- const { table, id, json } = query;
118
- try {
119
- return yield this.client(table).update([
120
- {
121
- id,
122
- fields: json,
123
- },
124
- ]);
125
- }
126
- catch (err) {
127
- console.error("Error writing to airtable", err);
128
- throw err;
129
- }
130
- });
131
- }
132
- delete(query) {
133
- return __awaiter(this, void 0, void 0, function* () {
134
- try {
135
- return yield this.client(query.table).destroy(query.ids);
136
- }
137
- catch (err) {
138
- console.error("Error writing to airtable", err);
139
- throw err;
140
- }
141
- });
142
- }
143
- }
144
- exports.default = {
145
- schema: SCHEMA,
146
- integration: AirtableIntegration,
147
- };