@budibase/server 2.6.19-alpha.3 → 2.6.19-alpha.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.dockerignore +7 -6
- package/Dockerfile +16 -8
- package/builder/assets/{index.71388c79.js → index.3dd3d237.js} +435 -428
- package/builder/assets/{index.07382a47.css → index.8469b14c.css} +2 -2
- package/builder/index.html +2 -2
- package/client/manifest.json +5229 -0
- package/dist/automation.js +32436 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +44735 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24367 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +3 -0
- package/nodemon.json +1 -1
- package/package.json +32 -13
- 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 +20 -0
- package/src/api/controllers/row/index.ts +15 -22
- package/src/api/controllers/row/internal.ts +1 -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 +5 -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/{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 +4 -0
- 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 +4 -0
- package/src/automations/tests/openai.spec.ts +86 -0
- package/src/automations/triggers.ts +3 -2
- package/src/constants/index.ts +17 -16
- package/src/db/inMemoryView.ts +1 -0
- package/src/environment.ts +3 -0
- package/src/integration-test/postgres.spec.ts +47 -4
- package/src/integrations/airtable.ts +3 -1
- package/src/integrations/arangodb.ts +3 -1
- package/src/integrations/base/sqlTable.ts +0 -1
- package/src/integrations/couchdb.ts +3 -1
- package/src/integrations/dynamodb.ts +3 -1
- package/src/integrations/elasticsearch.ts +3 -1
- package/src/integrations/firebase.ts +3 -1
- package/src/integrations/googlesheets.ts +11 -3
- package/src/integrations/microsoftSqlServer.ts +18 -2
- package/src/integrations/mongodb.ts +3 -1
- package/src/integrations/mysql.ts +27 -11
- package/src/integrations/oracle.ts +11 -1
- package/src/integrations/postgres.ts +15 -1
- package/src/integrations/redis.ts +3 -1
- package/src/integrations/s3.ts +3 -1
- package/src/integrations/snowflake.ts +3 -1
- package/src/integrations/tests/googlesheets.spec.ts +41 -9
- package/src/middleware/builder.ts +4 -5
- package/src/sdk/app/automations/index.ts +2 -0
- package/src/sdk/app/automations/utils.ts +7 -0
- 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 +78 -22
- package/src/threads/index.ts +9 -3
- package/src/threads/utils.ts +2 -0
- package/src/utilities/fileSystem/app.ts +1 -1
- package/src/utilities/fileSystem/clientLibrary.ts +8 -3
- package/src/utilities/fileSystem/filesystem.ts +3 -1
- package/src/utilities/redis.ts +19 -2
- package/src/websockets/builder.ts +69 -0
- package/src/websockets/grid.ts +25 -7
- package/src/websockets/index.ts +5 -2
- package/src/websockets/websocket.ts +20 -4
- package/tsconfig.build.json +9 -1
- package/tsconfig.json +1 -14
- 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 -337
- 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 -44
- 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 -134
- package/dist/automations/steps/outgoingWebhook.js +0 -166
- package/dist/automations/steps/queryRows.js +0 -216
- 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 -130
- 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 -173
- package/dist/integrations/arangodb.js +0 -119
- 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 -140
- package/dist/integrations/dynamodb.js +0 -210
- package/dist/integrations/elasticsearch.js +0 -201
- package/dist/integrations/firebase.js +0 -189
- package/dist/integrations/googlesheets.js +0 -484
- package/dist/integrations/index.js +0 -138
- package/dist/integrations/microsoftSqlServer.js +0 -289
- package/dist/integrations/mongodb.js +0 -630
- package/dist/integrations/mysql.js +0 -272
- package/dist/integrations/oracle.js +0 -404
- package/dist/integrations/postgres.js +0 -320
- package/dist/integrations/queries/sql.js +0 -84
- package/dist/integrations/redis.js +0 -187
- package/dist/integrations/rest.js +0 -400
- package/dist/integrations/s3.js +0 -256
- package/dist/integrations/snowflake.js +0 -114
- 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 -49
- 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 -173
- 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 -87
- 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 -149
- 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/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,80 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.fetchSelf = void 0;
|
|
13
|
-
const rowProcessor_1 = require("../../utilities/rowProcessor");
|
|
14
|
-
const utils_1 = require("../../db/utils");
|
|
15
|
-
const users_1 = require("../../utilities/users");
|
|
16
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
17
|
-
const pro_1 = require("@budibase/pro");
|
|
18
|
-
const PUBLIC_ROLE = backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC;
|
|
19
|
-
/**
|
|
20
|
-
* Add the attributes that are session based to the current user.
|
|
21
|
-
*/
|
|
22
|
-
const addSessionAttributesToUser = (ctx) => {
|
|
23
|
-
if (ctx.user) {
|
|
24
|
-
ctx.body.license = ctx.user.license;
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
function fetchSelf(ctx) {
|
|
28
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
29
|
-
let userId = ctx.user.userId || ctx.user._id;
|
|
30
|
-
/* istanbul ignore next */
|
|
31
|
-
if (!userId || !ctx.isAuthenticated) {
|
|
32
|
-
ctx.body = {};
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
const appId = backend_core_1.context.getAppId();
|
|
36
|
-
const user = yield (0, users_1.getFullUser)(ctx, userId);
|
|
37
|
-
// this shouldn't be returned by the app self
|
|
38
|
-
delete user.roles;
|
|
39
|
-
// forward the csrf token from the session
|
|
40
|
-
user.csrfToken = ctx.user.csrfToken;
|
|
41
|
-
if (appId) {
|
|
42
|
-
const db = backend_core_1.context.getAppDB();
|
|
43
|
-
// check for group permissions
|
|
44
|
-
if (!user.roleId || user.roleId === PUBLIC_ROLE) {
|
|
45
|
-
const groupRoleId = yield pro_1.groups.getGroupRoleId(user, appId);
|
|
46
|
-
user.roleId = groupRoleId || user.roleId;
|
|
47
|
-
}
|
|
48
|
-
// remove the full roles structure
|
|
49
|
-
delete user.roles;
|
|
50
|
-
try {
|
|
51
|
-
const userTable = yield db.get(utils_1.InternalTables.USER_METADATA);
|
|
52
|
-
// specifically needs to make sure is enriched
|
|
53
|
-
ctx.body = yield (0, rowProcessor_1.outputProcessing)(userTable, user);
|
|
54
|
-
}
|
|
55
|
-
catch (err) {
|
|
56
|
-
let response;
|
|
57
|
-
// user didn't exist in app, don't pretend they do
|
|
58
|
-
if (user.roleId === PUBLIC_ROLE) {
|
|
59
|
-
response = {};
|
|
60
|
-
}
|
|
61
|
-
// user has a role of some sort, return them
|
|
62
|
-
else if (err.status === 404) {
|
|
63
|
-
const metadata = Object.assign(Object.assign({}, user), { _id: userId });
|
|
64
|
-
const dbResp = yield db.put(metadata);
|
|
65
|
-
user._rev = dbResp.rev;
|
|
66
|
-
response = user;
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
response = user;
|
|
70
|
-
}
|
|
71
|
-
ctx.body = response;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
ctx.body = user;
|
|
76
|
-
}
|
|
77
|
-
addSessionAttributesToUser(ctx);
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
exports.fetchSelf = fetchSelf;
|
|
@@ -1,303 +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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
35
|
-
exports.test = exports.trigger = exports.getDefinitionList = exports.getTriggerList = exports.getActionList = exports.clearLogError = exports.logSearch = exports.destroy = exports.find = exports.fetch = exports.update = exports.handleStepEvents = exports.getDeletedSteps = exports.getNewSteps = exports.create = void 0;
|
|
36
|
-
const triggers = __importStar(require("../../automations/triggers"));
|
|
37
|
-
const utils_1 = require("../../db/utils");
|
|
38
|
-
const utils_2 = require("../../automations/utils");
|
|
39
|
-
const utilities_1 = require("../../utilities");
|
|
40
|
-
const constants_1 = require("../../constants");
|
|
41
|
-
const redis_1 = require("../../utilities/redis");
|
|
42
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
43
|
-
const pro_1 = require("@budibase/pro");
|
|
44
|
-
const actions_1 = require("../../automations/actions");
|
|
45
|
-
function getActionDefinitions() {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
return (0, utils_2.removeDeprecated)(yield (0, actions_1.getActionDefinitions)());
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
function getTriggerDefinitions() {
|
|
51
|
-
return (0, utils_2.removeDeprecated)(triggers.TRIGGER_DEFINITIONS);
|
|
52
|
-
}
|
|
53
|
-
/*************************
|
|
54
|
-
* *
|
|
55
|
-
* BUILDER FUNCTIONS *
|
|
56
|
-
* *
|
|
57
|
-
*************************/
|
|
58
|
-
function cleanupAutomationMetadata(automationId) {
|
|
59
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
-
yield (0, utilities_1.deleteEntityMetadata)(constants_1.MetadataTypes.AUTOMATION_TEST_INPUT, automationId);
|
|
61
|
-
yield (0, utilities_1.deleteEntityMetadata)(constants_1.MetadataTypes.AUTOMATION_TEST_HISTORY, automationId);
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
function cleanAutomationInputs(automation) {
|
|
65
|
-
if (automation == null) {
|
|
66
|
-
return automation;
|
|
67
|
-
}
|
|
68
|
-
let steps = automation.definition.steps;
|
|
69
|
-
let trigger = automation.definition.trigger;
|
|
70
|
-
let allSteps = [...steps, trigger];
|
|
71
|
-
// live is not a property used anymore
|
|
72
|
-
if (automation.live != null) {
|
|
73
|
-
delete automation.live;
|
|
74
|
-
}
|
|
75
|
-
for (let step of allSteps) {
|
|
76
|
-
if (step == null) {
|
|
77
|
-
continue;
|
|
78
|
-
}
|
|
79
|
-
for (let inputName of Object.keys(step.inputs)) {
|
|
80
|
-
if (!step.inputs[inputName] || step.inputs[inputName] === "") {
|
|
81
|
-
delete step.inputs[inputName];
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return automation;
|
|
86
|
-
}
|
|
87
|
-
function create(ctx) {
|
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
const db = backend_core_1.context.getAppDB();
|
|
90
|
-
let automation = ctx.request.body;
|
|
91
|
-
automation.appId = ctx.appId;
|
|
92
|
-
// call through to update if already exists
|
|
93
|
-
if (automation._id && automation._rev) {
|
|
94
|
-
yield update(ctx);
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
// Respect existing IDs if recreating a deleted automation
|
|
98
|
-
if (!automation._id) {
|
|
99
|
-
automation._id = (0, utils_1.generateAutomationID)();
|
|
100
|
-
}
|
|
101
|
-
automation.type = "automation";
|
|
102
|
-
automation = cleanAutomationInputs(automation);
|
|
103
|
-
automation = yield (0, utils_2.checkForWebhooks)({
|
|
104
|
-
newAuto: automation,
|
|
105
|
-
});
|
|
106
|
-
const response = yield db.put(automation);
|
|
107
|
-
yield backend_core_1.events.automation.created(automation);
|
|
108
|
-
for (let step of automation.definition.steps) {
|
|
109
|
-
yield backend_core_1.events.automation.stepCreated(automation, step);
|
|
110
|
-
}
|
|
111
|
-
automation._rev = response.rev;
|
|
112
|
-
ctx.status = 200;
|
|
113
|
-
ctx.body = {
|
|
114
|
-
message: "Automation created successfully",
|
|
115
|
-
automation: Object.assign(Object.assign({}, automation), response),
|
|
116
|
-
};
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
exports.create = create;
|
|
120
|
-
function getNewSteps(oldAutomation, automation) {
|
|
121
|
-
const oldStepIds = oldAutomation.definition.steps.map(s => s.id);
|
|
122
|
-
return automation.definition.steps.filter(s => !oldStepIds.includes(s.id));
|
|
123
|
-
}
|
|
124
|
-
exports.getNewSteps = getNewSteps;
|
|
125
|
-
function getDeletedSteps(oldAutomation, automation) {
|
|
126
|
-
const stepIds = automation.definition.steps.map(s => s.id);
|
|
127
|
-
return oldAutomation.definition.steps.filter(s => !stepIds.includes(s.id));
|
|
128
|
-
}
|
|
129
|
-
exports.getDeletedSteps = getDeletedSteps;
|
|
130
|
-
function handleStepEvents(oldAutomation, automation) {
|
|
131
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
132
|
-
// new steps
|
|
133
|
-
const newSteps = getNewSteps(oldAutomation, automation);
|
|
134
|
-
for (let step of newSteps) {
|
|
135
|
-
yield backend_core_1.events.automation.stepCreated(automation, step);
|
|
136
|
-
}
|
|
137
|
-
// old steps
|
|
138
|
-
const deletedSteps = getDeletedSteps(oldAutomation, automation);
|
|
139
|
-
for (let step of deletedSteps) {
|
|
140
|
-
yield backend_core_1.events.automation.stepDeleted(automation, step);
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
}
|
|
144
|
-
exports.handleStepEvents = handleStepEvents;
|
|
145
|
-
function update(ctx) {
|
|
146
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
147
|
-
const db = backend_core_1.context.getAppDB();
|
|
148
|
-
let automation = ctx.request.body;
|
|
149
|
-
automation.appId = ctx.appId;
|
|
150
|
-
// Call through to create if it doesn't exist
|
|
151
|
-
if (!automation._id || !automation._rev) {
|
|
152
|
-
yield create(ctx);
|
|
153
|
-
return;
|
|
154
|
-
}
|
|
155
|
-
const oldAutomation = yield db.get(automation._id);
|
|
156
|
-
automation = cleanAutomationInputs(automation);
|
|
157
|
-
automation = yield (0, utils_2.checkForWebhooks)({
|
|
158
|
-
oldAuto: oldAutomation,
|
|
159
|
-
newAuto: automation,
|
|
160
|
-
});
|
|
161
|
-
const response = yield db.put(automation);
|
|
162
|
-
automation._rev = response.rev;
|
|
163
|
-
const oldAutoTrigger = oldAutomation && oldAutomation.definition.trigger
|
|
164
|
-
? oldAutomation.definition.trigger
|
|
165
|
-
: undefined;
|
|
166
|
-
const newAutoTrigger = automation && automation.definition.trigger
|
|
167
|
-
? automation.definition.trigger
|
|
168
|
-
: {};
|
|
169
|
-
// trigger has been updated, remove the test inputs
|
|
170
|
-
if (oldAutoTrigger && oldAutoTrigger.id !== newAutoTrigger.id) {
|
|
171
|
-
yield backend_core_1.events.automation.triggerUpdated(automation);
|
|
172
|
-
yield (0, utilities_1.deleteEntityMetadata)(constants_1.MetadataTypes.AUTOMATION_TEST_INPUT, automation._id);
|
|
173
|
-
}
|
|
174
|
-
yield handleStepEvents(oldAutomation, automation);
|
|
175
|
-
ctx.status = 200;
|
|
176
|
-
ctx.body = {
|
|
177
|
-
message: `Automation ${automation._id} updated successfully.`,
|
|
178
|
-
automation: Object.assign(Object.assign({}, automation), { _rev: response.rev, _id: response.id }),
|
|
179
|
-
};
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
exports.update = update;
|
|
183
|
-
function fetch(ctx) {
|
|
184
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
185
|
-
const db = backend_core_1.context.getAppDB();
|
|
186
|
-
const response = yield db.allDocs((0, utils_1.getAutomationParams)(null, {
|
|
187
|
-
include_docs: true,
|
|
188
|
-
}));
|
|
189
|
-
ctx.body = response.rows.map(row => row.doc);
|
|
190
|
-
});
|
|
191
|
-
}
|
|
192
|
-
exports.fetch = fetch;
|
|
193
|
-
function find(ctx) {
|
|
194
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
195
|
-
const db = backend_core_1.context.getAppDB();
|
|
196
|
-
ctx.body = yield db.get(ctx.params.id);
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
exports.find = find;
|
|
200
|
-
function destroy(ctx) {
|
|
201
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
202
|
-
const db = backend_core_1.context.getAppDB();
|
|
203
|
-
const automationId = ctx.params.id;
|
|
204
|
-
const oldAutomation = yield db.get(automationId);
|
|
205
|
-
yield (0, utils_2.checkForWebhooks)({
|
|
206
|
-
oldAuto: oldAutomation,
|
|
207
|
-
});
|
|
208
|
-
// delete metadata first
|
|
209
|
-
yield cleanupAutomationMetadata(automationId);
|
|
210
|
-
ctx.body = yield db.remove(automationId, ctx.params.rev);
|
|
211
|
-
yield backend_core_1.events.automation.deleted(oldAutomation);
|
|
212
|
-
});
|
|
213
|
-
}
|
|
214
|
-
exports.destroy = destroy;
|
|
215
|
-
function logSearch(ctx) {
|
|
216
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
217
|
-
ctx.body = yield pro_1.automations.logs.logSearch(ctx.request.body);
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
exports.logSearch = logSearch;
|
|
221
|
-
function clearLogError(ctx) {
|
|
222
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
223
|
-
const { automationId, appId } = ctx.request.body;
|
|
224
|
-
yield backend_core_1.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
|
|
225
|
-
const db = backend_core_1.context.getProdAppDB();
|
|
226
|
-
const metadata = yield db.get(utils_1.DocumentType.APP_METADATA);
|
|
227
|
-
if (!automationId) {
|
|
228
|
-
delete metadata.automationErrors;
|
|
229
|
-
}
|
|
230
|
-
else if (metadata.automationErrors &&
|
|
231
|
-
metadata.automationErrors[automationId]) {
|
|
232
|
-
delete metadata.automationErrors[automationId];
|
|
233
|
-
}
|
|
234
|
-
yield db.put(metadata);
|
|
235
|
-
yield backend_core_1.cache.app.invalidateAppMetadata(metadata.appId, metadata);
|
|
236
|
-
ctx.body = { message: `Error logs cleared.` };
|
|
237
|
-
}));
|
|
238
|
-
});
|
|
239
|
-
}
|
|
240
|
-
exports.clearLogError = clearLogError;
|
|
241
|
-
function getActionList(ctx) {
|
|
242
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
243
|
-
ctx.body = yield getActionDefinitions();
|
|
244
|
-
});
|
|
245
|
-
}
|
|
246
|
-
exports.getActionList = getActionList;
|
|
247
|
-
function getTriggerList(ctx) {
|
|
248
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
249
|
-
ctx.body = getTriggerDefinitions();
|
|
250
|
-
});
|
|
251
|
-
}
|
|
252
|
-
exports.getTriggerList = getTriggerList;
|
|
253
|
-
function getDefinitionList(ctx) {
|
|
254
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
255
|
-
ctx.body = {
|
|
256
|
-
trigger: getTriggerDefinitions(),
|
|
257
|
-
action: yield getActionDefinitions(),
|
|
258
|
-
};
|
|
259
|
-
});
|
|
260
|
-
}
|
|
261
|
-
exports.getDefinitionList = getDefinitionList;
|
|
262
|
-
/*********************
|
|
263
|
-
* *
|
|
264
|
-
* API FUNCTIONS *
|
|
265
|
-
* *
|
|
266
|
-
*********************/
|
|
267
|
-
function trigger(ctx) {
|
|
268
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
269
|
-
const db = backend_core_1.context.getAppDB();
|
|
270
|
-
let automation = yield db.get(ctx.params.id);
|
|
271
|
-
yield triggers.externalTrigger(automation, Object.assign(Object.assign({}, ctx.request.body), { appId: ctx.appId }));
|
|
272
|
-
ctx.body = {
|
|
273
|
-
message: `Automation ${automation._id} has been triggered.`,
|
|
274
|
-
automation,
|
|
275
|
-
};
|
|
276
|
-
});
|
|
277
|
-
}
|
|
278
|
-
exports.trigger = trigger;
|
|
279
|
-
function prepareTestInput(input) {
|
|
280
|
-
// prepare the test parameters
|
|
281
|
-
if (input.id && input.row) {
|
|
282
|
-
input.row._id = input.id;
|
|
283
|
-
}
|
|
284
|
-
if (input.revision && input.row) {
|
|
285
|
-
input.row._rev = input.revision;
|
|
286
|
-
}
|
|
287
|
-
return input;
|
|
288
|
-
}
|
|
289
|
-
function test(ctx) {
|
|
290
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
291
|
-
const db = backend_core_1.context.getAppDB();
|
|
292
|
-
let automation = yield db.get(ctx.params.id);
|
|
293
|
-
yield (0, redis_1.setTestFlag)(automation._id);
|
|
294
|
-
const testInput = prepareTestInput(ctx.request.body);
|
|
295
|
-
const response = yield triggers.externalTrigger(automation, Object.assign(Object.assign({}, testInput), { appId: ctx.appId }), { getResponses: true });
|
|
296
|
-
// save a test history run
|
|
297
|
-
yield (0, utils_2.updateTestHistory)(ctx.appId, automation, Object.assign(Object.assign({}, ctx.request.body), { occurredAt: new Date().getTime() }));
|
|
298
|
-
yield (0, redis_1.clearTestFlag)(automation._id);
|
|
299
|
-
ctx.body = response;
|
|
300
|
-
yield backend_core_1.events.automation.tested(automation);
|
|
301
|
-
});
|
|
302
|
-
}
|
|
303
|
-
exports.test = test;
|
|
@@ -1,37 +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.exportAppDump = void 0;
|
|
16
|
-
const sdk_1 = __importDefault(require("../../sdk"));
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
const utils_1 = require("../../db/utils");
|
|
19
|
-
const utilities_1 = require("../../utilities");
|
|
20
|
-
function exportAppDump(ctx) {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
let { appId, excludeRows } = ctx.query;
|
|
23
|
-
// remove the 120 second limit for the request
|
|
24
|
-
ctx.req.setTimeout(0);
|
|
25
|
-
const appName = decodeURI(ctx.query.appname);
|
|
26
|
-
excludeRows = (0, utilities_1.isQsTrue)(excludeRows);
|
|
27
|
-
const backupIdentifier = `${appName}-export-${new Date().getTime()}.tar.gz`;
|
|
28
|
-
ctx.attachment(backupIdentifier);
|
|
29
|
-
ctx.body = yield sdk_1.default.backups.streamExportApp(appId, excludeRows);
|
|
30
|
-
yield backend_core_1.context.doInAppContext(appId, () => __awaiter(this, void 0, void 0, function* () {
|
|
31
|
-
const appDb = backend_core_1.context.getAppDB();
|
|
32
|
-
const app = yield appDb.get(utils_1.DocumentType.APP_METADATA);
|
|
33
|
-
yield backend_core_1.events.app.exported(app);
|
|
34
|
-
}));
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
exports.exportAppDump = exportAppDump;
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.fetchAppComponentDefinitions = void 0;
|
|
13
|
-
const utils_1 = require("../../db/utils");
|
|
14
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
15
|
-
const fileSystem_1 = require("../../utilities/fileSystem");
|
|
16
|
-
function fetchAppComponentDefinitions(ctx) {
|
|
17
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
18
|
-
try {
|
|
19
|
-
const db = backend_core_1.context.getAppDB();
|
|
20
|
-
const app = yield db.get(utils_1.DocumentType.APP_METADATA);
|
|
21
|
-
let componentManifests = yield Promise.all(app.componentLibraries.map((library) => __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
let manifest = yield (0, fileSystem_1.getComponentLibraryManifest)(library);
|
|
23
|
-
return {
|
|
24
|
-
manifest,
|
|
25
|
-
library,
|
|
26
|
-
};
|
|
27
|
-
})));
|
|
28
|
-
const definitions = {};
|
|
29
|
-
for (let { manifest, library } of componentManifests) {
|
|
30
|
-
for (let key of Object.keys(manifest)) {
|
|
31
|
-
if (key === "features") {
|
|
32
|
-
definitions[key] = manifest[key];
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
const fullComponentName = `${library}/${key}`.toLowerCase();
|
|
36
|
-
definitions[fullComponentName] = Object.assign({ component: fullComponentName }, manifest[key]);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
// Add custom components
|
|
41
|
-
const globalDB = backend_core_1.tenancy.getGlobalDB();
|
|
42
|
-
const response = yield globalDB.allDocs(backend_core_1.db.getPluginParams(null, {
|
|
43
|
-
include_docs: true,
|
|
44
|
-
}));
|
|
45
|
-
response.rows
|
|
46
|
-
.map((row) => row.doc)
|
|
47
|
-
.filter((plugin) => plugin.schema.type === "component")
|
|
48
|
-
.forEach((plugin) => {
|
|
49
|
-
const fullComponentName = `plugin/${plugin.name}`;
|
|
50
|
-
definitions[fullComponentName] = Object.assign({ component: fullComponentName }, plugin.schema.schema);
|
|
51
|
-
});
|
|
52
|
-
ctx.body = definitions;
|
|
53
|
-
}
|
|
54
|
-
catch (err) {
|
|
55
|
-
console.error(`component-definitions=failed`, err);
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
exports.fetchAppComponentDefinitions = fetchAppComponentDefinitions;
|