@budibase/server 2.6.19-alpha.3 → 2.6.19-alpha.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.dockerignore +7 -6
- package/Dockerfile +16 -8
- package/builder/assets/{index.71388c79.js → index.3dd3d237.js} +435 -428
- package/builder/assets/{index.07382a47.css → index.8469b14c.css} +2 -2
- package/builder/index.html +2 -2
- package/client/manifest.json +5229 -0
- package/dist/automation.js +32436 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +44735 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24367 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +3 -0
- package/nodemon.json +1 -1
- package/package.json +32 -13
- package/pm2.config.js +1 -1
- package/scripts/build.js +48 -0
- package/src/api/controllers/application.ts +21 -22
- package/src/api/controllers/automation.ts +37 -9
- package/src/api/controllers/datasource.ts +20 -0
- package/src/api/controllers/row/index.ts +15 -22
- package/src/api/controllers/row/internal.ts +1 -1
- package/src/api/controllers/row/utils.ts +12 -0
- package/src/api/controllers/static/index.ts +3 -3
- package/src/api/controllers/table/index.ts +3 -0
- package/src/api/controllers/table/internal.ts +2 -6
- package/src/api/controllers/table/utils.ts +32 -1
- package/src/api/controllers/view/index.ts +5 -5
- package/src/api/controllers/webhook.ts +33 -9
- package/src/api/routes/application.ts +5 -0
- package/src/api/routes/automation.ts +0 -1
- package/src/api/routes/datasource.ts +5 -0
- package/src/api/routes/static.ts +3 -1
- package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
- package/src/api/routes/tests/datasource.spec.ts +1 -1
- package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
- package/src/app.ts +0 -1
- package/src/automations/actions.ts +8 -0
- package/src/automations/logging/index.ts +21 -0
- package/src/automations/steps/bash.ts +4 -0
- package/src/automations/steps/collect.ts +58 -0
- package/src/automations/steps/createRow.ts +4 -0
- package/src/automations/steps/delay.ts +1 -0
- package/src/automations/steps/deleteRow.ts +4 -0
- package/src/automations/steps/discord.ts +4 -0
- package/src/automations/steps/executeQuery.ts +4 -0
- package/src/automations/steps/executeScript.ts +4 -0
- package/src/automations/steps/filter.ts +1 -0
- package/src/automations/steps/loop.ts +1 -0
- package/src/automations/steps/make.ts +4 -0
- package/src/automations/steps/openai.ts +106 -0
- package/src/automations/steps/outgoingWebhook.ts +4 -0
- package/src/automations/steps/queryRows.ts +4 -0
- package/src/automations/steps/sendSmtpEmail.ts +4 -0
- package/src/automations/steps/serverLog.ts +4 -0
- package/src/automations/steps/slack.ts +4 -0
- package/src/automations/steps/updateRow.ts +4 -0
- package/src/automations/steps/zapier.ts +4 -0
- package/src/automations/tests/openai.spec.ts +86 -0
- package/src/automations/triggers.ts +3 -2
- package/src/constants/index.ts +17 -16
- package/src/db/inMemoryView.ts +1 -0
- package/src/environment.ts +3 -0
- package/src/integration-test/postgres.spec.ts +47 -4
- package/src/integrations/airtable.ts +3 -1
- package/src/integrations/arangodb.ts +3 -1
- package/src/integrations/base/sqlTable.ts +0 -1
- package/src/integrations/couchdb.ts +3 -1
- package/src/integrations/dynamodb.ts +3 -1
- package/src/integrations/elasticsearch.ts +3 -1
- package/src/integrations/firebase.ts +3 -1
- package/src/integrations/googlesheets.ts +11 -3
- package/src/integrations/microsoftSqlServer.ts +18 -2
- package/src/integrations/mongodb.ts +3 -1
- package/src/integrations/mysql.ts +27 -11
- package/src/integrations/oracle.ts +11 -1
- package/src/integrations/postgres.ts +15 -1
- package/src/integrations/redis.ts +3 -1
- package/src/integrations/s3.ts +3 -1
- package/src/integrations/snowflake.ts +3 -1
- package/src/integrations/tests/googlesheets.spec.ts +41 -9
- package/src/middleware/builder.ts +4 -5
- package/src/sdk/app/automations/index.ts +2 -0
- package/src/sdk/app/automations/utils.ts +7 -0
- package/src/startup.ts +2 -0
- package/src/tests/utilities/TestConfiguration.ts +4 -2
- package/src/tests/utilities/structures.ts +42 -0
- package/src/threads/automation.ts +78 -22
- package/src/threads/index.ts +9 -3
- package/src/threads/utils.ts +2 -0
- package/src/utilities/fileSystem/app.ts +1 -1
- package/src/utilities/fileSystem/clientLibrary.ts +8 -3
- package/src/utilities/fileSystem/filesystem.ts +3 -1
- package/src/utilities/redis.ts +19 -2
- package/src/websockets/builder.ts +69 -0
- package/src/websockets/grid.ts +25 -7
- package/src/websockets/index.ts +5 -2
- package/src/websockets/websocket.ts +20 -4
- package/tsconfig.build.json +9 -1
- package/tsconfig.json +1 -14
- package/dist/api/controllers/analytics.js +0 -46
- package/dist/api/controllers/apikeys.js +0 -72
- package/dist/api/controllers/application.js +0 -574
- package/dist/api/controllers/auth.js +0 -80
- package/dist/api/controllers/automation.js +0 -303
- package/dist/api/controllers/backup.js +0 -37
- package/dist/api/controllers/component.js +0 -59
- package/dist/api/controllers/datasource.js +0 -337
- package/dist/api/controllers/deploy/Deployment.js +0 -53
- package/dist/api/controllers/deploy/index.js +0 -198
- package/dist/api/controllers/dev.js +0 -146
- package/dist/api/controllers/integration.js +0 -28
- package/dist/api/controllers/layout.js +0 -49
- package/dist/api/controllers/metadata.js +0 -63
- package/dist/api/controllers/migrations.js +0 -29
- package/dist/api/controllers/ops.js +0 -40
- package/dist/api/controllers/permission.js +0 -162
- package/dist/api/controllers/plugin/file.js +0 -24
- package/dist/api/controllers/plugin/github.js +0 -69
- package/dist/api/controllers/plugin/index.js +0 -112
- package/dist/api/controllers/plugin/npm.js +0 -58
- package/dist/api/controllers/plugin/uploaders.js +0 -11
- package/dist/api/controllers/plugin/url.js +0 -24
- package/dist/api/controllers/plugin/utils.js +0 -27
- package/dist/api/controllers/public/applications.js +0 -146
- package/dist/api/controllers/public/mapping/applications.js +0 -29
- package/dist/api/controllers/public/mapping/index.js +0 -11
- package/dist/api/controllers/public/mapping/queries.js +0 -36
- package/dist/api/controllers/public/mapping/rows.js +0 -24
- package/dist/api/controllers/public/mapping/tables.js +0 -23
- package/dist/api/controllers/public/mapping/types.js +0 -2
- package/dist/api/controllers/public/mapping/users.js +0 -29
- package/dist/api/controllers/public/metrics.js +0 -113
- package/dist/api/controllers/public/queries.js +0 -58
- package/dist/api/controllers/public/rows.js +0 -120
- package/dist/api/controllers/public/tables.js +0 -95
- package/dist/api/controllers/public/users.js +0 -93
- package/dist/api/controllers/public/utils.js +0 -56
- package/dist/api/controllers/query/import/index.js +0 -87
- package/dist/api/controllers/query/import/sources/base/index.js +0 -75
- package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
- package/dist/api/controllers/query/import/sources/curl.js +0 -99
- package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
- package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
- package/dist/api/controllers/query/index.js +0 -299
- package/dist/api/controllers/query/validation.js +0 -53
- package/dist/api/controllers/role.js +0 -109
- package/dist/api/controllers/routing.js +0 -105
- package/dist/api/controllers/row/ExternalRequest.js +0 -683
- package/dist/api/controllers/row/external.js +0 -339
- package/dist/api/controllers/row/index.js +0 -203
- package/dist/api/controllers/row/internal.js +0 -509
- package/dist/api/controllers/row/internalSearch.js +0 -28
- package/dist/api/controllers/row/staticFormula.js +0 -165
- package/dist/api/controllers/row/utils.js +0 -183
- package/dist/api/controllers/screen.js +0 -110
- package/dist/api/controllers/script.js +0 -30
- package/dist/api/controllers/static/index.js +0 -268
- package/dist/api/controllers/table/bulkFormula.js +0 -173
- package/dist/api/controllers/table/external.js +0 -279
- package/dist/api/controllers/table/index.js +0 -179
- package/dist/api/controllers/table/internal.js +0 -197
- package/dist/api/controllers/table/utils.js +0 -379
- package/dist/api/controllers/templates.js +0 -56
- package/dist/api/controllers/user.js +0 -124
- package/dist/api/controllers/view/exporters.js +0 -46
- package/dist/api/controllers/view/index.js +0 -193
- package/dist/api/controllers/view/utils.js +0 -177
- package/dist/api/controllers/view/viewBuilder.js +0 -158
- package/dist/api/controllers/webhook.js +0 -134
- package/dist/api/index.js +0 -55
- package/dist/api/routes/analytics.js +0 -34
- package/dist/api/routes/apikeys.js +0 -37
- package/dist/api/routes/application.js +0 -48
- package/dist/api/routes/auth.js +0 -33
- package/dist/api/routes/automation.js +0 -50
- package/dist/api/routes/backup.js +0 -35
- package/dist/api/routes/component.js +0 -35
- package/dist/api/routes/datasource.js +0 -44
- package/dist/api/routes/deploy.js +0 -37
- package/dist/api/routes/dev.js +0 -49
- package/dist/api/routes/index.js +0 -75
- package/dist/api/routes/integration.js +0 -37
- package/dist/api/routes/layout.js +0 -37
- package/dist/api/routes/metadata.js +0 -40
- package/dist/api/routes/migrations.js +0 -36
- package/dist/api/routes/ops.js +0 -52
- package/dist/api/routes/permission.js +0 -44
- package/dist/api/routes/plugin.js +0 -39
- package/dist/api/routes/public/applications.js +0 -174
- package/dist/api/routes/public/index.js +0 -140
- package/dist/api/routes/public/metrics.js +0 -30
- package/dist/api/routes/public/middleware/mapper.js +0 -97
- package/dist/api/routes/public/queries.js +0 -72
- package/dist/api/routes/public/rows.js +0 -158
- package/dist/api/routes/public/tables.js +0 -152
- package/dist/api/routes/public/users.js +0 -135
- package/dist/api/routes/public/utils/Endpoint.js +0 -36
- package/dist/api/routes/query.js +0 -47
- package/dist/api/routes/role.js +0 -40
- package/dist/api/routes/routing.js +0 -39
- package/dist/api/routes/row.js +0 -239
- package/dist/api/routes/screen.js +0 -39
- package/dist/api/routes/script.js +0 -35
- package/dist/api/routes/static.js +0 -80
- package/dist/api/routes/table.js +0 -163
- package/dist/api/routes/templates.js +0 -37
- package/dist/api/routes/user.js +0 -43
- package/dist/api/routes/utils/validators.js +0 -238
- package/dist/api/routes/view.js +0 -42
- package/dist/api/routes/webhook.js +0 -43
- package/dist/app.js +0 -132
- package/dist/automations/actions.js +0 -137
- package/dist/automations/automationUtils.js +0 -173
- package/dist/automations/bullboard.js +0 -71
- package/dist/automations/index.js +0 -43
- package/dist/automations/logging/index.js +0 -53
- package/dist/automations/steps/bash.js +0 -111
- package/dist/automations/steps/createRow.js +0 -108
- package/dist/automations/steps/delay.js +0 -53
- package/dist/automations/steps/deleteRow.js +0 -96
- package/dist/automations/steps/discord.js +0 -116
- package/dist/automations/steps/executeQuery.js +0 -134
- package/dist/automations/steps/executeScript.js +0 -106
- package/dist/automations/steps/filter.js +0 -112
- package/dist/automations/steps/loop.js +0 -54
- package/dist/automations/steps/make.js +0 -134
- package/dist/automations/steps/outgoingWebhook.js +0 -166
- package/dist/automations/steps/queryRows.js +0 -216
- package/dist/automations/steps/sendSmtpEmail.js +0 -115
- package/dist/automations/steps/serverLog.js +0 -65
- package/dist/automations/steps/slack.js +0 -98
- package/dist/automations/steps/updateRow.js +0 -144
- package/dist/automations/steps/utils.js +0 -56
- package/dist/automations/steps/zapier.js +0 -130
- package/dist/automations/triggerInfo/app.js +0 -36
- package/dist/automations/triggerInfo/cron.js +0 -35
- package/dist/automations/triggerInfo/index.js +0 -40
- package/dist/automations/triggerInfo/rowDeleted.js +0 -36
- package/dist/automations/triggerInfo/rowSaved.js +0 -44
- package/dist/automations/triggerInfo/rowUpdated.js +0 -44
- package/dist/automations/triggerInfo/webhook.js +0 -40
- package/dist/automations/triggers.js +0 -181
- package/dist/automations/utils.js +0 -275
- package/dist/constants/definitions.js +0 -2
- package/dist/constants/index.js +0 -181
- package/dist/constants/layouts.js +0 -148
- package/dist/constants/screens.js +0 -51
- package/dist/db/defaultData/datasource_bb_default.js +0 -574
- package/dist/db/defaultData/employeeImport.js +0 -155
- package/dist/db/defaultData/expensesImport.js +0 -117
- package/dist/db/defaultData/inventoryImport.js +0 -109
- package/dist/db/defaultData/jobsImport.js +0 -152
- package/dist/db/dynamoClient.js +0 -124
- package/dist/db/inMemoryView.js +0 -62
- package/dist/db/index.js +0 -43
- package/dist/db/linkedRows/LinkController.js +0 -392
- package/dist/db/linkedRows/LinkDocument.js +0 -33
- package/dist/db/linkedRows/index.js +0 -206
- package/dist/db/linkedRows/linkUtils.js +0 -131
- package/dist/db/newid.js +0 -7
- package/dist/db/utils.js +0 -248
- package/dist/db/views/staticViews.js +0 -144
- package/dist/ddApm.js +0 -11
- package/dist/definitions/automations.js +0 -8
- package/dist/definitions/common.js +0 -2
- package/dist/definitions/datasource.js +0 -7
- package/dist/definitions/openapi.js +0 -6
- package/dist/environment.js +0 -109
- package/dist/events/AutomationEmitter.js +0 -53
- package/dist/events/BudibaseEmitter.js +0 -25
- package/dist/events/docUpdates/index.js +0 -17
- package/dist/events/docUpdates/processors.js +0 -18
- package/dist/events/docUpdates/syncUsers.js +0 -49
- package/dist/events/index.js +0 -11
- package/dist/events/utils.js +0 -43
- package/dist/integrations/airtable.js +0 -173
- package/dist/integrations/arangodb.js +0 -119
- package/dist/integrations/base/query.js +0 -32
- package/dist/integrations/base/sql.js +0 -600
- package/dist/integrations/base/sqlTable.js +0 -167
- package/dist/integrations/base/types.js +0 -2
- package/dist/integrations/couchdb.js +0 -140
- package/dist/integrations/dynamodb.js +0 -210
- package/dist/integrations/elasticsearch.js +0 -201
- package/dist/integrations/firebase.js +0 -189
- package/dist/integrations/googlesheets.js +0 -484
- package/dist/integrations/index.js +0 -138
- package/dist/integrations/microsoftSqlServer.js +0 -289
- package/dist/integrations/mongodb.js +0 -630
- package/dist/integrations/mysql.js +0 -272
- package/dist/integrations/oracle.js +0 -404
- package/dist/integrations/postgres.js +0 -320
- package/dist/integrations/queries/sql.js +0 -84
- package/dist/integrations/redis.js +0 -187
- package/dist/integrations/rest.js +0 -400
- package/dist/integrations/s3.js +0 -256
- package/dist/integrations/snowflake.js +0 -114
- package/dist/integrations/utils.js +0 -295
- package/dist/middleware/appInfo.js +0 -22
- package/dist/middleware/authorized.js +0 -112
- package/dist/middleware/builder.js +0 -93
- package/dist/middleware/currentapp.js +0 -103
- package/dist/middleware/joi-validator.js +0 -43
- package/dist/middleware/publicApi.js +0 -25
- package/dist/middleware/resourceId.js +0 -59
- package/dist/middleware/selfhost.js +0 -24
- package/dist/middleware/utils.js +0 -8
- package/dist/migrations/functions/appUrls.js +0 -42
- package/dist/migrations/functions/backfill/app/automations.js +0 -31
- package/dist/migrations/functions/backfill/app/datasources.js +0 -28
- package/dist/migrations/functions/backfill/app/layouts.js +0 -33
- package/dist/migrations/functions/backfill/app/queries.js +0 -49
- package/dist/migrations/functions/backfill/app/roles.js +0 -28
- package/dist/migrations/functions/backfill/app/screens.js +0 -28
- package/dist/migrations/functions/backfill/app/tables.js +0 -37
- package/dist/migrations/functions/backfill/app.js +0 -176
- package/dist/migrations/functions/backfill/global/configs.js +0 -67
- package/dist/migrations/functions/backfill/global/quotas.js +0 -60
- package/dist/migrations/functions/backfill/global/users.js +0 -50
- package/dist/migrations/functions/backfill/global.js +0 -205
- package/dist/migrations/functions/backfill/index.js +0 -32
- package/dist/migrations/functions/backfill/installation.js +0 -80
- package/dist/migrations/functions/syncQuotas.js +0 -52
- package/dist/migrations/functions/tableSettings.js +0 -130
- package/dist/migrations/functions/usageQuotas/index.js +0 -16
- package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
- package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
- package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
- package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
- package/dist/migrations/functions/userEmailViewCasing.js +0 -24
- package/dist/migrations/index.js +0 -111
- package/dist/migrations/tests/helpers.js +0 -72
- package/dist/migrations/tests/structures.js +0 -37
- package/dist/sdk/app/applications/index.js +0 -28
- package/dist/sdk/app/applications/sync.js +0 -164
- package/dist/sdk/app/applications/utils.js +0 -21
- package/dist/sdk/app/automations/index.js +0 -29
- package/dist/sdk/app/automations/webhook.js +0 -54
- package/dist/sdk/app/backups/constants.js +0 -6
- package/dist/sdk/app/backups/exports.js +0 -160
- package/dist/sdk/app/backups/imports.js +0 -170
- package/dist/sdk/app/backups/index.js +0 -29
- package/dist/sdk/app/backups/statistics.js +0 -73
- package/dist/sdk/app/datasources/datasources.js +0 -173
- package/dist/sdk/app/datasources/index.js +0 -27
- package/dist/sdk/app/queries/index.js +0 -27
- package/dist/sdk/app/queries/queries.js +0 -60
- package/dist/sdk/app/rows/attachments.js +0 -61
- package/dist/sdk/app/rows/index.js +0 -28
- package/dist/sdk/app/rows/rows.js +0 -30
- package/dist/sdk/app/tables/index.js +0 -65
- package/dist/sdk/index.js +0 -27
- package/dist/sdk/plugins/index.js +0 -27
- package/dist/sdk/plugins/plugins.js +0 -53
- package/dist/sdk/users/index.js +0 -27
- package/dist/sdk/users/utils.js +0 -87
- package/dist/sdk/utils/index.js +0 -29
- package/dist/startup.js +0 -158
- package/dist/threads/automation.js +0 -450
- package/dist/threads/definitions.js +0 -2
- package/dist/threads/index.js +0 -140
- package/dist/threads/query.js +0 -265
- package/dist/threads/utils.js +0 -120
- package/dist/tsconfig.build.tsbuildinfo +0 -1
- package/dist/utilities/appDirectoryTemplate/package.json +0 -10
- package/dist/utilities/budibaseDir.js +0 -5
- package/dist/utilities/centralPath.js +0 -27
- package/dist/utilities/csv.js +0 -33
- package/dist/utilities/fileSystem/app.js +0 -88
- package/dist/utilities/fileSystem/clientLibrary.js +0 -138
- package/dist/utilities/fileSystem/filesystem.js +0 -180
- package/dist/utilities/fileSystem/index.js +0 -21
- package/dist/utilities/fileSystem/plugin.js +0 -76
- package/dist/utilities/fileSystem/processor.js +0 -34
- package/dist/utilities/fileSystem/template.js +0 -47
- package/dist/utilities/global.js +0 -149
- package/dist/utilities/index.js +0 -143
- package/dist/utilities/redis.js +0 -117
- package/dist/utilities/retry.js +0 -30
- package/dist/utilities/routing/index.js +0 -39
- package/dist/utilities/rowProcessor/index.js +0 -282
- package/dist/utilities/rowProcessor/map.js +0 -116
- package/dist/utilities/rowProcessor/utils.js +0 -87
- package/dist/utilities/schema.js +0 -112
- package/dist/utilities/scriptRunner.js +0 -26
- package/dist/utilities/security.js +0 -57
- package/dist/utilities/statusCodes.js +0 -9
- package/dist/utilities/usageQuota/rows.js +0 -88
- package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
- package/dist/utilities/users.js +0 -57
- package/dist/utilities/workerRequests.js +0 -171
- package/dist/watch.js +0 -53
- package/dist/websockets/client.js +0 -14
- package/dist/websockets/grid.js +0 -60
- package/dist/websockets/index.js +0 -17
- package/dist/websockets/websocket.js +0 -78
- /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
- /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
- /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
package/dist/utilities/global.js
DELETED
|
@@ -1,149 +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.getGlobalUsersFromMetadata = exports.getGlobalUsers = exports.getGlobalUser = exports.getRawGlobalUser = exports.getCachedSelf = exports.processUser = exports.updateAppRole = void 0;
|
|
16
|
-
const utils_1 = require("../db/utils");
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
19
|
-
const pro_1 = require("@budibase/pro");
|
|
20
|
-
function updateAppRole(user, { appId } = {}) {
|
|
21
|
-
var _a;
|
|
22
|
-
appId = appId || backend_core_1.context.getAppId();
|
|
23
|
-
if (!user || (!user.roles && !user.userGroups)) {
|
|
24
|
-
return user;
|
|
25
|
-
}
|
|
26
|
-
// if in an multi-tenancy environment make sure roles are never updated
|
|
27
|
-
if (environment_1.default.MULTI_TENANCY && appId && !backend_core_1.tenancy.isUserInAppTenant(appId, user)) {
|
|
28
|
-
delete user.builder;
|
|
29
|
-
delete user.admin;
|
|
30
|
-
user.roleId = backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC;
|
|
31
|
-
return user;
|
|
32
|
-
}
|
|
33
|
-
// always use the deployed app
|
|
34
|
-
if (appId && user.roles) {
|
|
35
|
-
user.roleId = user.roles[backend_core_1.db.getProdAppID(appId)];
|
|
36
|
-
}
|
|
37
|
-
// if a role wasn't found then either set as admin (builder) or public (everyone else)
|
|
38
|
-
if (!user.roleId && user.builder && user.builder.global) {
|
|
39
|
-
user.roleId = backend_core_1.roles.BUILTIN_ROLE_IDS.ADMIN;
|
|
40
|
-
}
|
|
41
|
-
else if (!user.roleId && !((_a = user === null || user === void 0 ? void 0 : user.userGroups) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
42
|
-
user.roleId = backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC;
|
|
43
|
-
}
|
|
44
|
-
delete user.roles;
|
|
45
|
-
return user;
|
|
46
|
-
}
|
|
47
|
-
exports.updateAppRole = updateAppRole;
|
|
48
|
-
function checkGroupRoles(user, opts = {}) {
|
|
49
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
50
|
-
if (user.roleId && user.roleId !== backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC) {
|
|
51
|
-
return user;
|
|
52
|
-
}
|
|
53
|
-
if (opts.appId) {
|
|
54
|
-
user.roleId = yield pro_1.groups.getGroupRoleId(user, opts.appId, {
|
|
55
|
-
groups: opts.groups,
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
// final fallback, simply couldn't find a role - user must be public
|
|
59
|
-
if (!user.roleId) {
|
|
60
|
-
user.roleId = backend_core_1.roles.BUILTIN_ROLE_IDS.PUBLIC;
|
|
61
|
-
}
|
|
62
|
-
return user;
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
function processUser(user, opts = {}) {
|
|
66
|
-
var _a;
|
|
67
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
68
|
-
if (user) {
|
|
69
|
-
delete user.password;
|
|
70
|
-
}
|
|
71
|
-
const appId = opts.appId || backend_core_1.context.getAppId();
|
|
72
|
-
user = updateAppRole(user, { appId });
|
|
73
|
-
if (!user.roleId && ((_a = user === null || user === void 0 ? void 0 : user.userGroups) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
74
|
-
user = yield checkGroupRoles(user, { appId, groups: opts === null || opts === void 0 ? void 0 : opts.groups });
|
|
75
|
-
}
|
|
76
|
-
return user;
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
exports.processUser = processUser;
|
|
80
|
-
function getCachedSelf(ctx, appId) {
|
|
81
|
-
var _a;
|
|
82
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
-
// this has to be tenant aware, can't depend on the context to find it out
|
|
84
|
-
// running some middlewares before the tenancy causes context to break
|
|
85
|
-
const user = yield backend_core_1.cache.user.getUser((_a = ctx.user) === null || _a === void 0 ? void 0 : _a._id);
|
|
86
|
-
return processUser(user, { appId });
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
exports.getCachedSelf = getCachedSelf;
|
|
90
|
-
function getRawGlobalUser(userId) {
|
|
91
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
-
const db = backend_core_1.tenancy.getGlobalDB();
|
|
93
|
-
return db.get((0, utils_1.getGlobalIDFromUserMetadataID)(userId));
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
exports.getRawGlobalUser = getRawGlobalUser;
|
|
97
|
-
function getGlobalUser(userId) {
|
|
98
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
99
|
-
const appId = backend_core_1.context.getAppId();
|
|
100
|
-
let user = yield getRawGlobalUser(userId);
|
|
101
|
-
return processUser(user, { appId });
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
exports.getGlobalUser = getGlobalUser;
|
|
105
|
-
function getGlobalUsers(userIds, opts) {
|
|
106
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
107
|
-
const appId = backend_core_1.context.getAppId();
|
|
108
|
-
const db = backend_core_1.tenancy.getGlobalDB();
|
|
109
|
-
let globalUsers;
|
|
110
|
-
if (userIds) {
|
|
111
|
-
globalUsers = (yield db.allDocs((0, utils_1.getMultiIDParams)(userIds))).rows.map(row => row.doc);
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
globalUsers = (yield db.allDocs(backend_core_1.db.getGlobalUserParams(null, {
|
|
115
|
-
include_docs: true,
|
|
116
|
-
}))).rows.map(row => row.doc);
|
|
117
|
-
}
|
|
118
|
-
globalUsers = globalUsers
|
|
119
|
-
.filter(user => user != null)
|
|
120
|
-
.map(user => {
|
|
121
|
-
delete user.password;
|
|
122
|
-
delete user.forceResetPassword;
|
|
123
|
-
return user;
|
|
124
|
-
});
|
|
125
|
-
if (!appId) {
|
|
126
|
-
return globalUsers;
|
|
127
|
-
}
|
|
128
|
-
if (opts === null || opts === void 0 ? void 0 : opts.noProcessing) {
|
|
129
|
-
return globalUsers;
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
// pass in the groups, meaning we don't actually need to retrieve them for
|
|
133
|
-
// each user individually
|
|
134
|
-
const allGroups = yield pro_1.groups.fetch();
|
|
135
|
-
return Promise.all(globalUsers.map(user => processUser(user, { groups: allGroups })));
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
exports.getGlobalUsers = getGlobalUsers;
|
|
140
|
-
function getGlobalUsersFromMetadata(users) {
|
|
141
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
142
|
-
const globalUsers = yield getGlobalUsers(users.map(user => user._id));
|
|
143
|
-
return users.map(user => {
|
|
144
|
-
const globalUser = globalUsers.find(globalUser => { var _a; return globalUser && ((_a = user._id) === null || _a === void 0 ? void 0 : _a.includes(globalUser._id)); });
|
|
145
|
-
return Object.assign(Object.assign({}, globalUser), user);
|
|
146
|
-
});
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
exports.getGlobalUsersFromMetadata = getGlobalUsersFromMetadata;
|
package/dist/utilities/index.js
DELETED
|
@@ -1,143 +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.isQsTrue = exports.convertBookmark = exports.formatBytes = exports.stringToReadStream = exports.escapeDangerousCharacters = exports.deleteEntityMetadata = exports.saveEntityMetadata = exports.updateEntityMetadata = exports.checkSlashesInUrl = exports.removeFromArray = exports.NUMBER_REGEX = exports.isDev = exports.wait = void 0;
|
|
16
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
const utils_1 = require("../db/utils");
|
|
19
|
-
const stream_1 = __importDefault(require("stream"));
|
|
20
|
-
const Readable = stream_1.default.Readable;
|
|
21
|
-
function wait(ms) {
|
|
22
|
-
return new Promise(resolve => setTimeout(resolve, ms));
|
|
23
|
-
}
|
|
24
|
-
exports.wait = wait;
|
|
25
|
-
exports.isDev = environment_1.default.isDev;
|
|
26
|
-
exports.NUMBER_REGEX = /^[+-]?([0-9]*[.])?[0-9]+$/g;
|
|
27
|
-
function removeFromArray(array, element) {
|
|
28
|
-
const index = array.indexOf(element);
|
|
29
|
-
if (index !== -1) {
|
|
30
|
-
array.splice(index, 1);
|
|
31
|
-
}
|
|
32
|
-
return array;
|
|
33
|
-
}
|
|
34
|
-
exports.removeFromArray = removeFromArray;
|
|
35
|
-
/**
|
|
36
|
-
* Makes sure that a URL has the correct number of slashes, while maintaining the
|
|
37
|
-
* http(s):// double slashes.
|
|
38
|
-
* @param {string} url The URL to test and remove any extra double slashes.
|
|
39
|
-
* @return {string} The updated url.
|
|
40
|
-
*/
|
|
41
|
-
function checkSlashesInUrl(url) {
|
|
42
|
-
return url.replace(/(https?:\/\/)|(\/)+/g, "$1$2");
|
|
43
|
-
}
|
|
44
|
-
exports.checkSlashesInUrl = checkSlashesInUrl;
|
|
45
|
-
function updateEntityMetadata(type, entityId, updateFn) {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const db = backend_core_1.context.getAppDB();
|
|
48
|
-
const id = (0, utils_1.generateMetadataID)(type, entityId);
|
|
49
|
-
// read it to see if it exists, we'll overwrite it no matter what
|
|
50
|
-
let rev, metadata;
|
|
51
|
-
try {
|
|
52
|
-
const oldMetadata = yield db.get(id);
|
|
53
|
-
rev = oldMetadata._rev;
|
|
54
|
-
metadata = updateFn(oldMetadata);
|
|
55
|
-
}
|
|
56
|
-
catch (err) {
|
|
57
|
-
rev = null;
|
|
58
|
-
metadata = updateFn({});
|
|
59
|
-
}
|
|
60
|
-
metadata._id = id;
|
|
61
|
-
if (rev) {
|
|
62
|
-
metadata._rev = rev;
|
|
63
|
-
}
|
|
64
|
-
const response = yield db.put(metadata);
|
|
65
|
-
return Object.assign(Object.assign({}, metadata), { _id: id, _rev: response.rev });
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
exports.updateEntityMetadata = updateEntityMetadata;
|
|
69
|
-
function saveEntityMetadata(type, entityId, metadata) {
|
|
70
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
71
|
-
return updateEntityMetadata(type, entityId, () => {
|
|
72
|
-
return metadata;
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
exports.saveEntityMetadata = saveEntityMetadata;
|
|
77
|
-
function deleteEntityMetadata(type, entityId) {
|
|
78
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
79
|
-
const db = backend_core_1.context.getAppDB();
|
|
80
|
-
const id = (0, utils_1.generateMetadataID)(type, entityId);
|
|
81
|
-
let rev;
|
|
82
|
-
try {
|
|
83
|
-
const metadata = yield db.get(id);
|
|
84
|
-
if (metadata) {
|
|
85
|
-
rev = metadata._rev;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
catch (err) {
|
|
89
|
-
// don't need to error if it doesn't exist
|
|
90
|
-
}
|
|
91
|
-
if (id && rev) {
|
|
92
|
-
yield db.remove(id, rev);
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
exports.deleteEntityMetadata = deleteEntityMetadata;
|
|
97
|
-
function escapeDangerousCharacters(string) {
|
|
98
|
-
return string
|
|
99
|
-
.replace(/[\\]/g, "\\\\")
|
|
100
|
-
.replace(/[\b]/g, "\\b")
|
|
101
|
-
.replace(/[\f]/g, "\\f")
|
|
102
|
-
.replace(/[\n]/g, "\\n")
|
|
103
|
-
.replace(/[\r]/g, "\\r")
|
|
104
|
-
.replace(/[\t]/g, "\\t");
|
|
105
|
-
}
|
|
106
|
-
exports.escapeDangerousCharacters = escapeDangerousCharacters;
|
|
107
|
-
function stringToReadStream(string) {
|
|
108
|
-
return new Readable({
|
|
109
|
-
read() {
|
|
110
|
-
this.push(string);
|
|
111
|
-
this.push(null);
|
|
112
|
-
},
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
exports.stringToReadStream = stringToReadStream;
|
|
116
|
-
function formatBytes(bytes) {
|
|
117
|
-
const units = ["B", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
|
|
118
|
-
const byteIncrements = 1024;
|
|
119
|
-
let unit = 0;
|
|
120
|
-
let size = parseInt(bytes, 10) || 0;
|
|
121
|
-
while (size >= byteIncrements && ++unit) {
|
|
122
|
-
size /= byteIncrements;
|
|
123
|
-
}
|
|
124
|
-
return `${size.toFixed(size < 10 && unit > 0 ? 1 : 0)}${units[unit]}`;
|
|
125
|
-
}
|
|
126
|
-
exports.formatBytes = formatBytes;
|
|
127
|
-
function convertBookmark(bookmark) {
|
|
128
|
-
const IS_NUMBER = /^\d+\.?\d*$/;
|
|
129
|
-
if (typeof bookmark === "string" && bookmark.match(IS_NUMBER)) {
|
|
130
|
-
return parseFloat(bookmark);
|
|
131
|
-
}
|
|
132
|
-
return bookmark;
|
|
133
|
-
}
|
|
134
|
-
exports.convertBookmark = convertBookmark;
|
|
135
|
-
function isQsTrue(param) {
|
|
136
|
-
if (typeof param === "string") {
|
|
137
|
-
return param.toLowerCase() === "true";
|
|
138
|
-
}
|
|
139
|
-
else {
|
|
140
|
-
return param === true;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
exports.isQsTrue = isQsTrue;
|
package/dist/utilities/redis.js
DELETED
|
@@ -1,117 +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.clearTestFlag = exports.checkTestFlag = exports.setTestFlag = exports.setDebounce = exports.checkDebounce = exports.clearLock = exports.updateLock = exports.getLocksById = exports.doesUserHaveLock = exports.shutdown = exports.init = void 0;
|
|
13
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
14
|
-
const utils_1 = require("../db/utils");
|
|
15
|
-
const APP_DEV_LOCK_SECONDS = 600;
|
|
16
|
-
const AUTOMATION_TEST_FLAG_SECONDS = 60;
|
|
17
|
-
let devAppClient, debounceClient, flagClient;
|
|
18
|
-
// we init this as we want to keep the connection open all the time
|
|
19
|
-
// reduces the performance hit
|
|
20
|
-
function init() {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
devAppClient = new backend_core_1.redis.Client(backend_core_1.redis.utils.Databases.DEV_LOCKS);
|
|
23
|
-
debounceClient = new backend_core_1.redis.Client(backend_core_1.redis.utils.Databases.DEBOUNCE);
|
|
24
|
-
flagClient = new backend_core_1.redis.Client(backend_core_1.redis.utils.Databases.FLAGS);
|
|
25
|
-
yield devAppClient.init();
|
|
26
|
-
yield debounceClient.init();
|
|
27
|
-
yield flagClient.init();
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
exports.init = init;
|
|
31
|
-
function shutdown() {
|
|
32
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
if (devAppClient)
|
|
34
|
-
yield devAppClient.finish();
|
|
35
|
-
if (debounceClient)
|
|
36
|
-
yield debounceClient.finish();
|
|
37
|
-
if (flagClient)
|
|
38
|
-
yield flagClient.finish();
|
|
39
|
-
// shutdown core clients
|
|
40
|
-
yield backend_core_1.redis.clients.shutdown();
|
|
41
|
-
console.log("Redis shutdown");
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
exports.shutdown = shutdown;
|
|
45
|
-
function doesUserHaveLock(devAppId, user) {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const value = yield devAppClient.get(devAppId);
|
|
48
|
-
if (!value) {
|
|
49
|
-
return true;
|
|
50
|
-
}
|
|
51
|
-
// make sure both IDs are global
|
|
52
|
-
const expected = (0, utils_1.getGlobalIDFromUserMetadataID)(value._id);
|
|
53
|
-
const userId = (0, utils_1.getGlobalIDFromUserMetadataID)(user._id);
|
|
54
|
-
return expected === userId;
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
exports.doesUserHaveLock = doesUserHaveLock;
|
|
58
|
-
function getLocksById(appIds) {
|
|
59
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
-
return yield devAppClient.bulkGet(appIds);
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
exports.getLocksById = getLocksById;
|
|
64
|
-
function updateLock(devAppId, user) {
|
|
65
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
-
// make sure always global user ID
|
|
67
|
-
const globalId = (0, utils_1.getGlobalIDFromUserMetadataID)(user._id);
|
|
68
|
-
const inputUser = Object.assign(Object.assign({}, user), { userId: globalId, _id: globalId, lockedAt: new Date().getTime() });
|
|
69
|
-
yield devAppClient.store(devAppId, inputUser, APP_DEV_LOCK_SECONDS);
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
exports.updateLock = updateLock;
|
|
73
|
-
function clearLock(devAppId, user) {
|
|
74
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
75
|
-
const value = yield devAppClient.get(devAppId);
|
|
76
|
-
if (!value) {
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
const userId = (0, utils_1.getGlobalIDFromUserMetadataID)(user._id);
|
|
80
|
-
if (value._id !== userId) {
|
|
81
|
-
throw "User does not hold lock, cannot clear it.";
|
|
82
|
-
}
|
|
83
|
-
yield devAppClient.delete(devAppId);
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
exports.clearLock = clearLock;
|
|
87
|
-
function checkDebounce(id) {
|
|
88
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
-
return debounceClient.get(id);
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
exports.checkDebounce = checkDebounce;
|
|
93
|
-
function setDebounce(id, seconds) {
|
|
94
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
95
|
-
yield debounceClient.store(id, "debouncing", seconds);
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
exports.setDebounce = setDebounce;
|
|
99
|
-
function setTestFlag(id) {
|
|
100
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
101
|
-
yield flagClient.store(id, { testing: true }, AUTOMATION_TEST_FLAG_SECONDS);
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
exports.setTestFlag = setTestFlag;
|
|
105
|
-
function checkTestFlag(id) {
|
|
106
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
107
|
-
const flag = yield flagClient.get(id);
|
|
108
|
-
return !!(flag && flag.testing);
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
exports.checkTestFlag = checkTestFlag;
|
|
112
|
-
function clearTestFlag(id) {
|
|
113
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
114
|
-
yield devAppClient.delete(id);
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
exports.clearTestFlag = clearTestFlag;
|
package/dist/utilities/retry.js
DELETED
|
@@ -1,30 +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.retry = void 0;
|
|
13
|
-
function retry(fn, maxTry = 5, retryCount = 1) {
|
|
14
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
15
|
-
const currRetry = typeof retryCount === "number" ? retryCount : 1;
|
|
16
|
-
try {
|
|
17
|
-
const result = yield fn();
|
|
18
|
-
return result;
|
|
19
|
-
}
|
|
20
|
-
catch (e) {
|
|
21
|
-
console.log(`Retry ${currRetry} failed.`);
|
|
22
|
-
if (currRetry > maxTry) {
|
|
23
|
-
console.log(`All ${maxTry} retry attempts exhausted`);
|
|
24
|
-
throw e;
|
|
25
|
-
}
|
|
26
|
-
return retry(fn, maxTry, currRetry + 1);
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
exports.retry = retry;
|
|
@@ -1,39 +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.getRoutingInfo = void 0;
|
|
13
|
-
const staticViews_1 = require("../../db/views/staticViews");
|
|
14
|
-
const utils_1 = require("../../db/utils");
|
|
15
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
16
|
-
function getRoutingInfo() {
|
|
17
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
18
|
-
const db = backend_core_1.context.getAppDB();
|
|
19
|
-
try {
|
|
20
|
-
const allRouting = yield db.query((0, utils_1.getQueryIndex)(utils_1.ViewName.ROUTING), {
|
|
21
|
-
startkey: "",
|
|
22
|
-
endkey: utils_1.UNICODE_MAX,
|
|
23
|
-
});
|
|
24
|
-
return allRouting.rows.map(row => row.value);
|
|
25
|
-
}
|
|
26
|
-
catch (err) {
|
|
27
|
-
// check if the view doesn't exist, it should for all new instances
|
|
28
|
-
/* istanbul ignore next */
|
|
29
|
-
if (err != null && err.name === "not_found") {
|
|
30
|
-
yield (0, staticViews_1.createRoutingView)();
|
|
31
|
-
return getRoutingInfo();
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
throw err;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
exports.getRoutingInfo = getRoutingInfo;
|