@budibase/server 2.6.19-alpha.2 → 2.6.19-alpha.20

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 (358) hide show
  1. package/.dockerignore +7 -6
  2. package/Dockerfile +16 -8
  3. package/builder/assets/{index.07382a47.css → index.46d94ca7.css} +2 -2
  4. package/builder/assets/{index.6c1171e2.js → index.9a9bace2.js} +346 -338
  5. package/builder/index.html +2 -2
  6. package/client/manifest.json +5229 -0
  7. package/dist/automation.js +32208 -0
  8. package/dist/automation.js.map +7 -0
  9. package/dist/index.js +44381 -13
  10. package/dist/index.js.map +7 -0
  11. package/dist/query.js +24327 -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 +30 -13
  16. package/pm2.config.js +1 -1
  17. package/scripts/build.js +48 -0
  18. package/src/api/controllers/datasource.ts +16 -0
  19. package/src/api/controllers/row/internal.ts +1 -1
  20. package/src/api/controllers/static/index.ts +3 -3
  21. package/src/api/controllers/table/internal.ts +2 -6
  22. package/src/api/controllers/table/utils.ts +32 -1
  23. package/src/api/routes/datasource.ts +5 -0
  24. package/src/api/routes/static.ts +3 -1
  25. package/src/api/routes/tests/datasource.spec.ts +1 -1
  26. package/src/automations/actions.ts +5 -0
  27. package/src/automations/steps/openai.ts +105 -0
  28. package/src/automations/tests/openai.spec.ts +86 -0
  29. package/src/constants/index.ts +17 -16
  30. package/src/db/inMemoryView.ts +1 -0
  31. package/src/environment.ts +2 -0
  32. package/src/integration-test/postgres.spec.ts +47 -4
  33. package/src/integrations/airtable.ts +3 -1
  34. package/src/integrations/arangodb.ts +3 -1
  35. package/src/integrations/base/sqlTable.ts +0 -1
  36. package/src/integrations/couchdb.ts +3 -1
  37. package/src/integrations/dynamodb.ts +3 -1
  38. package/src/integrations/elasticsearch.ts +3 -1
  39. package/src/integrations/firebase.ts +3 -1
  40. package/src/integrations/googlesheets.ts +11 -3
  41. package/src/integrations/microsoftSqlServer.ts +18 -2
  42. package/src/integrations/mongodb.ts +3 -1
  43. package/src/integrations/mysql.ts +27 -11
  44. package/src/integrations/oracle.ts +11 -1
  45. package/src/integrations/postgres.ts +27 -10
  46. package/src/integrations/redis.ts +3 -1
  47. package/src/integrations/s3.ts +3 -1
  48. package/src/integrations/snowflake.ts +3 -1
  49. package/src/integrations/tests/googlesheets.spec.ts +41 -9
  50. package/src/utilities/fileSystem/app.ts +1 -1
  51. package/src/utilities/fileSystem/clientLibrary.ts +8 -3
  52. package/src/utilities/fileSystem/filesystem.ts +3 -1
  53. package/tsconfig.build.json +9 -1
  54. package/tsconfig.json +1 -14
  55. package/dist/api/controllers/analytics.js +0 -46
  56. package/dist/api/controllers/apikeys.js +0 -72
  57. package/dist/api/controllers/application.js +0 -574
  58. package/dist/api/controllers/auth.js +0 -80
  59. package/dist/api/controllers/automation.js +0 -303
  60. package/dist/api/controllers/backup.js +0 -37
  61. package/dist/api/controllers/component.js +0 -59
  62. package/dist/api/controllers/datasource.js +0 -337
  63. package/dist/api/controllers/deploy/Deployment.js +0 -53
  64. package/dist/api/controllers/deploy/index.js +0 -198
  65. package/dist/api/controllers/dev.js +0 -146
  66. package/dist/api/controllers/integration.js +0 -28
  67. package/dist/api/controllers/layout.js +0 -49
  68. package/dist/api/controllers/metadata.js +0 -63
  69. package/dist/api/controllers/migrations.js +0 -29
  70. package/dist/api/controllers/ops.js +0 -40
  71. package/dist/api/controllers/permission.js +0 -162
  72. package/dist/api/controllers/plugin/file.js +0 -24
  73. package/dist/api/controllers/plugin/github.js +0 -69
  74. package/dist/api/controllers/plugin/index.js +0 -112
  75. package/dist/api/controllers/plugin/npm.js +0 -58
  76. package/dist/api/controllers/plugin/uploaders.js +0 -11
  77. package/dist/api/controllers/plugin/url.js +0 -24
  78. package/dist/api/controllers/plugin/utils.js +0 -27
  79. package/dist/api/controllers/public/applications.js +0 -146
  80. package/dist/api/controllers/public/mapping/applications.js +0 -29
  81. package/dist/api/controllers/public/mapping/index.js +0 -11
  82. package/dist/api/controllers/public/mapping/queries.js +0 -36
  83. package/dist/api/controllers/public/mapping/rows.js +0 -24
  84. package/dist/api/controllers/public/mapping/tables.js +0 -23
  85. package/dist/api/controllers/public/mapping/types.js +0 -2
  86. package/dist/api/controllers/public/mapping/users.js +0 -29
  87. package/dist/api/controllers/public/metrics.js +0 -113
  88. package/dist/api/controllers/public/queries.js +0 -58
  89. package/dist/api/controllers/public/rows.js +0 -120
  90. package/dist/api/controllers/public/tables.js +0 -95
  91. package/dist/api/controllers/public/users.js +0 -93
  92. package/dist/api/controllers/public/utils.js +0 -56
  93. package/dist/api/controllers/query/import/index.js +0 -87
  94. package/dist/api/controllers/query/import/sources/base/index.js +0 -75
  95. package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
  96. package/dist/api/controllers/query/import/sources/curl.js +0 -99
  97. package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
  98. package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
  99. package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
  100. package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
  101. package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
  102. package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
  103. package/dist/api/controllers/query/index.js +0 -299
  104. package/dist/api/controllers/query/validation.js +0 -53
  105. package/dist/api/controllers/role.js +0 -109
  106. package/dist/api/controllers/routing.js +0 -105
  107. package/dist/api/controllers/row/ExternalRequest.js +0 -683
  108. package/dist/api/controllers/row/external.js +0 -339
  109. package/dist/api/controllers/row/index.js +0 -203
  110. package/dist/api/controllers/row/internal.js +0 -509
  111. package/dist/api/controllers/row/internalSearch.js +0 -28
  112. package/dist/api/controllers/row/staticFormula.js +0 -165
  113. package/dist/api/controllers/row/utils.js +0 -183
  114. package/dist/api/controllers/screen.js +0 -110
  115. package/dist/api/controllers/script.js +0 -30
  116. package/dist/api/controllers/static/index.js +0 -268
  117. package/dist/api/controllers/table/bulkFormula.js +0 -173
  118. package/dist/api/controllers/table/external.js +0 -279
  119. package/dist/api/controllers/table/index.js +0 -179
  120. package/dist/api/controllers/table/internal.js +0 -197
  121. package/dist/api/controllers/table/utils.js +0 -379
  122. package/dist/api/controllers/templates.js +0 -56
  123. package/dist/api/controllers/user.js +0 -124
  124. package/dist/api/controllers/view/exporters.js +0 -46
  125. package/dist/api/controllers/view/index.js +0 -193
  126. package/dist/api/controllers/view/utils.js +0 -177
  127. package/dist/api/controllers/view/viewBuilder.js +0 -158
  128. package/dist/api/controllers/webhook.js +0 -134
  129. package/dist/api/index.js +0 -55
  130. package/dist/api/routes/analytics.js +0 -34
  131. package/dist/api/routes/apikeys.js +0 -37
  132. package/dist/api/routes/application.js +0 -48
  133. package/dist/api/routes/auth.js +0 -33
  134. package/dist/api/routes/automation.js +0 -50
  135. package/dist/api/routes/backup.js +0 -35
  136. package/dist/api/routes/component.js +0 -35
  137. package/dist/api/routes/datasource.js +0 -44
  138. package/dist/api/routes/deploy.js +0 -37
  139. package/dist/api/routes/dev.js +0 -49
  140. package/dist/api/routes/index.js +0 -75
  141. package/dist/api/routes/integration.js +0 -37
  142. package/dist/api/routes/layout.js +0 -37
  143. package/dist/api/routes/metadata.js +0 -40
  144. package/dist/api/routes/migrations.js +0 -36
  145. package/dist/api/routes/ops.js +0 -52
  146. package/dist/api/routes/permission.js +0 -44
  147. package/dist/api/routes/plugin.js +0 -39
  148. package/dist/api/routes/public/applications.js +0 -174
  149. package/dist/api/routes/public/index.js +0 -140
  150. package/dist/api/routes/public/metrics.js +0 -30
  151. package/dist/api/routes/public/middleware/mapper.js +0 -97
  152. package/dist/api/routes/public/queries.js +0 -72
  153. package/dist/api/routes/public/rows.js +0 -158
  154. package/dist/api/routes/public/tables.js +0 -152
  155. package/dist/api/routes/public/users.js +0 -135
  156. package/dist/api/routes/public/utils/Endpoint.js +0 -36
  157. package/dist/api/routes/query.js +0 -47
  158. package/dist/api/routes/role.js +0 -40
  159. package/dist/api/routes/routing.js +0 -39
  160. package/dist/api/routes/row.js +0 -239
  161. package/dist/api/routes/screen.js +0 -39
  162. package/dist/api/routes/script.js +0 -35
  163. package/dist/api/routes/static.js +0 -80
  164. package/dist/api/routes/table.js +0 -163
  165. package/dist/api/routes/templates.js +0 -37
  166. package/dist/api/routes/user.js +0 -43
  167. package/dist/api/routes/utils/validators.js +0 -238
  168. package/dist/api/routes/view.js +0 -42
  169. package/dist/api/routes/webhook.js +0 -43
  170. package/dist/app.js +0 -132
  171. package/dist/automations/actions.js +0 -137
  172. package/dist/automations/automationUtils.js +0 -173
  173. package/dist/automations/bullboard.js +0 -71
  174. package/dist/automations/index.js +0 -43
  175. package/dist/automations/logging/index.js +0 -53
  176. package/dist/automations/steps/bash.js +0 -111
  177. package/dist/automations/steps/createRow.js +0 -108
  178. package/dist/automations/steps/delay.js +0 -53
  179. package/dist/automations/steps/deleteRow.js +0 -96
  180. package/dist/automations/steps/discord.js +0 -116
  181. package/dist/automations/steps/executeQuery.js +0 -134
  182. package/dist/automations/steps/executeScript.js +0 -106
  183. package/dist/automations/steps/filter.js +0 -112
  184. package/dist/automations/steps/loop.js +0 -54
  185. package/dist/automations/steps/make.js +0 -134
  186. package/dist/automations/steps/outgoingWebhook.js +0 -166
  187. package/dist/automations/steps/queryRows.js +0 -216
  188. package/dist/automations/steps/sendSmtpEmail.js +0 -115
  189. package/dist/automations/steps/serverLog.js +0 -65
  190. package/dist/automations/steps/slack.js +0 -98
  191. package/dist/automations/steps/updateRow.js +0 -144
  192. package/dist/automations/steps/utils.js +0 -56
  193. package/dist/automations/steps/zapier.js +0 -130
  194. package/dist/automations/triggerInfo/app.js +0 -36
  195. package/dist/automations/triggerInfo/cron.js +0 -35
  196. package/dist/automations/triggerInfo/index.js +0 -40
  197. package/dist/automations/triggerInfo/rowDeleted.js +0 -36
  198. package/dist/automations/triggerInfo/rowSaved.js +0 -44
  199. package/dist/automations/triggerInfo/rowUpdated.js +0 -44
  200. package/dist/automations/triggerInfo/webhook.js +0 -40
  201. package/dist/automations/triggers.js +0 -181
  202. package/dist/automations/utils.js +0 -275
  203. package/dist/constants/definitions.js +0 -2
  204. package/dist/constants/index.js +0 -181
  205. package/dist/constants/layouts.js +0 -148
  206. package/dist/constants/screens.js +0 -51
  207. package/dist/db/defaultData/datasource_bb_default.js +0 -574
  208. package/dist/db/defaultData/employeeImport.js +0 -155
  209. package/dist/db/defaultData/expensesImport.js +0 -117
  210. package/dist/db/defaultData/inventoryImport.js +0 -109
  211. package/dist/db/defaultData/jobsImport.js +0 -152
  212. package/dist/db/dynamoClient.js +0 -124
  213. package/dist/db/inMemoryView.js +0 -62
  214. package/dist/db/index.js +0 -43
  215. package/dist/db/linkedRows/LinkController.js +0 -392
  216. package/dist/db/linkedRows/LinkDocument.js +0 -33
  217. package/dist/db/linkedRows/index.js +0 -206
  218. package/dist/db/linkedRows/linkUtils.js +0 -131
  219. package/dist/db/newid.js +0 -7
  220. package/dist/db/utils.js +0 -248
  221. package/dist/db/views/staticViews.js +0 -144
  222. package/dist/ddApm.js +0 -11
  223. package/dist/definitions/automations.js +0 -8
  224. package/dist/definitions/common.js +0 -2
  225. package/dist/definitions/datasource.js +0 -7
  226. package/dist/definitions/openapi.js +0 -6
  227. package/dist/environment.js +0 -109
  228. package/dist/events/AutomationEmitter.js +0 -53
  229. package/dist/events/BudibaseEmitter.js +0 -25
  230. package/dist/events/docUpdates/index.js +0 -17
  231. package/dist/events/docUpdates/processors.js +0 -18
  232. package/dist/events/docUpdates/syncUsers.js +0 -49
  233. package/dist/events/index.js +0 -11
  234. package/dist/events/utils.js +0 -43
  235. package/dist/integrations/airtable.js +0 -173
  236. package/dist/integrations/arangodb.js +0 -119
  237. package/dist/integrations/base/query.js +0 -32
  238. package/dist/integrations/base/sql.js +0 -600
  239. package/dist/integrations/base/sqlTable.js +0 -167
  240. package/dist/integrations/base/types.js +0 -2
  241. package/dist/integrations/couchdb.js +0 -140
  242. package/dist/integrations/dynamodb.js +0 -210
  243. package/dist/integrations/elasticsearch.js +0 -201
  244. package/dist/integrations/firebase.js +0 -189
  245. package/dist/integrations/googlesheets.js +0 -484
  246. package/dist/integrations/index.js +0 -138
  247. package/dist/integrations/microsoftSqlServer.js +0 -289
  248. package/dist/integrations/mongodb.js +0 -630
  249. package/dist/integrations/mysql.js +0 -272
  250. package/dist/integrations/oracle.js +0 -404
  251. package/dist/integrations/postgres.js +0 -319
  252. package/dist/integrations/queries/sql.js +0 -84
  253. package/dist/integrations/redis.js +0 -187
  254. package/dist/integrations/rest.js +0 -400
  255. package/dist/integrations/s3.js +0 -256
  256. package/dist/integrations/snowflake.js +0 -114
  257. package/dist/integrations/utils.js +0 -295
  258. package/dist/middleware/appInfo.js +0 -22
  259. package/dist/middleware/authorized.js +0 -112
  260. package/dist/middleware/builder.js +0 -93
  261. package/dist/middleware/currentapp.js +0 -103
  262. package/dist/middleware/joi-validator.js +0 -43
  263. package/dist/middleware/publicApi.js +0 -25
  264. package/dist/middleware/resourceId.js +0 -59
  265. package/dist/middleware/selfhost.js +0 -24
  266. package/dist/middleware/utils.js +0 -8
  267. package/dist/migrations/functions/appUrls.js +0 -42
  268. package/dist/migrations/functions/backfill/app/automations.js +0 -31
  269. package/dist/migrations/functions/backfill/app/datasources.js +0 -28
  270. package/dist/migrations/functions/backfill/app/layouts.js +0 -33
  271. package/dist/migrations/functions/backfill/app/queries.js +0 -49
  272. package/dist/migrations/functions/backfill/app/roles.js +0 -28
  273. package/dist/migrations/functions/backfill/app/screens.js +0 -28
  274. package/dist/migrations/functions/backfill/app/tables.js +0 -37
  275. package/dist/migrations/functions/backfill/app.js +0 -176
  276. package/dist/migrations/functions/backfill/global/configs.js +0 -67
  277. package/dist/migrations/functions/backfill/global/quotas.js +0 -60
  278. package/dist/migrations/functions/backfill/global/users.js +0 -50
  279. package/dist/migrations/functions/backfill/global.js +0 -205
  280. package/dist/migrations/functions/backfill/index.js +0 -32
  281. package/dist/migrations/functions/backfill/installation.js +0 -80
  282. package/dist/migrations/functions/syncQuotas.js +0 -52
  283. package/dist/migrations/functions/tableSettings.js +0 -130
  284. package/dist/migrations/functions/usageQuotas/index.js +0 -16
  285. package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
  286. package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
  287. package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
  288. package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
  289. package/dist/migrations/functions/userEmailViewCasing.js +0 -24
  290. package/dist/migrations/index.js +0 -111
  291. package/dist/migrations/tests/helpers.js +0 -72
  292. package/dist/migrations/tests/structures.js +0 -37
  293. package/dist/sdk/app/applications/index.js +0 -28
  294. package/dist/sdk/app/applications/sync.js +0 -164
  295. package/dist/sdk/app/applications/utils.js +0 -21
  296. package/dist/sdk/app/automations/index.js +0 -29
  297. package/dist/sdk/app/automations/webhook.js +0 -54
  298. package/dist/sdk/app/backups/constants.js +0 -6
  299. package/dist/sdk/app/backups/exports.js +0 -160
  300. package/dist/sdk/app/backups/imports.js +0 -170
  301. package/dist/sdk/app/backups/index.js +0 -29
  302. package/dist/sdk/app/backups/statistics.js +0 -73
  303. package/dist/sdk/app/datasources/datasources.js +0 -173
  304. package/dist/sdk/app/datasources/index.js +0 -27
  305. package/dist/sdk/app/queries/index.js +0 -27
  306. package/dist/sdk/app/queries/queries.js +0 -60
  307. package/dist/sdk/app/rows/attachments.js +0 -61
  308. package/dist/sdk/app/rows/index.js +0 -28
  309. package/dist/sdk/app/rows/rows.js +0 -30
  310. package/dist/sdk/app/tables/index.js +0 -65
  311. package/dist/sdk/index.js +0 -27
  312. package/dist/sdk/plugins/index.js +0 -27
  313. package/dist/sdk/plugins/plugins.js +0 -53
  314. package/dist/sdk/users/index.js +0 -27
  315. package/dist/sdk/users/utils.js +0 -87
  316. package/dist/sdk/utils/index.js +0 -29
  317. package/dist/startup.js +0 -158
  318. package/dist/threads/automation.js +0 -450
  319. package/dist/threads/definitions.js +0 -2
  320. package/dist/threads/index.js +0 -140
  321. package/dist/threads/query.js +0 -265
  322. package/dist/threads/utils.js +0 -120
  323. package/dist/tsconfig.build.tsbuildinfo +0 -1
  324. package/dist/utilities/appDirectoryTemplate/package.json +0 -10
  325. package/dist/utilities/budibaseDir.js +0 -5
  326. package/dist/utilities/centralPath.js +0 -27
  327. package/dist/utilities/csv.js +0 -33
  328. package/dist/utilities/fileSystem/app.js +0 -88
  329. package/dist/utilities/fileSystem/clientLibrary.js +0 -138
  330. package/dist/utilities/fileSystem/filesystem.js +0 -180
  331. package/dist/utilities/fileSystem/index.js +0 -21
  332. package/dist/utilities/fileSystem/plugin.js +0 -76
  333. package/dist/utilities/fileSystem/processor.js +0 -34
  334. package/dist/utilities/fileSystem/template.js +0 -47
  335. package/dist/utilities/global.js +0 -149
  336. package/dist/utilities/index.js +0 -143
  337. package/dist/utilities/redis.js +0 -117
  338. package/dist/utilities/retry.js +0 -30
  339. package/dist/utilities/routing/index.js +0 -39
  340. package/dist/utilities/rowProcessor/index.js +0 -282
  341. package/dist/utilities/rowProcessor/map.js +0 -116
  342. package/dist/utilities/rowProcessor/utils.js +0 -87
  343. package/dist/utilities/schema.js +0 -112
  344. package/dist/utilities/scriptRunner.js +0 -26
  345. package/dist/utilities/security.js +0 -57
  346. package/dist/utilities/statusCodes.js +0 -9
  347. package/dist/utilities/usageQuota/rows.js +0 -88
  348. package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
  349. package/dist/utilities/users.js +0 -57
  350. package/dist/utilities/workerRequests.js +0 -171
  351. package/dist/watch.js +0 -53
  352. package/dist/websockets/client.js +0 -14
  353. package/dist/websockets/grid.js +0 -60
  354. package/dist/websockets/index.js +0 -17
  355. package/dist/websockets/websocket.js +0 -78
  356. /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
  357. /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
  358. /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
@@ -1,379 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.TableSaveFunctions = exports.setStaticSchemas = exports.hasTypeChanged = exports.areSwitchableTypes = exports.foreignKeyStructure = exports.generateJunctionTableName = exports.generateForeignKey = exports.checkForViewUpdates = exports.checkStaticTables = exports.handleSearchIndexes = exports.handleDataImport = exports.importToRows = exports.makeSureTableUpToDate = exports.checkForColumnUpdates = exports.clearColumns = void 0;
16
- const schema_1 = require("../../../utilities/schema");
17
- const utils_1 = require("../../../db/utils");
18
- const lodash_1 = require("lodash");
19
- const constants_1 = require("../../../constants");
20
- const rowProcessor_1 = require("../../../utilities/rowProcessor");
21
- const constants_2 = require("../../../constants");
22
- const utils_2 = require("../view/utils");
23
- const viewBuilder_1 = __importDefault(require("../view/viewBuilder"));
24
- const fp_1 = require("lodash/fp");
25
- const pro_1 = require("@budibase/pro");
26
- const backend_core_1 = require("@budibase/backend-core");
27
- const types_1 = require("@budibase/types");
28
- function clearColumns(table, columnNames) {
29
- return __awaiter(this, void 0, void 0, function* () {
30
- const db = backend_core_1.context.getAppDB();
31
- const rows = yield db.allDocs((0, utils_1.getRowParams)(table._id, null, {
32
- include_docs: true,
33
- }));
34
- return (yield db.bulkDocs(rows.rows.map(({ doc }) => {
35
- columnNames.forEach((colName) => delete doc[colName]);
36
- return doc;
37
- })));
38
- });
39
- }
40
- exports.clearColumns = clearColumns;
41
- function checkForColumnUpdates(oldTable, updatedTable) {
42
- return __awaiter(this, void 0, void 0, function* () {
43
- const db = backend_core_1.context.getAppDB();
44
- let updatedRows = [];
45
- const rename = updatedTable._rename;
46
- let deletedColumns = [];
47
- if (oldTable && oldTable.schema && updatedTable.schema) {
48
- deletedColumns = Object.keys(oldTable.schema).filter(colName => updatedTable.schema[colName] == null);
49
- }
50
- // check for renaming of columns or deleted columns
51
- if (rename || deletedColumns.length !== 0) {
52
- // Update all rows
53
- const rows = yield db.allDocs((0, utils_1.getRowParams)(updatedTable._id, null, {
54
- include_docs: true,
55
- }));
56
- const rawRows = rows.rows.map(({ doc }) => doc);
57
- updatedRows = rawRows.map((row) => {
58
- row = (0, fp_1.cloneDeep)(row);
59
- if (rename) {
60
- row[rename.updated] = row[rename.old];
61
- delete row[rename.old];
62
- }
63
- else if (deletedColumns.length !== 0) {
64
- deletedColumns.forEach((colName) => delete row[colName]);
65
- }
66
- return row;
67
- });
68
- // cleanup any attachments from object storage for deleted attachment columns
69
- yield (0, rowProcessor_1.cleanupAttachments)(updatedTable, { oldTable, rows: rawRows });
70
- // Update views
71
- yield checkForViewUpdates(updatedTable, rename, deletedColumns);
72
- delete updatedTable._rename;
73
- }
74
- return { rows: updatedRows, table: updatedTable };
75
- });
76
- }
77
- exports.checkForColumnUpdates = checkForColumnUpdates;
78
- // makes sure the passed in table isn't going to reset the auto ID
79
- function makeSureTableUpToDate(table, tableToSave) {
80
- if (!table) {
81
- return tableToSave;
82
- }
83
- // sure sure rev is up to date
84
- tableToSave._rev = table._rev;
85
- // make sure auto IDs are always updated - these are internal
86
- // so the client may not know they have changed
87
- let field;
88
- let column;
89
- for ([field, column] of Object.entries(table.schema)) {
90
- if (column.autocolumn &&
91
- column.subtype === constants_1.AutoFieldSubTypes.AUTO_ID &&
92
- tableToSave.schema[field]) {
93
- tableToSave.schema[field].lastID = column.lastID;
94
- }
95
- }
96
- return tableToSave;
97
- }
98
- exports.makeSureTableUpToDate = makeSureTableUpToDate;
99
- function importToRows(data, table, user = null) {
100
- let originalTable = table;
101
- let finalData = [];
102
- for (let i = 0; i < data.length; i++) {
103
- let row = data[i];
104
- row._id = (0, utils_1.generateRowID)(table._id);
105
- row.tableId = table._id;
106
- // We use a reference to table here and update it after input processing,
107
- // so that we can auto increment auto IDs in imported data properly
108
- const processed = (0, rowProcessor_1.inputProcessing)(user, table, row, {
109
- noAutoRelationships: true,
110
- });
111
- row = processed.row;
112
- table = processed.table;
113
- // However here we must reference the original table, as we want to mutate
114
- // the real schema of the table passed in, not the clone used for
115
- // incrementing auto IDs
116
- for (const [fieldName, schema] of Object.entries(originalTable.schema)) {
117
- const rowVal = Array.isArray(row[fieldName])
118
- ? row[fieldName]
119
- : [row[fieldName]];
120
- if ((schema.type === constants_1.FieldTypes.OPTIONS ||
121
- schema.type === constants_1.FieldTypes.ARRAY) &&
122
- row[fieldName]) {
123
- let merged = [...schema.constraints.inclusion, ...rowVal];
124
- let superSet = new Set(merged);
125
- schema.constraints.inclusion = Array.from(superSet);
126
- schema.constraints.inclusion.sort();
127
- }
128
- }
129
- finalData.push(row);
130
- }
131
- return finalData;
132
- }
133
- exports.importToRows = importToRows;
134
- function handleDataImport(user, table, rows) {
135
- return __awaiter(this, void 0, void 0, function* () {
136
- const schema = table.schema;
137
- if (!rows || !(0, schema_1.isRows)(rows) || !(0, schema_1.isSchema)(schema)) {
138
- return table;
139
- }
140
- const db = backend_core_1.context.getAppDB();
141
- const data = (0, schema_1.parse)(rows, schema);
142
- let finalData = importToRows(data, table, user);
143
- yield pro_1.quotas.addRows(finalData.length, () => db.bulkDocs(finalData), {
144
- tableId: table._id,
145
- });
146
- yield backend_core_1.events.rows.imported(table, finalData.length);
147
- return table;
148
- });
149
- }
150
- exports.handleDataImport = handleDataImport;
151
- function handleSearchIndexes(table) {
152
- return __awaiter(this, void 0, void 0, function* () {
153
- const db = backend_core_1.context.getAppDB();
154
- // create relevant search indexes
155
- if (table.indexes && table.indexes.length > 0) {
156
- const currentIndexes = yield db.getIndexes();
157
- const indexName = `search:${table._id}`;
158
- const existingIndex = currentIndexes.indexes.find((existing) => existing.name === indexName);
159
- if (existingIndex) {
160
- const currentFields = existingIndex.def.fields.map((field) => Object.keys(field)[0]);
161
- // if index fields have changed, delete the original index
162
- if (!(0, lodash_1.isEqual)(currentFields, table.indexes)) {
163
- yield db.deleteIndex(existingIndex);
164
- // create/recreate the index with fields
165
- yield db.createIndex({
166
- index: {
167
- fields: table.indexes,
168
- name: indexName,
169
- ddoc: "search_ddoc",
170
- type: "json",
171
- },
172
- });
173
- }
174
- }
175
- else {
176
- // create/recreate the index with fields
177
- yield db.createIndex({
178
- index: {
179
- fields: table.indexes,
180
- name: indexName,
181
- ddoc: "search_ddoc",
182
- type: "json",
183
- },
184
- });
185
- }
186
- }
187
- return table;
188
- });
189
- }
190
- exports.handleSearchIndexes = handleSearchIndexes;
191
- function checkStaticTables(table) {
192
- // check user schema has all required elements
193
- if (table._id === utils_1.InternalTables.USER_METADATA) {
194
- for (let [key, schema] of Object.entries(constants_2.USERS_TABLE_SCHEMA.schema)) {
195
- // check if the schema exists on the table to be created/updated
196
- if (table.schema[key] == null) {
197
- table.schema[key] = schema;
198
- }
199
- }
200
- }
201
- return table;
202
- }
203
- exports.checkStaticTables = checkStaticTables;
204
- class TableSaveFunctions {
205
- constructor({ user, oldTable, importRows }) {
206
- this.db = backend_core_1.context.getAppDB();
207
- this.user = user;
208
- this.oldTable = oldTable;
209
- this.importRows = importRows;
210
- // any rows that need updated
211
- this.rows = [];
212
- }
213
- // before anything is done
214
- before(table) {
215
- return __awaiter(this, void 0, void 0, function* () {
216
- if (this.oldTable) {
217
- table = makeSureTableUpToDate(this.oldTable, table);
218
- }
219
- table = checkStaticTables(table);
220
- return table;
221
- });
222
- }
223
- // when confirmed valid
224
- mid(table) {
225
- return __awaiter(this, void 0, void 0, function* () {
226
- let response = yield checkForColumnUpdates(this.oldTable, table);
227
- this.rows = this.rows.concat(response.rows);
228
- return table;
229
- });
230
- }
231
- // after saving
232
- after(table) {
233
- return __awaiter(this, void 0, void 0, function* () {
234
- table = yield handleSearchIndexes(table);
235
- table = yield handleDataImport(this.user, table, this.importRows);
236
- return table;
237
- });
238
- }
239
- getUpdatedRows() {
240
- return this.rows;
241
- }
242
- }
243
- function checkForViewUpdates(table, rename, deletedColumns) {
244
- return __awaiter(this, void 0, void 0, function* () {
245
- const views = yield (0, utils_2.getViews)();
246
- const tableViews = views.filter(view => view.meta.tableId === table._id);
247
- // Check each table view to see if impacted by this table action
248
- for (let view of tableViews) {
249
- let needsUpdated = false;
250
- // First check for renames, otherwise check for deletions
251
- if (rename) {
252
- // Update calculation field if required
253
- if (view.meta.field === rename.old) {
254
- view.meta.field = rename.updated;
255
- needsUpdated = true;
256
- }
257
- // Update group by field if required
258
- if (view.meta.groupBy === rename.old) {
259
- view.meta.groupBy = rename.updated;
260
- needsUpdated = true;
261
- }
262
- // Update filters if required
263
- if (view.meta.filters) {
264
- view.meta.filters.forEach((filter) => {
265
- if (filter.key === rename.old) {
266
- filter.key = rename.updated;
267
- needsUpdated = true;
268
- }
269
- });
270
- }
271
- }
272
- else if (deletedColumns) {
273
- deletedColumns.forEach((column) => {
274
- // Remove calculation statement if required
275
- if (view.meta.field === column) {
276
- delete view.meta.field;
277
- delete view.meta.calculation;
278
- delete view.meta.groupBy;
279
- needsUpdated = true;
280
- }
281
- // Remove group by field if required
282
- if (view.meta.groupBy === column) {
283
- delete view.meta.groupBy;
284
- needsUpdated = true;
285
- }
286
- // Remove filters referencing deleted field if required
287
- if (view.meta.filters && view.meta.filters.length) {
288
- const initialLength = view.meta.filters.length;
289
- view.meta.filters = view.meta.filters.filter((filter) => {
290
- return filter.key !== column;
291
- });
292
- if (initialLength !== view.meta.filters.length) {
293
- needsUpdated = true;
294
- }
295
- }
296
- });
297
- }
298
- // Update view if required
299
- if (needsUpdated) {
300
- const groupByField = Object.values(table.schema).find((field) => field.name == view.groupBy);
301
- const newViewTemplate = (0, viewBuilder_1.default)(view.meta, (groupByField === null || groupByField === void 0 ? void 0 : groupByField.type) === constants_1.FieldTypes.ARRAY);
302
- yield (0, utils_2.saveView)(null, view.name, newViewTemplate);
303
- if (!newViewTemplate.meta.schema) {
304
- newViewTemplate.meta.schema = table.schema;
305
- }
306
- table.views[view.name] = newViewTemplate.meta;
307
- }
308
- }
309
- });
310
- }
311
- exports.checkForViewUpdates = checkForViewUpdates;
312
- function generateForeignKey(column, relatedTable) {
313
- return `fk_${relatedTable.name}_${column.fieldName}`;
314
- }
315
- exports.generateForeignKey = generateForeignKey;
316
- function generateJunctionTableName(column, table, relatedTable) {
317
- return `jt_${table.name}_${relatedTable.name}_${column.name}_${column.fieldName}`;
318
- }
319
- exports.generateJunctionTableName = generateJunctionTableName;
320
- function foreignKeyStructure(keyName, meta) {
321
- const structure = {
322
- type: constants_1.FieldTypes.NUMBER,
323
- constraints: {},
324
- name: keyName,
325
- };
326
- if (meta) {
327
- structure.meta = meta;
328
- }
329
- return structure;
330
- }
331
- exports.foreignKeyStructure = foreignKeyStructure;
332
- function areSwitchableTypes(type1, type2) {
333
- if (constants_2.SwitchableTypes.indexOf(type1) === -1 &&
334
- constants_2.SwitchableTypes.indexOf(type2) === -1) {
335
- return false;
336
- }
337
- for (let option of constants_2.CanSwitchTypes) {
338
- const index1 = option.indexOf(type1), index2 = option.indexOf(type2);
339
- if (index1 !== -1 && index2 !== -1 && index1 !== index2) {
340
- return true;
341
- }
342
- }
343
- return false;
344
- }
345
- exports.areSwitchableTypes = areSwitchableTypes;
346
- function hasTypeChanged(table, oldTable) {
347
- if (!oldTable) {
348
- return false;
349
- }
350
- let key;
351
- let field;
352
- for ([key, field] of Object.entries(oldTable.schema)) {
353
- const oldType = field.type;
354
- if (!table.schema[key]) {
355
- continue;
356
- }
357
- const newType = table.schema[key].type;
358
- if (oldType !== newType && !areSwitchableTypes(oldType, newType)) {
359
- return true;
360
- }
361
- }
362
- return false;
363
- }
364
- exports.hasTypeChanged = hasTypeChanged;
365
- // used for external tables, some of them will have static schemas that need
366
- // to be hard set
367
- function setStaticSchemas(datasource, table) {
368
- var _a;
369
- // GSheets is a specific case - only ever has a static primary key
370
- if (table && datasource.source === types_1.SourceName.GOOGLE_SHEETS) {
371
- table.primary = [constants_1.GOOGLE_SHEETS_PRIMARY_KEY];
372
- // if there is an id column, remove it, should never exist in GSheets
373
- (_a = table.schema) === null || _a === void 0 ? true : delete _a.id;
374
- }
375
- return table;
376
- }
377
- exports.setStaticSchemas = setStaticSchemas;
378
- const _TableSaveFunctions = TableSaveFunctions;
379
- exports.TableSaveFunctions = _TableSaveFunctions;
@@ -1,56 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.downloadTemplate = exports.fetch = void 0;
16
- const node_fetch_1 = __importDefault(require("node-fetch"));
17
- const fileSystem_1 = require("../../utilities/fileSystem");
18
- const environment_1 = __importDefault(require("../../environment"));
19
- // development flag, can be used to test against templates exported locally
20
- const DEFAULT_TEMPLATES_BUCKET = "prod-budi-templates.s3-eu-west-1.amazonaws.com";
21
- function fetch(ctx) {
22
- return __awaiter(this, void 0, void 0, function* () {
23
- let type = environment_1.default.TEMPLATE_REPOSITORY;
24
- let response, error = false;
25
- try {
26
- response = yield (0, node_fetch_1.default)(`https://${DEFAULT_TEMPLATES_BUCKET}/manifest.json`);
27
- if (response.status !== 200) {
28
- error = true;
29
- }
30
- }
31
- catch (err) {
32
- error = true;
33
- }
34
- // if there is an error, simply return no templates
35
- if (!error && response) {
36
- const json = yield response.json();
37
- ctx.body = Object.values(json.templates[type]);
38
- }
39
- else {
40
- ctx.body = [];
41
- }
42
- });
43
- }
44
- exports.fetch = fetch;
45
- // can't currently test this, have to ignore from coverage
46
- /* istanbul ignore next */
47
- function downloadTemplate(ctx) {
48
- return __awaiter(this, void 0, void 0, function* () {
49
- const { type, name } = ctx.params;
50
- yield (0, fileSystem_1.downloadTemplate)(type, name);
51
- ctx.body = {
52
- message: `template ${type}:${name} downloaded successfully.`,
53
- };
54
- });
55
- }
56
- exports.downloadTemplate = downloadTemplate;
@@ -1,124 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.getFlags = exports.setFlag = exports.findMetadata = exports.destroyMetadata = exports.updateMetadata = exports.updateSelfMetadata = exports.fetchMetadata = void 0;
16
- const utils_1 = require("../../db/utils");
17
- const utils_2 = require("../../db/utils");
18
- const global_1 = require("../../utilities/global");
19
- const users_1 = require("../../utilities/users");
20
- const backend_core_1 = require("@budibase/backend-core");
21
- const sdk_1 = __importDefault(require("../../sdk"));
22
- function fetchMetadata(ctx) {
23
- return __awaiter(this, void 0, void 0, function* () {
24
- const global = yield (0, global_1.getGlobalUsers)();
25
- const metadata = yield sdk_1.default.users.rawUserMetadata();
26
- const users = [];
27
- for (let user of global) {
28
- // find the metadata that matches up to the global ID
29
- const info = metadata.find(meta => meta._id.includes(user._id));
30
- // remove these props, not for the correct DB
31
- users.push(Object.assign(Object.assign(Object.assign({}, user), info), { tableId: utils_2.InternalTables.USER_METADATA,
32
- // make sure the ID is always a local ID, not a global one
33
- _id: (0, utils_1.generateUserMetadataID)(user._id) }));
34
- }
35
- ctx.body = users;
36
- });
37
- }
38
- exports.fetchMetadata = fetchMetadata;
39
- function updateSelfMetadata(ctx) {
40
- var _a;
41
- return __awaiter(this, void 0, void 0, function* () {
42
- // overwrite the ID with current users
43
- ctx.request.body._id = (_a = ctx.user) === null || _a === void 0 ? void 0 : _a._id;
44
- // make sure no stale rev
45
- delete ctx.request.body._rev;
46
- // make sure no csrf token
47
- delete ctx.request.body.csrfToken;
48
- yield updateMetadata(ctx);
49
- });
50
- }
51
- exports.updateSelfMetadata = updateSelfMetadata;
52
- function updateMetadata(ctx) {
53
- return __awaiter(this, void 0, void 0, function* () {
54
- const db = backend_core_1.context.getAppDB();
55
- const user = ctx.request.body;
56
- // this isn't applicable to the user
57
- delete user.roles;
58
- const metadata = Object.assign({ tableId: utils_2.InternalTables.USER_METADATA }, user);
59
- ctx.body = yield db.put(metadata);
60
- });
61
- }
62
- exports.updateMetadata = updateMetadata;
63
- function destroyMetadata(ctx) {
64
- return __awaiter(this, void 0, void 0, function* () {
65
- const db = backend_core_1.context.getAppDB();
66
- try {
67
- const dbUser = yield db.get(ctx.params.id);
68
- yield db.remove(dbUser._id, dbUser._rev);
69
- }
70
- catch (err) {
71
- // error just means the global user has no config in this app
72
- }
73
- ctx.body = {
74
- message: `User metadata ${ctx.params.id} deleted.`,
75
- };
76
- });
77
- }
78
- exports.destroyMetadata = destroyMetadata;
79
- function findMetadata(ctx) {
80
- return __awaiter(this, void 0, void 0, function* () {
81
- ctx.body = yield (0, users_1.getFullUser)(ctx, ctx.params.id);
82
- });
83
- }
84
- exports.findMetadata = findMetadata;
85
- function setFlag(ctx) {
86
- var _a;
87
- return __awaiter(this, void 0, void 0, function* () {
88
- const userId = (_a = ctx.user) === null || _a === void 0 ? void 0 : _a._id;
89
- const { flag, value } = ctx.request.body;
90
- if (!flag) {
91
- ctx.throw(400, "Must supply a 'flag' field in request body.");
92
- }
93
- const flagDocId = (0, utils_1.generateUserFlagID)(userId);
94
- const db = backend_core_1.context.getAppDB();
95
- let doc;
96
- try {
97
- doc = yield db.get(flagDocId);
98
- }
99
- catch (err) {
100
- doc = { _id: flagDocId };
101
- }
102
- doc[flag] = value || true;
103
- yield db.put(doc);
104
- ctx.body = { message: "Flag set successfully" };
105
- });
106
- }
107
- exports.setFlag = setFlag;
108
- function getFlags(ctx) {
109
- var _a;
110
- return __awaiter(this, void 0, void 0, function* () {
111
- const userId = (_a = ctx.user) === null || _a === void 0 ? void 0 : _a._id;
112
- const docId = (0, utils_1.generateUserFlagID)(userId);
113
- const db = backend_core_1.context.getAppDB();
114
- let doc;
115
- try {
116
- doc = yield db.get(docId);
117
- }
118
- catch (err) {
119
- doc = { _id: docId };
120
- }
121
- ctx.body = doc;
122
- });
123
- }
124
- exports.getFlags = getFlags;
@@ -1,46 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isFormat = exports.Format = exports.jsonWithSchema = exports.json = exports.csv = void 0;
4
- function csv(headers, rows) {
5
- let csv = headers.map(key => `"${key}"`).join(",");
6
- for (let row of rows) {
7
- csv = `${csv}\n${headers
8
- .map(header => {
9
- let val = row[header];
10
- val =
11
- typeof val === "object" && !(val instanceof Date)
12
- ? `"${JSON.stringify(val).replace(/"/g, "'")}"`
13
- : val !== undefined
14
- ? `"${val}"`
15
- : "";
16
- return val.trim();
17
- })
18
- .join(",")}`;
19
- }
20
- return csv;
21
- }
22
- exports.csv = csv;
23
- function json(rows) {
24
- return JSON.stringify(rows, undefined, 2);
25
- }
26
- exports.json = json;
27
- function jsonWithSchema(schema, rows) {
28
- const newSchema = {};
29
- Object.values(schema).forEach(column => {
30
- if (!column.autocolumn) {
31
- newSchema[column.name] = column;
32
- }
33
- });
34
- return JSON.stringify({ schema: newSchema, rows }, undefined, 2);
35
- }
36
- exports.jsonWithSchema = jsonWithSchema;
37
- var Format;
38
- (function (Format) {
39
- Format["CSV"] = "csv";
40
- Format["JSON"] = "json";
41
- Format["JSON_WITH_SCHEMA"] = "jsonWithSchema";
42
- })(Format = exports.Format || (exports.Format = {}));
43
- function isFormat(format) {
44
- return Object.values(Format).includes(format);
45
- }
46
- exports.isFormat = isFormat;