@budibase/server 2.6.19-alpha.2 → 2.6.19-alpha.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.dockerignore +7 -6
- package/Dockerfile +16 -8
- package/builder/assets/{index.07382a47.css → index.46d94ca7.css} +2 -2
- package/builder/assets/{index.6c1171e2.js → index.9a9bace2.js} +346 -338
- package/builder/index.html +2 -2
- package/client/manifest.json +5229 -0
- package/dist/automation.js +32208 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +44381 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24327 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +3 -0
- package/nodemon.json +1 -1
- package/package.json +30 -13
- package/pm2.config.js +1 -1
- package/scripts/build.js +48 -0
- package/src/api/controllers/datasource.ts +16 -0
- package/src/api/controllers/row/internal.ts +1 -1
- package/src/api/controllers/static/index.ts +3 -3
- package/src/api/controllers/table/internal.ts +2 -6
- package/src/api/controllers/table/utils.ts +32 -1
- package/src/api/routes/datasource.ts +5 -0
- package/src/api/routes/static.ts +3 -1
- package/src/api/routes/tests/datasource.spec.ts +1 -1
- package/src/automations/actions.ts +5 -0
- package/src/automations/steps/openai.ts +105 -0
- package/src/automations/tests/openai.spec.ts +86 -0
- package/src/constants/index.ts +17 -16
- package/src/db/inMemoryView.ts +1 -0
- package/src/environment.ts +2 -0
- package/src/integration-test/postgres.spec.ts +47 -4
- package/src/integrations/airtable.ts +3 -1
- package/src/integrations/arangodb.ts +3 -1
- package/src/integrations/base/sqlTable.ts +0 -1
- package/src/integrations/couchdb.ts +3 -1
- package/src/integrations/dynamodb.ts +3 -1
- package/src/integrations/elasticsearch.ts +3 -1
- package/src/integrations/firebase.ts +3 -1
- package/src/integrations/googlesheets.ts +11 -3
- package/src/integrations/microsoftSqlServer.ts +18 -2
- package/src/integrations/mongodb.ts +3 -1
- package/src/integrations/mysql.ts +27 -11
- package/src/integrations/oracle.ts +11 -1
- package/src/integrations/postgres.ts +27 -10
- package/src/integrations/redis.ts +3 -1
- package/src/integrations/s3.ts +3 -1
- package/src/integrations/snowflake.ts +3 -1
- package/src/integrations/tests/googlesheets.spec.ts +41 -9
- package/src/utilities/fileSystem/app.ts +1 -1
- package/src/utilities/fileSystem/clientLibrary.ts +8 -3
- package/src/utilities/fileSystem/filesystem.ts +3 -1
- package/tsconfig.build.json +9 -1
- package/tsconfig.json +1 -14
- package/dist/api/controllers/analytics.js +0 -46
- package/dist/api/controllers/apikeys.js +0 -72
- package/dist/api/controllers/application.js +0 -574
- package/dist/api/controllers/auth.js +0 -80
- package/dist/api/controllers/automation.js +0 -303
- package/dist/api/controllers/backup.js +0 -37
- package/dist/api/controllers/component.js +0 -59
- package/dist/api/controllers/datasource.js +0 -337
- package/dist/api/controllers/deploy/Deployment.js +0 -53
- package/dist/api/controllers/deploy/index.js +0 -198
- package/dist/api/controllers/dev.js +0 -146
- package/dist/api/controllers/integration.js +0 -28
- package/dist/api/controllers/layout.js +0 -49
- package/dist/api/controllers/metadata.js +0 -63
- package/dist/api/controllers/migrations.js +0 -29
- package/dist/api/controllers/ops.js +0 -40
- package/dist/api/controllers/permission.js +0 -162
- package/dist/api/controllers/plugin/file.js +0 -24
- package/dist/api/controllers/plugin/github.js +0 -69
- package/dist/api/controllers/plugin/index.js +0 -112
- package/dist/api/controllers/plugin/npm.js +0 -58
- package/dist/api/controllers/plugin/uploaders.js +0 -11
- package/dist/api/controllers/plugin/url.js +0 -24
- package/dist/api/controllers/plugin/utils.js +0 -27
- package/dist/api/controllers/public/applications.js +0 -146
- package/dist/api/controllers/public/mapping/applications.js +0 -29
- package/dist/api/controllers/public/mapping/index.js +0 -11
- package/dist/api/controllers/public/mapping/queries.js +0 -36
- package/dist/api/controllers/public/mapping/rows.js +0 -24
- package/dist/api/controllers/public/mapping/tables.js +0 -23
- package/dist/api/controllers/public/mapping/types.js +0 -2
- package/dist/api/controllers/public/mapping/users.js +0 -29
- package/dist/api/controllers/public/metrics.js +0 -113
- package/dist/api/controllers/public/queries.js +0 -58
- package/dist/api/controllers/public/rows.js +0 -120
- package/dist/api/controllers/public/tables.js +0 -95
- package/dist/api/controllers/public/users.js +0 -93
- package/dist/api/controllers/public/utils.js +0 -56
- package/dist/api/controllers/query/import/index.js +0 -87
- package/dist/api/controllers/query/import/sources/base/index.js +0 -75
- package/dist/api/controllers/query/import/sources/base/openapi.js +0 -42
- package/dist/api/controllers/query/import/sources/curl.js +0 -99
- package/dist/api/controllers/query/import/sources/openapi2.js +0 -145
- package/dist/api/controllers/query/import/sources/openapi3.js +0 -177
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi2/data/petstore/petstore.json +0 -1054
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/crud/crud.json +0 -253
- package/dist/api/controllers/query/import/sources/tests/openapi3/data/petstore/petstore.json +0 -1225
- package/dist/api/controllers/query/index.js +0 -299
- package/dist/api/controllers/query/validation.js +0 -53
- package/dist/api/controllers/role.js +0 -109
- package/dist/api/controllers/routing.js +0 -105
- package/dist/api/controllers/row/ExternalRequest.js +0 -683
- package/dist/api/controllers/row/external.js +0 -339
- package/dist/api/controllers/row/index.js +0 -203
- package/dist/api/controllers/row/internal.js +0 -509
- package/dist/api/controllers/row/internalSearch.js +0 -28
- package/dist/api/controllers/row/staticFormula.js +0 -165
- package/dist/api/controllers/row/utils.js +0 -183
- package/dist/api/controllers/screen.js +0 -110
- package/dist/api/controllers/script.js +0 -30
- package/dist/api/controllers/static/index.js +0 -268
- package/dist/api/controllers/table/bulkFormula.js +0 -173
- package/dist/api/controllers/table/external.js +0 -279
- package/dist/api/controllers/table/index.js +0 -179
- package/dist/api/controllers/table/internal.js +0 -197
- package/dist/api/controllers/table/utils.js +0 -379
- package/dist/api/controllers/templates.js +0 -56
- package/dist/api/controllers/user.js +0 -124
- package/dist/api/controllers/view/exporters.js +0 -46
- package/dist/api/controllers/view/index.js +0 -193
- package/dist/api/controllers/view/utils.js +0 -177
- package/dist/api/controllers/view/viewBuilder.js +0 -158
- package/dist/api/controllers/webhook.js +0 -134
- package/dist/api/index.js +0 -55
- package/dist/api/routes/analytics.js +0 -34
- package/dist/api/routes/apikeys.js +0 -37
- package/dist/api/routes/application.js +0 -48
- package/dist/api/routes/auth.js +0 -33
- package/dist/api/routes/automation.js +0 -50
- package/dist/api/routes/backup.js +0 -35
- package/dist/api/routes/component.js +0 -35
- package/dist/api/routes/datasource.js +0 -44
- package/dist/api/routes/deploy.js +0 -37
- package/dist/api/routes/dev.js +0 -49
- package/dist/api/routes/index.js +0 -75
- package/dist/api/routes/integration.js +0 -37
- package/dist/api/routes/layout.js +0 -37
- package/dist/api/routes/metadata.js +0 -40
- package/dist/api/routes/migrations.js +0 -36
- package/dist/api/routes/ops.js +0 -52
- package/dist/api/routes/permission.js +0 -44
- package/dist/api/routes/plugin.js +0 -39
- package/dist/api/routes/public/applications.js +0 -174
- package/dist/api/routes/public/index.js +0 -140
- package/dist/api/routes/public/metrics.js +0 -30
- package/dist/api/routes/public/middleware/mapper.js +0 -97
- package/dist/api/routes/public/queries.js +0 -72
- package/dist/api/routes/public/rows.js +0 -158
- package/dist/api/routes/public/tables.js +0 -152
- package/dist/api/routes/public/users.js +0 -135
- package/dist/api/routes/public/utils/Endpoint.js +0 -36
- package/dist/api/routes/query.js +0 -47
- package/dist/api/routes/role.js +0 -40
- package/dist/api/routes/routing.js +0 -39
- package/dist/api/routes/row.js +0 -239
- package/dist/api/routes/screen.js +0 -39
- package/dist/api/routes/script.js +0 -35
- package/dist/api/routes/static.js +0 -80
- package/dist/api/routes/table.js +0 -163
- package/dist/api/routes/templates.js +0 -37
- package/dist/api/routes/user.js +0 -43
- package/dist/api/routes/utils/validators.js +0 -238
- package/dist/api/routes/view.js +0 -42
- package/dist/api/routes/webhook.js +0 -43
- package/dist/app.js +0 -132
- package/dist/automations/actions.js +0 -137
- package/dist/automations/automationUtils.js +0 -173
- package/dist/automations/bullboard.js +0 -71
- package/dist/automations/index.js +0 -43
- package/dist/automations/logging/index.js +0 -53
- package/dist/automations/steps/bash.js +0 -111
- package/dist/automations/steps/createRow.js +0 -108
- package/dist/automations/steps/delay.js +0 -53
- package/dist/automations/steps/deleteRow.js +0 -96
- package/dist/automations/steps/discord.js +0 -116
- package/dist/automations/steps/executeQuery.js +0 -134
- package/dist/automations/steps/executeScript.js +0 -106
- package/dist/automations/steps/filter.js +0 -112
- package/dist/automations/steps/loop.js +0 -54
- package/dist/automations/steps/make.js +0 -134
- package/dist/automations/steps/outgoingWebhook.js +0 -166
- package/dist/automations/steps/queryRows.js +0 -216
- package/dist/automations/steps/sendSmtpEmail.js +0 -115
- package/dist/automations/steps/serverLog.js +0 -65
- package/dist/automations/steps/slack.js +0 -98
- package/dist/automations/steps/updateRow.js +0 -144
- package/dist/automations/steps/utils.js +0 -56
- package/dist/automations/steps/zapier.js +0 -130
- package/dist/automations/triggerInfo/app.js +0 -36
- package/dist/automations/triggerInfo/cron.js +0 -35
- package/dist/automations/triggerInfo/index.js +0 -40
- package/dist/automations/triggerInfo/rowDeleted.js +0 -36
- package/dist/automations/triggerInfo/rowSaved.js +0 -44
- package/dist/automations/triggerInfo/rowUpdated.js +0 -44
- package/dist/automations/triggerInfo/webhook.js +0 -40
- package/dist/automations/triggers.js +0 -181
- package/dist/automations/utils.js +0 -275
- package/dist/constants/definitions.js +0 -2
- package/dist/constants/index.js +0 -181
- package/dist/constants/layouts.js +0 -148
- package/dist/constants/screens.js +0 -51
- package/dist/db/defaultData/datasource_bb_default.js +0 -574
- package/dist/db/defaultData/employeeImport.js +0 -155
- package/dist/db/defaultData/expensesImport.js +0 -117
- package/dist/db/defaultData/inventoryImport.js +0 -109
- package/dist/db/defaultData/jobsImport.js +0 -152
- package/dist/db/dynamoClient.js +0 -124
- package/dist/db/inMemoryView.js +0 -62
- package/dist/db/index.js +0 -43
- package/dist/db/linkedRows/LinkController.js +0 -392
- package/dist/db/linkedRows/LinkDocument.js +0 -33
- package/dist/db/linkedRows/index.js +0 -206
- package/dist/db/linkedRows/linkUtils.js +0 -131
- package/dist/db/newid.js +0 -7
- package/dist/db/utils.js +0 -248
- package/dist/db/views/staticViews.js +0 -144
- package/dist/ddApm.js +0 -11
- package/dist/definitions/automations.js +0 -8
- package/dist/definitions/common.js +0 -2
- package/dist/definitions/datasource.js +0 -7
- package/dist/definitions/openapi.js +0 -6
- package/dist/environment.js +0 -109
- package/dist/events/AutomationEmitter.js +0 -53
- package/dist/events/BudibaseEmitter.js +0 -25
- package/dist/events/docUpdates/index.js +0 -17
- package/dist/events/docUpdates/processors.js +0 -18
- package/dist/events/docUpdates/syncUsers.js +0 -49
- package/dist/events/index.js +0 -11
- package/dist/events/utils.js +0 -43
- package/dist/integrations/airtable.js +0 -173
- package/dist/integrations/arangodb.js +0 -119
- package/dist/integrations/base/query.js +0 -32
- package/dist/integrations/base/sql.js +0 -600
- package/dist/integrations/base/sqlTable.js +0 -167
- package/dist/integrations/base/types.js +0 -2
- package/dist/integrations/couchdb.js +0 -140
- package/dist/integrations/dynamodb.js +0 -210
- package/dist/integrations/elasticsearch.js +0 -201
- package/dist/integrations/firebase.js +0 -189
- package/dist/integrations/googlesheets.js +0 -484
- package/dist/integrations/index.js +0 -138
- package/dist/integrations/microsoftSqlServer.js +0 -289
- package/dist/integrations/mongodb.js +0 -630
- package/dist/integrations/mysql.js +0 -272
- package/dist/integrations/oracle.js +0 -404
- package/dist/integrations/postgres.js +0 -319
- package/dist/integrations/queries/sql.js +0 -84
- package/dist/integrations/redis.js +0 -187
- package/dist/integrations/rest.js +0 -400
- package/dist/integrations/s3.js +0 -256
- package/dist/integrations/snowflake.js +0 -114
- package/dist/integrations/utils.js +0 -295
- package/dist/middleware/appInfo.js +0 -22
- package/dist/middleware/authorized.js +0 -112
- package/dist/middleware/builder.js +0 -93
- package/dist/middleware/currentapp.js +0 -103
- package/dist/middleware/joi-validator.js +0 -43
- package/dist/middleware/publicApi.js +0 -25
- package/dist/middleware/resourceId.js +0 -59
- package/dist/middleware/selfhost.js +0 -24
- package/dist/middleware/utils.js +0 -8
- package/dist/migrations/functions/appUrls.js +0 -42
- package/dist/migrations/functions/backfill/app/automations.js +0 -31
- package/dist/migrations/functions/backfill/app/datasources.js +0 -28
- package/dist/migrations/functions/backfill/app/layouts.js +0 -33
- package/dist/migrations/functions/backfill/app/queries.js +0 -49
- package/dist/migrations/functions/backfill/app/roles.js +0 -28
- package/dist/migrations/functions/backfill/app/screens.js +0 -28
- package/dist/migrations/functions/backfill/app/tables.js +0 -37
- package/dist/migrations/functions/backfill/app.js +0 -176
- package/dist/migrations/functions/backfill/global/configs.js +0 -67
- package/dist/migrations/functions/backfill/global/quotas.js +0 -60
- package/dist/migrations/functions/backfill/global/users.js +0 -50
- package/dist/migrations/functions/backfill/global.js +0 -205
- package/dist/migrations/functions/backfill/index.js +0 -32
- package/dist/migrations/functions/backfill/installation.js +0 -80
- package/dist/migrations/functions/syncQuotas.js +0 -52
- package/dist/migrations/functions/tableSettings.js +0 -130
- package/dist/migrations/functions/usageQuotas/index.js +0 -16
- package/dist/migrations/functions/usageQuotas/syncApps.js +0 -24
- package/dist/migrations/functions/usageQuotas/syncPlugins.js +0 -23
- package/dist/migrations/functions/usageQuotas/syncRows.js +0 -33
- package/dist/migrations/functions/usageQuotas/syncUsers.js +0 -21
- package/dist/migrations/functions/userEmailViewCasing.js +0 -24
- package/dist/migrations/index.js +0 -111
- package/dist/migrations/tests/helpers.js +0 -72
- package/dist/migrations/tests/structures.js +0 -37
- package/dist/sdk/app/applications/index.js +0 -28
- package/dist/sdk/app/applications/sync.js +0 -164
- package/dist/sdk/app/applications/utils.js +0 -21
- package/dist/sdk/app/automations/index.js +0 -29
- package/dist/sdk/app/automations/webhook.js +0 -54
- package/dist/sdk/app/backups/constants.js +0 -6
- package/dist/sdk/app/backups/exports.js +0 -160
- package/dist/sdk/app/backups/imports.js +0 -170
- package/dist/sdk/app/backups/index.js +0 -29
- package/dist/sdk/app/backups/statistics.js +0 -73
- package/dist/sdk/app/datasources/datasources.js +0 -173
- package/dist/sdk/app/datasources/index.js +0 -27
- package/dist/sdk/app/queries/index.js +0 -27
- package/dist/sdk/app/queries/queries.js +0 -60
- package/dist/sdk/app/rows/attachments.js +0 -61
- package/dist/sdk/app/rows/index.js +0 -28
- package/dist/sdk/app/rows/rows.js +0 -30
- package/dist/sdk/app/tables/index.js +0 -65
- package/dist/sdk/index.js +0 -27
- package/dist/sdk/plugins/index.js +0 -27
- package/dist/sdk/plugins/plugins.js +0 -53
- package/dist/sdk/users/index.js +0 -27
- package/dist/sdk/users/utils.js +0 -87
- package/dist/sdk/utils/index.js +0 -29
- package/dist/startup.js +0 -158
- package/dist/threads/automation.js +0 -450
- package/dist/threads/definitions.js +0 -2
- package/dist/threads/index.js +0 -140
- package/dist/threads/query.js +0 -265
- package/dist/threads/utils.js +0 -120
- package/dist/tsconfig.build.tsbuildinfo +0 -1
- package/dist/utilities/appDirectoryTemplate/package.json +0 -10
- package/dist/utilities/budibaseDir.js +0 -5
- package/dist/utilities/centralPath.js +0 -27
- package/dist/utilities/csv.js +0 -33
- package/dist/utilities/fileSystem/app.js +0 -88
- package/dist/utilities/fileSystem/clientLibrary.js +0 -138
- package/dist/utilities/fileSystem/filesystem.js +0 -180
- package/dist/utilities/fileSystem/index.js +0 -21
- package/dist/utilities/fileSystem/plugin.js +0 -76
- package/dist/utilities/fileSystem/processor.js +0 -34
- package/dist/utilities/fileSystem/template.js +0 -47
- package/dist/utilities/global.js +0 -149
- package/dist/utilities/index.js +0 -143
- package/dist/utilities/redis.js +0 -117
- package/dist/utilities/retry.js +0 -30
- package/dist/utilities/routing/index.js +0 -39
- package/dist/utilities/rowProcessor/index.js +0 -282
- package/dist/utilities/rowProcessor/map.js +0 -116
- package/dist/utilities/rowProcessor/utils.js +0 -87
- package/dist/utilities/schema.js +0 -112
- package/dist/utilities/scriptRunner.js +0 -26
- package/dist/utilities/security.js +0 -57
- package/dist/utilities/statusCodes.js +0 -9
- package/dist/utilities/usageQuota/rows.js +0 -88
- package/dist/utilities/usageQuota/usageQuoteReset.js +0 -16
- package/dist/utilities/users.js +0 -57
- package/dist/utilities/workerRequests.js +0 -171
- package/dist/watch.js +0 -53
- package/dist/websockets/client.js +0 -14
- package/dist/websockets/grid.js +0 -60
- package/dist/websockets/index.js +0 -17
- package/dist/websockets/websocket.js +0 -78
- /package/dist/{api/controllers/static/templates/BudibaseApp.svelte → BudibaseApp-Y5NZEDTC.svelte} +0 -0
- /package/dist/{api/controllers/static/templates/app.hbs → app.hbs} +0 -0
- /package/dist/{api/controllers/static/templates/preview.hbs → preview.hbs} +0 -0
|
@@ -1,337 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.query = exports.find = exports.destroy = exports.save = exports.update = exports.buildSchemaFromDb = exports.verify = exports.fetch = void 0;
|
|
16
|
-
const utils_1 = require("../../db/utils");
|
|
17
|
-
const internal_1 = require("./table/internal");
|
|
18
|
-
const constants_1 = require("../../constants");
|
|
19
|
-
const integrations_1 = require("../../integrations");
|
|
20
|
-
const utils_2 = require("./row/utils");
|
|
21
|
-
const utils_3 = require("../../threads/utils");
|
|
22
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
23
|
-
const sdk_1 = __importDefault(require("../../sdk"));
|
|
24
|
-
function getErrorTables(errors, errorType) {
|
|
25
|
-
return Object.entries(errors)
|
|
26
|
-
.filter(entry => entry[1] === errorType)
|
|
27
|
-
.map(([name]) => name);
|
|
28
|
-
}
|
|
29
|
-
function updateError(error, newError, tables) {
|
|
30
|
-
if (!error) {
|
|
31
|
-
error = "";
|
|
32
|
-
}
|
|
33
|
-
if (error.length > 0) {
|
|
34
|
-
error += "\n";
|
|
35
|
-
}
|
|
36
|
-
error += `${newError} ${tables.join(", ")}`;
|
|
37
|
-
return error;
|
|
38
|
-
}
|
|
39
|
-
function getConnector(datasource) {
|
|
40
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
const Connector = yield (0, integrations_1.getIntegration)(datasource.source);
|
|
42
|
-
// can't enrich if it doesn't have an ID yet
|
|
43
|
-
if (datasource._id) {
|
|
44
|
-
datasource = yield sdk_1.default.datasources.enrich(datasource);
|
|
45
|
-
}
|
|
46
|
-
// Connect to the DB and build the schema
|
|
47
|
-
return new Connector(datasource.config);
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
function buildSchemaHelper(datasource) {
|
|
51
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
52
|
-
const connector = (yield getConnector(datasource));
|
|
53
|
-
yield connector.buildSchema(datasource._id, datasource.entities);
|
|
54
|
-
const errors = connector.schemaErrors;
|
|
55
|
-
let error = null;
|
|
56
|
-
if (errors && Object.keys(errors).length > 0) {
|
|
57
|
-
const noKey = getErrorTables(errors, constants_1.BuildSchemaErrors.NO_KEY);
|
|
58
|
-
const invalidCol = getErrorTables(errors, constants_1.BuildSchemaErrors.INVALID_COLUMN);
|
|
59
|
-
if (noKey.length) {
|
|
60
|
-
error = updateError(error, "No primary key constraint found for the following:", noKey);
|
|
61
|
-
}
|
|
62
|
-
if (invalidCol.length) {
|
|
63
|
-
const invalidCols = Object.values(constants_1.InvalidColumns).join(", ");
|
|
64
|
-
error = updateError(error, `Cannot use columns ${invalidCols} found in following:`, invalidCol);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
return { tables: connector.tables, error };
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
function fetch(ctx) {
|
|
71
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
72
|
-
// Get internal tables
|
|
73
|
-
const db = backend_core_1.context.getAppDB();
|
|
74
|
-
const internalTables = yield db.allDocs((0, utils_1.getTableParams)(null, {
|
|
75
|
-
include_docs: true,
|
|
76
|
-
}));
|
|
77
|
-
const internal = internalTables.rows.reduce((acc, row) => {
|
|
78
|
-
const sourceId = row.doc.sourceId || "bb_internal";
|
|
79
|
-
acc[sourceId] = acc[sourceId] || [];
|
|
80
|
-
acc[sourceId].push(row.doc);
|
|
81
|
-
return acc;
|
|
82
|
-
}, {});
|
|
83
|
-
const bbInternalDb = Object.assign({}, utils_1.BudibaseInternalDB);
|
|
84
|
-
// Get external datasources
|
|
85
|
-
const datasources = (yield db.allDocs((0, utils_1.getDatasourceParams)(null, {
|
|
86
|
-
include_docs: true,
|
|
87
|
-
}))).rows.map(row => row.doc);
|
|
88
|
-
const allDatasources = yield sdk_1.default.datasources.removeSecrets([
|
|
89
|
-
bbInternalDb,
|
|
90
|
-
...datasources,
|
|
91
|
-
]);
|
|
92
|
-
for (let datasource of allDatasources) {
|
|
93
|
-
if (datasource.type === backend_core_1.db.BUDIBASE_DATASOURCE_TYPE) {
|
|
94
|
-
datasource.entities = internal[datasource._id];
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
ctx.body = [bbInternalDb, ...datasources];
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
exports.fetch = fetch;
|
|
101
|
-
function verify(ctx) {
|
|
102
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
103
|
-
const { datasource } = ctx.request.body;
|
|
104
|
-
let existingDatasource;
|
|
105
|
-
if (datasource._id) {
|
|
106
|
-
existingDatasource = yield sdk_1.default.datasources.get(datasource._id);
|
|
107
|
-
}
|
|
108
|
-
let enrichedDatasource = datasource;
|
|
109
|
-
if (existingDatasource) {
|
|
110
|
-
enrichedDatasource = sdk_1.default.datasources.mergeConfigs(datasource, existingDatasource);
|
|
111
|
-
}
|
|
112
|
-
const connector = yield getConnector(enrichedDatasource);
|
|
113
|
-
if (!connector.testConnection) {
|
|
114
|
-
ctx.throw(400, "Connection information verification not supported");
|
|
115
|
-
}
|
|
116
|
-
const response = yield connector.testConnection();
|
|
117
|
-
ctx.body = {
|
|
118
|
-
connected: response.connected,
|
|
119
|
-
error: response.error,
|
|
120
|
-
};
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
exports.verify = verify;
|
|
124
|
-
function buildSchemaFromDb(ctx) {
|
|
125
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
const db = backend_core_1.context.getAppDB();
|
|
127
|
-
const datasource = yield sdk_1.default.datasources.get(ctx.params.datasourceId);
|
|
128
|
-
const tablesFilter = ctx.request.body.tablesFilter;
|
|
129
|
-
let { tables, error } = yield buildSchemaHelper(datasource);
|
|
130
|
-
if (tablesFilter) {
|
|
131
|
-
if (!datasource.entities) {
|
|
132
|
-
datasource.entities = {};
|
|
133
|
-
}
|
|
134
|
-
for (let key in tables) {
|
|
135
|
-
if (tablesFilter.some((filter) => filter.toLowerCase() === key.toLowerCase())) {
|
|
136
|
-
datasource.entities[key] = tables[key];
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
else {
|
|
141
|
-
datasource.entities = tables;
|
|
142
|
-
}
|
|
143
|
-
setDefaultDisplayColumns(datasource);
|
|
144
|
-
const dbResp = yield db.put(datasource);
|
|
145
|
-
datasource._rev = dbResp.rev;
|
|
146
|
-
const cleanedDatasource = yield sdk_1.default.datasources.removeSecretSingle(datasource);
|
|
147
|
-
const response = { datasource: cleanedDatasource };
|
|
148
|
-
if (error) {
|
|
149
|
-
response.error = error;
|
|
150
|
-
}
|
|
151
|
-
ctx.body = response;
|
|
152
|
-
});
|
|
153
|
-
}
|
|
154
|
-
exports.buildSchemaFromDb = buildSchemaFromDb;
|
|
155
|
-
/**
|
|
156
|
-
* Make sure all datasource entities have a display name selected
|
|
157
|
-
*/
|
|
158
|
-
function setDefaultDisplayColumns(datasource) {
|
|
159
|
-
//
|
|
160
|
-
for (let entity of Object.values(datasource.entities || {})) {
|
|
161
|
-
if (entity.primaryDisplay) {
|
|
162
|
-
continue;
|
|
163
|
-
}
|
|
164
|
-
const notAutoColumn = Object.values(entity.schema).find(schema => !schema.autocolumn);
|
|
165
|
-
if (notAutoColumn) {
|
|
166
|
-
entity.primaryDisplay = notAutoColumn.name;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* Check for variables that have been updated or removed and invalidate them.
|
|
172
|
-
*/
|
|
173
|
-
function invalidateVariables(existingDatasource, updatedDatasource) {
|
|
174
|
-
var _a, _b;
|
|
175
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
176
|
-
const existingVariables = (_a = existingDatasource.config) === null || _a === void 0 ? void 0 : _a.dynamicVariables;
|
|
177
|
-
const updatedVariables = (_b = updatedDatasource.config) === null || _b === void 0 ? void 0 : _b.dynamicVariables;
|
|
178
|
-
const toInvalidate = [];
|
|
179
|
-
if (!existingVariables) {
|
|
180
|
-
return;
|
|
181
|
-
}
|
|
182
|
-
if (!updatedVariables) {
|
|
183
|
-
// invalidate all
|
|
184
|
-
toInvalidate.push(...existingVariables);
|
|
185
|
-
}
|
|
186
|
-
else {
|
|
187
|
-
// invaldate changed / removed
|
|
188
|
-
existingVariables.forEach((existing) => {
|
|
189
|
-
const unchanged = updatedVariables.find((updated) => existing.name === updated.name &&
|
|
190
|
-
existing.queryId === updated.queryId &&
|
|
191
|
-
existing.value === updated.value);
|
|
192
|
-
if (!unchanged) {
|
|
193
|
-
toInvalidate.push(existing);
|
|
194
|
-
}
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
yield (0, utils_3.invalidateDynamicVariables)(toInvalidate);
|
|
198
|
-
});
|
|
199
|
-
}
|
|
200
|
-
function update(ctx) {
|
|
201
|
-
var _a, _b;
|
|
202
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
203
|
-
const db = backend_core_1.context.getAppDB();
|
|
204
|
-
const datasourceId = ctx.params.datasourceId;
|
|
205
|
-
let datasource = yield sdk_1.default.datasources.get(datasourceId);
|
|
206
|
-
const auth = (_a = datasource.config) === null || _a === void 0 ? void 0 : _a.auth;
|
|
207
|
-
yield invalidateVariables(datasource, ctx.request.body);
|
|
208
|
-
const isBudibaseSource = datasource.type === backend_core_1.db.BUDIBASE_DATASOURCE_TYPE;
|
|
209
|
-
const dataSourceBody = isBudibaseSource
|
|
210
|
-
? { name: (_b = ctx.request.body) === null || _b === void 0 ? void 0 : _b.name }
|
|
211
|
-
: ctx.request.body;
|
|
212
|
-
datasource = Object.assign(Object.assign({}, datasource), sdk_1.default.datasources.mergeConfigs(dataSourceBody, datasource));
|
|
213
|
-
if (auth && !ctx.request.body.auth) {
|
|
214
|
-
// don't strip auth config from DB
|
|
215
|
-
datasource.config.auth = auth;
|
|
216
|
-
}
|
|
217
|
-
const response = yield db.put(datasource);
|
|
218
|
-
yield backend_core_1.events.datasource.updated(datasource);
|
|
219
|
-
datasource._rev = response.rev;
|
|
220
|
-
// Drain connection pools when configuration is changed
|
|
221
|
-
if (datasource.source && !isBudibaseSource) {
|
|
222
|
-
const source = yield (0, integrations_1.getIntegration)(datasource.source);
|
|
223
|
-
if (source && source.pool) {
|
|
224
|
-
yield source.pool.end();
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
ctx.status = 200;
|
|
228
|
-
ctx.message = "Datasource saved successfully.";
|
|
229
|
-
ctx.body = {
|
|
230
|
-
datasource: yield sdk_1.default.datasources.removeSecretSingle(datasource),
|
|
231
|
-
};
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
exports.update = update;
|
|
235
|
-
function save(ctx) {
|
|
236
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
237
|
-
const db = backend_core_1.context.getAppDB();
|
|
238
|
-
const plus = ctx.request.body.datasource.plus;
|
|
239
|
-
const fetchSchema = ctx.request.body.fetchSchema;
|
|
240
|
-
const datasource = Object.assign(Object.assign({ _id: (0, utils_1.generateDatasourceID)({ plus }) }, ctx.request.body.datasource), { type: plus ? utils_1.DocumentType.DATASOURCE_PLUS : utils_1.DocumentType.DATASOURCE });
|
|
241
|
-
let schemaError = null;
|
|
242
|
-
if (fetchSchema) {
|
|
243
|
-
const { tables, error } = yield buildSchemaHelper(datasource);
|
|
244
|
-
schemaError = error;
|
|
245
|
-
datasource.entities = tables;
|
|
246
|
-
setDefaultDisplayColumns(datasource);
|
|
247
|
-
}
|
|
248
|
-
const dbResp = yield db.put(datasource);
|
|
249
|
-
yield backend_core_1.events.datasource.created(datasource);
|
|
250
|
-
datasource._rev = dbResp.rev;
|
|
251
|
-
// Drain connection pools when configuration is changed
|
|
252
|
-
if (datasource.source) {
|
|
253
|
-
const source = yield (0, integrations_1.getIntegration)(datasource.source);
|
|
254
|
-
if (source && source.pool) {
|
|
255
|
-
yield source.pool.end();
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
const response = {
|
|
259
|
-
datasource: yield sdk_1.default.datasources.removeSecretSingle(datasource),
|
|
260
|
-
};
|
|
261
|
-
if (schemaError) {
|
|
262
|
-
response.error = schemaError;
|
|
263
|
-
}
|
|
264
|
-
ctx.body = response;
|
|
265
|
-
});
|
|
266
|
-
}
|
|
267
|
-
exports.save = save;
|
|
268
|
-
function destroyInternalTablesBySourceId(datasourceId) {
|
|
269
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
270
|
-
const db = backend_core_1.context.getAppDB();
|
|
271
|
-
// Get all internal tables
|
|
272
|
-
const internalTables = yield db.allDocs((0, utils_1.getTableParams)(null, {
|
|
273
|
-
include_docs: true,
|
|
274
|
-
}));
|
|
275
|
-
// Filter by datasource and return the docs.
|
|
276
|
-
const datasourceTableDocs = internalTables.rows.reduce((acc, table) => {
|
|
277
|
-
if (table.doc.sourceId == datasourceId) {
|
|
278
|
-
acc.push(table.doc);
|
|
279
|
-
}
|
|
280
|
-
return acc;
|
|
281
|
-
}, []);
|
|
282
|
-
// Destroy the tables.
|
|
283
|
-
for (const table of datasourceTableDocs) {
|
|
284
|
-
yield (0, internal_1.destroy)({
|
|
285
|
-
params: {
|
|
286
|
-
tableId: table._id,
|
|
287
|
-
},
|
|
288
|
-
});
|
|
289
|
-
}
|
|
290
|
-
});
|
|
291
|
-
}
|
|
292
|
-
function destroy(ctx) {
|
|
293
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
294
|
-
const db = backend_core_1.context.getAppDB();
|
|
295
|
-
const datasourceId = ctx.params.datasourceId;
|
|
296
|
-
const datasource = yield sdk_1.default.datasources.get(datasourceId);
|
|
297
|
-
// Delete all queries for the datasource
|
|
298
|
-
if (datasource.type === backend_core_1.db.BUDIBASE_DATASOURCE_TYPE) {
|
|
299
|
-
yield destroyInternalTablesBySourceId(datasourceId);
|
|
300
|
-
}
|
|
301
|
-
else {
|
|
302
|
-
const queries = yield db.allDocs((0, utils_1.getQueryParams)(datasourceId, null));
|
|
303
|
-
yield db.bulkDocs(queries.rows.map((row) => ({
|
|
304
|
-
_id: row.id,
|
|
305
|
-
_rev: row.value.rev,
|
|
306
|
-
_deleted: true,
|
|
307
|
-
})));
|
|
308
|
-
}
|
|
309
|
-
// delete the datasource
|
|
310
|
-
yield db.remove(datasourceId, ctx.params.revId);
|
|
311
|
-
yield backend_core_1.events.datasource.deleted(datasource);
|
|
312
|
-
ctx.message = `Datasource deleted.`;
|
|
313
|
-
ctx.status = 200;
|
|
314
|
-
});
|
|
315
|
-
}
|
|
316
|
-
exports.destroy = destroy;
|
|
317
|
-
function find(ctx) {
|
|
318
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
319
|
-
const database = backend_core_1.context.getAppDB();
|
|
320
|
-
const datasource = yield database.get(ctx.params.datasourceId);
|
|
321
|
-
ctx.body = yield sdk_1.default.datasources.removeSecretSingle(datasource);
|
|
322
|
-
});
|
|
323
|
-
}
|
|
324
|
-
exports.find = find;
|
|
325
|
-
// dynamic query functionality
|
|
326
|
-
function query(ctx) {
|
|
327
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
328
|
-
const queryJson = ctx.request.body;
|
|
329
|
-
try {
|
|
330
|
-
ctx.body = yield (0, utils_2.getDatasourceAndQuery)(queryJson);
|
|
331
|
-
}
|
|
332
|
-
catch (err) {
|
|
333
|
-
ctx.throw(400, err);
|
|
334
|
-
}
|
|
335
|
-
});
|
|
336
|
-
}
|
|
337
|
-
exports.query = query;
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const newid_1 = __importDefault(require("../../../db/newid"));
|
|
7
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
8
|
-
/**
|
|
9
|
-
* This is used to pass around information about the deployment that is occurring
|
|
10
|
-
*/
|
|
11
|
-
class Deployment {
|
|
12
|
-
constructor(id = null) {
|
|
13
|
-
this._id = id || (0, newid_1.default)();
|
|
14
|
-
}
|
|
15
|
-
setVerification(verification) {
|
|
16
|
-
if (!verification) {
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
this.verification = verification;
|
|
20
|
-
}
|
|
21
|
-
getVerification() {
|
|
22
|
-
return this.verification;
|
|
23
|
-
}
|
|
24
|
-
setStatus(status, err) {
|
|
25
|
-
this.status = status;
|
|
26
|
-
if (err) {
|
|
27
|
-
this.err = err;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
fromJSON(json) {
|
|
31
|
-
if (json.verification) {
|
|
32
|
-
this.setVerification(json.verification);
|
|
33
|
-
}
|
|
34
|
-
if (json.status) {
|
|
35
|
-
this.setStatus(json.status, json.err);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
getJSON() {
|
|
39
|
-
const obj = {
|
|
40
|
-
_id: this._id,
|
|
41
|
-
appId: backend_core_1.context.getAppId(),
|
|
42
|
-
status: this.status,
|
|
43
|
-
};
|
|
44
|
-
if (this.err) {
|
|
45
|
-
obj.err = this.err;
|
|
46
|
-
}
|
|
47
|
-
if (this.verification && this.verification.cfDistribution) {
|
|
48
|
-
obj.cfDistribution = this.verification.cfDistribution;
|
|
49
|
-
}
|
|
50
|
-
return obj;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
exports.default = Deployment;
|
|
@@ -1,198 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.publishApp = exports.deploymentProgress = exports.fetchDeployments = void 0;
|
|
16
|
-
const Deployment_1 = __importDefault(require("./Deployment"));
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
const utils_1 = require("../../../db/utils");
|
|
19
|
-
const utils_2 = require("../../../automations/utils");
|
|
20
|
-
const pro_1 = require("@budibase/pro");
|
|
21
|
-
const types_1 = require("@budibase/types");
|
|
22
|
-
const sdk_1 = __importDefault(require("../../../sdk"));
|
|
23
|
-
// the max time we can wait for an invalidation to complete before considering it failed
|
|
24
|
-
const MAX_PENDING_TIME_MS = 30 * 60000;
|
|
25
|
-
const DeploymentStatus = {
|
|
26
|
-
SUCCESS: "SUCCESS",
|
|
27
|
-
PENDING: "PENDING",
|
|
28
|
-
FAILURE: "FAILURE",
|
|
29
|
-
};
|
|
30
|
-
// checks that deployments are in a good state, any pending will be updated
|
|
31
|
-
function checkAllDeployments(deployments) {
|
|
32
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
let updated = false;
|
|
34
|
-
let deployment;
|
|
35
|
-
for (deployment of Object.values(deployments.history)) {
|
|
36
|
-
// check that no deployments have crashed etc and are now stuck
|
|
37
|
-
if (deployment.status === DeploymentStatus.PENDING &&
|
|
38
|
-
Date.now() - deployment.updatedAt > MAX_PENDING_TIME_MS) {
|
|
39
|
-
deployment.status = DeploymentStatus.FAILURE;
|
|
40
|
-
deployment.err = "Timed out";
|
|
41
|
-
updated = true;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
return { updated, deployments };
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
function storeDeploymentHistory(deployment) {
|
|
48
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
-
const deploymentJSON = deployment.getJSON();
|
|
50
|
-
const db = backend_core_1.context.getAppDB();
|
|
51
|
-
let deploymentDoc;
|
|
52
|
-
try {
|
|
53
|
-
// theres only one deployment doc per app database
|
|
54
|
-
deploymentDoc = yield db.get(utils_1.DocumentType.DEPLOYMENTS);
|
|
55
|
-
}
|
|
56
|
-
catch (err) {
|
|
57
|
-
deploymentDoc = { _id: utils_1.DocumentType.DEPLOYMENTS, history: {} };
|
|
58
|
-
}
|
|
59
|
-
const deploymentId = deploymentJSON._id;
|
|
60
|
-
// first time deployment
|
|
61
|
-
if (!deploymentDoc.history[deploymentId])
|
|
62
|
-
deploymentDoc.history[deploymentId] = {};
|
|
63
|
-
deploymentDoc.history[deploymentId] = Object.assign(Object.assign(Object.assign({}, deploymentDoc.history[deploymentId]), deploymentJSON), { updatedAt: Date.now() });
|
|
64
|
-
yield db.put(deploymentDoc);
|
|
65
|
-
deployment.fromJSON(deploymentDoc.history[deploymentId]);
|
|
66
|
-
return deployment;
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
function initDeployedApp(prodAppId) {
|
|
70
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
71
|
-
const db = backend_core_1.context.getProdAppDB();
|
|
72
|
-
console.log("Reading automation docs");
|
|
73
|
-
const automations = (yield db.allDocs((0, utils_1.getAutomationParams)(null, {
|
|
74
|
-
include_docs: true,
|
|
75
|
-
}))).rows.map((row) => row.doc);
|
|
76
|
-
yield (0, utils_2.clearMetadata)();
|
|
77
|
-
console.log("You have " + automations.length + " automations");
|
|
78
|
-
const promises = [];
|
|
79
|
-
console.log("Disabling prod crons..");
|
|
80
|
-
yield (0, utils_2.disableAllCrons)(prodAppId);
|
|
81
|
-
console.log("Prod Cron triggers disabled..");
|
|
82
|
-
console.log("Enabling cron triggers for deployed app..");
|
|
83
|
-
for (let automation of automations) {
|
|
84
|
-
promises.push((0, utils_2.enableCronTrigger)(prodAppId, automation));
|
|
85
|
-
}
|
|
86
|
-
yield Promise.all(promises);
|
|
87
|
-
console.log("Enabled cron triggers for deployed app..");
|
|
88
|
-
// sync the automations back to the dev DB - since there is now cron
|
|
89
|
-
// information attached
|
|
90
|
-
yield sdk_1.default.applications.syncApp(backend_core_1.db.getDevAppID(prodAppId), {
|
|
91
|
-
automationOnly: true,
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
function fetchDeployments(ctx) {
|
|
96
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
97
|
-
try {
|
|
98
|
-
const db = backend_core_1.context.getAppDB();
|
|
99
|
-
const deploymentDoc = yield db.get(utils_1.DocumentType.DEPLOYMENTS);
|
|
100
|
-
const { updated, deployments } = yield checkAllDeployments(deploymentDoc);
|
|
101
|
-
if (updated) {
|
|
102
|
-
yield db.put(deployments);
|
|
103
|
-
}
|
|
104
|
-
ctx.body = Object.values(deployments.history).reverse();
|
|
105
|
-
}
|
|
106
|
-
catch (err) {
|
|
107
|
-
ctx.body = [];
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
exports.fetchDeployments = fetchDeployments;
|
|
112
|
-
function deploymentProgress(ctx) {
|
|
113
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
114
|
-
try {
|
|
115
|
-
const db = backend_core_1.context.getAppDB();
|
|
116
|
-
const deploymentDoc = yield db.get(utils_1.DocumentType.DEPLOYMENTS);
|
|
117
|
-
ctx.body = deploymentDoc[ctx.params.deploymentId];
|
|
118
|
-
}
|
|
119
|
-
catch (err) {
|
|
120
|
-
ctx.throw(500, `Error fetching data for deployment ${ctx.params.deploymentId}`);
|
|
121
|
-
}
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
exports.deploymentProgress = deploymentProgress;
|
|
125
|
-
const publishApp = function (ctx) {
|
|
126
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
127
|
-
let deployment = new Deployment_1.default();
|
|
128
|
-
console.log("Deployment object created");
|
|
129
|
-
deployment.setStatus(DeploymentStatus.PENDING);
|
|
130
|
-
console.log("Deployment object set to pending");
|
|
131
|
-
deployment = yield storeDeploymentHistory(deployment);
|
|
132
|
-
console.log("Stored deployment history");
|
|
133
|
-
console.log("Deploying app...");
|
|
134
|
-
let app;
|
|
135
|
-
let replication;
|
|
136
|
-
try {
|
|
137
|
-
const appId = backend_core_1.context.getAppId();
|
|
138
|
-
const devAppId = backend_core_1.db.getDevelopmentAppID(appId);
|
|
139
|
-
const productionAppId = backend_core_1.db.getProdAppID(appId);
|
|
140
|
-
// don't try this if feature isn't allowed, will error
|
|
141
|
-
if (yield pro_1.backups.isEnabled()) {
|
|
142
|
-
// trigger backup initially
|
|
143
|
-
yield pro_1.backups.triggerAppBackup(productionAppId, types_1.AppBackupTrigger.PUBLISH, {
|
|
144
|
-
createdBy: ctx.user._id,
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
const config = {
|
|
148
|
-
source: devAppId,
|
|
149
|
-
target: productionAppId,
|
|
150
|
-
};
|
|
151
|
-
replication = new backend_core_1.db.Replication(config);
|
|
152
|
-
const devDb = backend_core_1.context.getDevAppDB();
|
|
153
|
-
console.log("Compacting development DB");
|
|
154
|
-
yield devDb.compact();
|
|
155
|
-
console.log("Replication object created");
|
|
156
|
-
yield replication.replicate(replication.appReplicateOpts());
|
|
157
|
-
console.log("replication complete.. replacing app meta doc");
|
|
158
|
-
// app metadata is excluded as it is likely to be in conflict
|
|
159
|
-
// replicate the app metadata document manually
|
|
160
|
-
const db = backend_core_1.context.getProdAppDB();
|
|
161
|
-
const appDoc = yield devDb.get(utils_1.DocumentType.APP_METADATA);
|
|
162
|
-
try {
|
|
163
|
-
const prodAppDoc = yield db.get(utils_1.DocumentType.APP_METADATA);
|
|
164
|
-
appDoc._rev = prodAppDoc._rev;
|
|
165
|
-
}
|
|
166
|
-
catch (err) {
|
|
167
|
-
delete appDoc._rev;
|
|
168
|
-
}
|
|
169
|
-
// switch to production app ID
|
|
170
|
-
deployment.appUrl = appDoc.url;
|
|
171
|
-
appDoc.appId = productionAppId;
|
|
172
|
-
appDoc.instance._id = productionAppId;
|
|
173
|
-
// remove automation errors if they exist
|
|
174
|
-
delete appDoc.automationErrors;
|
|
175
|
-
yield db.put(appDoc);
|
|
176
|
-
yield backend_core_1.cache.app.invalidateAppMetadata(productionAppId);
|
|
177
|
-
console.log("New app doc written successfully.");
|
|
178
|
-
yield initDeployedApp(productionAppId);
|
|
179
|
-
console.log("Deployed app initialised, setting deployment to successful");
|
|
180
|
-
deployment.setStatus(DeploymentStatus.SUCCESS);
|
|
181
|
-
yield storeDeploymentHistory(deployment);
|
|
182
|
-
app = appDoc;
|
|
183
|
-
}
|
|
184
|
-
catch (err) {
|
|
185
|
-
deployment.setStatus(DeploymentStatus.FAILURE, err.message);
|
|
186
|
-
yield storeDeploymentHistory(deployment);
|
|
187
|
-
throw Object.assign(Object.assign({}, err), { message: `Deployment Failed: ${err.message}` });
|
|
188
|
-
}
|
|
189
|
-
finally {
|
|
190
|
-
if (replication) {
|
|
191
|
-
yield replication.close();
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
yield backend_core_1.events.app.published(app);
|
|
195
|
-
ctx.body = deployment;
|
|
196
|
-
});
|
|
197
|
-
};
|
|
198
|
-
exports.publishApp = publishApp;
|