@budibase/server 2.6.23 → 2.6.24-alpha.1
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.
- package/.dockerignore +7 -6
- package/Dockerfile +16 -8
- package/builder/assets/index.b33e8ad5.css +6 -0
- package/builder/assets/index.c0b0be95.js +1869 -0
- package/builder/index.html +2 -2
- package/client/manifest.json +5229 -0
- package/dist/automation.js +32576 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +45065 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24462 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +6 -3
- package/nodemon.json +8 -4
- package/package.json +35 -16
- package/pm2.config.js +1 -1
- package/scripts/build.js +48 -0
- package/src/api/controllers/application.ts +21 -22
- package/src/api/controllers/automation.ts +37 -9
- package/src/api/controllers/datasource.ts +114 -49
- package/src/api/controllers/deploy/index.ts +1 -0
- package/src/api/controllers/integration.ts +3 -3
- package/src/api/controllers/plugin/index.ts +1 -1
- package/src/api/controllers/row/external.ts +39 -15
- package/src/api/controllers/row/index.ts +18 -24
- package/src/api/controllers/row/internal.ts +1 -1
- package/src/api/controllers/row/staticFormula.ts +6 -1
- package/src/api/controllers/row/utils.ts +12 -0
- package/src/api/controllers/static/index.ts +3 -3
- package/src/api/controllers/table/index.ts +3 -0
- package/src/api/controllers/table/internal.ts +2 -6
- package/src/api/controllers/table/utils.ts +32 -1
- package/src/api/controllers/view/index.ts +5 -5
- package/src/api/controllers/webhook.ts +33 -9
- package/src/api/routes/application.ts +5 -0
- package/src/api/routes/automation.ts +0 -1
- package/src/api/routes/datasource.ts +10 -0
- package/src/api/routes/static.ts +3 -1
- package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
- package/src/api/routes/tests/datasource.spec.ts +1 -1
- package/src/api/routes/tests/view.spec.js +4 -3
- package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
- package/src/app.ts +0 -1
- package/src/automations/actions.ts +8 -0
- package/src/automations/logging/index.ts +21 -0
- package/src/automations/steps/bash.ts +4 -0
- package/src/automations/steps/collect.ts +58 -0
- package/src/automations/steps/createRow.ts +4 -0
- package/src/automations/steps/delay.ts +1 -0
- package/src/automations/steps/deleteRow.ts +4 -0
- package/src/automations/steps/discord.ts +4 -0
- package/src/automations/steps/executeQuery.ts +4 -0
- package/src/automations/steps/executeScript.ts +4 -0
- package/src/automations/steps/filter.ts +1 -0
- package/src/automations/steps/loop.ts +1 -0
- package/src/automations/steps/make.ts +22 -1
- package/src/automations/steps/openai.ts +106 -0
- package/src/automations/steps/outgoingWebhook.ts +4 -0
- package/src/automations/steps/queryRows.ts +4 -0
- package/src/automations/steps/sendSmtpEmail.ts +4 -0
- package/src/automations/steps/serverLog.ts +4 -0
- package/src/automations/steps/slack.ts +4 -0
- package/src/automations/steps/updateRow.ts +4 -0
- package/src/automations/steps/zapier.ts +22 -1
- package/src/automations/tests/make.spec.ts +54 -0
- package/src/automations/tests/openai.spec.ts +86 -0
- package/src/automations/tests/zapier.spec.ts +56 -0
- package/src/automations/triggers.ts +3 -2
- package/src/constants/index.ts +17 -16
- package/src/db/dynamoClient.ts +1 -1
- package/src/db/inMemoryView.ts +1 -0
- package/src/db/linkedRows/index.ts +5 -3
- package/src/environment.ts +3 -0
- package/src/integration-test/postgres.spec.ts +47 -5
- package/src/integrations/airtable.ts +33 -4
- package/src/integrations/arangodb.ts +20 -2
- package/src/integrations/base/sqlTable.ts +0 -1
- package/src/integrations/couchdb.ts +20 -4
- package/src/integrations/dynamodb.ts +36 -5
- package/src/integrations/elasticsearch.ts +18 -1
- package/src/integrations/firebase.ts +17 -0
- package/src/integrations/googlesheets.ts +66 -5
- package/src/integrations/index.ts +12 -7
- package/src/integrations/microsoftSqlServer.ts +33 -1
- package/src/integrations/mongodb.ts +18 -0
- package/src/integrations/mysql.ts +53 -26
- package/src/integrations/oracle.ts +38 -6
- package/src/integrations/postgres.ts +47 -12
- package/src/integrations/redis.ts +35 -4
- package/src/integrations/s3.ts +21 -3
- package/src/integrations/snowflake.ts +22 -1
- package/src/integrations/tests/googlesheets.spec.ts +41 -9
- package/src/middleware/builder.ts +26 -18
- package/src/migrations/functions/backfill/app/queries.ts +1 -1
- package/src/sdk/app/automations/index.ts +2 -0
- package/src/sdk/app/automations/utils.ts +7 -0
- package/src/sdk/app/datasources/datasources.ts +7 -1
- package/src/sdk/plugins/plugins.ts +1 -1
- package/src/startup.ts +2 -0
- package/src/tests/utilities/TestConfiguration.ts +4 -2
- package/src/tests/utilities/structures.ts +42 -0
- package/src/threads/automation.ts +91 -23
- package/src/threads/index.ts +9 -3
- package/src/threads/utils.ts +2 -0
- package/src/utilities/fileSystem/app.ts +14 -4
- package/src/utilities/fileSystem/clientLibrary.ts +8 -3
- package/src/utilities/fileSystem/filesystem.ts +3 -1
- package/src/utilities/redis.ts +25 -3
- package/src/utilities/rowProcessor/index.ts +4 -1
- package/src/utilities/rowProcessor/map.ts +1 -1
- package/src/websockets/builder.ts +95 -0
- package/src/websockets/client.ts +2 -2
- package/src/websockets/grid.ts +44 -44
- package/src/websockets/index.ts +13 -6
- package/src/websockets/websocket.ts +211 -7
- package/tsconfig.build.json +9 -1
- package/tsconfig.json +1 -14
- package/builder/assets/index.86c992bf.css +0 -6
- package/builder/assets/index.c16c35ca.js +0 -1794
- package/dist/api/controllers/analytics.js +0 -46
- package/dist/api/controllers/apikeys.js +0 -72
- package/dist/api/controllers/application.js +0 -574
- package/dist/api/controllers/auth.js +0 -80
- package/dist/api/controllers/automation.js +0 -303
- package/dist/api/controllers/backup.js +0 -37
- package/dist/api/controllers/component.js +0 -59
- package/dist/api/controllers/datasource.js +0 -306
- package/dist/api/controllers/deploy/Deployment.js +0 -53
- package/dist/api/controllers/deploy/index.js +0 -198
- package/dist/api/controllers/dev.js +0 -146
- package/dist/api/controllers/integration.js +0 -28
- package/dist/api/controllers/layout.js +0 -49
- package/dist/api/controllers/metadata.js +0 -63
- package/dist/api/controllers/migrations.js +0 -29
- package/dist/api/controllers/ops.js +0 -40
- package/dist/api/controllers/permission.js +0 -162
- package/dist/api/controllers/plugin/file.js +0 -24
- package/dist/api/controllers/plugin/github.js +0 -69
- package/dist/api/controllers/plugin/index.js +0 -112
- package/dist/api/controllers/plugin/npm.js +0 -58
- package/dist/api/controllers/plugin/uploaders.js +0 -11
- package/dist/api/controllers/plugin/url.js +0 -24
- package/dist/api/controllers/plugin/utils.js +0 -27
- package/dist/api/controllers/public/applications.js +0 -146
- package/dist/api/controllers/public/mapping/applications.js +0 -29
- package/dist/api/controllers/public/mapping/index.js +0 -11
- package/dist/api/controllers/public/mapping/queries.js +0 -36
- package/dist/api/controllers/public/mapping/rows.js +0 -24
- package/dist/api/controllers/public/mapping/tables.js +0 -23
- package/dist/api/controllers/public/mapping/types.js +0 -2
- package/dist/api/controllers/public/mapping/users.js +0 -29
- package/dist/api/controllers/public/metrics.js +0 -113
- package/dist/api/controllers/public/queries.js +0 -58
- package/dist/api/controllers/public/rows.js +0 -120
- package/dist/api/controllers/public/tables.js +0 -95
- package/dist/api/controllers/public/users.js +0 -93
- package/dist/api/controllers/public/utils.js +0 -56
- package/dist/api/controllers/query/import/index.js +0 -87
- package/dist/api/controllers/query/import/sources/base/index.js +0 -75
- package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
- package/dist/api/controllers/query/import/sources/curl.js +0 -99
- package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
- package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
- package/dist/api/controllers/query/index.js +0 -299
- package/dist/api/controllers/query/validation.js +0 -53
- package/dist/api/controllers/role.js +0 -109
- package/dist/api/controllers/routing.js +0 -105
- package/dist/api/controllers/row/ExternalRequest.js +0 -683
- package/dist/api/controllers/row/external.js +0 -339
- package/dist/api/controllers/row/index.js +0 -203
- package/dist/api/controllers/row/internal.js +0 -509
- package/dist/api/controllers/row/internalSearch.js +0 -28
- package/dist/api/controllers/row/staticFormula.js +0 -165
- package/dist/api/controllers/row/utils.js +0 -183
- package/dist/api/controllers/screen.js +0 -110
- package/dist/api/controllers/script.js +0 -30
- package/dist/api/controllers/static/index.js +0 -268
- package/dist/api/controllers/table/bulkFormula.js +0 -173
- package/dist/api/controllers/table/external.js +0 -279
- package/dist/api/controllers/table/index.js +0 -179
- package/dist/api/controllers/table/internal.js +0 -197
- package/dist/api/controllers/table/utils.js +0 -379
- package/dist/api/controllers/templates.js +0 -56
- package/dist/api/controllers/user.js +0 -124
- package/dist/api/controllers/view/exporters.js +0 -46
- package/dist/api/controllers/view/index.js +0 -193
- package/dist/api/controllers/view/utils.js +0 -177
- package/dist/api/controllers/view/viewBuilder.js +0 -158
- package/dist/api/controllers/webhook.js +0 -134
- package/dist/api/index.js +0 -55
- package/dist/api/routes/analytics.js +0 -34
- package/dist/api/routes/apikeys.js +0 -37
- package/dist/api/routes/application.js +0 -48
- package/dist/api/routes/auth.js +0 -33
- package/dist/api/routes/automation.js +0 -50
- package/dist/api/routes/backup.js +0 -35
- package/dist/api/routes/component.js +0 -35
- package/dist/api/routes/datasource.js +0 -43
- package/dist/api/routes/deploy.js +0 -37
- package/dist/api/routes/dev.js +0 -49
- package/dist/api/routes/index.js +0 -75
- package/dist/api/routes/integration.js +0 -37
- package/dist/api/routes/layout.js +0 -37
- package/dist/api/routes/metadata.js +0 -40
- package/dist/api/routes/migrations.js +0 -36
- package/dist/api/routes/ops.js +0 -52
- package/dist/api/routes/permission.js +0 -44
- package/dist/api/routes/plugin.js +0 -39
- package/dist/api/routes/public/applications.js +0 -174
- package/dist/api/routes/public/index.js +0 -140
- package/dist/api/routes/public/metrics.js +0 -30
- package/dist/api/routes/public/middleware/mapper.js +0 -97
- package/dist/api/routes/public/queries.js +0 -72
- package/dist/api/routes/public/rows.js +0 -158
- package/dist/api/routes/public/tables.js +0 -152
- package/dist/api/routes/public/users.js +0 -135
- package/dist/api/routes/public/utils/Endpoint.js +0 -36
- package/dist/api/routes/query.js +0 -47
- package/dist/api/routes/role.js +0 -40
- package/dist/api/routes/routing.js +0 -39
- package/dist/api/routes/row.js +0 -239
- package/dist/api/routes/screen.js +0 -39
- package/dist/api/routes/script.js +0 -35
- package/dist/api/routes/static.js +0 -80
- package/dist/api/routes/table.js +0 -163
- package/dist/api/routes/templates.js +0 -37
- package/dist/api/routes/user.js +0 -43
- package/dist/api/routes/utils/validators.js +0 -238
- package/dist/api/routes/view.js +0 -42
- package/dist/api/routes/webhook.js +0 -43
- package/dist/app.js +0 -132
- package/dist/automations/actions.js +0 -137
- package/dist/automations/automationUtils.js +0 -173
- package/dist/automations/bullboard.js +0 -71
- package/dist/automations/index.js +0 -43
- package/dist/automations/logging/index.js +0 -53
- package/dist/automations/steps/bash.js +0 -111
- package/dist/automations/steps/createRow.js +0 -108
- package/dist/automations/steps/delay.js +0 -53
- package/dist/automations/steps/deleteRow.js +0 -96
- package/dist/automations/steps/discord.js +0 -116
- package/dist/automations/steps/executeQuery.js +0 -134
- package/dist/automations/steps/executeScript.js +0 -106
- package/dist/automations/steps/filter.js +0 -112
- package/dist/automations/steps/loop.js +0 -54
- package/dist/automations/steps/make.js +0 -120
- package/dist/automations/steps/outgoingWebhook.js +0 -166
- package/dist/automations/steps/queryRows.js +0 -220
- package/dist/automations/steps/sendSmtpEmail.js +0 -115
- package/dist/automations/steps/serverLog.js +0 -65
- package/dist/automations/steps/slack.js +0 -98
- package/dist/automations/steps/updateRow.js +0 -144
- package/dist/automations/steps/utils.js +0 -56
- package/dist/automations/steps/zapier.js +0 -117
- package/dist/automations/triggerInfo/app.js +0 -36
- package/dist/automations/triggerInfo/cron.js +0 -35
- package/dist/automations/triggerInfo/index.js +0 -40
- package/dist/automations/triggerInfo/rowDeleted.js +0 -36
- package/dist/automations/triggerInfo/rowSaved.js +0 -44
- package/dist/automations/triggerInfo/rowUpdated.js +0 -44
- package/dist/automations/triggerInfo/webhook.js +0 -40
- package/dist/automations/triggers.js +0 -181
- package/dist/automations/utils.js +0 -275
- package/dist/constants/definitions.js +0 -2
- package/dist/constants/index.js +0 -181
- package/dist/constants/layouts.js +0 -148
- package/dist/constants/screens.js +0 -51
- package/dist/db/defaultData/datasource_bb_default.js +0 -574
- package/dist/db/defaultData/employeeImport.js +0 -155
- package/dist/db/defaultData/expensesImport.js +0 -117
- package/dist/db/defaultData/inventoryImport.js +0 -109
- package/dist/db/defaultData/jobsImport.js +0 -152
- package/dist/db/dynamoClient.js +0 -124
- package/dist/db/inMemoryView.js +0 -62
- package/dist/db/index.js +0 -43
- package/dist/db/linkedRows/LinkController.js +0 -392
- package/dist/db/linkedRows/LinkDocument.js +0 -33
- package/dist/db/linkedRows/index.js +0 -206
- package/dist/db/linkedRows/linkUtils.js +0 -131
- package/dist/db/newid.js +0 -7
- package/dist/db/utils.js +0 -248
- package/dist/db/views/staticViews.js +0 -144
- package/dist/ddApm.js +0 -11
- package/dist/definitions/automations.js +0 -8
- package/dist/definitions/common.js +0 -2
- package/dist/definitions/datasource.js +0 -7
- package/dist/definitions/openapi.js +0 -6
- package/dist/environment.js +0 -109
- package/dist/events/AutomationEmitter.js +0 -53
- package/dist/events/BudibaseEmitter.js +0 -25
- package/dist/events/docUpdates/index.js +0 -17
- package/dist/events/docUpdates/processors.js +0 -18
- package/dist/events/docUpdates/syncUsers.js +0 -49
- package/dist/events/index.js +0 -11
- package/dist/events/utils.js +0 -43
- package/dist/integrations/airtable.js +0 -147
- package/dist/integrations/arangodb.js +0 -103
- package/dist/integrations/base/query.js +0 -32
- package/dist/integrations/base/sql.js +0 -600
- package/dist/integrations/base/sqlTable.js +0 -167
- package/dist/integrations/base/types.js +0 -2
- package/dist/integrations/couchdb.js +0 -125
- package/dist/integrations/dynamodb.js +0 -194
- package/dist/integrations/elasticsearch.js +0 -186
- package/dist/integrations/firebase.js +0 -174
- package/dist/integrations/googlesheets.js +0 -455
- package/dist/integrations/index.js +0 -135
- package/dist/integrations/microsoftSqlServer.js +0 -273
- package/dist/integrations/mongodb.js +0 -614
- package/dist/integrations/mysql.js +0 -256
- package/dist/integrations/oracle.js +0 -375
- package/dist/integrations/postgres.js +0 -300
- package/dist/integrations/queries/sql.js +0 -84
- package/dist/integrations/redis.js +0 -168
- package/dist/integrations/rest.js +0 -400
- package/dist/integrations/s3.js +0 -237
- package/dist/integrations/snowflake.js +0 -102
- package/dist/integrations/utils.js +0 -295
- package/dist/middleware/appInfo.js +0 -22
- package/dist/middleware/authorized.js +0 -112
- package/dist/middleware/builder.js +0 -93
- package/dist/middleware/currentapp.js +0 -103
- package/dist/middleware/joi-validator.js +0 -43
- package/dist/middleware/publicApi.js +0 -25
- package/dist/middleware/resourceId.js +0 -59
- package/dist/middleware/selfhost.js +0 -24
- package/dist/middleware/utils.js +0 -8
- package/dist/migrations/functions/appUrls.js +0 -42
- package/dist/migrations/functions/backfill/app/automations.js +0 -31
- package/dist/migrations/functions/backfill/app/datasources.js +0 -28
- package/dist/migrations/functions/backfill/app/layouts.js +0 -33
- package/dist/migrations/functions/backfill/app/queries.js +0 -50
- package/dist/migrations/functions/backfill/app/roles.js +0 -28
- package/dist/migrations/functions/backfill/app/screens.js +0 -28
- package/dist/migrations/functions/backfill/app/tables.js +0 -37
- package/dist/migrations/functions/backfill/app.js +0 -176
- package/dist/migrations/functions/backfill/global/configs.js +0 -67
- package/dist/migrations/functions/backfill/global/quotas.js +0 -60
- package/dist/migrations/functions/backfill/global/users.js +0 -50
- package/dist/migrations/functions/backfill/global.js +0 -205
- package/dist/migrations/functions/backfill/index.js +0 -32
- package/dist/migrations/functions/backfill/installation.js +0 -80
- package/dist/migrations/functions/syncQuotas.js +0 -52
- package/dist/migrations/functions/tableSettings.js +0 -130
- package/dist/migrations/functions/usageQuotas/index.js +0 -16
- package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
- package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
- package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
- package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
- package/dist/migrations/functions/userEmailViewCasing.js +0 -24
- package/dist/migrations/index.js +0 -111
- package/dist/migrations/tests/helpers.js +0 -72
- package/dist/migrations/tests/structures.js +0 -37
- package/dist/sdk/app/applications/index.js +0 -28
- package/dist/sdk/app/applications/sync.js +0 -164
- package/dist/sdk/app/applications/utils.js +0 -21
- package/dist/sdk/app/automations/index.js +0 -29
- package/dist/sdk/app/automations/webhook.js +0 -54
- package/dist/sdk/app/backups/constants.js +0 -6
- package/dist/sdk/app/backups/exports.js +0 -160
- package/dist/sdk/app/backups/imports.js +0 -170
- package/dist/sdk/app/backups/index.js +0 -29
- package/dist/sdk/app/backups/statistics.js +0 -73
- package/dist/sdk/app/datasources/datasources.js +0 -166
- package/dist/sdk/app/datasources/index.js +0 -27
- package/dist/sdk/app/queries/index.js +0 -27
- package/dist/sdk/app/queries/queries.js +0 -60
- package/dist/sdk/app/rows/attachments.js +0 -61
- package/dist/sdk/app/rows/index.js +0 -28
- package/dist/sdk/app/rows/rows.js +0 -30
- package/dist/sdk/app/tables/index.js +0 -65
- package/dist/sdk/index.js +0 -27
- package/dist/sdk/plugins/index.js +0 -27
- package/dist/sdk/plugins/plugins.js +0 -53
- package/dist/sdk/users/index.js +0 -27
- package/dist/sdk/users/utils.js +0 -94
- package/dist/sdk/utils/index.js +0 -29
- package/dist/startup.js +0 -158
- package/dist/threads/automation.js +0 -450
- package/dist/threads/definitions.js +0 -2
- package/dist/threads/index.js +0 -140
- package/dist/threads/query.js +0 -265
- package/dist/threads/utils.js +0 -120
- package/dist/tsconfig.build.tsbuildinfo +0 -1
- package/dist/utilities/appDirectoryTemplate/package.json +0 -10
- package/dist/utilities/budibaseDir.js +0 -5
- package/dist/utilities/centralPath.js +0 -27
- package/dist/utilities/csv.js +0 -33
- package/dist/utilities/fileSystem/app.js +0 -88
- package/dist/utilities/fileSystem/clientLibrary.js +0 -138
- package/dist/utilities/fileSystem/filesystem.js +0 -180
- package/dist/utilities/fileSystem/index.js +0 -21
- package/dist/utilities/fileSystem/plugin.js +0 -76
- package/dist/utilities/fileSystem/processor.js +0 -34
- package/dist/utilities/fileSystem/template.js +0 -47
- package/dist/utilities/global.js +0 -146
- package/dist/utilities/index.js +0 -143
- package/dist/utilities/redis.js +0 -117
- package/dist/utilities/retry.js +0 -30
- package/dist/utilities/routing/index.js +0 -39
- package/dist/utilities/rowProcessor/index.js +0 -282
- package/dist/utilities/rowProcessor/map.js +0 -116
- package/dist/utilities/rowProcessor/utils.js +0 -87
- package/dist/utilities/schema.js +0 -112
- package/dist/utilities/scriptRunner.js +0 -26
- package/dist/utilities/security.js +0 -57
- package/dist/utilities/statusCodes.js +0 -9
- package/dist/utilities/usageQuota/rows.js +0 -88
- package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
- package/dist/utilities/users.js +0 -57
- package/dist/utilities/workerRequests.js +0 -171
- package/dist/watch.js +0 -53
- package/dist/websockets/client.js +0 -14
- package/dist/websockets/grid.js +0 -60
- package/dist/websockets/index.js +0 -17
- package/dist/websockets/websocket.js +0 -78
- package/src/automations/tests/zapier.spec.js +0 -27
- /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
- /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
- /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
|
@@ -1,279 +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.bulkImport = exports.destroy = exports.save = void 0;
|
|
16
|
-
const utils_1 = require("../../../integrations/utils");
|
|
17
|
-
const utils_2 = require("./utils");
|
|
18
|
-
const constants_1 = require("../../../constants");
|
|
19
|
-
const query_1 = require("../../../integrations/base/query");
|
|
20
|
-
const external_1 = require("../row/external");
|
|
21
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
22
|
-
const schema_1 = require("../../../utilities/schema");
|
|
23
|
-
const types_1 = require("@budibase/types");
|
|
24
|
-
const sdk_1 = __importDefault(require("../../../sdk"));
|
|
25
|
-
const { cloneDeep } = require("lodash/fp");
|
|
26
|
-
function makeTableRequest(datasource, operation, table, tables, oldTable, renamed) {
|
|
27
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
-
const json = {
|
|
29
|
-
endpoint: {
|
|
30
|
-
datasourceId: datasource._id,
|
|
31
|
-
entityId: table._id,
|
|
32
|
-
operation,
|
|
33
|
-
},
|
|
34
|
-
meta: {
|
|
35
|
-
tables,
|
|
36
|
-
},
|
|
37
|
-
table,
|
|
38
|
-
};
|
|
39
|
-
if (oldTable) {
|
|
40
|
-
json.meta.table = oldTable;
|
|
41
|
-
}
|
|
42
|
-
if (renamed) {
|
|
43
|
-
json.meta.renamed = renamed;
|
|
44
|
-
}
|
|
45
|
-
return (0, query_1.makeExternalQuery)(datasource, json);
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
function cleanupRelationships(table, tables, oldTable) {
|
|
49
|
-
const tableToIterate = oldTable ? oldTable : table;
|
|
50
|
-
// clean up relationships in couch table schemas
|
|
51
|
-
for (let [key, schema] of Object.entries(tableToIterate.schema)) {
|
|
52
|
-
if (schema.type === constants_1.FieldTypes.LINK &&
|
|
53
|
-
(!oldTable || table.schema[key] == null)) {
|
|
54
|
-
const relatedTable = Object.values(tables).find(table => table._id === schema.tableId);
|
|
55
|
-
const foreignKey = schema.foreignKey;
|
|
56
|
-
if (!relatedTable || !foreignKey) {
|
|
57
|
-
continue;
|
|
58
|
-
}
|
|
59
|
-
for (let [relatedKey, relatedSchema] of Object.entries(relatedTable.schema)) {
|
|
60
|
-
if (relatedSchema.type === constants_1.FieldTypes.LINK &&
|
|
61
|
-
relatedSchema.fieldName === foreignKey) {
|
|
62
|
-
delete relatedTable.schema[relatedKey];
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
function getDatasourceId(table) {
|
|
69
|
-
if (!table) {
|
|
70
|
-
throw "No table supplied";
|
|
71
|
-
}
|
|
72
|
-
if (table.sourceId) {
|
|
73
|
-
return table.sourceId;
|
|
74
|
-
}
|
|
75
|
-
return (0, utils_1.breakExternalTableId)(table._id).datasourceId;
|
|
76
|
-
}
|
|
77
|
-
function otherRelationshipType(type) {
|
|
78
|
-
if (type === types_1.RelationshipTypes.MANY_TO_MANY) {
|
|
79
|
-
return types_1.RelationshipTypes.MANY_TO_MANY;
|
|
80
|
-
}
|
|
81
|
-
return type === types_1.RelationshipTypes.ONE_TO_MANY
|
|
82
|
-
? types_1.RelationshipTypes.MANY_TO_ONE
|
|
83
|
-
: types_1.RelationshipTypes.ONE_TO_MANY;
|
|
84
|
-
}
|
|
85
|
-
function generateManyLinkSchema(datasource, column, table, relatedTable) {
|
|
86
|
-
if (!table.primary || !relatedTable.primary) {
|
|
87
|
-
throw new Error("Unable to generate many link schema, no primary keys");
|
|
88
|
-
}
|
|
89
|
-
const primary = table.name + table.primary[0];
|
|
90
|
-
const relatedPrimary = relatedTable.name + relatedTable.primary[0];
|
|
91
|
-
const jcTblName = (0, utils_2.generateJunctionTableName)(column, table, relatedTable);
|
|
92
|
-
// first create the new table
|
|
93
|
-
const junctionTable = {
|
|
94
|
-
_id: (0, utils_1.buildExternalTableId)(datasource._id, jcTblName),
|
|
95
|
-
name: jcTblName,
|
|
96
|
-
primary: [primary, relatedPrimary],
|
|
97
|
-
constrained: [primary, relatedPrimary],
|
|
98
|
-
schema: {
|
|
99
|
-
[primary]: (0, utils_2.foreignKeyStructure)(primary, {
|
|
100
|
-
toTable: table.name,
|
|
101
|
-
toKey: table.primary[0],
|
|
102
|
-
}),
|
|
103
|
-
[relatedPrimary]: (0, utils_2.foreignKeyStructure)(relatedPrimary, {
|
|
104
|
-
toTable: relatedTable.name,
|
|
105
|
-
toKey: relatedTable.primary[0],
|
|
106
|
-
}),
|
|
107
|
-
},
|
|
108
|
-
};
|
|
109
|
-
column.through = junctionTable._id;
|
|
110
|
-
column.throughFrom = relatedPrimary;
|
|
111
|
-
column.throughTo = primary;
|
|
112
|
-
column.fieldName = relatedPrimary;
|
|
113
|
-
return junctionTable;
|
|
114
|
-
}
|
|
115
|
-
function generateLinkSchema(column, table, relatedTable, type) {
|
|
116
|
-
if (!table.primary || !relatedTable.primary) {
|
|
117
|
-
throw new Error("Unable to generate link schema, no primary keys");
|
|
118
|
-
}
|
|
119
|
-
const isOneSide = type === types_1.RelationshipTypes.ONE_TO_MANY;
|
|
120
|
-
const primary = isOneSide ? relatedTable.primary[0] : table.primary[0];
|
|
121
|
-
// generate a foreign key
|
|
122
|
-
const foreignKey = (0, utils_2.generateForeignKey)(column, relatedTable);
|
|
123
|
-
column.relationshipType = type;
|
|
124
|
-
column.foreignKey = isOneSide ? foreignKey : primary;
|
|
125
|
-
column.fieldName = isOneSide ? primary : foreignKey;
|
|
126
|
-
return foreignKey;
|
|
127
|
-
}
|
|
128
|
-
function generateRelatedSchema(linkColumn, table, relatedTable, columnName) {
|
|
129
|
-
// generate column for other table
|
|
130
|
-
const relatedSchema = cloneDeep(linkColumn);
|
|
131
|
-
// swap them from the main link
|
|
132
|
-
if (linkColumn.foreignKey) {
|
|
133
|
-
relatedSchema.fieldName = linkColumn.foreignKey;
|
|
134
|
-
relatedSchema.foreignKey = linkColumn.fieldName;
|
|
135
|
-
}
|
|
136
|
-
// is many to many
|
|
137
|
-
else {
|
|
138
|
-
// don't need to copy through, already got it
|
|
139
|
-
relatedSchema.fieldName = linkColumn.throughTo;
|
|
140
|
-
relatedSchema.throughTo = linkColumn.throughFrom;
|
|
141
|
-
relatedSchema.throughFrom = linkColumn.throughTo;
|
|
142
|
-
}
|
|
143
|
-
relatedSchema.relationshipType = otherRelationshipType(linkColumn.relationshipType);
|
|
144
|
-
relatedSchema.tableId = relatedTable._id;
|
|
145
|
-
relatedSchema.name = columnName;
|
|
146
|
-
table.schema[columnName] = relatedSchema;
|
|
147
|
-
}
|
|
148
|
-
function isRelationshipSetup(column) {
|
|
149
|
-
return column.foreignKey || column.through;
|
|
150
|
-
}
|
|
151
|
-
function save(ctx) {
|
|
152
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
-
const inputs = ctx.request.body;
|
|
154
|
-
const renamed = inputs === null || inputs === void 0 ? void 0 : inputs._rename;
|
|
155
|
-
// can't do this right now
|
|
156
|
-
delete inputs.rows;
|
|
157
|
-
const datasourceId = getDatasourceId(ctx.request.body);
|
|
158
|
-
// table doesn't exist already, note that it is created
|
|
159
|
-
if (!inputs._id) {
|
|
160
|
-
inputs.created = true;
|
|
161
|
-
}
|
|
162
|
-
let tableToSave = Object.assign({ type: "table", _id: (0, utils_1.buildExternalTableId)(datasourceId, inputs.name) }, inputs);
|
|
163
|
-
let oldTable;
|
|
164
|
-
if (ctx.request.body && ctx.request.body._id) {
|
|
165
|
-
oldTable = yield sdk_1.default.tables.getTable(ctx.request.body._id);
|
|
166
|
-
}
|
|
167
|
-
if ((0, utils_2.hasTypeChanged)(tableToSave, oldTable)) {
|
|
168
|
-
ctx.throw(400, "A column type has changed.");
|
|
169
|
-
}
|
|
170
|
-
const db = backend_core_1.context.getAppDB();
|
|
171
|
-
const datasource = yield sdk_1.default.datasources.get(datasourceId);
|
|
172
|
-
if (!datasource.entities) {
|
|
173
|
-
datasource.entities = {};
|
|
174
|
-
}
|
|
175
|
-
// GSheets is a specific case - only ever has a static primary key
|
|
176
|
-
tableToSave = (0, utils_2.setStaticSchemas)(datasource, tableToSave);
|
|
177
|
-
const oldTables = cloneDeep(datasource.entities);
|
|
178
|
-
const tables = datasource.entities;
|
|
179
|
-
const extraTablesToUpdate = [];
|
|
180
|
-
// check if relations need setup
|
|
181
|
-
for (let schema of Object.values(tableToSave.schema)) {
|
|
182
|
-
if (schema.type !== constants_1.FieldTypes.LINK || isRelationshipSetup(schema)) {
|
|
183
|
-
continue;
|
|
184
|
-
}
|
|
185
|
-
const relatedTable = Object.values(tables).find(table => table._id === schema.tableId);
|
|
186
|
-
if (!relatedTable) {
|
|
187
|
-
continue;
|
|
188
|
-
}
|
|
189
|
-
const relatedColumnName = schema.fieldName;
|
|
190
|
-
const relationType = schema.relationshipType;
|
|
191
|
-
if (relationType === types_1.RelationshipTypes.MANY_TO_MANY) {
|
|
192
|
-
const junctionTable = generateManyLinkSchema(datasource, schema, tableToSave, relatedTable);
|
|
193
|
-
if (tables[junctionTable.name]) {
|
|
194
|
-
throw "Junction table already exists, cannot create another relationship.";
|
|
195
|
-
}
|
|
196
|
-
tables[junctionTable.name] = junctionTable;
|
|
197
|
-
extraTablesToUpdate.push(junctionTable);
|
|
198
|
-
}
|
|
199
|
-
else {
|
|
200
|
-
const fkTable = relationType === types_1.RelationshipTypes.ONE_TO_MANY
|
|
201
|
-
? tableToSave
|
|
202
|
-
: relatedTable;
|
|
203
|
-
const foreignKey = generateLinkSchema(schema, tableToSave, relatedTable, relationType);
|
|
204
|
-
fkTable.schema[foreignKey] = (0, utils_2.foreignKeyStructure)(foreignKey);
|
|
205
|
-
if (fkTable.constrained == null) {
|
|
206
|
-
fkTable.constrained = [];
|
|
207
|
-
}
|
|
208
|
-
if (fkTable.constrained.indexOf(foreignKey) === -1) {
|
|
209
|
-
fkTable.constrained.push(foreignKey);
|
|
210
|
-
}
|
|
211
|
-
// foreign key is in other table, need to save it to external
|
|
212
|
-
if (fkTable._id !== tableToSave._id) {
|
|
213
|
-
extraTablesToUpdate.push(fkTable);
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
generateRelatedSchema(schema, relatedTable, tableToSave, relatedColumnName);
|
|
217
|
-
schema.main = true;
|
|
218
|
-
}
|
|
219
|
-
cleanupRelationships(tableToSave, tables, oldTable);
|
|
220
|
-
const operation = oldTable ? types_1.Operation.UPDATE_TABLE : types_1.Operation.CREATE_TABLE;
|
|
221
|
-
yield makeTableRequest(datasource, operation, tableToSave, tables, oldTable, renamed);
|
|
222
|
-
// update any extra tables (like foreign keys in other tables)
|
|
223
|
-
for (let extraTable of extraTablesToUpdate) {
|
|
224
|
-
const oldExtraTable = oldTables[extraTable.name];
|
|
225
|
-
let op = oldExtraTable ? types_1.Operation.UPDATE_TABLE : types_1.Operation.CREATE_TABLE;
|
|
226
|
-
yield makeTableRequest(datasource, op, extraTable, tables, oldExtraTable);
|
|
227
|
-
}
|
|
228
|
-
// make sure the constrained list, all still exist
|
|
229
|
-
if (Array.isArray(tableToSave.constrained)) {
|
|
230
|
-
tableToSave.constrained = tableToSave.constrained.filter(constraint => Object.keys(tableToSave.schema).includes(constraint));
|
|
231
|
-
}
|
|
232
|
-
// remove the rename prop
|
|
233
|
-
delete tableToSave._rename;
|
|
234
|
-
// store it into couch now for budibase reference
|
|
235
|
-
datasource.entities[tableToSave.name] = tableToSave;
|
|
236
|
-
yield db.put(datasource);
|
|
237
|
-
return tableToSave;
|
|
238
|
-
});
|
|
239
|
-
}
|
|
240
|
-
exports.save = save;
|
|
241
|
-
function destroy(ctx) {
|
|
242
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
243
|
-
const tableToDelete = yield sdk_1.default.tables.getTable(ctx.params.tableId);
|
|
244
|
-
if (!tableToDelete || !tableToDelete.created) {
|
|
245
|
-
ctx.throw(400, "Cannot delete tables which weren't created in Budibase.");
|
|
246
|
-
}
|
|
247
|
-
const datasourceId = getDatasourceId(tableToDelete);
|
|
248
|
-
const db = backend_core_1.context.getAppDB();
|
|
249
|
-
const datasource = yield sdk_1.default.datasources.get(datasourceId);
|
|
250
|
-
const tables = datasource.entities;
|
|
251
|
-
const operation = types_1.Operation.DELETE_TABLE;
|
|
252
|
-
if (tables) {
|
|
253
|
-
yield makeTableRequest(datasource, operation, tableToDelete, tables);
|
|
254
|
-
cleanupRelationships(tableToDelete, tables);
|
|
255
|
-
delete tables[tableToDelete.name];
|
|
256
|
-
datasource.entities = tables;
|
|
257
|
-
}
|
|
258
|
-
yield db.put(datasource);
|
|
259
|
-
return tableToDelete;
|
|
260
|
-
});
|
|
261
|
-
}
|
|
262
|
-
exports.destroy = destroy;
|
|
263
|
-
function bulkImport(ctx) {
|
|
264
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
265
|
-
const table = yield sdk_1.default.tables.getTable(ctx.params.tableId);
|
|
266
|
-
const { rows } = ctx.request.body;
|
|
267
|
-
const schema = table.schema;
|
|
268
|
-
if (!rows || !(0, schema_1.isRows)(rows) || !(0, schema_1.isSchema)(schema)) {
|
|
269
|
-
ctx.throw(400, "Provided data import information is invalid.");
|
|
270
|
-
}
|
|
271
|
-
const parsedRows = (0, schema_1.parse)(rows, schema);
|
|
272
|
-
yield (0, external_1.handleRequest)(types_1.Operation.BULK_CREATE, table._id, {
|
|
273
|
-
rows: parsedRows,
|
|
274
|
-
});
|
|
275
|
-
yield backend_core_1.events.rows.imported(table, parsedRows.length);
|
|
276
|
-
return table;
|
|
277
|
-
});
|
|
278
|
-
}
|
|
279
|
-
exports.bulkImport = bulkImport;
|
|
@@ -1,179 +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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
-
});
|
|
33
|
-
};
|
|
34
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
-
};
|
|
37
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
-
exports.validateExistingTableImport = exports.validateNewTableImport = exports.csvToJson = exports.bulkImport = exports.destroy = exports.save = exports.find = exports.fetch = void 0;
|
|
39
|
-
const internal = __importStar(require("./internal"));
|
|
40
|
-
const external = __importStar(require("./external"));
|
|
41
|
-
const schema_1 = require("../../../utilities/schema");
|
|
42
|
-
const utils_1 = require("../../../integrations/utils");
|
|
43
|
-
const utils_2 = require("../../../db/utils");
|
|
44
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
45
|
-
const sdk_1 = __importDefault(require("../../../sdk"));
|
|
46
|
-
const csv_1 = require("../../../utilities/csv");
|
|
47
|
-
function pickApi({ tableId, table }) {
|
|
48
|
-
if (table && !tableId) {
|
|
49
|
-
tableId = table._id;
|
|
50
|
-
}
|
|
51
|
-
if (table && table.type === "external") {
|
|
52
|
-
return external;
|
|
53
|
-
}
|
|
54
|
-
else if (tableId && (0, utils_1.isExternalTable)(tableId)) {
|
|
55
|
-
return external;
|
|
56
|
-
}
|
|
57
|
-
return internal;
|
|
58
|
-
}
|
|
59
|
-
// covers both internal and external
|
|
60
|
-
function fetch(ctx) {
|
|
61
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
-
const db = backend_core_1.context.getAppDB();
|
|
63
|
-
const internal = yield sdk_1.default.tables.getAllInternalTables();
|
|
64
|
-
const externalTables = yield db.allDocs((0, utils_2.getDatasourceParams)("plus", {
|
|
65
|
-
include_docs: true,
|
|
66
|
-
}));
|
|
67
|
-
const external = externalTables.rows.flatMap(tableDoc => {
|
|
68
|
-
let entities = tableDoc.doc.entities;
|
|
69
|
-
if (entities) {
|
|
70
|
-
return Object.values(entities).map((entity) => (Object.assign(Object.assign({}, entity), { type: "external", sourceId: tableDoc.doc._id, sql: (0, utils_1.isSQL)(tableDoc.doc) })));
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
return [];
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
ctx.body = [...internal, ...external];
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
exports.fetch = fetch;
|
|
80
|
-
function find(ctx) {
|
|
81
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
82
|
-
const tableId = ctx.params.tableId;
|
|
83
|
-
ctx.body = yield sdk_1.default.tables.getTable(tableId);
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
exports.find = find;
|
|
87
|
-
function save(ctx) {
|
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
const appId = ctx.appId;
|
|
90
|
-
const table = ctx.request.body;
|
|
91
|
-
const isImport = table.rows;
|
|
92
|
-
const savedTable = yield pickApi({ table }).save(ctx);
|
|
93
|
-
if (!table._id) {
|
|
94
|
-
yield backend_core_1.events.table.created(savedTable);
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
yield backend_core_1.events.table.updated(savedTable);
|
|
98
|
-
}
|
|
99
|
-
if (isImport) {
|
|
100
|
-
yield backend_core_1.events.table.imported(savedTable);
|
|
101
|
-
}
|
|
102
|
-
ctx.status = 200;
|
|
103
|
-
ctx.message = `Table ${table.name} saved successfully.`;
|
|
104
|
-
ctx.eventEmitter &&
|
|
105
|
-
ctx.eventEmitter.emitTable(`table:save`, appId, savedTable);
|
|
106
|
-
ctx.body = savedTable;
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
exports.save = save;
|
|
110
|
-
function destroy(ctx) {
|
|
111
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
112
|
-
const appId = ctx.appId;
|
|
113
|
-
const tableId = ctx.params.tableId;
|
|
114
|
-
const deletedTable = yield pickApi({ tableId }).destroy(ctx);
|
|
115
|
-
yield backend_core_1.events.table.deleted(deletedTable);
|
|
116
|
-
ctx.eventEmitter &&
|
|
117
|
-
ctx.eventEmitter.emitTable(`table:delete`, appId, deletedTable);
|
|
118
|
-
ctx.status = 200;
|
|
119
|
-
ctx.table = deletedTable;
|
|
120
|
-
ctx.body = { message: `Table ${tableId} deleted.` };
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
exports.destroy = destroy;
|
|
124
|
-
function bulkImport(ctx) {
|
|
125
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
const tableId = ctx.params.tableId;
|
|
127
|
-
yield pickApi({ tableId }).bulkImport(ctx);
|
|
128
|
-
// right now we don't trigger anything for bulk import because it
|
|
129
|
-
// can only be done in the builder, but in the future we may need to
|
|
130
|
-
// think about events for bulk items
|
|
131
|
-
ctx.status = 200;
|
|
132
|
-
ctx.body = { message: `Bulk rows created.` };
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
exports.bulkImport = bulkImport;
|
|
136
|
-
function csvToJson(ctx) {
|
|
137
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
138
|
-
const { csvString } = ctx.request.body;
|
|
139
|
-
const result = yield (0, csv_1.jsonFromCsvString)(csvString);
|
|
140
|
-
ctx.status = 200;
|
|
141
|
-
ctx.body = result;
|
|
142
|
-
});
|
|
143
|
-
}
|
|
144
|
-
exports.csvToJson = csvToJson;
|
|
145
|
-
function validateNewTableImport(ctx) {
|
|
146
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
147
|
-
const { rows, schema } = ctx.request.body;
|
|
148
|
-
if ((0, schema_1.isRows)(rows) && (0, schema_1.isSchema)(schema)) {
|
|
149
|
-
ctx.status = 200;
|
|
150
|
-
ctx.body = (0, schema_1.validate)(rows, schema);
|
|
151
|
-
}
|
|
152
|
-
else {
|
|
153
|
-
ctx.status = 422;
|
|
154
|
-
}
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
exports.validateNewTableImport = validateNewTableImport;
|
|
158
|
-
function validateExistingTableImport(ctx) {
|
|
159
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
160
|
-
const { rows, tableId } = ctx.request.body;
|
|
161
|
-
let schema = null;
|
|
162
|
-
if (tableId) {
|
|
163
|
-
const table = yield sdk_1.default.tables.getTable(tableId);
|
|
164
|
-
schema = table.schema;
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
|
-
ctx.status = 422;
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
|
-
if (tableId && (0, schema_1.isRows)(rows) && (0, schema_1.isSchema)(schema)) {
|
|
171
|
-
ctx.status = 200;
|
|
172
|
-
ctx.body = (0, schema_1.validate)(rows, schema);
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
ctx.status = 422;
|
|
176
|
-
}
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
exports.validateExistingTableImport = validateExistingTableImport;
|
|
@@ -1,197 +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 __rest = (this && this.__rest) || function (s, e) {
|
|
12
|
-
var t = {};
|
|
13
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
14
|
-
t[p] = s[p];
|
|
15
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
16
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
17
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
18
|
-
t[p[i]] = s[p[i]];
|
|
19
|
-
}
|
|
20
|
-
return t;
|
|
21
|
-
};
|
|
22
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
23
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.bulkImport = exports.destroy = exports.save = void 0;
|
|
27
|
-
const linkedRows_1 = require("../../../db/linkedRows");
|
|
28
|
-
const utils_1 = require("../../../db/utils");
|
|
29
|
-
const constants_1 = require("../../../constants");
|
|
30
|
-
const utils_2 = require("./utils");
|
|
31
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
32
|
-
const environment_1 = __importDefault(require("../../../environment"));
|
|
33
|
-
const rowProcessor_1 = require("../../../utilities/rowProcessor");
|
|
34
|
-
const bulkFormula_1 = require("./bulkFormula");
|
|
35
|
-
const pro_1 = require("@budibase/pro");
|
|
36
|
-
const lodash_1 = require("lodash");
|
|
37
|
-
const fp_1 = require("lodash/fp");
|
|
38
|
-
const sdk_1 = __importDefault(require("../../../sdk"));
|
|
39
|
-
function checkAutoColumns(table, oldTable) {
|
|
40
|
-
if (!table.schema) {
|
|
41
|
-
return table;
|
|
42
|
-
}
|
|
43
|
-
for (let [key, schema] of Object.entries(table.schema)) {
|
|
44
|
-
if (!schema.autocolumn || schema.subtype) {
|
|
45
|
-
continue;
|
|
46
|
-
}
|
|
47
|
-
const oldSchema = oldTable && oldTable.schema[key];
|
|
48
|
-
if (oldSchema && oldSchema.subtype) {
|
|
49
|
-
table.schema[key].subtype = oldSchema.subtype;
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
table.schema[key] = (0, rowProcessor_1.fixAutoColumnSubType)(schema);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
return table;
|
|
56
|
-
}
|
|
57
|
-
function save(ctx) {
|
|
58
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
-
const db = backend_core_1.context.getAppDB();
|
|
60
|
-
const _a = ctx.request.body, { rows } = _a, rest = __rest(_a, ["rows"]);
|
|
61
|
-
let tableToSave = Object.assign({ type: "table", _id: (0, utils_1.generateTableID)(), views: {} }, rest);
|
|
62
|
-
// if the table obj had an _id then it will have been retrieved
|
|
63
|
-
let oldTable;
|
|
64
|
-
if (ctx.request.body && ctx.request.body._id) {
|
|
65
|
-
oldTable = yield db.get(ctx.request.body._id);
|
|
66
|
-
}
|
|
67
|
-
// check all types are correct
|
|
68
|
-
if ((0, utils_2.hasTypeChanged)(tableToSave, oldTable)) {
|
|
69
|
-
ctx.throw(400, "A column type has changed.");
|
|
70
|
-
}
|
|
71
|
-
// check that subtypes have been maintained
|
|
72
|
-
tableToSave = checkAutoColumns(tableToSave, oldTable);
|
|
73
|
-
// saving a table is a complex operation, involving many different steps, this
|
|
74
|
-
// has been broken out into a utility to make it more obvious/easier to manipulate
|
|
75
|
-
const tableSaveFunctions = new utils_2.TableSaveFunctions({
|
|
76
|
-
user: ctx.user,
|
|
77
|
-
oldTable,
|
|
78
|
-
importRows: rows,
|
|
79
|
-
});
|
|
80
|
-
tableToSave = yield tableSaveFunctions.before(tableToSave);
|
|
81
|
-
// make sure that types don't change of a column, have to remove
|
|
82
|
-
// the column if you want to change the type
|
|
83
|
-
if (oldTable && oldTable.schema) {
|
|
84
|
-
for (let propKey of Object.keys(tableToSave.schema)) {
|
|
85
|
-
let oldColumn = oldTable.schema[propKey];
|
|
86
|
-
if (oldColumn && oldColumn.type === "internal") {
|
|
87
|
-
oldColumn.type = "auto";
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
// Don't rename if the name is the same
|
|
92
|
-
let { _rename } = tableToSave;
|
|
93
|
-
/* istanbul ignore next */
|
|
94
|
-
if (_rename && _rename.old === _rename.updated) {
|
|
95
|
-
_rename = null;
|
|
96
|
-
delete tableToSave._rename;
|
|
97
|
-
}
|
|
98
|
-
// rename row fields when table column is renamed
|
|
99
|
-
/* istanbul ignore next */
|
|
100
|
-
if (_rename && tableToSave.schema[_rename.updated].type === constants_1.FieldTypes.LINK) {
|
|
101
|
-
ctx.throw(400, "Cannot rename a linked column.");
|
|
102
|
-
}
|
|
103
|
-
tableToSave = yield tableSaveFunctions.mid(tableToSave);
|
|
104
|
-
// update schema of non-statistics views when new columns are added
|
|
105
|
-
for (let view in tableToSave.views) {
|
|
106
|
-
const tableView = tableToSave.views[view];
|
|
107
|
-
if (!tableView)
|
|
108
|
-
continue;
|
|
109
|
-
if (tableView.schema.group || tableView.schema.field)
|
|
110
|
-
continue;
|
|
111
|
-
tableView.schema = tableToSave.schema;
|
|
112
|
-
}
|
|
113
|
-
// update linked rows
|
|
114
|
-
try {
|
|
115
|
-
const linkResp = yield (0, linkedRows_1.updateLinks)({
|
|
116
|
-
eventType: oldTable ? linkedRows_1.EventType.TABLE_UPDATED : linkedRows_1.EventType.TABLE_SAVE,
|
|
117
|
-
table: tableToSave,
|
|
118
|
-
oldTable: oldTable,
|
|
119
|
-
});
|
|
120
|
-
if (linkResp != null && linkResp._rev) {
|
|
121
|
-
tableToSave._rev = linkResp._rev;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
catch (err) {
|
|
125
|
-
ctx.throw(400, err);
|
|
126
|
-
}
|
|
127
|
-
// don't perform any updates until relationships have been
|
|
128
|
-
// checked by the updateLinks function
|
|
129
|
-
const updatedRows = tableSaveFunctions.getUpdatedRows();
|
|
130
|
-
if (updatedRows && updatedRows.length !== 0) {
|
|
131
|
-
yield db.bulkDocs(updatedRows);
|
|
132
|
-
}
|
|
133
|
-
let result = yield db.put(tableToSave);
|
|
134
|
-
tableToSave._rev = result.rev;
|
|
135
|
-
const savedTable = (0, fp_1.cloneDeep)(tableToSave);
|
|
136
|
-
tableToSave = yield tableSaveFunctions.after(tableToSave);
|
|
137
|
-
// the table may be updated as part of the table save after functionality - need to write it
|
|
138
|
-
if (!(0, lodash_1.isEqual)(savedTable, tableToSave)) {
|
|
139
|
-
result = yield db.put(tableToSave);
|
|
140
|
-
tableToSave._rev = result.rev;
|
|
141
|
-
}
|
|
142
|
-
// has to run after, make sure it has _id
|
|
143
|
-
yield (0, bulkFormula_1.runStaticFormulaChecks)(tableToSave, { oldTable, deletion: false });
|
|
144
|
-
return tableToSave;
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
exports.save = save;
|
|
148
|
-
function destroy(ctx) {
|
|
149
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
150
|
-
const db = backend_core_1.context.getAppDB();
|
|
151
|
-
const tableToDelete = yield db.get(ctx.params.tableId);
|
|
152
|
-
// Delete all rows for that table
|
|
153
|
-
const rowsData = yield db.allDocs((0, utils_1.getRowParams)(ctx.params.tableId, null, {
|
|
154
|
-
include_docs: true,
|
|
155
|
-
}));
|
|
156
|
-
yield db.bulkDocs(rowsData.rows.map((row) => (Object.assign(Object.assign({}, row.doc), { _deleted: true }))));
|
|
157
|
-
yield pro_1.quotas.removeRows(rowsData.rows.length, {
|
|
158
|
-
tableId: ctx.params.tableId,
|
|
159
|
-
});
|
|
160
|
-
// update linked rows
|
|
161
|
-
yield (0, linkedRows_1.updateLinks)({
|
|
162
|
-
eventType: linkedRows_1.EventType.TABLE_DELETE,
|
|
163
|
-
table: tableToDelete,
|
|
164
|
-
});
|
|
165
|
-
// don't remove the table itself until very end
|
|
166
|
-
yield db.remove(tableToDelete._id, tableToDelete._rev);
|
|
167
|
-
// remove table search index
|
|
168
|
-
if (!environment_1.default.isTest() || environment_1.default.COUCH_DB_URL) {
|
|
169
|
-
const currentIndexes = yield db.getIndexes();
|
|
170
|
-
const existingIndex = currentIndexes.indexes.find((existing) => existing.name === `search:${ctx.params.tableId}`);
|
|
171
|
-
if (existingIndex) {
|
|
172
|
-
yield db.deleteIndex(existingIndex);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
// has to run after, make sure it has _id
|
|
176
|
-
yield (0, bulkFormula_1.runStaticFormulaChecks)(tableToDelete, {
|
|
177
|
-
deletion: true,
|
|
178
|
-
});
|
|
179
|
-
yield (0, rowProcessor_1.cleanupAttachments)(tableToDelete, {
|
|
180
|
-
rows: rowsData.rows.map((row) => row.doc),
|
|
181
|
-
});
|
|
182
|
-
return tableToDelete;
|
|
183
|
-
});
|
|
184
|
-
}
|
|
185
|
-
exports.destroy = destroy;
|
|
186
|
-
function bulkImport(ctx) {
|
|
187
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
188
|
-
const db = backend_core_1.context.getAppDB();
|
|
189
|
-
const table = yield sdk_1.default.tables.getTable(ctx.params.tableId);
|
|
190
|
-
const { rows } = ctx.request.body;
|
|
191
|
-
yield (0, utils_2.handleDataImport)(ctx.user, table, rows);
|
|
192
|
-
// Ensure auto id and other table updates are persisted
|
|
193
|
-
yield db.put(table);
|
|
194
|
-
return table;
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
exports.bulkImport = bulkImport;
|