@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,600 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
const knex_1 = require("knex");
|
|
16
|
-
const types_1 = require("@budibase/types");
|
|
17
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
18
|
-
const utils_1 = require("../utils");
|
|
19
|
-
const sqlTable_1 = __importDefault(require("./sqlTable"));
|
|
20
|
-
const environment_1 = __importDefault(require("../../environment"));
|
|
21
|
-
const envLimit = environment_1.default.SQL_MAX_ROWS
|
|
22
|
-
? parseInt(environment_1.default.SQL_MAX_ROWS)
|
|
23
|
-
: null;
|
|
24
|
-
const BASE_LIMIT = envLimit || 5000;
|
|
25
|
-
// these are invalid dates sent by the client, need to convert them to a real max date
|
|
26
|
-
const MIN_ISO_DATE = "0000-00-00T00:00:00.000Z";
|
|
27
|
-
const MAX_ISO_DATE = "9999-00-00T00:00:00.000Z";
|
|
28
|
-
function likeKey(client, key) {
|
|
29
|
-
let start, end;
|
|
30
|
-
switch (client) {
|
|
31
|
-
case utils_1.SqlClient.MY_SQL:
|
|
32
|
-
start = end = "`";
|
|
33
|
-
break;
|
|
34
|
-
case utils_1.SqlClient.ORACLE:
|
|
35
|
-
case utils_1.SqlClient.POSTGRES:
|
|
36
|
-
start = end = '"';
|
|
37
|
-
break;
|
|
38
|
-
case utils_1.SqlClient.MS_SQL:
|
|
39
|
-
start = "[";
|
|
40
|
-
end = "]";
|
|
41
|
-
break;
|
|
42
|
-
default:
|
|
43
|
-
throw "Unknown client";
|
|
44
|
-
}
|
|
45
|
-
const parts = key.split(".");
|
|
46
|
-
key = parts.map(part => `${start}${part}${end}`).join(".");
|
|
47
|
-
return key;
|
|
48
|
-
}
|
|
49
|
-
function parse(input) {
|
|
50
|
-
if (Array.isArray(input)) {
|
|
51
|
-
return JSON.stringify(input);
|
|
52
|
-
}
|
|
53
|
-
if (input == undefined) {
|
|
54
|
-
return null;
|
|
55
|
-
}
|
|
56
|
-
if (typeof input !== "string") {
|
|
57
|
-
return input;
|
|
58
|
-
}
|
|
59
|
-
if (input === MAX_ISO_DATE || input === MIN_ISO_DATE) {
|
|
60
|
-
return null;
|
|
61
|
-
}
|
|
62
|
-
if ((0, utils_1.isIsoDateString)(input)) {
|
|
63
|
-
return new Date(input);
|
|
64
|
-
}
|
|
65
|
-
return input;
|
|
66
|
-
}
|
|
67
|
-
function parseBody(body) {
|
|
68
|
-
for (let [key, value] of Object.entries(body)) {
|
|
69
|
-
body[key] = parse(value);
|
|
70
|
-
}
|
|
71
|
-
return body;
|
|
72
|
-
}
|
|
73
|
-
function parseFilters(filters) {
|
|
74
|
-
if (!filters) {
|
|
75
|
-
return {};
|
|
76
|
-
}
|
|
77
|
-
for (let [key, value] of Object.entries(filters)) {
|
|
78
|
-
let parsed;
|
|
79
|
-
if (typeof value === "object") {
|
|
80
|
-
parsed = parseFilters(value);
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
parsed = parse(value);
|
|
84
|
-
}
|
|
85
|
-
// @ts-ignore
|
|
86
|
-
filters[key] = parsed;
|
|
87
|
-
}
|
|
88
|
-
return filters;
|
|
89
|
-
}
|
|
90
|
-
function generateSelectStatement(json, knex) {
|
|
91
|
-
var _a;
|
|
92
|
-
const { resource, meta } = json;
|
|
93
|
-
if (!resource) {
|
|
94
|
-
return "*";
|
|
95
|
-
}
|
|
96
|
-
const schema = (_a = meta === null || meta === void 0 ? void 0 : meta.table) === null || _a === void 0 ? void 0 : _a.schema;
|
|
97
|
-
return resource.fields.map(field => {
|
|
98
|
-
const fieldNames = field.split(/\./g);
|
|
99
|
-
const tableName = fieldNames[0];
|
|
100
|
-
const columnName = fieldNames[1];
|
|
101
|
-
if (columnName &&
|
|
102
|
-
(schema === null || schema === void 0 ? void 0 : schema[columnName]) &&
|
|
103
|
-
knex.client.config.client === utils_1.SqlClient.POSTGRES) {
|
|
104
|
-
const externalType = schema[columnName].externalType;
|
|
105
|
-
if (externalType === null || externalType === void 0 ? void 0 : externalType.includes("money")) {
|
|
106
|
-
return knex.raw(`"${tableName}"."${columnName}"::money::numeric as "${field}"`);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
return `${field} as ${field}`;
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
class InternalBuilder {
|
|
113
|
-
constructor(client) {
|
|
114
|
-
this.client = client;
|
|
115
|
-
}
|
|
116
|
-
// right now we only do filters on the specific table being queried
|
|
117
|
-
addFilters(query, filters, opts) {
|
|
118
|
-
function iterate(structure, fn) {
|
|
119
|
-
for (let [key, value] of Object.entries(structure)) {
|
|
120
|
-
const updatedKey = backend_core_1.db.removeKeyNumbering(key);
|
|
121
|
-
const isRelationshipField = updatedKey.includes(".");
|
|
122
|
-
if (!opts.relationship && !isRelationshipField) {
|
|
123
|
-
fn(`${opts.tableName}.${updatedKey}`, value);
|
|
124
|
-
}
|
|
125
|
-
if (opts.relationship && isRelationshipField) {
|
|
126
|
-
fn(updatedKey, value);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
const like = (key, value) => {
|
|
131
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
132
|
-
// postgres supports ilike, nothing else does
|
|
133
|
-
if (this.client === utils_1.SqlClient.POSTGRES) {
|
|
134
|
-
query = query[fnc](key, "ilike", `%${value}%`);
|
|
135
|
-
}
|
|
136
|
-
else {
|
|
137
|
-
const rawFnc = `${fnc}Raw`;
|
|
138
|
-
// @ts-ignore
|
|
139
|
-
query = query[rawFnc](`LOWER(${likeKey(this.client, key)}) LIKE ?`, [
|
|
140
|
-
`%${value.toLowerCase()}%`,
|
|
141
|
-
]);
|
|
142
|
-
}
|
|
143
|
-
};
|
|
144
|
-
const contains = (mode, any = false) => {
|
|
145
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
146
|
-
const rawFnc = `${fnc}Raw`;
|
|
147
|
-
const not = mode === (filters === null || filters === void 0 ? void 0 : filters.notContains) ? "NOT " : "";
|
|
148
|
-
function stringifyArray(value, quoteStyle = '"') {
|
|
149
|
-
for (let i in value) {
|
|
150
|
-
if (typeof value[i] === "string") {
|
|
151
|
-
value[i] = `${quoteStyle}${value[i]}${quoteStyle}`;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
return `[${value.join(",")}]`;
|
|
155
|
-
}
|
|
156
|
-
if (this.client === utils_1.SqlClient.POSTGRES) {
|
|
157
|
-
iterate(mode, (key, value) => {
|
|
158
|
-
const wrap = any ? "" : "'";
|
|
159
|
-
const containsOp = any ? "\\?| array" : "@>";
|
|
160
|
-
const fieldNames = key.split(/\./g);
|
|
161
|
-
const tableName = fieldNames[0];
|
|
162
|
-
const columnName = fieldNames[1];
|
|
163
|
-
// @ts-ignore
|
|
164
|
-
query = query[rawFnc](`${not}"${tableName}"."${columnName}"::jsonb ${containsOp} ${wrap}${stringifyArray(value, any ? "'" : '"')}${wrap}`);
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
else if (this.client === utils_1.SqlClient.MY_SQL) {
|
|
168
|
-
const jsonFnc = any ? "JSON_OVERLAPS" : "JSON_CONTAINS";
|
|
169
|
-
iterate(mode, (key, value) => {
|
|
170
|
-
// @ts-ignore
|
|
171
|
-
query = query[rawFnc](`${not}${jsonFnc}(${key}, '${stringifyArray(value)}')`);
|
|
172
|
-
});
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
const andOr = mode === (filters === null || filters === void 0 ? void 0 : filters.containsAny) ? " OR " : " AND ";
|
|
176
|
-
iterate(mode, (key, value) => {
|
|
177
|
-
let statement = "";
|
|
178
|
-
for (let i in value) {
|
|
179
|
-
if (typeof value[i] === "string") {
|
|
180
|
-
value[i] = `%"${value[i].toLowerCase()}"%`;
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
value[i] = `%${value[i]}%`;
|
|
184
|
-
}
|
|
185
|
-
statement +=
|
|
186
|
-
(statement ? andOr : "") +
|
|
187
|
-
`LOWER(${likeKey(this.client, key)}) LIKE ?`;
|
|
188
|
-
}
|
|
189
|
-
// @ts-ignore
|
|
190
|
-
query = query[rawFnc](`${not}(${statement})`, value);
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
|
-
};
|
|
194
|
-
if (!filters) {
|
|
195
|
-
return query;
|
|
196
|
-
}
|
|
197
|
-
filters = parseFilters(filters);
|
|
198
|
-
// if all or specified in filters, then everything is an or
|
|
199
|
-
const allOr = filters.allOr;
|
|
200
|
-
if (filters.oneOf) {
|
|
201
|
-
iterate(filters.oneOf, (key, array) => {
|
|
202
|
-
const fnc = allOr ? "orWhereIn" : "whereIn";
|
|
203
|
-
query = query[fnc](key, Array.isArray(array) ? array : [array]);
|
|
204
|
-
});
|
|
205
|
-
}
|
|
206
|
-
if (filters.string) {
|
|
207
|
-
iterate(filters.string, (key, value) => {
|
|
208
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
209
|
-
// postgres supports ilike, nothing else does
|
|
210
|
-
if (this.client === utils_1.SqlClient.POSTGRES) {
|
|
211
|
-
query = query[fnc](key, "ilike", `${value}%`);
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
const rawFnc = `${fnc}Raw`;
|
|
215
|
-
// @ts-ignore
|
|
216
|
-
query = query[rawFnc](`LOWER(${likeKey(this.client, key)}) LIKE ?`, [
|
|
217
|
-
`${value.toLowerCase()}%`,
|
|
218
|
-
]);
|
|
219
|
-
}
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
if (filters.fuzzy) {
|
|
223
|
-
iterate(filters.fuzzy, like);
|
|
224
|
-
}
|
|
225
|
-
if (filters.range) {
|
|
226
|
-
iterate(filters.range, (key, value) => {
|
|
227
|
-
const isEmptyObject = (val) => {
|
|
228
|
-
return (val &&
|
|
229
|
-
Object.keys(val).length === 0 &&
|
|
230
|
-
Object.getPrototypeOf(val) === Object.prototype);
|
|
231
|
-
};
|
|
232
|
-
if (isEmptyObject(value.low)) {
|
|
233
|
-
value.low = "";
|
|
234
|
-
}
|
|
235
|
-
if (isEmptyObject(value.high)) {
|
|
236
|
-
value.high = "";
|
|
237
|
-
}
|
|
238
|
-
if (value.low && value.high) {
|
|
239
|
-
// Use a between operator if we have 2 valid range values
|
|
240
|
-
const fnc = allOr ? "orWhereBetween" : "whereBetween";
|
|
241
|
-
query = query[fnc](key, [value.low, value.high]);
|
|
242
|
-
}
|
|
243
|
-
else if (value.low) {
|
|
244
|
-
// Use just a single greater than operator if we only have a low
|
|
245
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
246
|
-
query = query[fnc](key, ">", value.low);
|
|
247
|
-
}
|
|
248
|
-
else if (value.high) {
|
|
249
|
-
// Use just a single less than operator if we only have a high
|
|
250
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
251
|
-
query = query[fnc](key, "<", value.high);
|
|
252
|
-
}
|
|
253
|
-
});
|
|
254
|
-
}
|
|
255
|
-
if (filters.equal) {
|
|
256
|
-
iterate(filters.equal, (key, value) => {
|
|
257
|
-
const fnc = allOr ? "orWhere" : "where";
|
|
258
|
-
query = query[fnc]({ [key]: value });
|
|
259
|
-
});
|
|
260
|
-
}
|
|
261
|
-
if (filters.notEqual) {
|
|
262
|
-
iterate(filters.notEqual, (key, value) => {
|
|
263
|
-
const fnc = allOr ? "orWhereNot" : "whereNot";
|
|
264
|
-
query = query[fnc]({ [key]: value });
|
|
265
|
-
});
|
|
266
|
-
}
|
|
267
|
-
if (filters.empty) {
|
|
268
|
-
iterate(filters.empty, key => {
|
|
269
|
-
const fnc = allOr ? "orWhereNull" : "whereNull";
|
|
270
|
-
query = query[fnc](key);
|
|
271
|
-
});
|
|
272
|
-
}
|
|
273
|
-
if (filters.notEmpty) {
|
|
274
|
-
iterate(filters.notEmpty, key => {
|
|
275
|
-
const fnc = allOr ? "orWhereNotNull" : "whereNotNull";
|
|
276
|
-
query = query[fnc](key);
|
|
277
|
-
});
|
|
278
|
-
}
|
|
279
|
-
if (filters.contains) {
|
|
280
|
-
contains(filters.contains);
|
|
281
|
-
}
|
|
282
|
-
if (filters.notContains) {
|
|
283
|
-
contains(filters.notContains);
|
|
284
|
-
}
|
|
285
|
-
if (filters.containsAny) {
|
|
286
|
-
contains(filters.containsAny, true);
|
|
287
|
-
}
|
|
288
|
-
return query;
|
|
289
|
-
}
|
|
290
|
-
addSorting(query, json) {
|
|
291
|
-
var _a;
|
|
292
|
-
let { sort, paginate } = json;
|
|
293
|
-
const table = (_a = json.meta) === null || _a === void 0 ? void 0 : _a.table;
|
|
294
|
-
if (sort) {
|
|
295
|
-
for (let [key, value] of Object.entries(sort)) {
|
|
296
|
-
const direction = value.direction === types_1.SortDirection.ASCENDING ? "asc" : "desc";
|
|
297
|
-
query = query.orderBy(`${table === null || table === void 0 ? void 0 : table.name}.${key}`, direction);
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
else if (this.client === utils_1.SqlClient.MS_SQL && (paginate === null || paginate === void 0 ? void 0 : paginate.limit)) {
|
|
301
|
-
// @ts-ignore
|
|
302
|
-
query = query.orderBy(`${table === null || table === void 0 ? void 0 : table.name}.${table === null || table === void 0 ? void 0 : table.primary[0]}`);
|
|
303
|
-
}
|
|
304
|
-
return query;
|
|
305
|
-
}
|
|
306
|
-
addRelationships(query, fromTable, relationships, schema) {
|
|
307
|
-
if (!relationships) {
|
|
308
|
-
return query;
|
|
309
|
-
}
|
|
310
|
-
const tableSets = {};
|
|
311
|
-
// aggregate into table sets (all the same to tables)
|
|
312
|
-
for (let relationship of relationships) {
|
|
313
|
-
const keyObj = {
|
|
314
|
-
toTable: relationship.tableName,
|
|
315
|
-
throughTable: undefined,
|
|
316
|
-
};
|
|
317
|
-
if (relationship.through) {
|
|
318
|
-
keyObj.throughTable = relationship.through;
|
|
319
|
-
}
|
|
320
|
-
const key = JSON.stringify(keyObj);
|
|
321
|
-
if (tableSets[key]) {
|
|
322
|
-
tableSets[key].push(relationship);
|
|
323
|
-
}
|
|
324
|
-
else {
|
|
325
|
-
tableSets[key] = [relationship];
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
for (let [key, relationships] of Object.entries(tableSets)) {
|
|
329
|
-
const { toTable, throughTable } = JSON.parse(key);
|
|
330
|
-
const toTableWithSchema = schema ? `${schema}.${toTable}` : toTable;
|
|
331
|
-
const throughTableWithSchema = schema
|
|
332
|
-
? `${schema}.${throughTable}`
|
|
333
|
-
: throughTable;
|
|
334
|
-
if (!throughTable) {
|
|
335
|
-
// @ts-ignore
|
|
336
|
-
query = query.leftJoin(toTableWithSchema, function () {
|
|
337
|
-
for (let relationship of relationships) {
|
|
338
|
-
const from = relationship.from, to = relationship.to;
|
|
339
|
-
// @ts-ignore
|
|
340
|
-
this.orOn(`${fromTable}.${from}`, "=", `${toTable}.${to}`);
|
|
341
|
-
}
|
|
342
|
-
});
|
|
343
|
-
}
|
|
344
|
-
else {
|
|
345
|
-
query = query
|
|
346
|
-
// @ts-ignore
|
|
347
|
-
.leftJoin(throughTableWithSchema, function () {
|
|
348
|
-
for (let relationship of relationships) {
|
|
349
|
-
const fromPrimary = relationship.fromPrimary;
|
|
350
|
-
const from = relationship.from;
|
|
351
|
-
// @ts-ignore
|
|
352
|
-
this.orOn(`${fromTable}.${fromPrimary}`, "=", `${throughTable}.${from}`);
|
|
353
|
-
}
|
|
354
|
-
})
|
|
355
|
-
.leftJoin(toTableWithSchema, function () {
|
|
356
|
-
for (let relationship of relationships) {
|
|
357
|
-
const toPrimary = relationship.toPrimary;
|
|
358
|
-
const to = relationship.to;
|
|
359
|
-
// @ts-ignore
|
|
360
|
-
this.orOn(`${toTable}.${toPrimary}`, `${throughTable}.${to}`);
|
|
361
|
-
}
|
|
362
|
-
});
|
|
363
|
-
}
|
|
364
|
-
}
|
|
365
|
-
return query.limit(BASE_LIMIT);
|
|
366
|
-
}
|
|
367
|
-
create(knex, json, opts) {
|
|
368
|
-
const { endpoint, body } = json;
|
|
369
|
-
let query = knex(endpoint.entityId);
|
|
370
|
-
if (endpoint.schema) {
|
|
371
|
-
query = query.withSchema(endpoint.schema);
|
|
372
|
-
}
|
|
373
|
-
const parsedBody = parseBody(body);
|
|
374
|
-
// make sure no null values in body for creation
|
|
375
|
-
for (let [key, value] of Object.entries(parsedBody)) {
|
|
376
|
-
if (value == null) {
|
|
377
|
-
delete parsedBody[key];
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
// mysql can't use returning
|
|
381
|
-
if (opts.disableReturning) {
|
|
382
|
-
return query.insert(parsedBody);
|
|
383
|
-
}
|
|
384
|
-
else {
|
|
385
|
-
return query.insert(parsedBody).returning("*");
|
|
386
|
-
}
|
|
387
|
-
}
|
|
388
|
-
bulkCreate(knex, json) {
|
|
389
|
-
const { endpoint, body } = json;
|
|
390
|
-
let query = knex(endpoint.entityId);
|
|
391
|
-
if (endpoint.schema) {
|
|
392
|
-
query = query.withSchema(endpoint.schema);
|
|
393
|
-
}
|
|
394
|
-
if (!Array.isArray(body)) {
|
|
395
|
-
return query;
|
|
396
|
-
}
|
|
397
|
-
const parsedBody = body.map(row => parseBody(row));
|
|
398
|
-
return query.insert(parsedBody);
|
|
399
|
-
}
|
|
400
|
-
read(knex, json, limit) {
|
|
401
|
-
let { endpoint, resource, filters, paginate, relationships } = json;
|
|
402
|
-
const tableName = endpoint.entityId;
|
|
403
|
-
// select all if not specified
|
|
404
|
-
if (!resource) {
|
|
405
|
-
resource = { fields: [] };
|
|
406
|
-
}
|
|
407
|
-
let selectStatement = "*";
|
|
408
|
-
// handle select
|
|
409
|
-
if (resource.fields && resource.fields.length > 0) {
|
|
410
|
-
// select the resources as the format "table.columnName" - this is what is provided
|
|
411
|
-
// by the resource builder further up
|
|
412
|
-
selectStatement = generateSelectStatement(json, knex);
|
|
413
|
-
}
|
|
414
|
-
let foundLimit = limit || BASE_LIMIT;
|
|
415
|
-
// handle pagination
|
|
416
|
-
let foundOffset = null;
|
|
417
|
-
if (paginate && paginate.page && paginate.limit) {
|
|
418
|
-
// @ts-ignore
|
|
419
|
-
const page = paginate.page <= 1 ? 0 : paginate.page - 1;
|
|
420
|
-
const offset = page * paginate.limit;
|
|
421
|
-
foundLimit = paginate.limit;
|
|
422
|
-
foundOffset = offset;
|
|
423
|
-
}
|
|
424
|
-
else if (paginate && paginate.limit) {
|
|
425
|
-
foundLimit = paginate.limit;
|
|
426
|
-
}
|
|
427
|
-
// start building the query
|
|
428
|
-
let query = knex(tableName).limit(foundLimit);
|
|
429
|
-
if (endpoint.schema) {
|
|
430
|
-
query = query.withSchema(endpoint.schema);
|
|
431
|
-
}
|
|
432
|
-
if (foundOffset) {
|
|
433
|
-
query = query.offset(foundOffset);
|
|
434
|
-
}
|
|
435
|
-
query = this.addFilters(query, filters, { tableName });
|
|
436
|
-
// add sorting to pre-query
|
|
437
|
-
query = this.addSorting(query, json);
|
|
438
|
-
// @ts-ignore
|
|
439
|
-
let preQuery = knex({
|
|
440
|
-
// @ts-ignore
|
|
441
|
-
[tableName]: query,
|
|
442
|
-
}).select(selectStatement);
|
|
443
|
-
// have to add after as well (this breaks MS-SQL)
|
|
444
|
-
if (this.client !== utils_1.SqlClient.MS_SQL) {
|
|
445
|
-
preQuery = this.addSorting(preQuery, json);
|
|
446
|
-
}
|
|
447
|
-
// handle joins
|
|
448
|
-
query = this.addRelationships(preQuery, tableName, relationships, endpoint.schema);
|
|
449
|
-
return this.addFilters(query, filters, { relationship: true });
|
|
450
|
-
}
|
|
451
|
-
update(knex, json, opts) {
|
|
452
|
-
const { endpoint, body, filters } = json;
|
|
453
|
-
let query = knex(endpoint.entityId);
|
|
454
|
-
if (endpoint.schema) {
|
|
455
|
-
query = query.withSchema(endpoint.schema);
|
|
456
|
-
}
|
|
457
|
-
const parsedBody = parseBody(body);
|
|
458
|
-
query = this.addFilters(query, filters, { tableName: endpoint.entityId });
|
|
459
|
-
// mysql can't use returning
|
|
460
|
-
if (opts.disableReturning) {
|
|
461
|
-
return query.update(parsedBody);
|
|
462
|
-
}
|
|
463
|
-
else {
|
|
464
|
-
return query.update(parsedBody).returning("*");
|
|
465
|
-
}
|
|
466
|
-
}
|
|
467
|
-
delete(knex, json, opts) {
|
|
468
|
-
const { endpoint, filters } = json;
|
|
469
|
-
let query = knex(endpoint.entityId);
|
|
470
|
-
if (endpoint.schema) {
|
|
471
|
-
query = query.withSchema(endpoint.schema);
|
|
472
|
-
}
|
|
473
|
-
query = this.addFilters(query, filters, { tableName: endpoint.entityId });
|
|
474
|
-
// mysql can't use returning
|
|
475
|
-
if (opts.disableReturning) {
|
|
476
|
-
return query.delete();
|
|
477
|
-
}
|
|
478
|
-
else {
|
|
479
|
-
return query.delete().returning(generateSelectStatement(json, knex));
|
|
480
|
-
}
|
|
481
|
-
}
|
|
482
|
-
}
|
|
483
|
-
class SqlQueryBuilder extends sqlTable_1.default {
|
|
484
|
-
// pass through client to get flavour of SQL
|
|
485
|
-
constructor(client, limit = BASE_LIMIT) {
|
|
486
|
-
super(client);
|
|
487
|
-
this.limit = limit;
|
|
488
|
-
}
|
|
489
|
-
/**
|
|
490
|
-
* @param json The JSON query DSL which is to be converted to SQL.
|
|
491
|
-
* @param opts extra options which are to be passed into the query builder, e.g. disableReturning
|
|
492
|
-
* which for the sake of mySQL stops adding the returning statement to inserts, updates and deletes.
|
|
493
|
-
* @return {{ sql: string, bindings: object }} the query ready to be passed to the driver.
|
|
494
|
-
*/
|
|
495
|
-
_query(json, opts = {}) {
|
|
496
|
-
const sqlClient = this.getSqlClient();
|
|
497
|
-
const client = (0, knex_1.knex)({ client: sqlClient });
|
|
498
|
-
let query;
|
|
499
|
-
const builder = new InternalBuilder(sqlClient);
|
|
500
|
-
switch (this._operation(json)) {
|
|
501
|
-
case types_1.Operation.CREATE:
|
|
502
|
-
query = builder.create(client, json, opts);
|
|
503
|
-
break;
|
|
504
|
-
case types_1.Operation.READ:
|
|
505
|
-
query = builder.read(client, json, this.limit);
|
|
506
|
-
break;
|
|
507
|
-
case types_1.Operation.UPDATE:
|
|
508
|
-
query = builder.update(client, json, opts);
|
|
509
|
-
break;
|
|
510
|
-
case types_1.Operation.DELETE:
|
|
511
|
-
query = builder.delete(client, json, opts);
|
|
512
|
-
break;
|
|
513
|
-
case types_1.Operation.BULK_CREATE:
|
|
514
|
-
query = builder.bulkCreate(client, json);
|
|
515
|
-
break;
|
|
516
|
-
case types_1.Operation.CREATE_TABLE:
|
|
517
|
-
case types_1.Operation.UPDATE_TABLE:
|
|
518
|
-
case types_1.Operation.DELETE_TABLE:
|
|
519
|
-
return this._tableQuery(json);
|
|
520
|
-
default:
|
|
521
|
-
throw `Operation type is not supported by SQL query builder`;
|
|
522
|
-
}
|
|
523
|
-
// @ts-ignore
|
|
524
|
-
return query.toSQL().toNative();
|
|
525
|
-
}
|
|
526
|
-
getReturningRow(queryFn, json) {
|
|
527
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
528
|
-
if (!json.extra || !json.extra.idFilter) {
|
|
529
|
-
return {};
|
|
530
|
-
}
|
|
531
|
-
const input = this._query({
|
|
532
|
-
endpoint: Object.assign(Object.assign({}, json.endpoint), { operation: types_1.Operation.READ }),
|
|
533
|
-
resource: {
|
|
534
|
-
fields: [],
|
|
535
|
-
},
|
|
536
|
-
filters: json.extra.idFilter,
|
|
537
|
-
paginate: {
|
|
538
|
-
limit: 1,
|
|
539
|
-
},
|
|
540
|
-
meta: json.meta,
|
|
541
|
-
});
|
|
542
|
-
return queryFn(input, types_1.Operation.READ);
|
|
543
|
-
});
|
|
544
|
-
}
|
|
545
|
-
// when creating if an ID has been inserted need to make sure
|
|
546
|
-
// the id filter is enriched with it before trying to retrieve the row
|
|
547
|
-
checkLookupKeys(id, json) {
|
|
548
|
-
var _a, _b;
|
|
549
|
-
if (!id || !((_a = json.meta) === null || _a === void 0 ? void 0 : _a.table) || !json.meta.table.primary) {
|
|
550
|
-
return json;
|
|
551
|
-
}
|
|
552
|
-
const primaryKey = (_b = json.meta.table.primary) === null || _b === void 0 ? void 0 : _b[0];
|
|
553
|
-
json.extra = {
|
|
554
|
-
idFilter: {
|
|
555
|
-
equal: {
|
|
556
|
-
[primaryKey]: id,
|
|
557
|
-
},
|
|
558
|
-
},
|
|
559
|
-
};
|
|
560
|
-
return json;
|
|
561
|
-
}
|
|
562
|
-
// this function recreates the returning functionality of postgres
|
|
563
|
-
queryWithReturning(json, queryFn, processFn = (result) => result) {
|
|
564
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
565
|
-
const sqlClient = this.getSqlClient();
|
|
566
|
-
const operation = this._operation(json);
|
|
567
|
-
const input = this._query(json, { disableReturning: true });
|
|
568
|
-
if (Array.isArray(input)) {
|
|
569
|
-
const responses = [];
|
|
570
|
-
for (let query of input) {
|
|
571
|
-
responses.push(yield queryFn(query, operation));
|
|
572
|
-
}
|
|
573
|
-
return responses;
|
|
574
|
-
}
|
|
575
|
-
let row;
|
|
576
|
-
// need to manage returning, a feature mySQL can't do
|
|
577
|
-
if (operation === types_1.Operation.DELETE) {
|
|
578
|
-
row = processFn(yield this.getReturningRow(queryFn, json));
|
|
579
|
-
}
|
|
580
|
-
const response = yield queryFn(input, operation);
|
|
581
|
-
const results = processFn(response);
|
|
582
|
-
// same as delete, manage returning
|
|
583
|
-
if (operation === types_1.Operation.CREATE || operation === types_1.Operation.UPDATE) {
|
|
584
|
-
let id;
|
|
585
|
-
if (sqlClient === utils_1.SqlClient.MS_SQL) {
|
|
586
|
-
id = results === null || results === void 0 ? void 0 : results[0].id;
|
|
587
|
-
}
|
|
588
|
-
else if (sqlClient === utils_1.SqlClient.MY_SQL) {
|
|
589
|
-
id = results === null || results === void 0 ? void 0 : results.insertId;
|
|
590
|
-
}
|
|
591
|
-
row = processFn(yield this.getReturningRow(queryFn, this.checkLookupKeys(id, json)));
|
|
592
|
-
}
|
|
593
|
-
if (operation !== types_1.Operation.READ) {
|
|
594
|
-
return row;
|
|
595
|
-
}
|
|
596
|
-
return results.length ? results : [{ [operation.toLowerCase()]: true }];
|
|
597
|
-
});
|
|
598
|
-
}
|
|
599
|
-
}
|
|
600
|
-
exports.default = SqlQueryBuilder;
|