@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,88 +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.getUniqueRows = void 0;
|
|
13
|
-
const utils_1 = require("../../db/utils");
|
|
14
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
15
|
-
const ROW_EXCLUSIONS = [utils_1.USER_METDATA_PREFIX];
|
|
16
|
-
function getAppPairs(appIds) {
|
|
17
|
-
// collect the app ids into dev / prod pairs
|
|
18
|
-
// keyed by the dev app id
|
|
19
|
-
const pairs = {};
|
|
20
|
-
for (let appId of appIds) {
|
|
21
|
-
const devId = backend_core_1.db.getDevelopmentAppID(appId);
|
|
22
|
-
if (!pairs[devId]) {
|
|
23
|
-
pairs[devId] = {};
|
|
24
|
-
}
|
|
25
|
-
if (backend_core_1.db.isDevAppID(appId)) {
|
|
26
|
-
pairs[devId].devId = appId;
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
pairs[devId].prodId = appId;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
return pairs;
|
|
33
|
-
}
|
|
34
|
-
function getAppRows(appId) {
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
// need to specify the app ID, as this is used for different apps in one call
|
|
37
|
-
return backend_core_1.db.doWithDB(appId, (db) => __awaiter(this, void 0, void 0, function* () {
|
|
38
|
-
const response = yield db.allDocs((0, utils_1.getRowParams)(null, null, {
|
|
39
|
-
include_docs: false,
|
|
40
|
-
}));
|
|
41
|
-
return response.rows
|
|
42
|
-
.map(r => r.id)
|
|
43
|
-
.filter(id => {
|
|
44
|
-
for (let exclusion of ROW_EXCLUSIONS) {
|
|
45
|
-
if (id.startsWith(exclusion)) {
|
|
46
|
-
return false;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return true;
|
|
50
|
-
});
|
|
51
|
-
}));
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Return a set of all rows in the given app ids.
|
|
56
|
-
* The returned rows will be unique on a per dev/prod app basis.
|
|
57
|
-
* Rows duplicates may exist across apps due to data import so they are not filtered out.
|
|
58
|
-
*/
|
|
59
|
-
function getUniqueRows(appIds) {
|
|
60
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
61
|
-
let uniqueRows = [], rowsByApp = {};
|
|
62
|
-
const pairs = getAppPairs(appIds);
|
|
63
|
-
for (let pair of Object.values(pairs)) {
|
|
64
|
-
let appRows = [];
|
|
65
|
-
for (let appId of [pair.devId, pair.prodId]) {
|
|
66
|
-
if (!appId) {
|
|
67
|
-
continue;
|
|
68
|
-
}
|
|
69
|
-
try {
|
|
70
|
-
appRows = appRows.concat(yield getAppRows(appId));
|
|
71
|
-
}
|
|
72
|
-
catch (e) {
|
|
73
|
-
console.error(e);
|
|
74
|
-
// don't error out if we can't count the app rows, just continue
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
// ensure uniqueness on a per app pair basis
|
|
78
|
-
// this can't be done on all rows because app import results in
|
|
79
|
-
// duplicate row ids across apps
|
|
80
|
-
// the array pre-concat is important to avoid stack overflow
|
|
81
|
-
const prodId = backend_core_1.db.getProdAppID((pair.devId || pair.prodId));
|
|
82
|
-
rowsByApp[prodId] = [...new Set(appRows)];
|
|
83
|
-
uniqueRows = uniqueRows.concat(rowsByApp[prodId]);
|
|
84
|
-
}
|
|
85
|
-
return { rows: uniqueRows, appRows: rowsByApp };
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
exports.getUniqueRows = getUniqueRows;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// UNUSED CODE
|
|
3
|
-
// Preserved for future use
|
|
4
|
-
/* eslint-disable no-unused-vars */
|
|
5
|
-
function getNewQuotaReset() {
|
|
6
|
-
return Date.now() + 2592000000;
|
|
7
|
-
}
|
|
8
|
-
function resetQuotasIfRequired(quota) {
|
|
9
|
-
// Check if the quota needs reset
|
|
10
|
-
if (Date.now() >= quota.quotaReset) {
|
|
11
|
-
quota.quotaReset = getNewQuotaReset();
|
|
12
|
-
for (let prop of Object.keys(quota.usageQuota)) {
|
|
13
|
-
quota.usageQuota[prop] = 0;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
}
|
package/dist/utilities/users.js
DELETED
|
@@ -1,57 +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.publicApiUserFix = exports.getFullUser = void 0;
|
|
13
|
-
const utils_1 = require("../db/utils");
|
|
14
|
-
const global_1 = require("./global");
|
|
15
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
16
|
-
function getFullUser(ctx, userId) {
|
|
17
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
18
|
-
const global = yield (0, global_1.getGlobalUser)(userId);
|
|
19
|
-
let metadata = {};
|
|
20
|
-
// always prefer the user metadata _id and _rev
|
|
21
|
-
delete global._id;
|
|
22
|
-
delete global._rev;
|
|
23
|
-
try {
|
|
24
|
-
// this will throw an error if the db doesn't exist, or there is no appId
|
|
25
|
-
const db = backend_core_1.context.getAppDB();
|
|
26
|
-
metadata = yield db.get(userId);
|
|
27
|
-
}
|
|
28
|
-
catch (err) {
|
|
29
|
-
// it is fine if there is no user metadata yet
|
|
30
|
-
}
|
|
31
|
-
delete metadata.csrfToken;
|
|
32
|
-
return Object.assign(Object.assign(Object.assign({}, metadata), global), { roleId: global.roleId || backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC, tableId: utils_1.InternalTables.USER_METADATA,
|
|
33
|
-
// make sure the ID is always a local ID, not a global one
|
|
34
|
-
_id: userId });
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
exports.getFullUser = getFullUser;
|
|
38
|
-
function publicApiUserFix(ctx) {
|
|
39
|
-
if (!ctx.request.body) {
|
|
40
|
-
return ctx;
|
|
41
|
-
}
|
|
42
|
-
if (!ctx.request.body._id && ctx.params.userId) {
|
|
43
|
-
ctx.request.body._id = ctx.params.userId;
|
|
44
|
-
}
|
|
45
|
-
if (!ctx.request.body.roles) {
|
|
46
|
-
ctx.request.body.roles = {};
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
const newRoles = {};
|
|
50
|
-
for (let [appId, role] of Object.entries(ctx.request.body.roles)) {
|
|
51
|
-
newRoles[backend_core_1.db.getProdAppID(appId)] = role;
|
|
52
|
-
}
|
|
53
|
-
ctx.request.body.roles = newRoles;
|
|
54
|
-
}
|
|
55
|
-
return ctx;
|
|
56
|
-
}
|
|
57
|
-
exports.publicApiUserFix = publicApiUserFix;
|
|
@@ -1,171 +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.generateApiKey = exports.getChecklist = exports.createAdminUser = exports.readGlobalUser = exports.deleteGlobalUser = exports.saveGlobalUser = exports.allGlobalUsers = exports.removeAppFromUserRoles = exports.getGlobalSelf = exports.sendSmtpEmail = exports.request = void 0;
|
|
16
|
-
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
17
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
18
|
-
const index_1 = require("./index");
|
|
19
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
20
|
-
const global_1 = require("./global");
|
|
21
|
-
function request(ctx, request) {
|
|
22
|
-
if (!request.headers) {
|
|
23
|
-
request.headers = {};
|
|
24
|
-
}
|
|
25
|
-
if (!ctx) {
|
|
26
|
-
request.headers[backend_core_1.constants.Header.API_KEY] = backend_core_1.env.INTERNAL_API_KEY;
|
|
27
|
-
if (backend_core_1.tenancy.isTenantIdSet()) {
|
|
28
|
-
request.headers[backend_core_1.constants.Header.TENANT_ID] = backend_core_1.tenancy.getTenantId();
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
if (request.body && Object.keys(request.body).length > 0) {
|
|
32
|
-
request.headers["Content-Type"] = "application/json";
|
|
33
|
-
request.body =
|
|
34
|
-
typeof request.body === "object"
|
|
35
|
-
? JSON.stringify(request.body)
|
|
36
|
-
: request.body;
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
delete request.body;
|
|
40
|
-
}
|
|
41
|
-
if (ctx && ctx.headers) {
|
|
42
|
-
request.headers = ctx.headers;
|
|
43
|
-
}
|
|
44
|
-
// add x-budibase-correlation-id header
|
|
45
|
-
backend_core_1.logging.correlation.setHeader(request.headers);
|
|
46
|
-
return request;
|
|
47
|
-
}
|
|
48
|
-
exports.request = request;
|
|
49
|
-
function checkResponse(response, errorMsg, { ctx } = {}) {
|
|
50
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
-
if (response.status !== 200) {
|
|
52
|
-
let error;
|
|
53
|
-
try {
|
|
54
|
-
error = yield response.json();
|
|
55
|
-
}
|
|
56
|
-
catch (err) {
|
|
57
|
-
error = yield response.text();
|
|
58
|
-
}
|
|
59
|
-
const msg = `Unable to ${errorMsg} - ${error.message ? error.message : error}`;
|
|
60
|
-
if (ctx) {
|
|
61
|
-
ctx.throw(400, msg);
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
throw msg;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
return response.json();
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
// have to pass in the tenant ID as this could be coming from an automation
|
|
71
|
-
function sendSmtpEmail(to, from, subject, contents, cc, bcc, automation) {
|
|
72
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
-
// tenant ID will be set in header
|
|
74
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + `/api/global/email/send`), request(undefined, {
|
|
75
|
-
method: "POST",
|
|
76
|
-
body: {
|
|
77
|
-
email: to,
|
|
78
|
-
from,
|
|
79
|
-
contents,
|
|
80
|
-
subject,
|
|
81
|
-
cc,
|
|
82
|
-
bcc,
|
|
83
|
-
purpose: "custom",
|
|
84
|
-
automation,
|
|
85
|
-
},
|
|
86
|
-
}));
|
|
87
|
-
return checkResponse(response, "send email");
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
exports.sendSmtpEmail = sendSmtpEmail;
|
|
91
|
-
function getGlobalSelf(ctx, appId) {
|
|
92
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
93
|
-
const endpoint = `/api/global/self`;
|
|
94
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + endpoint),
|
|
95
|
-
// we don't want to use API key when getting self
|
|
96
|
-
request(ctx, { method: "GET" }));
|
|
97
|
-
let json = yield checkResponse(response, "get self globally", { ctx });
|
|
98
|
-
if (appId) {
|
|
99
|
-
json = (0, global_1.updateAppRole)(json);
|
|
100
|
-
}
|
|
101
|
-
return json;
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
exports.getGlobalSelf = getGlobalSelf;
|
|
105
|
-
function removeAppFromUserRoles(ctx, appId) {
|
|
106
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
107
|
-
const prodAppId = backend_core_1.db.getProdAppID(appId);
|
|
108
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + `/api/global/roles/${prodAppId}`), request(ctx, {
|
|
109
|
-
method: "DELETE",
|
|
110
|
-
}));
|
|
111
|
-
return checkResponse(response, "remove app role");
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
exports.removeAppFromUserRoles = removeAppFromUserRoles;
|
|
115
|
-
function allGlobalUsers(ctx) {
|
|
116
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
117
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + "/api/global/users"),
|
|
118
|
-
// we don't want to use API key when getting self
|
|
119
|
-
request(ctx, { method: "GET" }));
|
|
120
|
-
return checkResponse(response, "get users", { ctx });
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
exports.allGlobalUsers = allGlobalUsers;
|
|
124
|
-
function saveGlobalUser(ctx) {
|
|
125
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + "/api/global/users"),
|
|
127
|
-
// we don't want to use API key when getting self
|
|
128
|
-
request(ctx, { method: "POST", body: ctx.request.body }));
|
|
129
|
-
return checkResponse(response, "save user", { ctx });
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
exports.saveGlobalUser = saveGlobalUser;
|
|
133
|
-
function deleteGlobalUser(ctx) {
|
|
134
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
135
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + `/api/global/users/${ctx.params.userId}`),
|
|
136
|
-
// we don't want to use API key when getting self
|
|
137
|
-
request(ctx, { method: "DELETE" }));
|
|
138
|
-
return checkResponse(response, "delete user", { ctx });
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
exports.deleteGlobalUser = deleteGlobalUser;
|
|
142
|
-
function readGlobalUser(ctx) {
|
|
143
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
144
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + `/api/global/users/${ctx.params.userId}`),
|
|
145
|
-
// we don't want to use API key when getting self
|
|
146
|
-
request(ctx, { method: "GET" }));
|
|
147
|
-
return checkResponse(response, "get user", { ctx });
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
exports.readGlobalUser = readGlobalUser;
|
|
151
|
-
function createAdminUser(email, password, tenantId) {
|
|
152
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + "/api/global/users/init"), request(undefined, { method: "POST", body: { email, password, tenantId } }));
|
|
154
|
-
return checkResponse(response, "create admin user");
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
exports.createAdminUser = createAdminUser;
|
|
158
|
-
function getChecklist() {
|
|
159
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
160
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + "/api/global/configs/checklist"), request(undefined, { method: "GET" }));
|
|
161
|
-
return checkResponse(response, "get checklist");
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
exports.getChecklist = getChecklist;
|
|
165
|
-
function generateApiKey(userId) {
|
|
166
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
167
|
-
const response = yield (0, node_fetch_1.default)((0, index_1.checkSlashesInUrl)(environment_1.default.WORKER_URL + "/api/global/self/api_key"), request(undefined, { method: "POST", body: { userId } }));
|
|
168
|
-
return checkResponse(response, "generate API key");
|
|
169
|
-
});
|
|
170
|
-
}
|
|
171
|
-
exports.generateApiKey = generateApiKey;
|
package/dist/watch.js
DELETED
|
@@ -1,53 +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.watch = void 0;
|
|
16
|
-
const path_1 = __importDefault(require("path"));
|
|
17
|
-
const environment_1 = __importDefault(require("./environment"));
|
|
18
|
-
const chokidar_1 = __importDefault(require("chokidar"));
|
|
19
|
-
const fs_1 = __importDefault(require("fs"));
|
|
20
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
21
|
-
const plugins_1 = __importDefault(require("./sdk/plugins"));
|
|
22
|
-
function watch() {
|
|
23
|
-
const watchPath = path_1.default.join(environment_1.default.PLUGINS_DIR, "./**/*.tar.gz");
|
|
24
|
-
chokidar_1.default
|
|
25
|
-
.watch(watchPath, {
|
|
26
|
-
ignored: "**/node_modules",
|
|
27
|
-
awaitWriteFinish: {
|
|
28
|
-
pollInterval: 100,
|
|
29
|
-
stabilityThreshold: 250,
|
|
30
|
-
},
|
|
31
|
-
usePolling: true,
|
|
32
|
-
interval: 250,
|
|
33
|
-
})
|
|
34
|
-
.on("all", (event, path) => __awaiter(this, void 0, void 0, function* () {
|
|
35
|
-
// Sanity checks
|
|
36
|
-
if (!(path === null || path === void 0 ? void 0 : path.endsWith(".tar.gz")) || !fs_1.default.existsSync(path)) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
yield backend_core_1.tenancy.doInTenant(backend_core_1.constants.DEFAULT_TENANT_ID, () => __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
try {
|
|
41
|
-
const split = path.split("/");
|
|
42
|
-
const name = split[split.length - 1];
|
|
43
|
-
console.log("Importing plugin:", path);
|
|
44
|
-
yield plugins_1.default.processUploaded({ name, path });
|
|
45
|
-
}
|
|
46
|
-
catch (err) {
|
|
47
|
-
const message = (err === null || err === void 0 ? void 0 : err.message) ? err === null || err === void 0 ? void 0 : err.message : err;
|
|
48
|
-
console.error("Failed to import plugin:", message);
|
|
49
|
-
}
|
|
50
|
-
}));
|
|
51
|
-
}));
|
|
52
|
-
}
|
|
53
|
-
exports.watch = watch;
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const websocket_1 = __importDefault(require("./websocket"));
|
|
7
|
-
const authorized_1 = __importDefault(require("../middleware/authorized"));
|
|
8
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
9
|
-
class ClientAppWebsocket extends websocket_1.default {
|
|
10
|
-
constructor(app, server) {
|
|
11
|
-
super(app, server, "/socket/client", [(0, authorized_1.default)(backend_core_1.permissions.BUILDER)]);
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
exports.default = ClientAppWebsocket;
|
package/dist/websockets/grid.js
DELETED
|
@@ -1,60 +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
|
-
const authorized_1 = __importDefault(require("../middleware/authorized"));
|
|
16
|
-
const websocket_1 = __importDefault(require("./websocket"));
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
class GridSocket extends websocket_1.default {
|
|
19
|
-
constructor(app, server) {
|
|
20
|
-
super(app, server, "/socket/grid", [(0, authorized_1.default)(backend_core_1.permissions.BUILDER)]);
|
|
21
|
-
this.io.on("connection", socket => {
|
|
22
|
-
const user = socket.data.user;
|
|
23
|
-
console.log(`Spreadsheet user connected: ${user === null || user === void 0 ? void 0 : user.id}`);
|
|
24
|
-
// Socket state
|
|
25
|
-
let currentRoom;
|
|
26
|
-
// Initial identification of connected spreadsheet
|
|
27
|
-
socket.on("select-table", (tableId, callback) => __awaiter(this, void 0, void 0, function* () {
|
|
28
|
-
// Leave current room
|
|
29
|
-
if (currentRoom) {
|
|
30
|
-
socket.to(currentRoom).emit("user-disconnect", socket.data.user);
|
|
31
|
-
socket.leave(currentRoom);
|
|
32
|
-
}
|
|
33
|
-
// Join new room
|
|
34
|
-
currentRoom = tableId;
|
|
35
|
-
socket.join(currentRoom);
|
|
36
|
-
socket.to(currentRoom).emit("user-update", socket.data.user);
|
|
37
|
-
// Reply with all users in current room
|
|
38
|
-
const sockets = yield this.io.in(currentRoom).fetchSockets();
|
|
39
|
-
callback({
|
|
40
|
-
users: sockets.map(socket => socket.data.user),
|
|
41
|
-
id: user.id,
|
|
42
|
-
});
|
|
43
|
-
}));
|
|
44
|
-
// Handle users selecting a new cell
|
|
45
|
-
socket.on("select-cell", cellId => {
|
|
46
|
-
socket.data.user.selectedCellId = cellId;
|
|
47
|
-
if (currentRoom) {
|
|
48
|
-
socket.to(currentRoom).emit("user-update", socket.data.user);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
// Disconnection cleanup
|
|
52
|
-
socket.on("disconnect", () => {
|
|
53
|
-
if (currentRoom) {
|
|
54
|
-
socket.to(currentRoom).emit("user-disconnect", socket.data.user);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
exports.default = GridSocket;
|
package/dist/websockets/index.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.gridSocket = exports.clientAppSocket = exports.initialise = void 0;
|
|
7
|
-
const grid_1 = __importDefault(require("./grid"));
|
|
8
|
-
const client_1 = __importDefault(require("./client"));
|
|
9
|
-
let clientAppSocket;
|
|
10
|
-
exports.clientAppSocket = clientAppSocket;
|
|
11
|
-
let gridSocket;
|
|
12
|
-
exports.gridSocket = gridSocket;
|
|
13
|
-
const initialise = (app, server) => {
|
|
14
|
-
exports.clientAppSocket = clientAppSocket = new client_1.default(app, server);
|
|
15
|
-
exports.gridSocket = gridSocket = new grid_1.default(app, server);
|
|
16
|
-
};
|
|
17
|
-
exports.initialise = initialise;
|
|
@@ -1,78 +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
|
-
const socket_io_1 = require("socket.io");
|
|
16
|
-
const http_1 = __importDefault(require("http"));
|
|
17
|
-
const cookies_1 = __importDefault(require("cookies"));
|
|
18
|
-
const koa_useragent_1 = require("koa-useragent");
|
|
19
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
20
|
-
const currentapp_1 = __importDefault(require("../middleware/currentapp"));
|
|
21
|
-
class Socket {
|
|
22
|
-
constructor(app, server, path, additionalMiddlewares) {
|
|
23
|
-
this.io = new socket_io_1.Server(server, {
|
|
24
|
-
path,
|
|
25
|
-
});
|
|
26
|
-
// Attach default middlewares
|
|
27
|
-
const authenticate = backend_core_1.auth.buildAuthMiddleware([], {
|
|
28
|
-
publicAllowed: true,
|
|
29
|
-
});
|
|
30
|
-
const middlewares = [
|
|
31
|
-
koa_useragent_1.userAgent,
|
|
32
|
-
authenticate,
|
|
33
|
-
currentapp_1.default,
|
|
34
|
-
...(additionalMiddlewares || []),
|
|
35
|
-
];
|
|
36
|
-
// Apply middlewares
|
|
37
|
-
this.io.use((socket, next) => __awaiter(this, void 0, void 0, function* () {
|
|
38
|
-
// Build fake koa context
|
|
39
|
-
const res = new http_1.default.ServerResponse(socket.request);
|
|
40
|
-
const ctx = Object.assign(Object.assign({}, app.createContext(socket.request, res)), {
|
|
41
|
-
// Additional overrides needed to make our middlewares work with this
|
|
42
|
-
// fake koa context
|
|
43
|
-
cookies: new cookies_1.default(socket.request, res), get: (field) => socket.request.headers[field], throw: (code, message) => {
|
|
44
|
-
throw new Error(message);
|
|
45
|
-
},
|
|
46
|
-
// Needed for koa-useragent middleware
|
|
47
|
-
headers: socket.request.headers, header: socket.request.headers,
|
|
48
|
-
// We don't really care about the path since it will never contain
|
|
49
|
-
// an app ID
|
|
50
|
-
path: "/socket" });
|
|
51
|
-
// Run all koa middlewares
|
|
52
|
-
try {
|
|
53
|
-
for (let [idx, middleware] of middlewares.entries()) {
|
|
54
|
-
yield middleware(ctx, () => {
|
|
55
|
-
if (idx === middlewares.length - 1) {
|
|
56
|
-
// Middlewares are finished.
|
|
57
|
-
// Extract some data from our enriched koa context to persist
|
|
58
|
-
// as metadata for the socket
|
|
59
|
-
socket.data.user = {
|
|
60
|
-
id: ctx.user._id,
|
|
61
|
-
email: ctx.user.email,
|
|
62
|
-
};
|
|
63
|
-
next();
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
catch (error) {
|
|
69
|
-
next(error);
|
|
70
|
-
}
|
|
71
|
-
}));
|
|
72
|
-
}
|
|
73
|
-
// Emit an event to all sockets
|
|
74
|
-
emit(event, payload) {
|
|
75
|
-
this.io.sockets.emit(event, payload);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.default = Socket;
|
/package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte}
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|