@budibase/server 2.3.20 → 2.3.21-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/__mocks__/aws-sdk.ts +1 -1
- package/__mocks__/node-fetch.ts +3 -0
- package/builder/assets/blankScreenPreview.72634dd1.png +0 -0
- package/builder/assets/{index.3faec52d.js → index.ab679a87.js} +439 -426
- package/builder/assets/index.b24b9dea.css +6 -0
- package/builder/assets/listScreenPreview.599c0aae.png +0 -0
- package/builder/index.html +2 -2
- package/dist/api/controllers/automation.js +11 -2
- package/dist/api/controllers/cloud.js +2 -2
- package/dist/api/controllers/query/index.js +2 -0
- package/dist/api/controllers/row/ExternalRequest.js +50 -23
- package/dist/api/controllers/row/external.js +12 -1
- package/dist/api/controllers/row/internalSearch.js +6 -450
- package/dist/api/controllers/row/utils.js +1 -3
- package/dist/api/controllers/table/external.js +8 -8
- package/dist/api/index.js +1 -21
- package/dist/api/routes/automation.js +1 -1
- package/dist/api/routes/public/applications.js +7 -7
- package/dist/api/routes/public/queries.js +2 -2
- package/dist/api/routes/public/rows.js +5 -5
- package/dist/api/routes/public/tables.js +5 -5
- package/dist/api/routes/public/users.js +5 -5
- package/dist/app.js +9 -1
- package/dist/constants/index.js +4 -24
- package/dist/db/defaultData/datasource_bb_default.js +6 -5
- package/dist/db/index.js +25 -2
- package/dist/db/linkedRows/LinkController.js +9 -8
- package/dist/db/utils.js +2 -5
- package/dist/db/views/staticViews.js +2 -1
- package/dist/ddApm.js +11 -0
- package/dist/elasticApm.js +14 -0
- package/dist/integrations/base/sql.js +6 -3
- package/dist/integrations/googlesheets.js +17 -20
- package/dist/middleware/authorized.js +5 -3
- package/dist/middleware/builder.js +6 -3
- package/dist/migrations/functions/backfill/global/configs.js +10 -4
- package/dist/migrations/tests/helpers.js +1 -1
- package/dist/migrations/tests/structures.js +1 -1
- package/dist/package.json +14 -9
- package/dist/sdk/app/backups/constants.js +2 -1
- package/dist/sdk/app/backups/exports.js +20 -7
- package/dist/sdk/app/datasources/datasources.js +3 -0
- package/dist/sdk/app/rows/attachments.js +1 -1
- package/dist/startup.js +3 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/utilities/redis.js +2 -0
- package/dist/utilities/retry.js +30 -0
- package/jest-testcontainers-config.js +8 -0
- package/jest.config.ts +35 -22
- package/package.json +15 -10
- package/scripts/load/create-many-apps.js +24 -0
- package/scripts/load/create-many-rows.js +30 -0
- package/scripts/load/utils.js +66 -0
- package/scripts/test.sh +12 -0
- package/specs/{generate.js → generate.ts} +7 -9
- package/specs/openapi.json +30 -30
- package/specs/openapi.yaml +27 -27
- package/specs/{parameters.js → parameters.ts} +6 -6
- package/specs/resources/{application.js → application.ts} +4 -4
- package/specs/resources/{index.js → index.ts} +8 -8
- package/specs/resources/{misc.js → misc.ts} +3 -3
- package/specs/resources/{query.js → query.ts} +4 -4
- package/specs/resources/{row.js → row.ts} +3 -4
- package/specs/resources/{table.js → table.ts} +5 -5
- package/specs/resources/{user.js → user.ts} +3 -3
- package/specs/resources/utils/Resource.ts +39 -0
- package/specs/resources/utils/{index.js → index.ts} +1 -1
- package/specs/{security.js → security.ts} +1 -1
- package/src/api/controllers/automation.ts +13 -2
- package/src/api/controllers/cloud.ts +2 -2
- package/src/api/controllers/query/import/tests/index.spec.js +1 -1
- package/src/api/controllers/query/index.ts +2 -0
- package/src/api/controllers/row/ExternalRequest.ts +98 -27
- package/src/api/controllers/row/external.ts +13 -1
- package/src/api/controllers/row/internalSearch.ts +11 -524
- package/src/api/controllers/row/utils.ts +1 -2
- package/src/api/controllers/table/external.ts +3 -2
- package/src/api/index.ts +3 -22
- package/src/api/routes/automation.ts +1 -1
- package/src/api/routes/public/applications.ts +7 -8
- package/src/api/routes/public/queries.ts +2 -2
- package/src/api/routes/public/rows.ts +5 -5
- package/src/api/routes/public/tables.ts +5 -5
- package/src/api/routes/public/tests/{compare.spec.js → compare.spec.ts} +45 -26
- package/src/api/routes/public/tests/users.spec.js +1 -1
- package/src/api/routes/public/tests/utils.ts +25 -8
- package/src/api/routes/public/users.ts +5 -5
- package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
- package/src/api/routes/tests/analytics.spec.js +4 -1
- package/src/api/routes/tests/apikeys.spec.js +1 -1
- package/src/api/routes/tests/application.spec.ts +20 -6
- package/src/api/routes/tests/auth.spec.js +2 -2
- package/src/api/routes/tests/automation.spec.js +6 -2
- package/src/api/routes/tests/backup.spec.ts +4 -14
- package/src/api/routes/tests/cloud.spec.ts +20 -31
- package/src/api/routes/tests/component.spec.js +1 -1
- package/src/api/routes/tests/datasource.spec.ts +20 -3
- package/src/api/routes/tests/dev.spec.js +1 -1
- package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
- package/src/api/routes/tests/integration.spec.js +1 -1
- package/src/api/routes/tests/layout.spec.js +1 -1
- package/src/api/routes/tests/metadata.spec.js +1 -1
- package/src/api/routes/tests/misc.spec.js +1 -1
- package/src/api/routes/tests/permissions.spec.js +4 -1
- package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
- package/src/api/routes/tests/role.spec.js +6 -1
- package/src/api/routes/tests/routing.spec.js +1 -1
- package/src/api/routes/tests/row.spec.js +11 -3
- package/src/api/routes/tests/screen.spec.js +1 -1
- package/src/api/routes/tests/static.spec.js +2 -13
- package/src/api/routes/tests/table.spec.js +1 -1
- package/src/api/routes/tests/templates.spec.js +1 -1
- package/src/api/routes/tests/user.spec.js +11 -12
- package/src/api/routes/tests/utilities/TestFunctions.ts +25 -3
- package/src/api/routes/tests/utilities/index.ts +5 -3
- package/src/api/routes/tests/view.spec.js +4 -1
- package/src/api/routes/tests/webhook.spec.js +11 -2
- package/src/app.ts +12 -1
- package/src/automations/tests/automation.spec.js +4 -4
- package/src/automations/tests/bash.spec.js +1 -1
- package/src/automations/tests/discord.spec.js +1 -1
- package/src/automations/tests/executeQuery.spec.js +2 -3
- package/src/automations/tests/executeScript.spec.js +1 -1
- package/src/automations/tests/outgoingWebhook.spec.js +1 -1
- package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
- package/src/automations/tests/serverLog.spec.js +1 -1
- package/src/automations/tests/updateRow.spec.js +1 -1
- package/src/automations/tests/zapier.spec.js +1 -1
- package/src/constants/index.ts +1 -23
- package/src/db/defaultData/datasource_bb_default.ts +6 -10
- package/src/db/index.ts +2 -2
- package/src/db/linkedRows/LinkController.ts +2 -1
- package/src/db/tests/linkController.spec.js +4 -1
- package/src/db/tests/linkTests.spec.js +1 -1
- package/src/db/utils.ts +0 -4
- package/src/db/views/staticViews.ts +3 -3
- package/src/ddApm.ts +7 -0
- package/src/definitions/openapi.ts +449 -63
- package/src/elasticApm.ts +10 -0
- package/src/integration-test/postgres.spec.ts +1032 -0
- package/src/integrations/base/sql.ts +11 -5
- package/src/integrations/googlesheets.ts +21 -22
- package/src/integrations/oracle.ts +1 -1
- package/src/integrations/tests/couchdb.spec.ts +0 -2
- package/src/integrations/tests/googlesheets.spec.ts +122 -0
- package/src/middleware/authorized.ts +6 -4
- package/src/middleware/builder.ts +8 -3
- package/src/migrations/functions/backfill/global/configs.ts +15 -9
- package/src/migrations/functions/tests/appUrls.spec.js +1 -1
- package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
- package/src/migrations/functions/tests/userEmailViewCasing.spec.js +4 -5
- package/src/migrations/tests/helpers.ts +2 -2
- package/src/migrations/tests/index.spec.ts +13 -20
- package/src/migrations/tests/structures.ts +1 -0
- package/src/sdk/app/backups/constants.ts +1 -0
- package/src/sdk/app/backups/exports.ts +32 -10
- package/src/sdk/app/datasources/datasources.ts +3 -0
- package/src/sdk/app/rows/attachments.ts +1 -1
- package/src/startup.ts +4 -1
- package/src/tests/jestEnv.ts +9 -11
- package/src/tests/jestSetup.ts +9 -7
- package/src/tests/logging.ts +34 -0
- package/src/tests/utilities/TestConfiguration.ts +187 -101
- package/src/tests/utilities/structures.ts +16 -4
- package/src/utilities/redis.ts +2 -0
- package/src/utilities/retry.ts +18 -0
- package/tsconfig.build.json +1 -0
- package/builder/assets/index.4488f38d.css +0 -6
- package/coverage/clover.xml +0 -11774
- package/coverage/coverage-final.json +0 -284
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -1031
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
- package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
- package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
- package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
- package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
- package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
- package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
- package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
- package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
- package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
- package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
- package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
- package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
- package/coverage/lcov-report/src/api/controllers/index.html +0 -431
- package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
- package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
- package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
- package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
- package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
- package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
- package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
- package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
- package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
- package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
- package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
- package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
- package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
- package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
- package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
- package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
- package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
- package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
- package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
- package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
- package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
- package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
- package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
- package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
- package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
- package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
- package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
- package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
- package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
- package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
- package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
- package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
- package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
- package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
- package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
- package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
- package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
- package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
- package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
- package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
- package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
- package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
- package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
- package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
- package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -595
- package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
- package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
- package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
- package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
- package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
- package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
- package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
- package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
- package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
- package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
- package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
- package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
- package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
- package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
- package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
- package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
- package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
- package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
- package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
- package/coverage/lcov-report/src/api/index.html +0 -116
- package/coverage/lcov-report/src/api/index.ts.html +0 -352
- package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
- package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
- package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
- package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
- package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
- package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
- package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
- package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
- package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
- package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
- package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
- package/coverage/lcov-report/src/api/routes/index.html +0 -551
- package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
- package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
- package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
- package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
- package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
- package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
- package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
- package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
- package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
- package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
- package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
- package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
- package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
- package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
- package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
- package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
- package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
- package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
- package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
- package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
- package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
- package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
- package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
- package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
- package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
- package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
- package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
- package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
- package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
- package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
- package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
- package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
- package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
- package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
- package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
- package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
- package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
- package/coverage/lcov-report/src/app.ts.html +0 -424
- package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
- package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
- package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
- package/coverage/lcov-report/src/automations/index.html +0 -191
- package/coverage/lcov-report/src/automations/index.ts.html +0 -163
- package/coverage/lcov-report/src/automations/logging/index.html +0 -116
- package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
- package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
- package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
- package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
- package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
- package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -397
- package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
- package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
- package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
- package/coverage/lcov-report/src/automations/steps/index.html +0 -371
- package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -409
- package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
- package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
- package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
- package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
- package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
- package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -340
- package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
- package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
- package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -403
- package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
- package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
- package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
- package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
- package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
- package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
- package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
- package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
- package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
- package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
- package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
- package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
- package/coverage/lcov-report/src/constants/index.html +0 -146
- package/coverage/lcov-report/src/constants/index.ts.html +0 -697
- package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
- package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
- package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
- package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
- package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
- package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
- package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
- package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
- package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
- package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
- package/coverage/lcov-report/src/db/index.html +0 -176
- package/coverage/lcov-report/src/db/index.ts.html +0 -133
- package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
- package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
- package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
- package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
- package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
- package/coverage/lcov-report/src/db/newid.ts.html +0 -100
- package/coverage/lcov-report/src/db/utils.ts.html +0 -913
- package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
- package/coverage/lcov-report/src/definitions/index.html +0 -116
- package/coverage/lcov-report/src/environment.ts.html +0 -472
- package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
- package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
- package/coverage/lcov-report/src/events/index.html +0 -161
- package/coverage/lcov-report/src/events/index.ts.html +0 -100
- package/coverage/lcov-report/src/events/utils.ts.html +0 -319
- package/coverage/lcov-report/src/index.html +0 -191
- package/coverage/lcov-report/src/index.ts.html +0 -133
- package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
- package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
- package/coverage/lcov-report/src/integrations/base/index.html +0 -161
- package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
- package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
- package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
- package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
- package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
- package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
- package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
- package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
- package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
- package/coverage/lcov-report/src/integrations/index.html +0 -371
- package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
- package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
- package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
- package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
- package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
- package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
- package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
- package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
- package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
- package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
- package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
- package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
- package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
- package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
- package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
- package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
- package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
- package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
- package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
- package/coverage/lcov-report/src/middleware/index.html +0 -236
- package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
- package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
- package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
- package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
- package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
- package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
- package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
- package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
- package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
- package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
- package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
- package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
- package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
- package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
- package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
- package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
- package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
- package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
- package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
- package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
- package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
- package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
- package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
- package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
- package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
- package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
- package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
- package/coverage/lcov-report/src/migrations/index.html +0 -116
- package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
- package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
- package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
- package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
- package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
- package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
- package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
- package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
- package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
- package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
- package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
- package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
- package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
- package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
- package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
- package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
- package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
- package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
- package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
- package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
- package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
- package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
- package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
- package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
- package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
- package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
- package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
- package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
- package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
- package/coverage/lcov-report/src/sdk/index.html +0 -116
- package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
- package/coverage/lcov-report/src/sdk/users/index.html +0 -131
- package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
- package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
- package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
- package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
- package/coverage/lcov-report/src/startup.ts.html +0 -484
- package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
- package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
- package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
- package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
- package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
- package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
- package/coverage/lcov-report/src/threads/index.html +0 -161
- package/coverage/lcov-report/src/threads/index.ts.html +0 -418
- package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
- package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
- package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
- package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
- package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
- package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
- package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
- package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
- package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
- package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
- package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
- package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
- package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
- package/coverage/lcov-report/src/utilities/index.html +0 -251
- package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
- package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
- package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
- package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
- package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
- package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
- package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
- package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
- package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
- package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
- package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
- package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
- package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
- package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
- package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
- package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
- package/coverage/lcov-report/src/watch.ts.html +0 -196
- package/coverage/lcov-report/src/websocket.ts.html +0 -163
- package/coverage/lcov.info +0 -21777
- package/dist/api/routes/public/tests/utils.js +0 -33
- package/dist/integrations/base/utils.js +0 -16
- package/specs/resources/utils/Resource.js +0 -26
- package/src/integrations/base/utils.ts +0 -12
|
@@ -1,604 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
<!doctype html>
|
|
3
|
-
<html lang="en">
|
|
4
|
-
|
|
5
|
-
<head>
|
|
6
|
-
<title>Code coverage report for src/sdk/app/backups/exports.ts</title>
|
|
7
|
-
<meta charset="utf-8" />
|
|
8
|
-
<link rel="stylesheet" href="../../../../prettify.css" />
|
|
9
|
-
<link rel="stylesheet" href="../../../../base.css" />
|
|
10
|
-
<link rel="shortcut icon" type="image/x-icon" href="../../../../favicon.png" />
|
|
11
|
-
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
-
<style type='text/css'>
|
|
13
|
-
.coverage-summary .sorter {
|
|
14
|
-
background-image: url(../../../../sort-arrow-sprite.png);
|
|
15
|
-
}
|
|
16
|
-
</style>
|
|
17
|
-
</head>
|
|
18
|
-
|
|
19
|
-
<body>
|
|
20
|
-
<div class='wrapper'>
|
|
21
|
-
<div class='pad1'>
|
|
22
|
-
<h1><a href="../../../../index.html">All files</a> / <a href="index.html">src/sdk/app/backups</a> exports.ts</h1>
|
|
23
|
-
<div class='clearfix'>
|
|
24
|
-
|
|
25
|
-
<div class='fl pad1y space-right2'>
|
|
26
|
-
<span class="strong">60% </span>
|
|
27
|
-
<span class="quiet">Statements</span>
|
|
28
|
-
<span class='fraction'>45/75</span>
|
|
29
|
-
</div>
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
<div class='fl pad1y space-right2'>
|
|
33
|
-
<span class="strong">41.66% </span>
|
|
34
|
-
<span class="quiet">Branches</span>
|
|
35
|
-
<span class='fraction'>5/12</span>
|
|
36
|
-
</div>
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
<div class='fl pad1y space-right2'>
|
|
40
|
-
<span class="strong">76.47% </span>
|
|
41
|
-
<span class="quiet">Functions</span>
|
|
42
|
-
<span class='fraction'>13/17</span>
|
|
43
|
-
</div>
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
<div class='fl pad1y space-right2'>
|
|
47
|
-
<span class="strong">59.72% </span>
|
|
48
|
-
<span class="quiet">Lines</span>
|
|
49
|
-
<span class='fraction'>43/72</span>
|
|
50
|
-
</div>
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
</div>
|
|
54
|
-
<p class="quiet">
|
|
55
|
-
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
-
</p>
|
|
57
|
-
<template id="filterTemplate">
|
|
58
|
-
<div class="quiet">
|
|
59
|
-
Filter:
|
|
60
|
-
<input oninput="onInput()" type="search" id="fileSearch">
|
|
61
|
-
</div>
|
|
62
|
-
</template>
|
|
63
|
-
</div>
|
|
64
|
-
<div class='status-line medium'></div>
|
|
65
|
-
<pre><table class="coverage">
|
|
66
|
-
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
67
|
-
<a name='L2'></a><a href='#L2'>2</a>
|
|
68
|
-
<a name='L3'></a><a href='#L3'>3</a>
|
|
69
|
-
<a name='L4'></a><a href='#L4'>4</a>
|
|
70
|
-
<a name='L5'></a><a href='#L5'>5</a>
|
|
71
|
-
<a name='L6'></a><a href='#L6'>6</a>
|
|
72
|
-
<a name='L7'></a><a href='#L7'>7</a>
|
|
73
|
-
<a name='L8'></a><a href='#L8'>8</a>
|
|
74
|
-
<a name='L9'></a><a href='#L9'>9</a>
|
|
75
|
-
<a name='L10'></a><a href='#L10'>10</a>
|
|
76
|
-
<a name='L11'></a><a href='#L11'>11</a>
|
|
77
|
-
<a name='L12'></a><a href='#L12'>12</a>
|
|
78
|
-
<a name='L13'></a><a href='#L13'>13</a>
|
|
79
|
-
<a name='L14'></a><a href='#L14'>14</a>
|
|
80
|
-
<a name='L15'></a><a href='#L15'>15</a>
|
|
81
|
-
<a name='L16'></a><a href='#L16'>16</a>
|
|
82
|
-
<a name='L17'></a><a href='#L17'>17</a>
|
|
83
|
-
<a name='L18'></a><a href='#L18'>18</a>
|
|
84
|
-
<a name='L19'></a><a href='#L19'>19</a>
|
|
85
|
-
<a name='L20'></a><a href='#L20'>20</a>
|
|
86
|
-
<a name='L21'></a><a href='#L21'>21</a>
|
|
87
|
-
<a name='L22'></a><a href='#L22'>22</a>
|
|
88
|
-
<a name='L23'></a><a href='#L23'>23</a>
|
|
89
|
-
<a name='L24'></a><a href='#L24'>24</a>
|
|
90
|
-
<a name='L25'></a><a href='#L25'>25</a>
|
|
91
|
-
<a name='L26'></a><a href='#L26'>26</a>
|
|
92
|
-
<a name='L27'></a><a href='#L27'>27</a>
|
|
93
|
-
<a name='L28'></a><a href='#L28'>28</a>
|
|
94
|
-
<a name='L29'></a><a href='#L29'>29</a>
|
|
95
|
-
<a name='L30'></a><a href='#L30'>30</a>
|
|
96
|
-
<a name='L31'></a><a href='#L31'>31</a>
|
|
97
|
-
<a name='L32'></a><a href='#L32'>32</a>
|
|
98
|
-
<a name='L33'></a><a href='#L33'>33</a>
|
|
99
|
-
<a name='L34'></a><a href='#L34'>34</a>
|
|
100
|
-
<a name='L35'></a><a href='#L35'>35</a>
|
|
101
|
-
<a name='L36'></a><a href='#L36'>36</a>
|
|
102
|
-
<a name='L37'></a><a href='#L37'>37</a>
|
|
103
|
-
<a name='L38'></a><a href='#L38'>38</a>
|
|
104
|
-
<a name='L39'></a><a href='#L39'>39</a>
|
|
105
|
-
<a name='L40'></a><a href='#L40'>40</a>
|
|
106
|
-
<a name='L41'></a><a href='#L41'>41</a>
|
|
107
|
-
<a name='L42'></a><a href='#L42'>42</a>
|
|
108
|
-
<a name='L43'></a><a href='#L43'>43</a>
|
|
109
|
-
<a name='L44'></a><a href='#L44'>44</a>
|
|
110
|
-
<a name='L45'></a><a href='#L45'>45</a>
|
|
111
|
-
<a name='L46'></a><a href='#L46'>46</a>
|
|
112
|
-
<a name='L47'></a><a href='#L47'>47</a>
|
|
113
|
-
<a name='L48'></a><a href='#L48'>48</a>
|
|
114
|
-
<a name='L49'></a><a href='#L49'>49</a>
|
|
115
|
-
<a name='L50'></a><a href='#L50'>50</a>
|
|
116
|
-
<a name='L51'></a><a href='#L51'>51</a>
|
|
117
|
-
<a name='L52'></a><a href='#L52'>52</a>
|
|
118
|
-
<a name='L53'></a><a href='#L53'>53</a>
|
|
119
|
-
<a name='L54'></a><a href='#L54'>54</a>
|
|
120
|
-
<a name='L55'></a><a href='#L55'>55</a>
|
|
121
|
-
<a name='L56'></a><a href='#L56'>56</a>
|
|
122
|
-
<a name='L57'></a><a href='#L57'>57</a>
|
|
123
|
-
<a name='L58'></a><a href='#L58'>58</a>
|
|
124
|
-
<a name='L59'></a><a href='#L59'>59</a>
|
|
125
|
-
<a name='L60'></a><a href='#L60'>60</a>
|
|
126
|
-
<a name='L61'></a><a href='#L61'>61</a>
|
|
127
|
-
<a name='L62'></a><a href='#L62'>62</a>
|
|
128
|
-
<a name='L63'></a><a href='#L63'>63</a>
|
|
129
|
-
<a name='L64'></a><a href='#L64'>64</a>
|
|
130
|
-
<a name='L65'></a><a href='#L65'>65</a>
|
|
131
|
-
<a name='L66'></a><a href='#L66'>66</a>
|
|
132
|
-
<a name='L67'></a><a href='#L67'>67</a>
|
|
133
|
-
<a name='L68'></a><a href='#L68'>68</a>
|
|
134
|
-
<a name='L69'></a><a href='#L69'>69</a>
|
|
135
|
-
<a name='L70'></a><a href='#L70'>70</a>
|
|
136
|
-
<a name='L71'></a><a href='#L71'>71</a>
|
|
137
|
-
<a name='L72'></a><a href='#L72'>72</a>
|
|
138
|
-
<a name='L73'></a><a href='#L73'>73</a>
|
|
139
|
-
<a name='L74'></a><a href='#L74'>74</a>
|
|
140
|
-
<a name='L75'></a><a href='#L75'>75</a>
|
|
141
|
-
<a name='L76'></a><a href='#L76'>76</a>
|
|
142
|
-
<a name='L77'></a><a href='#L77'>77</a>
|
|
143
|
-
<a name='L78'></a><a href='#L78'>78</a>
|
|
144
|
-
<a name='L79'></a><a href='#L79'>79</a>
|
|
145
|
-
<a name='L80'></a><a href='#L80'>80</a>
|
|
146
|
-
<a name='L81'></a><a href='#L81'>81</a>
|
|
147
|
-
<a name='L82'></a><a href='#L82'>82</a>
|
|
148
|
-
<a name='L83'></a><a href='#L83'>83</a>
|
|
149
|
-
<a name='L84'></a><a href='#L84'>84</a>
|
|
150
|
-
<a name='L85'></a><a href='#L85'>85</a>
|
|
151
|
-
<a name='L86'></a><a href='#L86'>86</a>
|
|
152
|
-
<a name='L87'></a><a href='#L87'>87</a>
|
|
153
|
-
<a name='L88'></a><a href='#L88'>88</a>
|
|
154
|
-
<a name='L89'></a><a href='#L89'>89</a>
|
|
155
|
-
<a name='L90'></a><a href='#L90'>90</a>
|
|
156
|
-
<a name='L91'></a><a href='#L91'>91</a>
|
|
157
|
-
<a name='L92'></a><a href='#L92'>92</a>
|
|
158
|
-
<a name='L93'></a><a href='#L93'>93</a>
|
|
159
|
-
<a name='L94'></a><a href='#L94'>94</a>
|
|
160
|
-
<a name='L95'></a><a href='#L95'>95</a>
|
|
161
|
-
<a name='L96'></a><a href='#L96'>96</a>
|
|
162
|
-
<a name='L97'></a><a href='#L97'>97</a>
|
|
163
|
-
<a name='L98'></a><a href='#L98'>98</a>
|
|
164
|
-
<a name='L99'></a><a href='#L99'>99</a>
|
|
165
|
-
<a name='L100'></a><a href='#L100'>100</a>
|
|
166
|
-
<a name='L101'></a><a href='#L101'>101</a>
|
|
167
|
-
<a name='L102'></a><a href='#L102'>102</a>
|
|
168
|
-
<a name='L103'></a><a href='#L103'>103</a>
|
|
169
|
-
<a name='L104'></a><a href='#L104'>104</a>
|
|
170
|
-
<a name='L105'></a><a href='#L105'>105</a>
|
|
171
|
-
<a name='L106'></a><a href='#L106'>106</a>
|
|
172
|
-
<a name='L107'></a><a href='#L107'>107</a>
|
|
173
|
-
<a name='L108'></a><a href='#L108'>108</a>
|
|
174
|
-
<a name='L109'></a><a href='#L109'>109</a>
|
|
175
|
-
<a name='L110'></a><a href='#L110'>110</a>
|
|
176
|
-
<a name='L111'></a><a href='#L111'>111</a>
|
|
177
|
-
<a name='L112'></a><a href='#L112'>112</a>
|
|
178
|
-
<a name='L113'></a><a href='#L113'>113</a>
|
|
179
|
-
<a name='L114'></a><a href='#L114'>114</a>
|
|
180
|
-
<a name='L115'></a><a href='#L115'>115</a>
|
|
181
|
-
<a name='L116'></a><a href='#L116'>116</a>
|
|
182
|
-
<a name='L117'></a><a href='#L117'>117</a>
|
|
183
|
-
<a name='L118'></a><a href='#L118'>118</a>
|
|
184
|
-
<a name='L119'></a><a href='#L119'>119</a>
|
|
185
|
-
<a name='L120'></a><a href='#L120'>120</a>
|
|
186
|
-
<a name='L121'></a><a href='#L121'>121</a>
|
|
187
|
-
<a name='L122'></a><a href='#L122'>122</a>
|
|
188
|
-
<a name='L123'></a><a href='#L123'>123</a>
|
|
189
|
-
<a name='L124'></a><a href='#L124'>124</a>
|
|
190
|
-
<a name='L125'></a><a href='#L125'>125</a>
|
|
191
|
-
<a name='L126'></a><a href='#L126'>126</a>
|
|
192
|
-
<a name='L127'></a><a href='#L127'>127</a>
|
|
193
|
-
<a name='L128'></a><a href='#L128'>128</a>
|
|
194
|
-
<a name='L129'></a><a href='#L129'>129</a>
|
|
195
|
-
<a name='L130'></a><a href='#L130'>130</a>
|
|
196
|
-
<a name='L131'></a><a href='#L131'>131</a>
|
|
197
|
-
<a name='L132'></a><a href='#L132'>132</a>
|
|
198
|
-
<a name='L133'></a><a href='#L133'>133</a>
|
|
199
|
-
<a name='L134'></a><a href='#L134'>134</a>
|
|
200
|
-
<a name='L135'></a><a href='#L135'>135</a>
|
|
201
|
-
<a name='L136'></a><a href='#L136'>136</a>
|
|
202
|
-
<a name='L137'></a><a href='#L137'>137</a>
|
|
203
|
-
<a name='L138'></a><a href='#L138'>138</a>
|
|
204
|
-
<a name='L139'></a><a href='#L139'>139</a>
|
|
205
|
-
<a name='L140'></a><a href='#L140'>140</a>
|
|
206
|
-
<a name='L141'></a><a href='#L141'>141</a>
|
|
207
|
-
<a name='L142'></a><a href='#L142'>142</a>
|
|
208
|
-
<a name='L143'></a><a href='#L143'>143</a>
|
|
209
|
-
<a name='L144'></a><a href='#L144'>144</a>
|
|
210
|
-
<a name='L145'></a><a href='#L145'>145</a>
|
|
211
|
-
<a name='L146'></a><a href='#L146'>146</a>
|
|
212
|
-
<a name='L147'></a><a href='#L147'>147</a>
|
|
213
|
-
<a name='L148'></a><a href='#L148'>148</a>
|
|
214
|
-
<a name='L149'></a><a href='#L149'>149</a>
|
|
215
|
-
<a name='L150'></a><a href='#L150'>150</a>
|
|
216
|
-
<a name='L151'></a><a href='#L151'>151</a>
|
|
217
|
-
<a name='L152'></a><a href='#L152'>152</a>
|
|
218
|
-
<a name='L153'></a><a href='#L153'>153</a>
|
|
219
|
-
<a name='L154'></a><a href='#L154'>154</a>
|
|
220
|
-
<a name='L155'></a><a href='#L155'>155</a>
|
|
221
|
-
<a name='L156'></a><a href='#L156'>156</a>
|
|
222
|
-
<a name='L157'></a><a href='#L157'>157</a>
|
|
223
|
-
<a name='L158'></a><a href='#L158'>158</a>
|
|
224
|
-
<a name='L159'></a><a href='#L159'>159</a>
|
|
225
|
-
<a name='L160'></a><a href='#L160'>160</a>
|
|
226
|
-
<a name='L161'></a><a href='#L161'>161</a>
|
|
227
|
-
<a name='L162'></a><a href='#L162'>162</a>
|
|
228
|
-
<a name='L163'></a><a href='#L163'>163</a>
|
|
229
|
-
<a name='L164'></a><a href='#L164'>164</a>
|
|
230
|
-
<a name='L165'></a><a href='#L165'>165</a>
|
|
231
|
-
<a name='L166'></a><a href='#L166'>166</a>
|
|
232
|
-
<a name='L167'></a><a href='#L167'>167</a>
|
|
233
|
-
<a name='L168'></a><a href='#L168'>168</a>
|
|
234
|
-
<a name='L169'></a><a href='#L169'>169</a>
|
|
235
|
-
<a name='L170'></a><a href='#L170'>170</a>
|
|
236
|
-
<a name='L171'></a><a href='#L171'>171</a>
|
|
237
|
-
<a name='L172'></a><a href='#L172'>172</a>
|
|
238
|
-
<a name='L173'></a><a href='#L173'>173</a>
|
|
239
|
-
<a name='L174'></a><a href='#L174'>174</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">59x</span>
|
|
240
|
-
<span class="cline-any cline-yes">59x</span>
|
|
241
|
-
<span class="cline-any cline-yes">59x</span>
|
|
242
|
-
<span class="cline-any cline-yes">59x</span>
|
|
243
|
-
<span class="cline-any cline-neutral"> </span>
|
|
244
|
-
<span class="cline-any cline-neutral"> </span>
|
|
245
|
-
<span class="cline-any cline-neutral"> </span>
|
|
246
|
-
<span class="cline-any cline-neutral"> </span>
|
|
247
|
-
<span class="cline-any cline-yes">59x</span>
|
|
248
|
-
<span class="cline-any cline-yes">59x</span>
|
|
249
|
-
<span class="cline-any cline-yes">59x</span>
|
|
250
|
-
<span class="cline-any cline-yes">59x</span>
|
|
251
|
-
<span class="cline-any cline-yes">59x</span>
|
|
252
|
-
<span class="cline-any cline-yes">59x</span>
|
|
253
|
-
<span class="cline-any cline-yes">59x</span>
|
|
254
|
-
<span class="cline-any cline-yes">59x</span>
|
|
255
|
-
<span class="cline-any cline-neutral"> </span>
|
|
256
|
-
<span class="cline-any cline-neutral"> </span>
|
|
257
|
-
<span class="cline-any cline-neutral"> </span>
|
|
258
|
-
<span class="cline-any cline-neutral"> </span>
|
|
259
|
-
<span class="cline-any cline-neutral"> </span>
|
|
260
|
-
<span class="cline-any cline-neutral"> </span>
|
|
261
|
-
<span class="cline-any cline-neutral"> </span>
|
|
262
|
-
<span class="cline-any cline-neutral"> </span>
|
|
263
|
-
<span class="cline-any cline-neutral"> </span>
|
|
264
|
-
<span class="cline-any cline-yes">1x</span>
|
|
265
|
-
<span class="cline-any cline-yes">1x</span>
|
|
266
|
-
<span class="cline-any cline-neutral"> </span>
|
|
267
|
-
<span class="cline-any cline-neutral"> </span>
|
|
268
|
-
<span class="cline-any cline-neutral"> </span>
|
|
269
|
-
<span class="cline-any cline-neutral"> </span>
|
|
270
|
-
<span class="cline-any cline-neutral"> </span>
|
|
271
|
-
<span class="cline-any cline-neutral"> </span>
|
|
272
|
-
<span class="cline-any cline-neutral"> </span>
|
|
273
|
-
<span class="cline-any cline-neutral"> </span>
|
|
274
|
-
<span class="cline-any cline-neutral"> </span>
|
|
275
|
-
<span class="cline-any cline-yes">1x</span>
|
|
276
|
-
<span class="cline-any cline-neutral"> </span>
|
|
277
|
-
<span class="cline-any cline-neutral"> </span>
|
|
278
|
-
<span class="cline-any cline-neutral"> </span>
|
|
279
|
-
<span class="cline-any cline-neutral"> </span>
|
|
280
|
-
<span class="cline-any cline-neutral"> </span>
|
|
281
|
-
<span class="cline-any cline-neutral"> </span>
|
|
282
|
-
<span class="cline-any cline-neutral"> </span>
|
|
283
|
-
<span class="cline-any cline-neutral"> </span>
|
|
284
|
-
<span class="cline-any cline-neutral"> </span>
|
|
285
|
-
<span class="cline-any cline-yes">59x</span>
|
|
286
|
-
<span class="cline-any cline-yes">1x</span>
|
|
287
|
-
<span class="cline-any cline-neutral"> </span>
|
|
288
|
-
<span class="cline-any cline-yes">1x</span>
|
|
289
|
-
<span class="cline-any cline-yes">1x</span>
|
|
290
|
-
<span class="cline-any cline-yes">1x</span>
|
|
291
|
-
<span class="cline-any cline-yes">1x</span>
|
|
292
|
-
<span class="cline-any cline-yes">1x</span>
|
|
293
|
-
<span class="cline-any cline-neutral"> </span>
|
|
294
|
-
<span class="cline-any cline-neutral"> </span>
|
|
295
|
-
<span class="cline-any cline-no"> </span>
|
|
296
|
-
<span class="cline-any cline-no"> </span>
|
|
297
|
-
<span class="cline-any cline-no"> </span>
|
|
298
|
-
<span class="cline-any cline-no"> </span>
|
|
299
|
-
<span class="cline-any cline-neutral"> </span>
|
|
300
|
-
<span class="cline-any cline-no"> </span>
|
|
301
|
-
<span class="cline-any cline-no"> </span>
|
|
302
|
-
<span class="cline-any cline-neutral"> </span>
|
|
303
|
-
<span class="cline-any cline-neutral"> </span>
|
|
304
|
-
<span class="cline-any cline-neutral"> </span>
|
|
305
|
-
<span class="cline-any cline-neutral"> </span>
|
|
306
|
-
<span class="cline-any cline-neutral"> </span>
|
|
307
|
-
<span class="cline-any cline-yes">1x</span>
|
|
308
|
-
<span class="cline-any cline-yes">1x</span>
|
|
309
|
-
<span class="cline-any cline-no"> </span>
|
|
310
|
-
<span class="cline-any cline-neutral"> </span>
|
|
311
|
-
<span class="cline-any cline-yes">1x</span>
|
|
312
|
-
<span class="cline-any cline-yes">12x</span>
|
|
313
|
-
<span class="cline-any cline-neutral"> </span>
|
|
314
|
-
<span class="cline-any cline-neutral"> </span>
|
|
315
|
-
<span class="cline-any cline-neutral"> </span>
|
|
316
|
-
<span class="cline-any cline-neutral"> </span>
|
|
317
|
-
<span class="cline-any cline-neutral"> </span>
|
|
318
|
-
<span class="cline-any cline-neutral"> </span>
|
|
319
|
-
<span class="cline-any cline-neutral"> </span>
|
|
320
|
-
<span class="cline-any cline-neutral"> </span>
|
|
321
|
-
<span class="cline-any cline-neutral"> </span>
|
|
322
|
-
<span class="cline-any cline-yes">59x</span>
|
|
323
|
-
<span class="cline-any cline-yes">1x</span>
|
|
324
|
-
<span class="cline-any cline-yes">1x</span>
|
|
325
|
-
<span class="cline-any cline-neutral"> </span>
|
|
326
|
-
<span class="cline-any cline-neutral"> </span>
|
|
327
|
-
<span class="cline-any cline-yes">1x</span>
|
|
328
|
-
<span class="cline-any cline-no"> </span>
|
|
329
|
-
<span class="cline-any cline-neutral"> </span>
|
|
330
|
-
<span class="cline-any cline-neutral"> </span>
|
|
331
|
-
<span class="cline-any cline-neutral"> </span>
|
|
332
|
-
<span class="cline-any cline-neutral"> </span>
|
|
333
|
-
<span class="cline-any cline-yes">1x</span>
|
|
334
|
-
<span class="cline-any cline-neutral"> </span>
|
|
335
|
-
<span class="cline-any cline-yes">1x</span>
|
|
336
|
-
<span class="cline-any cline-yes">1x</span>
|
|
337
|
-
<span class="cline-any cline-no"> </span>
|
|
338
|
-
<span class="cline-any cline-no"> </span>
|
|
339
|
-
<span class="cline-any cline-no"> </span>
|
|
340
|
-
<span class="cline-any cline-neutral"> </span>
|
|
341
|
-
<span class="cline-any cline-no"> </span>
|
|
342
|
-
<span class="cline-any cline-neutral"> </span>
|
|
343
|
-
<span class="cline-any cline-neutral"> </span>
|
|
344
|
-
<span class="cline-any cline-no"> </span>
|
|
345
|
-
<span class="cline-any cline-neutral"> </span>
|
|
346
|
-
<span class="cline-any cline-neutral"> </span>
|
|
347
|
-
<span class="cline-any cline-yes">1x</span>
|
|
348
|
-
<span class="cline-any cline-yes">1x</span>
|
|
349
|
-
<span class="cline-any cline-neutral"> </span>
|
|
350
|
-
<span class="cline-any cline-neutral"> </span>
|
|
351
|
-
<span class="cline-any cline-neutral"> </span>
|
|
352
|
-
<span class="cline-any cline-neutral"> </span>
|
|
353
|
-
<span class="cline-any cline-neutral"> </span>
|
|
354
|
-
<span class="cline-any cline-yes">1x</span>
|
|
355
|
-
<span class="cline-any cline-neutral"> </span>
|
|
356
|
-
<span class="cline-any cline-yes">1x</span>
|
|
357
|
-
<span class="cline-any cline-neutral"> </span>
|
|
358
|
-
<span class="cline-any cline-yes">1x</span>
|
|
359
|
-
<span class="cline-any cline-yes">1x</span>
|
|
360
|
-
<span class="cline-any cline-neutral"> </span>
|
|
361
|
-
<span class="cline-any cline-neutral"> </span>
|
|
362
|
-
<span class="cline-any cline-neutral"> </span>
|
|
363
|
-
<span class="cline-any cline-no"> </span>
|
|
364
|
-
<span class="cline-any cline-neutral"> </span>
|
|
365
|
-
<span class="cline-any cline-neutral"> </span>
|
|
366
|
-
<span class="cline-any cline-neutral"> </span>
|
|
367
|
-
<span class="cline-any cline-neutral"> </span>
|
|
368
|
-
<span class="cline-any cline-neutral"> </span>
|
|
369
|
-
<span class="cline-any cline-neutral"> </span>
|
|
370
|
-
<span class="cline-any cline-neutral"> </span>
|
|
371
|
-
<span class="cline-any cline-neutral"> </span>
|
|
372
|
-
<span class="cline-any cline-neutral"> </span>
|
|
373
|
-
<span class="cline-any cline-neutral"> </span>
|
|
374
|
-
<span class="cline-any cline-yes">59x</span>
|
|
375
|
-
<span class="cline-any cline-neutral"> </span>
|
|
376
|
-
<span class="cline-any cline-neutral"> </span>
|
|
377
|
-
<span class="cline-any cline-neutral"> </span>
|
|
378
|
-
<span class="cline-any cline-no"> </span>
|
|
379
|
-
<span class="cline-any cline-no"> </span>
|
|
380
|
-
<span class="cline-any cline-no"> </span>
|
|
381
|
-
<span class="cline-any cline-neutral"> </span>
|
|
382
|
-
<span class="cline-any cline-no"> </span>
|
|
383
|
-
<span class="cline-any cline-no"> </span>
|
|
384
|
-
<span class="cline-any cline-no"> </span>
|
|
385
|
-
<span class="cline-any cline-neutral"> </span>
|
|
386
|
-
<span class="cline-any cline-no"> </span>
|
|
387
|
-
<span class="cline-any cline-no"> </span>
|
|
388
|
-
<span class="cline-any cline-neutral"> </span>
|
|
389
|
-
<span class="cline-any cline-neutral"> </span>
|
|
390
|
-
<span class="cline-any cline-no"> </span>
|
|
391
|
-
<span class="cline-any cline-neutral"> </span>
|
|
392
|
-
<span class="cline-any cline-no"> </span>
|
|
393
|
-
<span class="cline-any cline-no"> </span>
|
|
394
|
-
<span class="cline-any cline-neutral"> </span>
|
|
395
|
-
<span class="cline-any cline-no"> </span>
|
|
396
|
-
<span class="cline-any cline-no"> </span>
|
|
397
|
-
<span class="cline-any cline-neutral"> </span>
|
|
398
|
-
<span class="cline-any cline-no"> </span>
|
|
399
|
-
<span class="cline-any cline-no"> </span>
|
|
400
|
-
<span class="cline-any cline-neutral"> </span>
|
|
401
|
-
<span class="cline-any cline-neutral"> </span>
|
|
402
|
-
<span class="cline-any cline-neutral"> </span>
|
|
403
|
-
<span class="cline-any cline-neutral"> </span>
|
|
404
|
-
<span class="cline-any cline-neutral"> </span>
|
|
405
|
-
<span class="cline-any cline-neutral"> </span>
|
|
406
|
-
<span class="cline-any cline-neutral"> </span>
|
|
407
|
-
<span class="cline-any cline-neutral"> </span>
|
|
408
|
-
<span class="cline-any cline-yes">59x</span>
|
|
409
|
-
<span class="cline-any cline-yes">1x</span>
|
|
410
|
-
<span class="cline-any cline-yes">1x</span>
|
|
411
|
-
<span class="cline-any cline-neutral"> </span>
|
|
412
|
-
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import { db as dbCore, objectStore } from "@budibase/backend-core"
|
|
413
|
-
import { budibaseTempDir } from "../../../utilities/budibaseDir"
|
|
414
|
-
import { streamFile, createTempFolder } from "../../../utilities/fileSystem"
|
|
415
|
-
import { ObjectStoreBuckets } from "../../../constants"
|
|
416
|
-
import {
|
|
417
|
-
LINK_USER_METADATA_PREFIX,
|
|
418
|
-
TABLE_ROW_PREFIX,
|
|
419
|
-
USER_METDATA_PREFIX,
|
|
420
|
-
} from "../../../db/utils"
|
|
421
|
-
import { DB_EXPORT_FILE, GLOBAL_DB_EXPORT_FILE } from "./constants"
|
|
422
|
-
import fs from "fs"
|
|
423
|
-
import { join } from "path"
|
|
424
|
-
import env from "../../../environment"
|
|
425
|
-
const uuid = require("uuid/v4")
|
|
426
|
-
const tar = require("tar")
|
|
427
|
-
const MemoryStream = require("memorystream")
|
|
428
|
-
|
|
429
|
-
type ExportOpts = {
|
|
430
|
-
filter?: any
|
|
431
|
-
exportPath?: string
|
|
432
|
-
tar?: boolean
|
|
433
|
-
excludeRows?: boolean
|
|
434
|
-
}
|
|
435
|
-
|
|
436
|
-
function tarFilesToTmp(tmpDir: string, files: string[]) {
|
|
437
|
-
const exportFile = join(budibaseTempDir(), `${uuid()}.tar.gz`)
|
|
438
|
-
tar.create(
|
|
439
|
-
{
|
|
440
|
-
sync: true,
|
|
441
|
-
gzip: true,
|
|
442
|
-
file: exportFile,
|
|
443
|
-
recursive: true,
|
|
444
|
-
cwd: tmpDir,
|
|
445
|
-
},
|
|
446
|
-
files
|
|
447
|
-
)
|
|
448
|
-
return exportFile
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
/**
|
|
452
|
-
* Exports a DB to either file or a variable (memory).
|
|
453
|
-
* @param {string} dbName the DB which is to be exported.
|
|
454
|
-
* @param {object} opts various options for the export, e.g. whether to stream,
|
|
455
|
-
* a filter function or the name of the export.
|
|
456
|
-
* @return {*} either a readable stream or a string
|
|
457
|
-
*/
|
|
458
|
-
export async function exportDB(dbName: string, opts: ExportOpts = <span class="branch-0 cbranch-no" title="branch not covered" >{})</span> {
|
|
459
|
-
return dbCore.doWithDB(dbName, async (db: any) => {
|
|
460
|
-
// Write the dump to file if required
|
|
461
|
-
if (opts?.exportPath) {
|
|
462
|
-
const path = opts?.exportPath
|
|
463
|
-
const writeStream = fs.createWriteStream(path)
|
|
464
|
-
await db.dump(writeStream, { filter: opts?.filter })
|
|
465
|
-
return path
|
|
466
|
-
} else <span class="missing-if-branch" title="else path not taken" >E</span>{
|
|
467
|
-
// Stringify the dump in memory if required
|
|
468
|
-
const memStream = <span class="cstat-no" title="statement not covered" >new MemoryStream()</span>
|
|
469
|
-
let appString = <span class="cstat-no" title="statement not covered" >""</span>
|
|
470
|
-
<span class="cstat-no" title="statement not covered" > memStream.on("data", <span class="fstat-no" title="function not covered" >(c</span>hunk: any) => {</span>
|
|
471
|
-
<span class="cstat-no" title="statement not covered" > appString += chunk.toString()</span>
|
|
472
|
-
})
|
|
473
|
-
<span class="cstat-no" title="statement not covered" > await db.dump(memStream, { filter: opts?.filter })</span>
|
|
474
|
-
<span class="cstat-no" title="statement not covered" > return appString</span>
|
|
475
|
-
}
|
|
476
|
-
})
|
|
477
|
-
}
|
|
478
|
-
|
|
479
|
-
function defineFilter(excludeRows?: boolean) {
|
|
480
|
-
const ids = [USER_METDATA_PREFIX, LINK_USER_METADATA_PREFIX]
|
|
481
|
-
<span class="missing-if-branch" title="if path not taken" >I</span>if (excludeRows) {
|
|
482
|
-
<span class="cstat-no" title="statement not covered" > ids.push(TABLE_ROW_PREFIX)</span>
|
|
483
|
-
}
|
|
484
|
-
return (doc: any) =>
|
|
485
|
-
!ids.map(key => doc._id.includes(key)).reduce((prev, curr) => prev || curr)
|
|
486
|
-
}
|
|
487
|
-
|
|
488
|
-
/**
|
|
489
|
-
* Local utility to back up the database state for an app, excluding global user
|
|
490
|
-
* data or user relationships.
|
|
491
|
-
* @param {string} appId The app to back up
|
|
492
|
-
* @param {object} config Config to send to export DB/attachment export
|
|
493
|
-
* @returns {*} either a string or a stream of the backup
|
|
494
|
-
*/
|
|
495
|
-
export async function exportApp(appId: string, config?: ExportOpts) {
|
|
496
|
-
const prodAppId = dbCore.getProdAppID(appId)
|
|
497
|
-
const appPath = `${prodAppId}/`
|
|
498
|
-
// export bucket contents
|
|
499
|
-
let tmpPath
|
|
500
|
-
<span class="missing-if-branch" title="if path not taken" >I</span>if (!env.isTest()) {
|
|
501
|
-
<span class="cstat-no" title="statement not covered" > tmpPath = await objectStore.retrieveDirectory(</span>
|
|
502
|
-
ObjectStoreBuckets.APPS,
|
|
503
|
-
appPath
|
|
504
|
-
)
|
|
505
|
-
} else {
|
|
506
|
-
tmpPath = createTempFolder(uuid())
|
|
507
|
-
}
|
|
508
|
-
const downloadedPath = join(tmpPath, appPath)
|
|
509
|
-
<span class="missing-if-branch" title="if path not taken" >I</span>if (fs.existsSync(downloadedPath)) {
|
|
510
|
-
const allFiles = <span class="cstat-no" title="statement not covered" >fs.readdirSync(downloadedPath)</span>
|
|
511
|
-
<span class="cstat-no" title="statement not covered" > for (let file of allFiles) {</span>
|
|
512
|
-
const path = <span class="cstat-no" title="statement not covered" >join(downloadedPath, file)</span>
|
|
513
|
-
// move out of app directory, simplify structure
|
|
514
|
-
<span class="cstat-no" title="statement not covered" > fs.renameSync(path, join(downloadedPath, "..", file))</span>
|
|
515
|
-
}
|
|
516
|
-
// remove the old app directory created by object export
|
|
517
|
-
<span class="cstat-no" title="statement not covered" > fs.rmdirSync(downloadedPath)</span>
|
|
518
|
-
}
|
|
519
|
-
// enforce an export of app DB to the tmp path
|
|
520
|
-
const dbPath = join(tmpPath, DB_EXPORT_FILE)
|
|
521
|
-
await exportDB(appId, {
|
|
522
|
-
...config,
|
|
523
|
-
filter: defineFilter(config?.excludeRows),
|
|
524
|
-
exportPath: dbPath,
|
|
525
|
-
})
|
|
526
|
-
// if tar requested, return where the tarball is
|
|
527
|
-
if (config?.tar) {
|
|
528
|
-
// now the tmpPath contains both the DB export and attachments, tar this
|
|
529
|
-
const tarPath = tarFilesToTmp(tmpPath, fs.readdirSync(tmpPath))
|
|
530
|
-
// cleanup the tmp export files as tarball returned
|
|
531
|
-
fs.rmSync(tmpPath, { recursive: true, force: true })
|
|
532
|
-
return tarPath
|
|
533
|
-
}
|
|
534
|
-
// tar not requested, turn the directory where export is
|
|
535
|
-
else <span class="missing-if-branch" title="else path not taken" >E</span>{
|
|
536
|
-
<span class="cstat-no" title="statement not covered" > return tmpPath</span>
|
|
537
|
-
}
|
|
538
|
-
}
|
|
539
|
-
|
|
540
|
-
/**
|
|
541
|
-
* Export all apps + global DB (if supplied) to a single tarball, this includes
|
|
542
|
-
* the attachments for each app as well.
|
|
543
|
-
* @param {object[]} appMetadata The IDs and names of apps to export.
|
|
544
|
-
* @param {string} globalDbContents The contents of the global DB to export as well.
|
|
545
|
-
* @return {string} The path to the tarball.
|
|
546
|
-
*/
|
|
547
|
-
export async function <span class="fstat-no" title="function not covered" >exportMultipleApps(</span>
|
|
548
|
-
appMetadata: { appId: string; name: string }[],
|
|
549
|
-
globalDbContents?: string
|
|
550
|
-
) {
|
|
551
|
-
const tmpPath = <span class="cstat-no" title="statement not covered" >join(budibaseTempDir(), uuid())</span>
|
|
552
|
-
<span class="cstat-no" title="statement not covered" > fs.mkdirSync(tmpPath)</span>
|
|
553
|
-
let exportPromises: Promise<void>[] = <span class="cstat-no" title="statement not covered" >[]</span>
|
|
554
|
-
// export each app to a directory, then move it into the complete export
|
|
555
|
-
const exportAndMove = <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >async (a</span>ppId: string, appName: string) => {</span>
|
|
556
|
-
const path = <span class="cstat-no" title="statement not covered" >await exportApp(appId)</span>
|
|
557
|
-
<span class="cstat-no" title="statement not covered" > await fs.promises.rename(path, join(tmpPath, appName))</span>
|
|
558
|
-
}
|
|
559
|
-
<span class="cstat-no" title="statement not covered" > for (let metadata of appMetadata) {</span>
|
|
560
|
-
<span class="cstat-no" title="statement not covered" > exportPromises.push(exportAndMove(metadata.appId, metadata.name))</span>
|
|
561
|
-
}
|
|
562
|
-
// wait for all exports to finish
|
|
563
|
-
<span class="cstat-no" title="statement not covered" > await Promise.all(exportPromises)</span>
|
|
564
|
-
// add the global DB contents
|
|
565
|
-
<span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (globalDbContents) {</span>
|
|
566
|
-
<span class="cstat-no" title="statement not covered" > fs.writeFileSync(join(tmpPath, GLOBAL_DB_EXPORT_FILE), globalDbContents)</span>
|
|
567
|
-
}
|
|
568
|
-
const appNames = <span class="cstat-no" title="statement not covered" >appMetadata.map(<span class="fstat-no" title="function not covered" >metadata => <span class="cstat-no" title="statement not covered" >m</span>etadata.name)</span></span>
|
|
569
|
-
const tarPath = <span class="cstat-no" title="statement not covered" >tarFilesToTmp(tmpPath, [...appNames, GLOBAL_DB_EXPORT_FILE])</span>
|
|
570
|
-
// clear up the tmp path now tarball generated
|
|
571
|
-
<span class="cstat-no" title="statement not covered" > fs.rmSync(tmpPath, { recursive: true, force: true })</span>
|
|
572
|
-
<span class="cstat-no" title="statement not covered" > return tarPath</span>
|
|
573
|
-
}
|
|
574
|
-
|
|
575
|
-
/**
|
|
576
|
-
* Streams a backup of the database state for an app
|
|
577
|
-
* @param {string} appId The ID of the app which is to be backed up.
|
|
578
|
-
* @param {boolean} excludeRows Flag to state whether the export should include data.
|
|
579
|
-
* @returns {*} a readable stream of the backup which is written in real time
|
|
580
|
-
*/
|
|
581
|
-
export async function streamExportApp(appId: string, excludeRows: boolean) {
|
|
582
|
-
const tmpPath = await exportApp(appId, { excludeRows, tar: true })
|
|
583
|
-
return streamFile(tmpPath)
|
|
584
|
-
}
|
|
585
|
-
</pre></td></tr></table></pre>
|
|
586
|
-
|
|
587
|
-
<div class='push'></div><!-- for sticky footer -->
|
|
588
|
-
</div><!-- /wrapper -->
|
|
589
|
-
<div class='footer quiet pad2 space-top1 center small'>
|
|
590
|
-
Code coverage generated by
|
|
591
|
-
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
592
|
-
at Wed Mar 01 2023 22:17:46 GMT+0000 (Coordinated Universal Time)
|
|
593
|
-
</div>
|
|
594
|
-
<script src="../../../../prettify.js"></script>
|
|
595
|
-
<script>
|
|
596
|
-
window.onload = function () {
|
|
597
|
-
prettyPrint();
|
|
598
|
-
};
|
|
599
|
-
</script>
|
|
600
|
-
<script src="../../../../sorter.js"></script>
|
|
601
|
-
<script src="../../../../block-navigation.js"></script>
|
|
602
|
-
</body>
|
|
603
|
-
</html>
|
|
604
|
-
|