@budibase/server 2.6.19-alpha.3 → 2.6.19-alpha.30
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 +32392 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +44698 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24363 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +3 -0
- package/nodemon.json +1 -1
- package/package.json +31 -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/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 +2 -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 +39 -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,146 +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.getBudibaseVersion = exports.revert = exports.clearLock = exports.buildRedirectDelete = exports.buildRedirectPost = exports.buildRedirectGet = void 0;
|
|
16
|
-
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
17
|
-
const environment_1 = __importDefault(require("../../environment"));
|
|
18
|
-
const utilities_1 = require("../../utilities");
|
|
19
|
-
const workerRequests_1 = require("../../utilities/workerRequests");
|
|
20
|
-
const redis_1 = require("../../utilities/redis");
|
|
21
|
-
const utils_1 = require("../../db/utils");
|
|
22
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
23
|
-
const backend_core_2 = require("@budibase/backend-core");
|
|
24
|
-
function redirect(ctx, method, path = "global") {
|
|
25
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
26
|
-
const { devPath } = ctx.params;
|
|
27
|
-
const queryString = ctx.originalUrl.split("?")[1] || "";
|
|
28
|
-
const response = yield (0, node_fetch_1.default)((0, utilities_1.checkSlashesInUrl)(`${environment_1.default.WORKER_URL}/api/${path}/${devPath}?${queryString}`), (0, workerRequests_1.request)(ctx, {
|
|
29
|
-
method,
|
|
30
|
-
body: ctx.request.body,
|
|
31
|
-
}));
|
|
32
|
-
if (response.status !== 200) {
|
|
33
|
-
const err = yield response.text();
|
|
34
|
-
ctx.throw(400, err);
|
|
35
|
-
}
|
|
36
|
-
const cookie = response.headers.get("set-cookie");
|
|
37
|
-
if (cookie) {
|
|
38
|
-
ctx.set("set-cookie", cookie);
|
|
39
|
-
}
|
|
40
|
-
let body;
|
|
41
|
-
try {
|
|
42
|
-
body = yield response.json();
|
|
43
|
-
}
|
|
44
|
-
catch (err) {
|
|
45
|
-
// don't worry about errors, likely no JSON
|
|
46
|
-
}
|
|
47
|
-
ctx.status = response.status;
|
|
48
|
-
if (body) {
|
|
49
|
-
ctx.body = body;
|
|
50
|
-
}
|
|
51
|
-
ctx.cookies;
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
function buildRedirectGet(path) {
|
|
55
|
-
return (ctx) => __awaiter(this, void 0, void 0, function* () {
|
|
56
|
-
yield redirect(ctx, "GET", path);
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
exports.buildRedirectGet = buildRedirectGet;
|
|
60
|
-
function buildRedirectPost(path) {
|
|
61
|
-
return (ctx) => __awaiter(this, void 0, void 0, function* () {
|
|
62
|
-
yield redirect(ctx, "POST", path);
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
exports.buildRedirectPost = buildRedirectPost;
|
|
66
|
-
function buildRedirectDelete(path) {
|
|
67
|
-
return (ctx) => __awaiter(this, void 0, void 0, function* () {
|
|
68
|
-
yield redirect(ctx, "DELETE", path);
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
exports.buildRedirectDelete = buildRedirectDelete;
|
|
72
|
-
function clearLock(ctx) {
|
|
73
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
74
|
-
const { appId } = ctx.params;
|
|
75
|
-
try {
|
|
76
|
-
yield (0, redis_1.clearLock)(appId, ctx.user);
|
|
77
|
-
}
|
|
78
|
-
catch (err) {
|
|
79
|
-
ctx.throw(400, `Unable to remove lock. ${err}`);
|
|
80
|
-
}
|
|
81
|
-
ctx.body = {
|
|
82
|
-
message: "Lock released successfully.",
|
|
83
|
-
};
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
exports.clearLock = clearLock;
|
|
87
|
-
function revert(ctx) {
|
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
const { appId } = ctx.params;
|
|
90
|
-
const productionAppId = backend_core_2.db.getProdAppID(appId);
|
|
91
|
-
// App must have been deployed first
|
|
92
|
-
try {
|
|
93
|
-
const db = backend_core_1.context.getProdAppDB({ skip_setup: true });
|
|
94
|
-
const exists = yield db.exists();
|
|
95
|
-
if (!exists) {
|
|
96
|
-
throw new Error("App must be deployed to be reverted.");
|
|
97
|
-
}
|
|
98
|
-
const deploymentDoc = yield db.get(utils_1.DocumentType.DEPLOYMENTS);
|
|
99
|
-
if (!deploymentDoc.history ||
|
|
100
|
-
Object.keys(deploymentDoc.history).length === 0) {
|
|
101
|
-
throw new Error("No deployments for app");
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
catch (err) {
|
|
105
|
-
return ctx.throw(400, "App has not yet been deployed");
|
|
106
|
-
}
|
|
107
|
-
const replication = new backend_core_2.db.Replication({
|
|
108
|
-
source: productionAppId,
|
|
109
|
-
target: appId,
|
|
110
|
-
});
|
|
111
|
-
try {
|
|
112
|
-
if (environment_1.default.COUCH_DB_URL) {
|
|
113
|
-
// in-memory db stalls on rollback
|
|
114
|
-
yield replication.rollback();
|
|
115
|
-
}
|
|
116
|
-
// update appID in reverted app to be dev version again
|
|
117
|
-
const db = backend_core_1.context.getAppDB();
|
|
118
|
-
const appDoc = yield db.get(utils_1.DocumentType.APP_METADATA);
|
|
119
|
-
appDoc.appId = appId;
|
|
120
|
-
appDoc.instance._id = appId;
|
|
121
|
-
yield db.put(appDoc);
|
|
122
|
-
yield backend_core_2.cache.app.invalidateAppMetadata(appId);
|
|
123
|
-
ctx.body = {
|
|
124
|
-
message: "Reverted changes successfully.",
|
|
125
|
-
};
|
|
126
|
-
yield backend_core_2.events.app.reverted(appDoc);
|
|
127
|
-
}
|
|
128
|
-
catch (err) {
|
|
129
|
-
ctx.throw(400, `Unable to revert. ${err}`);
|
|
130
|
-
}
|
|
131
|
-
finally {
|
|
132
|
-
yield replication.close();
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
exports.revert = revert;
|
|
137
|
-
function getBudibaseVersion(ctx) {
|
|
138
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
139
|
-
const version = backend_core_1.env.VERSION;
|
|
140
|
-
ctx.body = {
|
|
141
|
-
version,
|
|
142
|
-
};
|
|
143
|
-
yield backend_core_2.events.installation.versionChecked(version);
|
|
144
|
-
});
|
|
145
|
-
}
|
|
146
|
-
exports.getBudibaseVersion = getBudibaseVersion;
|
|
@@ -1,28 +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.find = exports.fetch = void 0;
|
|
13
|
-
const integrations_1 = require("../../integrations");
|
|
14
|
-
function fetch(ctx) {
|
|
15
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
16
|
-
ctx.status = 200;
|
|
17
|
-
ctx.body = yield (0, integrations_1.getDefinitions)();
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
exports.fetch = fetch;
|
|
21
|
-
function find(ctx) {
|
|
22
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const def = yield (0, integrations_1.getDefinition)(ctx.params.type);
|
|
24
|
-
ctx.body = def;
|
|
25
|
-
ctx.status = 200;
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
exports.find = find;
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.destroy = exports.save = void 0;
|
|
13
|
-
const layouts_1 = require("../../constants/layouts");
|
|
14
|
-
const utils_1 = require("../../db/utils");
|
|
15
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
16
|
-
function save(ctx) {
|
|
17
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
18
|
-
const db = backend_core_1.context.getAppDB();
|
|
19
|
-
let layout = ctx.request.body;
|
|
20
|
-
if (!layout.props) {
|
|
21
|
-
layout = Object.assign(Object.assign({}, layouts_1.EMPTY_LAYOUT), layout);
|
|
22
|
-
layout.props._instanceName = layout.name;
|
|
23
|
-
}
|
|
24
|
-
layout._id = layout._id || (0, utils_1.generateLayoutID)();
|
|
25
|
-
const response = yield db.put(layout);
|
|
26
|
-
yield backend_core_1.events.layout.created(layout);
|
|
27
|
-
layout._rev = response.rev;
|
|
28
|
-
ctx.body = layout;
|
|
29
|
-
ctx.status = 200;
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
exports.save = save;
|
|
33
|
-
function destroy(ctx) {
|
|
34
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
35
|
-
const db = backend_core_1.context.getAppDB();
|
|
36
|
-
const layoutId = ctx.params.layoutId, layoutRev = ctx.params.layoutRev;
|
|
37
|
-
const layoutsUsedByScreens = (yield db.allDocs((0, utils_1.getScreenParams)(null, {
|
|
38
|
-
include_docs: true,
|
|
39
|
-
}))).rows.map(element => element.doc.layoutId);
|
|
40
|
-
if (layoutsUsedByScreens.includes(layoutId)) {
|
|
41
|
-
ctx.throw(400, "Cannot delete a layout that's being used by a screen");
|
|
42
|
-
}
|
|
43
|
-
yield db.remove(layoutId, layoutRev);
|
|
44
|
-
yield backend_core_1.events.layout.deleted(layoutId);
|
|
45
|
-
ctx.body = { message: "Layout deleted successfully" };
|
|
46
|
-
ctx.status = 200;
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
exports.destroy = destroy;
|
|
@@ -1,63 +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.getMetadata = exports.deleteMetadata = exports.saveMetadata = exports.getTypes = void 0;
|
|
13
|
-
const constants_1 = require("../../constants");
|
|
14
|
-
const utils_1 = require("../../db/utils");
|
|
15
|
-
const utilities_1 = require("../../utilities");
|
|
16
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
17
|
-
function getTypes(ctx) {
|
|
18
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
19
|
-
ctx.body = {
|
|
20
|
-
types: constants_1.MetadataTypes,
|
|
21
|
-
};
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
exports.getTypes = getTypes;
|
|
25
|
-
function saveMetadata(ctx) {
|
|
26
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
27
|
-
const { type, entityId } = ctx.params;
|
|
28
|
-
if (type === constants_1.MetadataTypes.AUTOMATION_TEST_HISTORY) {
|
|
29
|
-
ctx.throw(400, "Cannot save automation history type");
|
|
30
|
-
}
|
|
31
|
-
ctx.body = yield (0, utilities_1.saveEntityMetadata)(type, entityId, ctx.request.body);
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
exports.saveMetadata = saveMetadata;
|
|
35
|
-
function deleteMetadata(ctx) {
|
|
36
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
37
|
-
const { type, entityId } = ctx.params;
|
|
38
|
-
yield (0, utilities_1.deleteEntityMetadata)(type, entityId);
|
|
39
|
-
ctx.body = {
|
|
40
|
-
message: "Metadata deleted successfully",
|
|
41
|
-
};
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
exports.deleteMetadata = deleteMetadata;
|
|
45
|
-
function getMetadata(ctx) {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const { type, entityId } = ctx.params;
|
|
48
|
-
const db = backend_core_1.context.getAppDB();
|
|
49
|
-
const id = (0, utils_1.generateMetadataID)(type, entityId);
|
|
50
|
-
try {
|
|
51
|
-
ctx.body = yield db.get(id);
|
|
52
|
-
}
|
|
53
|
-
catch (err) {
|
|
54
|
-
if (err.status === 404) {
|
|
55
|
-
ctx.body = {};
|
|
56
|
-
}
|
|
57
|
-
else {
|
|
58
|
-
ctx.throw(err.status, err);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
exports.getMetadata = getMetadata;
|
|
@@ -1,29 +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.fetchDefinitions = exports.migrate = void 0;
|
|
13
|
-
const migrations_1 = require("../../migrations");
|
|
14
|
-
function migrate(ctx) {
|
|
15
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
16
|
-
const options = ctx.request.body;
|
|
17
|
-
// don't await as can take a while, just return
|
|
18
|
-
(0, migrations_1.migrate)(options);
|
|
19
|
-
ctx.status = 200;
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
exports.migrate = migrate;
|
|
23
|
-
function fetchDefinitions(ctx) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
ctx.body = migrations_1.MIGRATIONS;
|
|
26
|
-
ctx.status = 200;
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
exports.fetchDefinitions = fetchDefinitions;
|
|
@@ -1,40 +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.error = exports.alert = exports.log = void 0;
|
|
13
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
14
|
-
function log(ctx) {
|
|
15
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
16
|
-
const body = ctx.request.body;
|
|
17
|
-
console.trace(body.message, body.data);
|
|
18
|
-
console.debug(body.message, body.data);
|
|
19
|
-
console.info(body.message, body.data);
|
|
20
|
-
console.warn(body.message, body.data);
|
|
21
|
-
console.error(body.message, body.data);
|
|
22
|
-
ctx.status = 204;
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
exports.log = log;
|
|
26
|
-
function alert(ctx) {
|
|
27
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
-
const body = ctx.request.body;
|
|
29
|
-
backend_core_1.logging.logAlert(body.message, new Error(body.message));
|
|
30
|
-
ctx.status = 204;
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
exports.alert = alert;
|
|
34
|
-
function error(ctx) {
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
const body = ctx.request.body;
|
|
37
|
-
throw new Error(body.message);
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
exports.error = error;
|
|
@@ -1,162 +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.removePermission = exports.addPermission = exports.getResourcePerms = exports.fetch = exports.fetchLevels = exports.fetchBuiltin = void 0;
|
|
13
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
14
|
-
const utils_1 = require("../../db/utils");
|
|
15
|
-
const security_1 = require("../../utilities/security");
|
|
16
|
-
const utilities_1 = require("../../utilities");
|
|
17
|
-
const PermissionUpdateType = {
|
|
18
|
-
REMOVE: "remove",
|
|
19
|
-
ADD: "add",
|
|
20
|
-
};
|
|
21
|
-
const SUPPORTED_LEVELS = security_1.CURRENTLY_SUPPORTED_LEVELS;
|
|
22
|
-
// utility function to stop this repetition - permissions always stored under roles
|
|
23
|
-
function getAllDBRoles(db) {
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
const body = yield db.allDocs((0, utils_1.getRoleParams)(null, {
|
|
26
|
-
include_docs: true,
|
|
27
|
-
}));
|
|
28
|
-
return body.rows.map(row => row.doc);
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
function updatePermissionOnRole(appId, { roleId, resourceId, level, }, updateType) {
|
|
32
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
const db = backend_core_1.context.getAppDB();
|
|
34
|
-
const remove = updateType === PermissionUpdateType.REMOVE;
|
|
35
|
-
const isABuiltin = backend_core_1.roles.isBuiltin(roleId);
|
|
36
|
-
const dbRoleId = backend_core_1.roles.getDBRoleID(roleId);
|
|
37
|
-
const dbRoles = yield getAllDBRoles(db);
|
|
38
|
-
const docUpdates = [];
|
|
39
|
-
// the permission is for a built in, make sure it exists
|
|
40
|
-
if (isABuiltin && !dbRoles.some(role => role._id === dbRoleId)) {
|
|
41
|
-
const builtin = backend_core_1.roles.getBuiltinRoles()[roleId];
|
|
42
|
-
builtin._id = backend_core_1.roles.getDBRoleID(builtin._id);
|
|
43
|
-
dbRoles.push(builtin);
|
|
44
|
-
}
|
|
45
|
-
// now try to find any roles which need updated, e.g. removing the
|
|
46
|
-
// resource from another role and then adding to the new role
|
|
47
|
-
for (let role of dbRoles) {
|
|
48
|
-
let updated = false;
|
|
49
|
-
const rolePermissions = role.permissions ? role.permissions : {};
|
|
50
|
-
// make sure its an array, also handle migrating
|
|
51
|
-
if (!rolePermissions[resourceId] ||
|
|
52
|
-
!Array.isArray(rolePermissions[resourceId])) {
|
|
53
|
-
rolePermissions[resourceId] =
|
|
54
|
-
typeof rolePermissions[resourceId] === "string"
|
|
55
|
-
? [rolePermissions[resourceId]]
|
|
56
|
-
: [];
|
|
57
|
-
}
|
|
58
|
-
// handle the removal/updating the role which has this permission first
|
|
59
|
-
// the updating (role._id !== dbRoleId) is required because a resource/level can
|
|
60
|
-
// only be permitted in a single role (this reduces hierarchy confusion and simplifies
|
|
61
|
-
// the general UI for this, rather than needing to show everywhere it is used)
|
|
62
|
-
if ((role._id !== dbRoleId || remove) &&
|
|
63
|
-
rolePermissions[resourceId].indexOf(level) !== -1) {
|
|
64
|
-
(0, utilities_1.removeFromArray)(rolePermissions[resourceId], level);
|
|
65
|
-
updated = true;
|
|
66
|
-
}
|
|
67
|
-
// handle the adding, we're on the correct role, at it to this
|
|
68
|
-
if (!remove && role._id === dbRoleId) {
|
|
69
|
-
const set = new Set(rolePermissions[resourceId]);
|
|
70
|
-
rolePermissions[resourceId] = [...set.add(level)];
|
|
71
|
-
updated = true;
|
|
72
|
-
}
|
|
73
|
-
// handle the update, add it to bulk docs to perform at end
|
|
74
|
-
if (updated) {
|
|
75
|
-
role.permissions = rolePermissions;
|
|
76
|
-
docUpdates.push(role);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
const response = yield db.bulkDocs(docUpdates);
|
|
80
|
-
return response.map((resp) => {
|
|
81
|
-
resp._id = backend_core_1.roles.getExternalRoleID(resp.id);
|
|
82
|
-
delete resp.id;
|
|
83
|
-
return resp;
|
|
84
|
-
});
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
function fetchBuiltin(ctx) {
|
|
88
|
-
ctx.body = Object.values(backend_core_1.permissions.getBuiltinPermissions());
|
|
89
|
-
}
|
|
90
|
-
exports.fetchBuiltin = fetchBuiltin;
|
|
91
|
-
function fetchLevels(ctx) {
|
|
92
|
-
// for now only provide the read/write perms externally
|
|
93
|
-
ctx.body = SUPPORTED_LEVELS;
|
|
94
|
-
}
|
|
95
|
-
exports.fetchLevels = fetchLevels;
|
|
96
|
-
function fetch(ctx) {
|
|
97
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
-
const db = backend_core_1.context.getAppDB();
|
|
99
|
-
const dbRoles = yield getAllDBRoles(db);
|
|
100
|
-
let permissions = {};
|
|
101
|
-
// create an object with structure role ID -> resource ID -> level
|
|
102
|
-
for (let role of dbRoles) {
|
|
103
|
-
if (!role.permissions) {
|
|
104
|
-
continue;
|
|
105
|
-
}
|
|
106
|
-
const roleId = backend_core_1.roles.getExternalRoleID(role._id);
|
|
107
|
-
if (!roleId) {
|
|
108
|
-
ctx.throw(400, "Unable to retrieve role");
|
|
109
|
-
}
|
|
110
|
-
for (let [resource, levelArr] of Object.entries(role.permissions)) {
|
|
111
|
-
const levels = Array.isArray(levelArr) ? levelArr : [levelArr];
|
|
112
|
-
const perms = {};
|
|
113
|
-
levels.forEach(level => (perms[level] = roleId));
|
|
114
|
-
permissions[resource] = perms;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
// apply the base permissions
|
|
118
|
-
const finalPermissions = {};
|
|
119
|
-
for (let [resource, permission] of Object.entries(permissions)) {
|
|
120
|
-
const basePerms = (0, security_1.getBasePermissions)(resource);
|
|
121
|
-
finalPermissions[resource] = Object.assign(basePerms, permission);
|
|
122
|
-
}
|
|
123
|
-
ctx.body = finalPermissions;
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
exports.fetch = fetch;
|
|
127
|
-
function getResourcePerms(ctx) {
|
|
128
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
129
|
-
const resourceId = ctx.params.resourceId;
|
|
130
|
-
const db = backend_core_1.context.getAppDB();
|
|
131
|
-
const body = yield db.allDocs((0, utils_1.getRoleParams)(null, {
|
|
132
|
-
include_docs: true,
|
|
133
|
-
}));
|
|
134
|
-
const rolesList = body.rows.map(row => row.doc);
|
|
135
|
-
let permissions = {};
|
|
136
|
-
for (let level of SUPPORTED_LEVELS) {
|
|
137
|
-
// update the various roleIds in the resource permissions
|
|
138
|
-
for (let role of rolesList) {
|
|
139
|
-
const rolePerms = backend_core_1.roles.checkForRoleResourceArray(role.permissions, resourceId);
|
|
140
|
-
if (rolePerms &&
|
|
141
|
-
rolePerms[resourceId] &&
|
|
142
|
-
rolePerms[resourceId].indexOf(level) !== -1) {
|
|
143
|
-
permissions[level] = backend_core_1.roles.getExternalRoleID(role._id);
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
ctx.body = Object.assign((0, security_1.getBasePermissions)(resourceId), permissions);
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
exports.getResourcePerms = getResourcePerms;
|
|
151
|
-
function addPermission(ctx) {
|
|
152
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
-
ctx.body = yield updatePermissionOnRole(ctx.appId, ctx.params, PermissionUpdateType.ADD);
|
|
154
|
-
});
|
|
155
|
-
}
|
|
156
|
-
exports.addPermission = addPermission;
|
|
157
|
-
function removePermission(ctx) {
|
|
158
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
159
|
-
ctx.body = yield updatePermissionOnRole(ctx.appId, ctx.params, PermissionUpdateType.REMOVE);
|
|
160
|
-
});
|
|
161
|
-
}
|
|
162
|
-
exports.removePermission = removePermission;
|
|
@@ -1,24 +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.fileUpload = void 0;
|
|
13
|
-
const fileSystem_1 = require("../../../utilities/fileSystem");
|
|
14
|
-
function fileUpload(file) {
|
|
15
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
16
|
-
if (!file.name.endsWith(".tar.gz")) {
|
|
17
|
-
throw new Error("Plugin must be compressed into a gzipped tarball.");
|
|
18
|
-
}
|
|
19
|
-
const path = (0, fileSystem_1.createTempFolder)(file.name.split(".tar.gz")[0]);
|
|
20
|
-
yield (0, fileSystem_1.extractTarball)(file.path, path);
|
|
21
|
-
return yield (0, fileSystem_1.getPluginMetadata)(path);
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
exports.fileUpload = fileUpload;
|
|
@@ -1,69 +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.githubUpload = exports.request = void 0;
|
|
16
|
-
const fileSystem_1 = require("../../../utilities/fileSystem");
|
|
17
|
-
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
18
|
-
const utils_1 = require("./utils");
|
|
19
|
-
function request(url, headers, err) {
|
|
20
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
const response = yield (0, node_fetch_1.default)(url, { headers });
|
|
22
|
-
if (response.status >= 300) {
|
|
23
|
-
const respErr = yield response.text();
|
|
24
|
-
throw new Error(`Error: ${err} - ${respErr}`);
|
|
25
|
-
}
|
|
26
|
-
return response.json();
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
exports.request = request;
|
|
30
|
-
function githubUpload(url, name = "", token = "") {
|
|
31
|
-
var _a;
|
|
32
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
let githubUrl = url;
|
|
34
|
-
if (!githubUrl.includes("https://github.com/")) {
|
|
35
|
-
throw new Error("The plugin origin must be from Github");
|
|
36
|
-
}
|
|
37
|
-
if (url.includes(".git")) {
|
|
38
|
-
githubUrl = url.replace(".git", "");
|
|
39
|
-
}
|
|
40
|
-
const githubApiUrl = githubUrl.replace("https://github.com/", "https://api.github.com/repos/");
|
|
41
|
-
const headers = token ? { Authorization: `Bearer ${token}` } : {};
|
|
42
|
-
const pluginDetails = yield request(githubApiUrl, headers, "Repository not found");
|
|
43
|
-
const pluginName = pluginDetails.name || name;
|
|
44
|
-
const pluginLatestReleaseUrl = (pluginDetails === null || pluginDetails === void 0 ? void 0 : pluginDetails["releases_url"])
|
|
45
|
-
? pluginDetails === null || pluginDetails === void 0 ? void 0 : pluginDetails["releases_url"].replace("{/id}", "/latest")
|
|
46
|
-
: undefined;
|
|
47
|
-
if (!pluginLatestReleaseUrl) {
|
|
48
|
-
throw new Error("Github release not found");
|
|
49
|
-
}
|
|
50
|
-
const pluginReleaseDetails = yield request(pluginLatestReleaseUrl, headers, "Github latest release not found");
|
|
51
|
-
const pluginReleaseTarballAsset = (_a = pluginReleaseDetails === null || pluginReleaseDetails === void 0 ? void 0 : pluginReleaseDetails.assets) === null || _a === void 0 ? void 0 : _a.find((x) => (x === null || x === void 0 ? void 0 : x["content_type"]) === "application/gzip");
|
|
52
|
-
const pluginLastReleaseTarballUrl = pluginReleaseTarballAsset === null || pluginReleaseTarballAsset === void 0 ? void 0 : pluginReleaseTarballAsset["browser_download_url"];
|
|
53
|
-
if (!pluginLastReleaseTarballUrl) {
|
|
54
|
-
throw new Error("Github latest release url not found");
|
|
55
|
-
}
|
|
56
|
-
try {
|
|
57
|
-
const path = yield (0, utils_1.downloadUnzipTarball)(pluginLastReleaseTarballUrl, pluginName, headers);
|
|
58
|
-
return yield (0, fileSystem_1.getPluginMetadata)(path);
|
|
59
|
-
}
|
|
60
|
-
catch (err) {
|
|
61
|
-
let errMsg = (err === null || err === void 0 ? void 0 : err.message) || err;
|
|
62
|
-
if (errMsg === "unexpected response Not Found") {
|
|
63
|
-
errMsg = "Github release tarball not found";
|
|
64
|
-
}
|
|
65
|
-
throw new Error(errMsg);
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
exports.githubUpload = githubUpload;
|