@budibase/server 2.2.26 → 2.2.27-alpha.0
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/Dockerfile +1 -1
- package/__mocks__/aws-sdk.ts +19 -0
- package/__mocks__/node-fetch.ts +80 -0
- package/builder/assets/{bb-emblem.4e4717da.svg → bb-emblem.05f7ae7a.svg} +1 -1
- package/builder/assets/bg.29e85dd5.png +0 -0
- package/builder/assets/bulgaria.bd68393d.png +0 -0
- package/builder/assets/covanta.72c46c1e.png +0 -0
- package/builder/assets/index.3dd03883.css +6 -0
- package/builder/assets/index.f9b8b175.js +1802 -0
- package/builder/assets/schnellecke.cf1837a8.png +0 -0
- package/builder/index.html +3 -3
- package/coverage/clover.xml +6618 -6528
- package/coverage/coverage-final.json +282 -276
- package/coverage/lcov-report/index.html +489 -444
- package/coverage/lcov-report/src/api/controllers/analytics.ts.html +9 -9
- package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +6 -6
- package/coverage/lcov-report/src/api/controllers/application.ts.html +362 -266
- package/coverage/lcov-report/src/api/controllers/auth.ts.html +12 -12
- package/coverage/lcov-report/src/api/controllers/automation.ts.html +61 -61
- package/coverage/lcov-report/src/api/controllers/backup.ts.html +8 -8
- package/coverage/lcov-report/src/api/controllers/cloud.ts.html +93 -81
- package/coverage/lcov-report/src/api/controllers/component.ts.html +12 -12
- package/coverage/lcov-report/src/api/controllers/datasource.ts.html +122 -98
- package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +21 -18
- package/coverage/lcov-report/src/api/controllers/deploy/index.html +21 -21
- package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +142 -196
- package/coverage/lcov-report/src/api/controllers/dev.ts.html +28 -28
- package/coverage/lcov-report/src/api/controllers/index.html +115 -115
- package/coverage/lcov-report/src/api/controllers/integration.ts.html +5 -5
- package/coverage/lcov-report/src/api/controllers/layout.ts.html +9 -9
- package/coverage/lcov-report/src/api/controllers/metadata.ts.html +11 -11
- package/coverage/lcov-report/src/api/controllers/migrations.ts.html +6 -6
- package/coverage/lcov-report/src/api/controllers/permission.ts.html +14 -14
- package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +20 -20
- package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +62 -62
- package/coverage/lcov-report/src/api/controllers/plugin/index.html +72 -72
- package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +150 -135
- package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +56 -56
- package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +11 -11
- package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +18 -18
- package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +20 -20
- package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +75 -24
- package/coverage/lcov-report/src/api/controllers/public/index.html +58 -58
- package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +7 -7
- package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +25 -25
- package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +9 -9
- package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +8 -8
- package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +4 -4
- package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +4 -4
- package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +4 -4
- package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +15 -15
- package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +21 -21
- package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +21 -21
- package/coverage/lcov-report/src/api/controllers/public/users.ts.html +27 -27
- package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +8 -8
- package/coverage/lcov-report/src/api/controllers/query/import/index.html +8 -8
- package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +11 -11
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +14 -14
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +14 -14
- package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +8 -8
- package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +12 -12
- package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +23 -23
- package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +16 -16
- package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +20 -20
- package/coverage/lcov-report/src/api/controllers/query/index.html +20 -20
- package/coverage/lcov-report/src/api/controllers/query/index.ts.html +131 -107
- package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +11 -11
- package/coverage/lcov-report/src/api/controllers/role.ts.html +9 -9
- package/coverage/lcov-report/src/api/controllers/routing.ts.html +10 -10
- package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +56 -41
- package/coverage/lcov-report/src/api/controllers/row/external.ts.html +87 -57
- package/coverage/lcov-report/src/api/controllers/row/index.html +66 -66
- package/coverage/lcov-report/src/api/controllers/row/index.ts.html +37 -37
- package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +181 -106
- package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +146 -146
- package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +44 -35
- package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +156 -39
- package/coverage/lcov-report/src/api/controllers/screen.ts.html +31 -31
- package/coverage/lcov-report/src/api/controllers/script.ts.html +19 -19
- package/coverage/lcov-report/src/api/controllers/static/index.html +18 -18
- package/coverage/lcov-report/src/api/controllers/static/index.ts.html +56 -71
- package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +60 -60
- package/coverage/lcov-report/src/api/controllers/table/external.ts.html +56 -50
- package/coverage/lcov-report/src/api/controllers/table/index.html +48 -48
- package/coverage/lcov-report/src/api/controllers/table/index.ts.html +157 -70
- package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +58 -61
- package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +109 -112
- package/coverage/lcov-report/src/api/controllers/templates.ts.html +21 -21
- package/coverage/lcov-report/src/api/controllers/user.ts.html +159 -135
- package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +64 -19
- package/coverage/lcov-report/src/api/controllers/view/index.html +38 -38
- package/coverage/lcov-report/src/api/controllers/view/index.ts.html +97 -133
- package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +31 -31
- package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +37 -37
- package/coverage/lcov-report/src/api/controllers/webhook.ts.html +69 -63
- package/coverage/lcov-report/src/api/index.html +15 -15
- package/coverage/lcov-report/src/api/index.ts.html +40 -40
- package/coverage/lcov-report/src/api/routes/analytics.ts.html +10 -10
- package/coverage/lcov-report/src/api/routes/apikeys.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/application.ts.html +46 -13
- package/coverage/lcov-report/src/api/routes/auth.ts.html +9 -9
- package/coverage/lcov-report/src/api/routes/automation.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/backup.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/cloud.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/component.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/datasource.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/deploy.ts.html +11 -14
- package/coverage/lcov-report/src/api/routes/dev.ts.html +17 -17
- package/coverage/lcov-report/src/api/routes/index.html +68 -68
- package/coverage/lcov-report/src/api/routes/index.ts.html +49 -40
- package/coverage/lcov-report/src/api/routes/integration.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/layout.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/metadata.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/migrations.ts.html +10 -10
- package/coverage/lcov-report/src/api/routes/permission.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/plugin.ts.html +10 -10
- package/coverage/lcov-report/src/api/routes/public/applications.ts.html +147 -15
- package/coverage/lcov-report/src/api/routes/public/index.html +27 -27
- package/coverage/lcov-report/src/api/routes/public/index.ts.html +60 -60
- package/coverage/lcov-report/src/api/routes/public/middleware/index.html +15 -15
- package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +28 -16
- package/coverage/lcov-report/src/api/routes/public/queries.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/public/rows.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/public/tables.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/public/tests/index.html +7 -7
- package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +5 -5
- package/coverage/lcov-report/src/api/routes/public/users.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +21 -21
- package/coverage/lcov-report/src/api/routes/public/utils/index.html +5 -5
- package/coverage/lcov-report/src/api/routes/query.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/role.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/routing.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/row.ts.html +14 -14
- package/coverage/lcov-report/src/api/routes/screen.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/script.ts.html +13 -13
- package/coverage/lcov-report/src/api/routes/static.ts.html +18 -18
- package/coverage/lcov-report/src/api/routes/table.ts.html +29 -98
- package/coverage/lcov-report/src/api/routes/templates.ts.html +11 -11
- package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +27 -27
- package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +23 -23
- package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +33 -33
- package/coverage/lcov-report/src/api/routes/user.ts.html +12 -12
- package/coverage/lcov-report/src/api/routes/utils/index.html +3 -3
- package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +44 -44
- package/coverage/lcov-report/src/api/routes/view.ts.html +13 -13
- package/coverage/lcov-report/src/api/routes/webhook.ts.html +13 -13
- package/coverage/lcov-report/src/app.ts.html +53 -47
- package/coverage/lcov-report/src/automations/actions.ts.html +31 -31
- package/coverage/lcov-report/src/automations/automationUtils.ts.html +127 -55
- package/coverage/lcov-report/src/automations/bullboard.ts.html +19 -19
- package/coverage/lcov-report/src/automations/index.html +54 -54
- package/coverage/lcov-report/src/automations/index.ts.html +23 -23
- package/coverage/lcov-report/src/automations/logging/index.html +3 -3
- package/coverage/lcov-report/src/automations/logging/index.ts.html +15 -15
- package/coverage/lcov-report/src/automations/steps/bash.ts.html +34 -34
- package/coverage/lcov-report/src/automations/steps/createRow.ts.html +9 -9
- package/coverage/lcov-report/src/automations/steps/delay.ts.html +7 -7
- package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +9 -9
- package/coverage/lcov-report/src/automations/steps/discord.ts.html +33 -33
- package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +35 -35
- package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +31 -31
- package/coverage/lcov-report/src/automations/steps/filter.ts.html +12 -12
- package/coverage/lcov-report/src/automations/steps/index.html +129 -129
- package/coverage/lcov-report/src/automations/steps/integromat.ts.html +10 -10
- package/coverage/lcov-report/src/automations/steps/loop.ts.html +5 -5
- package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +19 -19
- package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +43 -43
- package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +28 -28
- package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +19 -19
- package/coverage/lcov-report/src/automations/steps/slack.ts.html +10 -10
- package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +12 -12
- package/coverage/lcov-report/src/automations/steps/utils.ts.html +18 -18
- package/coverage/lcov-report/src/automations/steps/zapier.ts.html +22 -22
- package/coverage/lcov-report/src/automations/tests/utilities/index.html +15 -15
- package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +32 -32
- package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggerInfo/index.html +17 -17
- package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +10 -10
- package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +6 -6
- package/coverage/lcov-report/src/automations/triggers.ts.html +53 -38
- package/coverage/lcov-report/src/automations/utils.ts.html +80 -80
- package/coverage/lcov-report/src/constants/index.html +19 -19
- package/coverage/lcov-report/src/constants/index.ts.html +103 -103
- package/coverage/lcov-report/src/constants/layouts.ts.html +9 -9
- package/coverage/lcov-report/src/constants/screens.ts.html +5 -5
- package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +45 -45
- package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +8 -8
- package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +8 -8
- package/coverage/lcov-report/src/db/defaultData/index.html +43 -43
- package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +8 -8
- package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +8 -8
- package/coverage/lcov-report/src/db/dynamoClient.ts.html +26 -26
- package/coverage/lcov-report/src/db/inMemoryView.ts.html +13 -13
- package/coverage/lcov-report/src/db/index.html +34 -34
- package/coverage/lcov-report/src/db/index.ts.html +10 -10
- package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +38 -38
- package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +7 -7
- package/coverage/lcov-report/src/db/linkedRows/index.html +37 -37
- package/coverage/lcov-report/src/db/linkedRows/index.ts.html +40 -40
- package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +25 -25
- package/coverage/lcov-report/src/db/newid.ts.html +5 -5
- package/coverage/lcov-report/src/db/utils.ts.html +90 -90
- package/coverage/lcov-report/src/definitions/automations.ts.html +9 -6
- package/coverage/lcov-report/src/definitions/index.html +5 -20
- package/coverage/lcov-report/src/environment.ts.html +44 -32
- package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +14 -14
- package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +8 -8
- package/coverage/lcov-report/src/events/index.html +20 -20
- package/coverage/lcov-report/src/events/index.ts.html +7 -7
- package/coverage/lcov-report/src/events/utils.ts.html +11 -11
- package/coverage/lcov-report/src/index.html +47 -47
- package/coverage/lcov-report/src/index.ts.html +8 -8
- package/coverage/lcov-report/src/integrations/airtable.ts.html +10 -10
- package/coverage/lcov-report/src/integrations/arangodb.ts.html +9 -9
- package/coverage/lcov-report/src/integrations/base/index.html +29 -29
- package/coverage/lcov-report/src/integrations/base/query.ts.html +15 -9
- package/coverage/lcov-report/src/integrations/base/sql.ts.html +38 -38
- package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +23 -23
- package/coverage/lcov-report/src/integrations/base/utils.ts.html +5 -5
- package/coverage/lcov-report/src/integrations/couchdb.ts.html +109 -31
- package/coverage/lcov-report/src/integrations/dynamodb.ts.html +17 -17
- package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +27 -15
- package/coverage/lcov-report/src/integrations/firebase.ts.html +12 -12
- package/coverage/lcov-report/src/integrations/googlesheets.ts.html +42 -42
- package/coverage/lcov-report/src/integrations/index.html +130 -130
- package/coverage/lcov-report/src/integrations/index.ts.html +50 -62
- package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +31 -31
- package/coverage/lcov-report/src/integrations/mongodb.ts.html +421 -289
- package/coverage/lcov-report/src/integrations/mysql.ts.html +28 -28
- package/coverage/lcov-report/src/integrations/oracle.ts.html +31 -31
- package/coverage/lcov-report/src/integrations/postgres.ts.html +54 -54
- package/coverage/lcov-report/src/integrations/queries/index.html +19 -19
- package/coverage/lcov-report/src/integrations/queries/sql.ts.html +24 -159
- package/coverage/lcov-report/src/integrations/redis.ts.html +8 -8
- package/coverage/lcov-report/src/integrations/rest.ts.html +43 -52
- package/coverage/lcov-report/src/integrations/s3.ts.html +17 -17
- package/coverage/lcov-report/src/integrations/snowflake.ts.html +15 -15
- package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
- package/coverage/lcov-report/src/integrations/tests/index.html +1 -1
- package/coverage/lcov-report/src/integrations/utils.ts.html +54 -54
- package/coverage/lcov-report/src/middleware/appInfo.ts.html +11 -11
- package/coverage/lcov-report/src/middleware/authorized.ts.html +49 -37
- package/coverage/lcov-report/src/middleware/builder.ts.html +26 -26
- package/coverage/lcov-report/src/middleware/currentapp.ts.html +50 -47
- package/coverage/lcov-report/src/middleware/index.html +40 -40
- package/coverage/lcov-report/src/middleware/joi-validator.ts.html +10 -10
- package/coverage/lcov-report/src/middleware/publicApi.ts.html +9 -9
- package/coverage/lcov-report/src/middleware/resourceId.ts.html +23 -23
- package/coverage/lcov-report/src/middleware/selfhost.ts.html +2 -2
- package/coverage/lcov-report/src/middleware/utils.ts.html +4 -4
- package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +6 -6
- package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +31 -31
- package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +8 -8
- package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +13 -13
- package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +8 -8
- package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +21 -21
- package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +17 -14
- package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +19 -19
- package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +9 -9
- package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +13 -13
- package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +23 -23
- package/coverage/lcov-report/src/migrations/functions/backfill/index.html +26 -26
- package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +14 -14
- package/coverage/lcov-report/src/migrations/functions/index.html +18 -18
- package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +8 -8
- package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +11 -11
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +11 -11
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +3 -3
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +6 -6
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +8 -8
- package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +7 -7
- package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +4 -4
- package/coverage/lcov-report/src/migrations/index.html +15 -15
- package/coverage/lcov-report/src/migrations/index.ts.html +43 -43
- package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +4 -4
- package/coverage/lcov-report/src/migrations/tests/index.html +6 -6
- package/coverage/lcov-report/src/migrations/tests/structures.ts.html +3 -3
- package/coverage/lcov-report/src/sdk/app/applications/index.html +20 -20
- package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +6 -6
- package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +34 -34
- package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +15 -15
- package/coverage/lcov-report/src/sdk/app/automations/index.html +7 -7
- package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +5 -5
- package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +8 -8
- package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +5 -5
- package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +30 -30
- package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +45 -57
- package/coverage/lcov-report/src/sdk/app/backups/index.html +42 -42
- package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +7 -7
- package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +73 -73
- package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +493 -0
- package/coverage/lcov-report/src/sdk/app/datasources/index.html +131 -0
- package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +100 -0
- package/coverage/lcov-report/src/sdk/app/queries/index.html +131 -0
- package/coverage/lcov-report/src/{utilities/statusCodes.ts.html → sdk/app/queries/index.ts.html} +22 -28
- package/coverage/lcov-report/src/{definitions/datasource.ts.html → sdk/app/queries/queries.ts.html} +82 -82
- package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +8 -8
- package/coverage/lcov-report/src/sdk/app/rows/index.html +8 -8
- package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +6 -6
- package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +4 -4
- package/coverage/lcov-report/src/sdk/app/tables/index.html +15 -15
- package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +29 -20
- package/coverage/lcov-report/src/sdk/index.html +7 -7
- package/coverage/lcov-report/src/sdk/index.ts.html +24 -12
- package/coverage/lcov-report/src/sdk/users/index.html +10 -10
- package/coverage/lcov-report/src/sdk/users/index.ts.html +5 -5
- package/coverage/lcov-report/src/sdk/users/utils.ts.html +35 -35
- package/coverage/lcov-report/src/sdk/utils/index.html +116 -0
- package/coverage/lcov-report/src/sdk/utils/index.ts.html +133 -0
- package/coverage/lcov-report/src/startup.ts.html +48 -63
- package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +218 -152
- package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +20 -20
- package/coverage/lcov-report/src/tests/utilities/index.html +33 -33
- package/coverage/lcov-report/src/tests/utilities/index.ts.html +2 -2
- package/coverage/lcov-report/src/tests/utilities/structures.ts.html +235 -46
- package/coverage/lcov-report/src/threads/automation.ts.html +212 -251
- package/coverage/lcov-report/src/threads/index.html +46 -46
- package/coverage/lcov-report/src/threads/index.ts.html +39 -39
- package/coverage/lcov-report/src/threads/query.ts.html +140 -101
- package/coverage/lcov-report/src/threads/utils.ts.html +29 -29
- package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +5 -5
- package/coverage/lcov-report/src/utilities/centralPath.ts.html +11 -11
- package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +343 -0
- package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +20 -20
- package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +601 -0
- package/coverage/lcov-report/src/utilities/fileSystem/index.html +88 -28
- package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +20 -1049
- package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +277 -0
- package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +9 -9
- package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +193 -0
- package/coverage/lcov-report/src/utilities/global.ts.html +60 -60
- package/coverage/lcov-report/src/utilities/index.html +89 -119
- package/coverage/lcov-report/src/utilities/index.ts.html +40 -172
- package/coverage/lcov-report/src/utilities/redis.ts.html +38 -38
- package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
- package/coverage/lcov-report/src/utilities/routing/index.ts.html +5 -5
- package/coverage/lcov-report/src/utilities/rowProcessor/index.html +34 -34
- package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +102 -75
- package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +9 -9
- package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +54 -54
- package/coverage/lcov-report/src/utilities/{csvParser.ts.html → schema.ts.html} +174 -234
- package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +33 -33
- package/coverage/lcov-report/src/utilities/security.ts.html +13 -13
- package/coverage/lcov-report/src/utilities/usageQuota/index.html +9 -9
- package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +38 -38
- package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +3 -3
- package/coverage/lcov-report/src/utilities/users.ts.html +7 -7
- package/coverage/lcov-report/src/utilities/workerRequests.ts.html +89 -62
- package/coverage/lcov-report/src/watch.ts.html +20 -20
- package/coverage/lcov-report/src/websocket.ts.html +15 -15
- package/coverage/lcov.info +13499 -12800
- package/dist/api/controllers/application.js +120 -109
- package/dist/api/controllers/cloud.js +6 -2
- package/dist/api/controllers/datasource.js +24 -15
- package/dist/api/controllers/deploy/index.js +43 -60
- package/dist/api/controllers/plugin/index.js +6 -6
- package/dist/api/controllers/public/applications.js +22 -1
- package/dist/api/controllers/query/index.js +23 -13
- package/dist/api/controllers/row/ExternalRequest.js +12 -4
- package/dist/api/controllers/row/external.js +20 -13
- package/dist/api/controllers/row/internal.js +52 -27
- package/dist/api/controllers/row/staticFormula.js +1 -1
- package/dist/api/controllers/row/utils.js +35 -3
- package/dist/api/controllers/static/index.js +47 -47
- package/dist/api/controllers/static/templates/BudibaseApp.svelte +0 -1
- package/dist/api/controllers/table/external.js +16 -35
- package/dist/api/controllers/table/index.js +44 -15
- package/dist/api/controllers/table/internal.js +6 -7
- package/dist/api/controllers/table/utils.js +9 -9
- package/dist/api/controllers/user.js +14 -6
- package/dist/api/controllers/view/exporters.js +22 -6
- package/dist/api/controllers/view/index.js +23 -58
- package/dist/api/controllers/view/viewBuilder.js +15 -2
- package/dist/api/controllers/webhook.js +45 -43
- package/dist/api/routes/analytics.js +2 -1
- package/dist/api/routes/apikeys.js +2 -1
- package/dist/api/routes/application.js +5 -1
- package/dist/api/routes/auth.js +2 -1
- package/dist/api/routes/automation.js +2 -1
- package/dist/api/routes/backup.js +2 -1
- package/dist/api/routes/cloud.js +2 -1
- package/dist/api/routes/component.js +2 -1
- package/dist/api/routes/datasource.js +2 -1
- package/dist/api/routes/deploy.js +3 -3
- package/dist/api/routes/dev.js +2 -1
- package/dist/api/routes/index.js +2 -0
- package/dist/api/routes/integration.js +2 -1
- package/dist/api/routes/layout.js +2 -1
- package/dist/api/routes/metadata.js +2 -1
- package/dist/api/routes/migrations.js +2 -1
- package/dist/api/routes/permission.js +2 -1
- package/dist/api/routes/public/applications.js +37 -0
- package/dist/api/routes/public/middleware/mapper.js +3 -0
- package/dist/api/routes/query.js +2 -1
- package/dist/api/routes/role.js +2 -1
- package/dist/api/routes/routing.js +2 -1
- package/dist/api/routes/row.js +2 -2
- package/dist/api/routes/screen.js +2 -1
- package/dist/api/routes/script.js +2 -1
- package/dist/api/routes/static.js +6 -5
- package/dist/api/routes/table.js +8 -38
- package/dist/api/routes/templates.js +2 -1
- package/dist/api/routes/user.js +2 -1
- package/dist/api/routes/utils/validators.js +1 -1
- package/dist/api/routes/view.js +2 -1
- package/dist/api/routes/webhook.js +2 -1
- package/dist/app.js +9 -7
- package/dist/automations/automationUtils.js +26 -1
- package/dist/automations/logging/index.js +5 -25
- package/dist/automations/triggers.js +1 -0
- package/dist/db/index.js +5 -2
- package/dist/db/linkedRows/LinkController.js +2 -1
- package/dist/db/linkedRows/LinkDocument.js +2 -1
- package/dist/db/newid.js +4 -2
- package/dist/definitions/datasource.js +0 -6
- package/dist/environment.js +7 -2
- package/dist/events/AutomationEmitter.js +2 -1
- package/dist/events/BudibaseEmitter.js +2 -1
- package/dist/events/index.js +2 -1
- package/dist/index.js +2 -2
- package/dist/integrations/base/query.js +7 -2
- package/dist/integrations/base/sqlTable.js +14 -14
- package/dist/integrations/couchdb.js +34 -8
- package/dist/integrations/dynamodb.js +8 -5
- package/dist/integrations/elasticsearch.js +7 -3
- package/dist/integrations/googlesheets.js +1 -1
- package/dist/integrations/index.js +6 -7
- package/dist/integrations/mongodb.js +311 -271
- package/dist/integrations/mysql.js +2 -2
- package/dist/integrations/queries/sql.js +73 -100
- package/dist/integrations/rest.js +16 -18
- package/dist/middleware/authorized.js +2 -1
- package/dist/middleware/builder.js +4 -2
- package/dist/middleware/currentapp.js +6 -3
- package/dist/middleware/publicApi.js +4 -2
- package/dist/middleware/selfhost.js +4 -1
- package/dist/migrations/functions/backfill/global/configs.js +4 -4
- package/dist/package.json +12 -8
- package/dist/sdk/app/backups/imports.js +2 -6
- package/dist/sdk/app/datasources/datasources.js +147 -0
- package/dist/sdk/app/datasources/index.js +27 -0
- package/dist/sdk/app/queries/index.js +27 -0
- package/dist/sdk/app/queries/queries.js +60 -0
- package/dist/sdk/app/tables/index.js +6 -2
- package/dist/sdk/index.js +4 -0
- package/dist/sdk/utils/index.js +29 -0
- package/dist/startup.js +17 -17
- package/dist/threads/automation.js +22 -35
- package/dist/threads/index.js +4 -4
- package/dist/threads/query.js +27 -13
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/utilities/fileSystem/app.js +97 -0
- package/dist/utilities/fileSystem/clientLibrary.js +3 -3
- package/dist/utilities/fileSystem/filesystem.js +184 -0
- package/dist/utilities/fileSystem/index.js +18 -342
- package/dist/utilities/fileSystem/plugin.js +66 -0
- package/dist/utilities/fileSystem/template.js +47 -0
- package/dist/utilities/index.js +1 -44
- package/dist/utilities/rowProcessor/index.js +12 -4
- package/dist/utilities/schema.js +108 -0
- package/dist/utilities/scriptRunner.js +2 -1
- package/dist/utilities/statusCodes.js +2 -1
- package/dist/utilities/workerRequests.js +2 -0
- package/dist/watch.js +2 -25
- package/jest.config.ts +5 -2
- package/package.json +13 -9
- package/scripts/dev/manage.js +3 -2
- package/specs/openapi.json +84 -0
- package/specs/openapi.yaml +53 -0
- package/specs/resources/application.js +19 -0
- package/src/api/controllers/application.ts +142 -110
- package/src/api/controllers/auth.ts +2 -2
- package/src/api/controllers/cloud.ts +10 -6
- package/src/api/controllers/datasource.ts +33 -25
- package/src/api/controllers/deploy/Deployment.ts +1 -0
- package/src/api/controllers/deploy/index.ts +40 -58
- package/src/api/controllers/plugin/index.ts +14 -9
- package/src/api/controllers/public/applications.ts +17 -0
- package/src/api/controllers/query/index.ts +49 -41
- package/src/api/controllers/row/ExternalRequest.ts +8 -3
- package/src/api/controllers/row/external.ts +24 -14
- package/src/api/controllers/row/internal.ts +66 -41
- package/src/api/controllers/row/staticFormula.ts +5 -2
- package/src/api/controllers/row/utils.ts +42 -3
- package/src/api/controllers/static/index.ts +22 -27
- package/src/api/controllers/static/templates/BudibaseApp.svelte +0 -1
- package/src/api/controllers/table/external.ts +18 -16
- package/src/api/controllers/table/index.ts +46 -17
- package/src/api/controllers/table/internal.ts +6 -7
- package/src/api/controllers/table/utils.ts +12 -13
- package/src/api/controllers/user.ts +21 -13
- package/src/api/controllers/view/exporters.ts +20 -5
- package/src/api/controllers/view/index.ts +30 -42
- package/src/api/controllers/view/tests/viewBuilder.spec.js +1 -1
- package/src/api/controllers/view/viewBuilder.ts +1 -1
- package/src/api/controllers/webhook.ts +48 -46
- package/src/api/routes/analytics.ts +1 -1
- package/src/api/routes/apikeys.ts +1 -1
- package/src/api/routes/application.ts +12 -1
- package/src/api/routes/auth.ts +1 -1
- package/src/api/routes/automation.ts +1 -1
- package/src/api/routes/backup.ts +1 -1
- package/src/api/routes/cloud.ts +1 -1
- package/src/api/routes/component.ts +1 -1
- package/src/api/routes/datasource.ts +1 -1
- package/src/api/routes/deploy.ts +1 -2
- package/src/api/routes/dev.ts +1 -1
- package/src/api/routes/index.ts +6 -3
- package/src/api/routes/integration.ts +1 -1
- package/src/api/routes/layout.ts +1 -1
- package/src/api/routes/metadata.ts +1 -1
- package/src/api/routes/migrations.ts +1 -1
- package/src/api/routes/permission.ts +1 -1
- package/src/api/routes/public/applications.ts +44 -0
- package/src/api/routes/public/middleware/mapper.ts +4 -0
- package/src/api/routes/query.ts +1 -1
- package/src/api/routes/role.ts +1 -1
- package/src/api/routes/routing.ts +1 -1
- package/src/api/routes/row.ts +1 -1
- package/src/api/routes/screen.ts +1 -1
- package/src/api/routes/script.ts +1 -1
- package/src/api/routes/static.ts +2 -2
- package/src/api/routes/table.ts +16 -39
- package/src/api/routes/templates.ts +1 -1
- package/src/api/routes/tests/__snapshots__/{datasource.spec.js.snap → datasource.spec.ts.snap} +0 -0
- package/src/api/routes/tests/{application.spec.js → application.spec.ts} +94 -18
- package/src/api/routes/tests/{backup.spec.js → backup.spec.ts} +17 -6
- package/src/api/routes/tests/cloud.spec.ts +65 -0
- package/src/api/routes/tests/data/budibase-component-1.0.1.tgz +0 -0
- package/src/api/routes/tests/data/comment-box-1.0.2.tar.gz +0 -0
- package/src/api/routes/tests/data/export-test.tar.gz +0 -0
- package/src/api/routes/tests/{datasource.spec.js → datasource.spec.ts} +56 -14
- package/src/api/routes/tests/misc.spec.js +4 -10
- package/src/api/routes/tests/permissions.spec.js +1 -1
- package/src/api/routes/tests/plugin.spec.ts +179 -0
- package/src/api/routes/tests/routing.spec.js +1 -2
- package/src/api/routes/tests/row.spec.js +4 -2
- package/src/api/routes/tests/static.spec.js +2 -17
- package/src/api/routes/tests/table.spec.js +16 -32
- package/src/api/routes/tests/user.spec.js +105 -0
- package/src/api/routes/tests/utilities/TestFunctions.ts +1 -1
- package/src/api/routes/tests/utilities/index.ts +2 -2
- package/src/api/routes/tests/webhook.spec.js +1 -1
- package/src/api/routes/user.ts +1 -1
- package/src/api/routes/utils/validators.ts +1 -1
- package/src/api/routes/view.ts +1 -1
- package/src/api/routes/webhook.ts +1 -1
- package/src/app.ts +5 -3
- package/src/automations/automationUtils.ts +24 -0
- package/src/automations/logging/index.ts +1 -1
- package/src/automations/tests/bash.spec.js +34 -0
- package/src/automations/tests/discord.spec.js +27 -0
- package/src/automations/tests/executeQuery.spec.js +49 -0
- package/src/automations/tests/executeScript.spec.js +48 -0
- package/src/automations/tests/loop.spec.ts +45 -0
- package/src/automations/tests/sendSmtpEmail.spec.js +71 -0
- package/src/automations/tests/serverLog.spec.js +22 -0
- package/src/automations/tests/utilities/index.ts +2 -2
- package/src/automations/tests/zapier.spec.js +27 -0
- package/src/automations/triggers.ts +6 -1
- package/src/automations/unitTests/automationUtils.spec.ts +65 -0
- package/src/db/index.ts +1 -1
- package/src/db/linkedRows/LinkController.ts +1 -1
- package/src/db/linkedRows/LinkDocument.ts +1 -1
- package/src/db/newid.ts +1 -1
- package/src/db/tests/linkController.spec.js +1 -1
- package/src/definitions/automations.ts +1 -0
- package/src/definitions/datasource.ts +0 -41
- package/src/definitions/openapi.ts +10 -0
- package/src/environment.ts +6 -2
- package/src/events/AutomationEmitter.ts +1 -1
- package/src/events/BudibaseEmitter.ts +1 -1
- package/src/events/index.ts +1 -1
- package/src/index.ts +1 -1
- package/src/integrations/base/query.ts +3 -1
- package/src/integrations/base/sqlTable.ts +1 -1
- package/src/integrations/couchdb.ts +40 -14
- package/src/integrations/dynamodb.ts +3 -3
- package/src/integrations/elasticsearch.ts +8 -4
- package/src/integrations/googlesheets.ts +1 -1
- package/src/integrations/index.ts +5 -9
- package/src/integrations/mongodb.ts +315 -271
- package/src/integrations/mysql.ts +1 -1
- package/src/integrations/queries/sql.ts +5 -50
- package/src/integrations/rest.ts +16 -19
- package/src/integrations/tests/couchdb.spec.ts +33 -21
- package/src/integrations/tests/rest.spec.ts +19 -15
- package/src/middleware/authorized.ts +5 -1
- package/src/middleware/builder.ts +1 -1
- package/src/middleware/currentapp.ts +4 -3
- package/src/middleware/publicApi.ts +1 -1
- package/src/middleware/selfhost.ts +1 -1
- package/src/middleware/tests/authorized.spec.js +1 -1
- package/src/middleware/tests/currentapp.spec.js +1 -1
- package/src/middleware/tests/selfhost.spec.js +1 -1
- package/src/migrations/functions/backfill/global/configs.ts +5 -4
- package/src/migrations/functions/usageQuotas/tests/syncRows.spec.ts +10 -6
- package/src/sdk/app/backups/imports.ts +2 -6
- package/src/sdk/app/datasources/datasources.ts +136 -0
- package/src/sdk/app/datasources/index.ts +5 -0
- package/src/sdk/app/queries/index.ts +5 -0
- package/src/sdk/app/queries/queries.ts +50 -0
- package/src/sdk/app/tables/index.ts +6 -3
- package/src/sdk/index.ts +4 -0
- package/src/sdk/tests/attachments.spec.ts +1 -4
- package/src/sdk/utils/index.ts +16 -0
- package/src/startup.ts +3 -8
- package/src/tests/jestEnv.ts +13 -0
- package/src/tests/jestSetup.ts +4 -15
- package/src/tests/utilities/TestConfiguration.ts +38 -16
- package/src/tests/utilities/structures.ts +65 -2
- package/src/threads/automation.ts +22 -35
- package/src/threads/definitions.ts +3 -0
- package/src/threads/index.ts +1 -1
- package/src/threads/query.ts +28 -15
- package/src/utilities/fileSystem/app.ts +86 -0
- package/src/utilities/fileSystem/clientLibrary.ts +1 -1
- package/src/utilities/fileSystem/filesystem.ts +172 -0
- package/src/utilities/fileSystem/index.ts +5 -348
- package/src/utilities/fileSystem/plugin.ts +64 -0
- package/src/utilities/fileSystem/template.ts +36 -0
- package/src/utilities/index.ts +1 -45
- package/src/utilities/rowProcessor/index.ts +17 -8
- package/src/utilities/rowProcessor/tests/utils.spec.ts +57 -0
- package/src/utilities/schema.ts +141 -0
- package/src/utilities/scriptRunner.ts +1 -1
- package/src/utilities/statusCodes.ts +1 -1
- package/src/utilities/workerRequests.ts +10 -1
- package/src/watch.ts +1 -1
- package/tsconfig.build.json +2 -0
- package/tsconfig.json +2 -1
- package/builder/assets/index.96b9ffed.css +0 -6
- package/builder/assets/index.fae8f9eb.js +0 -1024
- package/coverage/lcov-report/src/utilities/plugins.ts.html +0 -151
- package/dist/api/routes/tests/utilities/TestFunctions.js +0 -167
- package/dist/api/routes/tests/utilities/index.js +0 -131
- package/dist/automations/tests/utilities/index.js +0 -81
- package/dist/tests/utilities/TestConfiguration.js +0 -562
- package/dist/tests/utilities/controllers.js +0 -40
- package/dist/tests/utilities/structures.js +0 -168
- package/dist/utilities/csvParser.js +0 -152
- package/dist/utilities/plugins.js +0 -26
- package/src/api/routes/tests/deployment.spec.ts +0 -25
- package/src/automations/unitTests/automationUtils.spec.js +0 -17
- package/src/utilities/csvParser.ts +0 -161
- package/src/utilities/plugins.ts +0 -22
- package/src/utilities/tests/__snapshots__/csvParser.spec.js.snap +0 -15
- package/src/utilities/tests/csvParser.spec.js +0 -112
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { PathLike } from "fs"
|
|
2
|
+
import fs from "fs"
|
|
3
|
+
import { budibaseTempDir } from "../budibaseDir"
|
|
4
|
+
import { join } from "path"
|
|
5
|
+
import env from "../../environment"
|
|
6
|
+
import tar from "tar"
|
|
7
|
+
const uuid = require("uuid/v4")
|
|
8
|
+
|
|
9
|
+
export const TOP_LEVEL_PATH = join(__dirname, "..", "..", "..")
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Upon first startup of instance there may not be everything we need in tmp directory, set it up.
|
|
13
|
+
*/
|
|
14
|
+
export const init = () => {
|
|
15
|
+
const tempDir = budibaseTempDir()
|
|
16
|
+
if (!fs.existsSync(tempDir)) {
|
|
17
|
+
// some test cases fire this quickly enough that
|
|
18
|
+
// synchronous cases can end up here at the same time
|
|
19
|
+
try {
|
|
20
|
+
fs.mkdirSync(tempDir)
|
|
21
|
+
} catch (err: any) {
|
|
22
|
+
if (!err || err.code !== "EEXIST") {
|
|
23
|
+
throw err
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const clientLibPath = join(budibaseTempDir(), "budibase-client.js")
|
|
28
|
+
if (env.isTest() && !fs.existsSync(clientLibPath)) {
|
|
29
|
+
fs.copyFileSync(require.resolve("@budibase/client"), clientLibPath)
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Checks if the system is currently in development mode and if it is makes sure
|
|
35
|
+
* everything required to function is ready.
|
|
36
|
+
*/
|
|
37
|
+
export const checkDevelopmentEnvironment = () => {
|
|
38
|
+
if (!env.isDev() || env.isTest()) {
|
|
39
|
+
return
|
|
40
|
+
}
|
|
41
|
+
if (!fs.existsSync(budibaseTempDir())) {
|
|
42
|
+
fs.mkdirSync(budibaseTempDir())
|
|
43
|
+
}
|
|
44
|
+
let error
|
|
45
|
+
if (!fs.existsSync(join(process.cwd(), ".env"))) {
|
|
46
|
+
error = "Must run via yarn once to generate environment."
|
|
47
|
+
}
|
|
48
|
+
if (error) {
|
|
49
|
+
console.error(error)
|
|
50
|
+
process.exit(-1)
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Used to retrieve a handlebars file from the system which will be used as a template.
|
|
56
|
+
* This is allowable as the template handlebars files should be static and identical across
|
|
57
|
+
* the cluster.
|
|
58
|
+
* @param {string} path The path to the handlebars file which is to be loaded.
|
|
59
|
+
* @returns {string} The loaded handlebars file as a string - loaded as utf8.
|
|
60
|
+
*/
|
|
61
|
+
export const loadHandlebarsFile = (path: PathLike) => {
|
|
62
|
+
return fs.readFileSync(path, "utf8")
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* When return a file from the API need to write the file to the system temporarily so we
|
|
67
|
+
* can create a read stream to send.
|
|
68
|
+
* @param {string} contents the contents of the file which is to be returned from the API.
|
|
69
|
+
* @return {Object} the read stream which can be put into the koa context body.
|
|
70
|
+
*/
|
|
71
|
+
export const apiFileReturn = (contents: any) => {
|
|
72
|
+
const path = join(budibaseTempDir(), uuid())
|
|
73
|
+
fs.writeFileSync(path, contents)
|
|
74
|
+
return fs.createReadStream(path)
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export const streamFile = (path: string) => {
|
|
78
|
+
return fs.createReadStream(path)
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Writes the provided contents to a temporary file, which can be used briefly.
|
|
83
|
+
* @param {string} fileContents contents which will be written to a temp file.
|
|
84
|
+
* @return {string} the path to the temp file.
|
|
85
|
+
*/
|
|
86
|
+
export const storeTempFile = (fileContents: any) => {
|
|
87
|
+
const path = join(budibaseTempDir(), uuid())
|
|
88
|
+
fs.writeFileSync(path, fileContents)
|
|
89
|
+
return path
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* Utility function for getting a file read stream - a simple in memory buffered read
|
|
94
|
+
* stream doesn't work for pouchdb.
|
|
95
|
+
*/
|
|
96
|
+
export const stringToFileStream = (contents: any) => {
|
|
97
|
+
const path = storeTempFile(contents)
|
|
98
|
+
return fs.createReadStream(path)
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Creates a temp file and returns it from the API.
|
|
103
|
+
* @param {string} fileContents the contents to be returned in file.
|
|
104
|
+
*/
|
|
105
|
+
export const sendTempFile = (fileContents: any) => {
|
|
106
|
+
const path = storeTempFile(fileContents)
|
|
107
|
+
return fs.createReadStream(path)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* All file reads come through here just to make sure all of them make sense
|
|
112
|
+
* allows a centralised location to check logic is all good.
|
|
113
|
+
*/
|
|
114
|
+
export const readFileSync = (filepath: PathLike, options = "utf8") => {
|
|
115
|
+
// @ts-ignore
|
|
116
|
+
return fs.readFileSync(filepath, options)
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export const createTempFolder = (item: any) => {
|
|
120
|
+
const path = join(budibaseTempDir(), item)
|
|
121
|
+
try {
|
|
122
|
+
// remove old tmp directories automatically - don't combine
|
|
123
|
+
if (fs.existsSync(path)) {
|
|
124
|
+
fs.rmSync(path, { recursive: true, force: true })
|
|
125
|
+
}
|
|
126
|
+
fs.mkdirSync(path)
|
|
127
|
+
} catch (err: any) {
|
|
128
|
+
throw new Error(`Path cannot be created: ${err.message}`)
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return path
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
export const extractTarball = async (fromFilePath: string, toPath: string) => {
|
|
135
|
+
await tar.extract({
|
|
136
|
+
file: fromFilePath,
|
|
137
|
+
C: toPath,
|
|
138
|
+
})
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* Find for a file recursively from start path applying filter, return first match
|
|
143
|
+
*/
|
|
144
|
+
export const findFileRec = (startPath: PathLike, filter: string): any => {
|
|
145
|
+
if (!fs.existsSync(startPath)) {
|
|
146
|
+
return
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
const files = fs.readdirSync(startPath)
|
|
150
|
+
for (let i = 0, len = files.length; i < len; i++) {
|
|
151
|
+
// @ts-ignore
|
|
152
|
+
const filename = join(startPath, files[i])
|
|
153
|
+
const stat = fs.lstatSync(filename)
|
|
154
|
+
|
|
155
|
+
if (stat.isDirectory()) {
|
|
156
|
+
return findFileRec(filename, filter)
|
|
157
|
+
} else if (filename.endsWith(filter)) {
|
|
158
|
+
return filename
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/**
|
|
164
|
+
* Remove a folder which is not empty from the file system
|
|
165
|
+
*/
|
|
166
|
+
export const deleteFolderFileSystem = (path: PathLike) => {
|
|
167
|
+
if (!fs.existsSync(path)) {
|
|
168
|
+
return
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
fs.rmSync(path, { recursive: true, force: true })
|
|
172
|
+
}
|
|
@@ -1,348 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
import { updateClientLibrary } from "./clientLibrary"
|
|
7
|
-
import { checkSlashesInUrl } from "../"
|
|
8
|
-
import env from "../../environment"
|
|
9
|
-
import fetch from "node-fetch"
|
|
10
|
-
const uuid = require("uuid/v4")
|
|
11
|
-
const tar = require("tar")
|
|
12
|
-
|
|
13
|
-
export const TOP_LEVEL_PATH = join(__dirname, "..", "..", "..")
|
|
14
|
-
export const NODE_MODULES_PATH = join(TOP_LEVEL_PATH, "node_modules")
|
|
15
|
-
const DATASOURCE_PATH = join(budibaseTempDir(), "datasource")
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* The single stack system (Cloud and Builder) should not make use of the file system where possible,
|
|
19
|
-
* this file handles all of the file access for the system with the intention of limiting it all to one
|
|
20
|
-
* place. Keeping all of this logic in one place means that when we need to do file system access (like
|
|
21
|
-
* downloading a package or opening a temporary file) in can be done in way that we can confirm it shouldn't
|
|
22
|
-
* be done through an object store instead.
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Upon first startup of instance there may not be everything we need in tmp directory, set it up.
|
|
27
|
-
*/
|
|
28
|
-
export function init() {
|
|
29
|
-
const tempDir = budibaseTempDir()
|
|
30
|
-
if (!fs.existsSync(tempDir)) {
|
|
31
|
-
// some test cases fire this quickly enough that
|
|
32
|
-
// synchronous cases can end up here at the same time
|
|
33
|
-
try {
|
|
34
|
-
fs.mkdirSync(tempDir)
|
|
35
|
-
} catch (err: any) {
|
|
36
|
-
if (!err || err.code !== "EEXIST") {
|
|
37
|
-
throw err
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
const clientLibPath = join(budibaseTempDir(), "budibase-client.js")
|
|
42
|
-
if (env.isTest() && !fs.existsSync(clientLibPath)) {
|
|
43
|
-
fs.copyFileSync(require.resolve("@budibase/client"), clientLibPath)
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Checks if the system is currently in development mode and if it is makes sure
|
|
49
|
-
* everything required to function is ready.
|
|
50
|
-
*/
|
|
51
|
-
exports.checkDevelopmentEnvironment = () => {
|
|
52
|
-
if (!env.isDev() || env.isTest()) {
|
|
53
|
-
return
|
|
54
|
-
}
|
|
55
|
-
if (!fs.existsSync(budibaseTempDir())) {
|
|
56
|
-
fs.mkdirSync(budibaseTempDir())
|
|
57
|
-
}
|
|
58
|
-
let error
|
|
59
|
-
if (!fs.existsSync(join(process.cwd(), ".env"))) {
|
|
60
|
-
error = "Must run via yarn once to generate environment."
|
|
61
|
-
}
|
|
62
|
-
if (error) {
|
|
63
|
-
console.error(error)
|
|
64
|
-
process.exit(-1)
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Used to retrieve a handlebars file from the system which will be used as a template.
|
|
70
|
-
* This is allowable as the template handlebars files should be static and identical across
|
|
71
|
-
* the cluster.
|
|
72
|
-
* @param {string} path The path to the handlebars file which is to be loaded.
|
|
73
|
-
* @returns {string} The loaded handlebars file as a string - loaded as utf8.
|
|
74
|
-
*/
|
|
75
|
-
export function loadHandlebarsFile(path: string) {
|
|
76
|
-
return fs.readFileSync(path, "utf8")
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* When return a file from the API need to write the file to the system temporarily so we
|
|
81
|
-
* can create a read stream to send.
|
|
82
|
-
* @param {string} contents the contents of the file which is to be returned from the API.
|
|
83
|
-
* @param {string} encoding the encoding of the file to return (utf8 default)
|
|
84
|
-
* @return {Object} the read stream which can be put into the koa context body.
|
|
85
|
-
*/
|
|
86
|
-
export function apiFileReturn(
|
|
87
|
-
contents: string,
|
|
88
|
-
encoding: BufferEncoding = "utf8"
|
|
89
|
-
) {
|
|
90
|
-
const path = join(budibaseTempDir(), uuid())
|
|
91
|
-
fs.writeFileSync(path, contents, { encoding })
|
|
92
|
-
return fs.createReadStream(path, { encoding })
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
export function streamFile(path: string) {
|
|
96
|
-
return fs.createReadStream(path)
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
* Writes the provided contents to a temporary file, which can be used briefly.
|
|
101
|
-
* @param {string} fileContents contents which will be written to a temp file.
|
|
102
|
-
* @return {string} the path to the temp file.
|
|
103
|
-
*/
|
|
104
|
-
export function storeTempFile(fileContents: string) {
|
|
105
|
-
const path = join(budibaseTempDir(), uuid())
|
|
106
|
-
fs.writeFileSync(path, fileContents)
|
|
107
|
-
return path
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* Utility function for getting a file read stream - a simple in memory buffered read
|
|
112
|
-
* stream doesn't work for pouchdb.
|
|
113
|
-
*/
|
|
114
|
-
export function stringToFileStream(contents: string) {
|
|
115
|
-
const path = exports.storeTempFile(contents)
|
|
116
|
-
return fs.createReadStream(path)
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
/**
|
|
120
|
-
* Creates a temp file and returns it from the API.
|
|
121
|
-
* @param {string} fileContents the contents to be returned in file.
|
|
122
|
-
*/
|
|
123
|
-
export function sendTempFile(fileContents: string) {
|
|
124
|
-
const path = exports.storeTempFile(fileContents)
|
|
125
|
-
return fs.createReadStream(path)
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
/**
|
|
129
|
-
* Uploads the latest client library to the object store.
|
|
130
|
-
* @param {string} appId The ID of the app which is being created.
|
|
131
|
-
* @return {Promise<void>} once promise completes app resources should be ready in object store.
|
|
132
|
-
*/
|
|
133
|
-
export async function createApp(appId: string) {
|
|
134
|
-
await updateClientLibrary(appId)
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
/**
|
|
138
|
-
* Removes all of the assets created for an app in the object store.
|
|
139
|
-
* @param {string} appId The ID of the app which is being deleted.
|
|
140
|
-
* @return {Promise<void>} once promise completes the app resources will be removed from object store.
|
|
141
|
-
*/
|
|
142
|
-
export async function deleteApp(appId: string) {
|
|
143
|
-
await objectStore.deleteFolder(ObjectStoreBuckets.APPS, `${appId}/`)
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
/**
|
|
147
|
-
* Retrieves a template and pipes it to minio as well as making it available temporarily.
|
|
148
|
-
* @param {string} type The type of template which is to be retrieved.
|
|
149
|
-
* @param name
|
|
150
|
-
* @return {Promise<*>}
|
|
151
|
-
*/
|
|
152
|
-
export async function downloadTemplate(type: string, name: string) {
|
|
153
|
-
const DEFAULT_TEMPLATES_BUCKET =
|
|
154
|
-
"prod-budi-templates.s3-eu-west-1.amazonaws.com"
|
|
155
|
-
const templateUrl = `https://${DEFAULT_TEMPLATES_BUCKET}/templates/${type}/${name}.tar.gz`
|
|
156
|
-
return objectStore.downloadTarball(
|
|
157
|
-
templateUrl,
|
|
158
|
-
ObjectStoreBuckets.TEMPLATES,
|
|
159
|
-
type
|
|
160
|
-
)
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
/**
|
|
164
|
-
* Retrieves component libraries from object store (or tmp symlink if in local)
|
|
165
|
-
*/
|
|
166
|
-
export async function getComponentLibraryManifest(library: string) {
|
|
167
|
-
const appId = context.getAppId()
|
|
168
|
-
const filename = "manifest.json"
|
|
169
|
-
/* istanbul ignore next */
|
|
170
|
-
// when testing in cypress and so on we need to get the package
|
|
171
|
-
// as the environment may not be fully fleshed out for dev or prod
|
|
172
|
-
if (env.isTest()) {
|
|
173
|
-
library = library.replace("standard-components", "client")
|
|
174
|
-
const lib = library.split("/")[1]
|
|
175
|
-
const path = require.resolve(library).split(lib)[0]
|
|
176
|
-
return require(join(path, lib, filename))
|
|
177
|
-
} else if (env.isDev()) {
|
|
178
|
-
const path = join(NODE_MODULES_PATH, "@budibase", "client", filename)
|
|
179
|
-
// always load from new so that updates are refreshed
|
|
180
|
-
delete require.cache[require.resolve(path)]
|
|
181
|
-
return require(path)
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
if (!appId) {
|
|
185
|
-
throw new Error("No app ID found - cannot get component libraries")
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
let resp
|
|
189
|
-
let path
|
|
190
|
-
try {
|
|
191
|
-
// Try to load the manifest from the new file location
|
|
192
|
-
path = join(appId, filename)
|
|
193
|
-
resp = await objectStore.retrieve(ObjectStoreBuckets.APPS, path)
|
|
194
|
-
} catch (error) {
|
|
195
|
-
console.error(
|
|
196
|
-
`component-manifest-objectstore=failed appId=${appId} path=${path}`,
|
|
197
|
-
error
|
|
198
|
-
)
|
|
199
|
-
// Fallback to loading it from the old location for old apps
|
|
200
|
-
path = join(appId, "node_modules", library, "package", filename)
|
|
201
|
-
resp = await objectStore.retrieve(ObjectStoreBuckets.APPS, path)
|
|
202
|
-
}
|
|
203
|
-
if (typeof resp !== "string") {
|
|
204
|
-
resp = resp.toString("utf8")
|
|
205
|
-
}
|
|
206
|
-
return JSON.parse(resp)
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
* All file reads come through here just to make sure all of them make sense
|
|
211
|
-
* allows a centralised location to check logic is all good.
|
|
212
|
-
*/
|
|
213
|
-
export function readFileSync(
|
|
214
|
-
filepath: string,
|
|
215
|
-
options: BufferEncoding = "utf8"
|
|
216
|
-
) {
|
|
217
|
-
return fs.readFileSync(filepath, { encoding: options })
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
/**
|
|
221
|
-
* Given a set of app IDs makes sure file system is cleared of any of their temp info.
|
|
222
|
-
*/
|
|
223
|
-
export function cleanup(appIds: string[]) {
|
|
224
|
-
for (let appId of appIds) {
|
|
225
|
-
const path = join(budibaseTempDir(), appId)
|
|
226
|
-
if (fs.existsSync(path)) {
|
|
227
|
-
fs.rmdirSync(path, { recursive: true })
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
export function createTempFolder(item: string) {
|
|
233
|
-
const path = join(budibaseTempDir(), item)
|
|
234
|
-
try {
|
|
235
|
-
// remove old tmp directories automatically - don't combine
|
|
236
|
-
if (fs.existsSync(path)) {
|
|
237
|
-
fs.rmSync(path, { recursive: true, force: true })
|
|
238
|
-
}
|
|
239
|
-
fs.mkdirSync(path)
|
|
240
|
-
} catch (err: any) {
|
|
241
|
-
throw new Error(`Path cannot be created: ${err.message}`)
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
return path
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
export async function extractTarball(fromFilePath: string, toPath: string) {
|
|
248
|
-
await tar.extract({
|
|
249
|
-
file: fromFilePath,
|
|
250
|
-
C: toPath,
|
|
251
|
-
})
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
export async function getPluginMetadata(path: string) {
|
|
255
|
-
let metadata: { schema?: any; package?: any } = {}
|
|
256
|
-
try {
|
|
257
|
-
const pkg = fs.readFileSync(join(path, "package.json"), "utf8")
|
|
258
|
-
const schema = fs.readFileSync(join(path, "schema.json"), "utf8")
|
|
259
|
-
|
|
260
|
-
metadata.schema = JSON.parse(schema)
|
|
261
|
-
metadata.package = JSON.parse(pkg)
|
|
262
|
-
|
|
263
|
-
if (
|
|
264
|
-
!metadata.package.name ||
|
|
265
|
-
!metadata.package.version ||
|
|
266
|
-
!metadata.package.description
|
|
267
|
-
) {
|
|
268
|
-
throw new Error(
|
|
269
|
-
"package.json is missing one of 'name', 'version' or 'description'."
|
|
270
|
-
)
|
|
271
|
-
}
|
|
272
|
-
} catch (err: any) {
|
|
273
|
-
throw new Error(
|
|
274
|
-
`Unable to process schema.json/package.json in plugin. ${err.message}`
|
|
275
|
-
)
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
return { metadata, directory: path }
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
export async function getDatasourcePlugin(
|
|
282
|
-
name: string,
|
|
283
|
-
url: string,
|
|
284
|
-
hash: string
|
|
285
|
-
) {
|
|
286
|
-
if (!fs.existsSync(DATASOURCE_PATH)) {
|
|
287
|
-
fs.mkdirSync(DATASOURCE_PATH)
|
|
288
|
-
}
|
|
289
|
-
const filename = join(DATASOURCE_PATH, name)
|
|
290
|
-
const metadataName = `${filename}.bbmetadata`
|
|
291
|
-
if (fs.existsSync(filename)) {
|
|
292
|
-
const currentHash = fs.readFileSync(metadataName, "utf8")
|
|
293
|
-
// if hash is the same return the file, otherwise remove it and re-download
|
|
294
|
-
if (currentHash === hash) {
|
|
295
|
-
return require(filename)
|
|
296
|
-
} else {
|
|
297
|
-
console.log(`Updating plugin: ${name}`)
|
|
298
|
-
delete require.cache[require.resolve(filename)]
|
|
299
|
-
fs.unlinkSync(filename)
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
const fullUrl = checkSlashesInUrl(
|
|
303
|
-
`${env.MINIO_URL}/${ObjectStoreBuckets.PLUGINS}/${url}`
|
|
304
|
-
)
|
|
305
|
-
const response = await fetch(fullUrl)
|
|
306
|
-
if (response.status === 200) {
|
|
307
|
-
const content = await response.text()
|
|
308
|
-
fs.writeFileSync(filename, content)
|
|
309
|
-
fs.writeFileSync(metadataName, hash)
|
|
310
|
-
return require(filename)
|
|
311
|
-
} else {
|
|
312
|
-
throw new Error(
|
|
313
|
-
`Unable to retrieve plugin - reason: ${await response.text()}`
|
|
314
|
-
)
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
/**
|
|
319
|
-
* Find for a file recursively from start path applying filter, return first match
|
|
320
|
-
*/
|
|
321
|
-
export function findFileRec(startPath: string, filter: any) {
|
|
322
|
-
if (!fs.existsSync(startPath)) {
|
|
323
|
-
return
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
const files = fs.readdirSync(startPath)
|
|
327
|
-
for (let i = 0, len = files.length; i < len; i++) {
|
|
328
|
-
const filename = join(startPath, files[i])
|
|
329
|
-
const stat = fs.lstatSync(filename)
|
|
330
|
-
|
|
331
|
-
if (stat.isDirectory()) {
|
|
332
|
-
return exports.findFileRec(filename, filter)
|
|
333
|
-
} else if (filename.endsWith(filter)) {
|
|
334
|
-
return filename
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
/**
|
|
340
|
-
* Remove a folder which is not empty from the file system
|
|
341
|
-
*/
|
|
342
|
-
export function deleteFolderFileSystem(path: string) {
|
|
343
|
-
if (!fs.existsSync(path)) {
|
|
344
|
-
return
|
|
345
|
-
}
|
|
346
|
-
|
|
347
|
-
fs.rmSync(path, { recursive: true, force: true })
|
|
348
|
-
}
|
|
1
|
+
export * from "./app"
|
|
2
|
+
export * from "./clientLibrary"
|
|
3
|
+
export * from "./filesystem"
|
|
4
|
+
export * from "./plugin"
|
|
5
|
+
export * from "./template"
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Plugin } from "@budibase/types"
|
|
2
|
+
import { budibaseTempDir } from "../budibaseDir"
|
|
3
|
+
import fs from "fs"
|
|
4
|
+
import { join } from "path"
|
|
5
|
+
import { objectStore } from "@budibase/backend-core"
|
|
6
|
+
|
|
7
|
+
const DATASOURCE_PATH = join(budibaseTempDir(), "datasource")
|
|
8
|
+
|
|
9
|
+
export const getPluginMetadata = async (path: string) => {
|
|
10
|
+
let metadata: any = {}
|
|
11
|
+
try {
|
|
12
|
+
const pkg = fs.readFileSync(join(path, "package.json"), "utf8")
|
|
13
|
+
const schema = fs.readFileSync(join(path, "schema.json"), "utf8")
|
|
14
|
+
|
|
15
|
+
metadata.schema = JSON.parse(schema)
|
|
16
|
+
metadata.package = JSON.parse(pkg)
|
|
17
|
+
|
|
18
|
+
if (
|
|
19
|
+
!metadata.package.name ||
|
|
20
|
+
!metadata.package.version ||
|
|
21
|
+
!metadata.package.description
|
|
22
|
+
) {
|
|
23
|
+
throw new Error(
|
|
24
|
+
"package.json is missing one of 'name', 'version' or 'description'."
|
|
25
|
+
)
|
|
26
|
+
}
|
|
27
|
+
} catch (err: any) {
|
|
28
|
+
throw new Error(
|
|
29
|
+
`Unable to process schema.json/package.json in plugin. ${err.message}`
|
|
30
|
+
)
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return { metadata, directory: path }
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export const getDatasourcePlugin = async (plugin: Plugin) => {
|
|
37
|
+
const hash = plugin.schema?.hash
|
|
38
|
+
if (!fs.existsSync(DATASOURCE_PATH)) {
|
|
39
|
+
fs.mkdirSync(DATASOURCE_PATH)
|
|
40
|
+
}
|
|
41
|
+
const filename = join(DATASOURCE_PATH, plugin.name)
|
|
42
|
+
const metadataName = `${filename}.bbmetadata`
|
|
43
|
+
if (fs.existsSync(filename)) {
|
|
44
|
+
const currentHash = fs.readFileSync(metadataName, "utf8")
|
|
45
|
+
// if hash is the same return the file, otherwise remove it and re-download
|
|
46
|
+
if (currentHash === hash) {
|
|
47
|
+
return require(filename)
|
|
48
|
+
} else {
|
|
49
|
+
console.log(`Updating plugin: ${plugin.name}`)
|
|
50
|
+
delete require.cache[require.resolve(filename)]
|
|
51
|
+
fs.unlinkSync(filename)
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
const pluginKey = objectStore.getPluginJSKey(plugin)
|
|
55
|
+
const pluginJs = await objectStore.retrieve(
|
|
56
|
+
objectStore.ObjectStoreBuckets.PLUGINS,
|
|
57
|
+
pluginKey
|
|
58
|
+
)
|
|
59
|
+
|
|
60
|
+
fs.writeFileSync(filename, pluginJs)
|
|
61
|
+
fs.writeFileSync(metadataName, hash)
|
|
62
|
+
|
|
63
|
+
return require(filename)
|
|
64
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import fs from "fs"
|
|
2
|
+
import { join } from "path"
|
|
3
|
+
import { ObjectStoreBuckets } from "../../constants"
|
|
4
|
+
import { objectStore } from "@budibase/backend-core"
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* This function manages temporary template files which are stored by Koa.
|
|
8
|
+
* @param {Object} template The template object retrieved from the Koa context object.
|
|
9
|
+
* @returns {Object} Returns an fs read stream which can be loaded into the database.
|
|
10
|
+
*/
|
|
11
|
+
export const getTemplateStream = async (template: any) => {
|
|
12
|
+
if (template.file) {
|
|
13
|
+
return fs.createReadStream(template.file.path)
|
|
14
|
+
} else {
|
|
15
|
+
const [type, name] = template.key.split("/")
|
|
16
|
+
const tmpPath = await downloadTemplate(type, name)
|
|
17
|
+
return fs.createReadStream(join(tmpPath, name, "db", "dump.txt"))
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Retrieves a template and pipes it to minio as well as making it available temporarily.
|
|
23
|
+
* @param {string} type The type of template which is to be retrieved.
|
|
24
|
+
* @param name
|
|
25
|
+
* @return {Promise<*>}
|
|
26
|
+
*/
|
|
27
|
+
export const downloadTemplate = async (type: string, name: string) => {
|
|
28
|
+
const DEFAULT_TEMPLATES_BUCKET =
|
|
29
|
+
"prod-budi-templates.s3-eu-west-1.amazonaws.com"
|
|
30
|
+
const templateUrl = `https://${DEFAULT_TEMPLATES_BUCKET}/templates/${type}/${name}.tar.gz`
|
|
31
|
+
return objectStore.downloadTarball(
|
|
32
|
+
templateUrl,
|
|
33
|
+
ObjectStoreBuckets.TEMPLATES,
|
|
34
|
+
type
|
|
35
|
+
)
|
|
36
|
+
}
|
package/src/utilities/index.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import env from "../environment"
|
|
2
|
-
import {
|
|
3
|
-
import { objectStore, context } from "@budibase/backend-core"
|
|
2
|
+
import { context } from "@budibase/backend-core"
|
|
4
3
|
import { generateMetadataID } from "../db/utils"
|
|
5
4
|
import { Document } from "@budibase/types"
|
|
6
5
|
import stream from "stream"
|
|
@@ -32,49 +31,6 @@ export function checkSlashesInUrl(url: string) {
|
|
|
32
31
|
return url.replace(/(https?:\/\/)|(\/)+/g, "$1$2")
|
|
33
32
|
}
|
|
34
33
|
|
|
35
|
-
/**
|
|
36
|
-
* Gets the address of the object store, depending on whether self hosted or in cloud.
|
|
37
|
-
* @return {string} The base URL of the object store (MinIO or S3).
|
|
38
|
-
*/
|
|
39
|
-
export function objectStoreUrl() {
|
|
40
|
-
if (env.SELF_HOSTED || env.MINIO_URL) {
|
|
41
|
-
// can use a relative url for this as all goes through the proxy (this is hosted in minio)
|
|
42
|
-
return OBJ_STORE_DIRECTORY
|
|
43
|
-
} else {
|
|
44
|
-
return env.CDN_URL
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
* In production the client library is stored in the object store, however in development
|
|
50
|
-
* we use the symlinked version produced by lerna, located in node modules. We link to this
|
|
51
|
-
* via a specific endpoint (under /api/assets/client).
|
|
52
|
-
* @param {string} appId In production we need the appId to look up the correct bucket, as the
|
|
53
|
-
* version of the client lib may differ between apps.
|
|
54
|
-
* @param {string} version The version to retrieve.
|
|
55
|
-
* @return {string} The URL to be inserted into appPackage response or server rendered
|
|
56
|
-
* app index file.
|
|
57
|
-
*/
|
|
58
|
-
export function clientLibraryPath(appId: string, version: string) {
|
|
59
|
-
if (env.isProd()) {
|
|
60
|
-
let url = `${objectStoreUrl()}/${objectStore.sanitizeKey(
|
|
61
|
-
appId
|
|
62
|
-
)}/budibase-client.js`
|
|
63
|
-
|
|
64
|
-
// append app version to bust the cache
|
|
65
|
-
if (version) {
|
|
66
|
-
url += `?v=${version}`
|
|
67
|
-
}
|
|
68
|
-
return url
|
|
69
|
-
} else {
|
|
70
|
-
return `/api/assets/client`
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
export function attachmentsRelativeURL(attachmentKey: string) {
|
|
75
|
-
return checkSlashesInUrl(`${objectStoreUrl()}/${attachmentKey}`)
|
|
76
|
-
}
|
|
77
|
-
|
|
78
34
|
export async function updateEntityMetadata(
|
|
79
35
|
type: string,
|
|
80
36
|
entityId: string,
|