@budibase/server 2.6.19-alpha.5 → 2.6.19-alpha.51
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.4f47d591.js +1869 -0
- package/builder/assets/index.6ebb99b3.css +6 -0
- package/builder/index.html +2 -2
- package/client/manifest.json +5229 -0
- package/dist/automation.js +32566 -0
- package/dist/automation.js.map +7 -0
- package/dist/index.js +45038 -13
- package/dist/index.js.map +7 -0
- package/dist/query.js +24454 -0
- package/dist/query.js.map +7 -0
- package/jest.config.ts +3 -0
- package/nodemon.json +1 -1
- package/package.json +33 -15
- package/pm2.config.js +1 -1
- package/scripts/build.js +48 -0
- package/src/api/controllers/application.ts +21 -22
- package/src/api/controllers/automation.ts +37 -9
- package/src/api/controllers/datasource.ts +25 -15
- package/src/api/controllers/deploy/index.ts +1 -0
- package/src/api/controllers/plugin/index.ts +1 -1
- package/src/api/controllers/row/external.ts +39 -15
- package/src/api/controllers/row/index.ts +18 -24
- package/src/api/controllers/row/internal.ts +1 -1
- package/src/api/controllers/row/staticFormula.ts +6 -1
- package/src/api/controllers/row/utils.ts +12 -0
- package/src/api/controllers/static/index.ts +3 -3
- package/src/api/controllers/table/index.ts +3 -0
- package/src/api/controllers/table/internal.ts +2 -6
- package/src/api/controllers/table/utils.ts +32 -1
- package/src/api/controllers/view/index.ts +5 -5
- package/src/api/controllers/webhook.ts +33 -9
- package/src/api/routes/application.ts +5 -0
- package/src/api/routes/automation.ts +0 -1
- package/src/api/routes/datasource.ts +2 -2
- package/src/api/routes/static.ts +3 -1
- package/src/api/routes/tests/{automation.spec.js → automation.spec.ts} +106 -31
- package/src/api/routes/tests/view.spec.js +4 -3
- package/src/api/routes/tests/{webhook.spec.js → webhook.spec.ts} +33 -11
- package/src/app.ts +0 -1
- package/src/automations/actions.ts +8 -0
- package/src/automations/logging/index.ts +21 -0
- package/src/automations/steps/bash.ts +4 -0
- package/src/automations/steps/collect.ts +58 -0
- package/src/automations/steps/createRow.ts +4 -0
- package/src/automations/steps/delay.ts +1 -0
- package/src/automations/steps/deleteRow.ts +4 -0
- package/src/automations/steps/discord.ts +4 -0
- package/src/automations/steps/executeQuery.ts +4 -0
- package/src/automations/steps/executeScript.ts +4 -0
- package/src/automations/steps/filter.ts +1 -0
- package/src/automations/steps/loop.ts +1 -0
- package/src/automations/steps/make.ts +4 -0
- package/src/automations/steps/openai.ts +106 -0
- package/src/automations/steps/outgoingWebhook.ts +4 -0
- package/src/automations/steps/queryRows.ts +4 -0
- package/src/automations/steps/sendSmtpEmail.ts +4 -0
- package/src/automations/steps/serverLog.ts +4 -0
- package/src/automations/steps/slack.ts +4 -0
- package/src/automations/steps/updateRow.ts +4 -0
- package/src/automations/steps/zapier.ts +4 -0
- package/src/automations/tests/openai.spec.ts +86 -0
- package/src/automations/triggers.ts +3 -2
- package/src/constants/index.ts +17 -16
- package/src/db/inMemoryView.ts +1 -0
- package/src/db/linkedRows/index.ts +5 -3
- package/src/environment.ts +3 -0
- package/src/integration-test/postgres.spec.ts +5 -5
- 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 +37 -13
- package/src/integrations/microsoftSqlServer.ts +4 -4
- package/src/integrations/mongodb.ts +3 -1
- package/src/integrations/mysql.ts +4 -4
- package/src/integrations/oracle.ts +4 -4
- package/src/integrations/postgres.ts +4 -4
- package/src/integrations/redis.ts +10 -2
- package/src/integrations/s3.ts +3 -1
- package/src/integrations/snowflake.ts +3 -1
- package/src/middleware/builder.ts +26 -18
- package/src/sdk/app/automations/index.ts +2 -0
- package/src/sdk/app/automations/utils.ts +7 -0
- package/src/sdk/plugins/plugins.ts +1 -1
- package/src/startup.ts +2 -0
- package/src/tests/utilities/TestConfiguration.ts +4 -2
- package/src/tests/utilities/structures.ts +42 -0
- package/src/threads/automation.ts +91 -23
- package/src/threads/index.ts +9 -3
- package/src/threads/utils.ts +2 -0
- package/src/utilities/fileSystem/app.ts +14 -4
- package/src/utilities/fileSystem/clientLibrary.ts +8 -3
- package/src/utilities/fileSystem/filesystem.ts +3 -1
- package/src/utilities/redis.ts +25 -3
- package/src/utilities/rowProcessor/index.ts +4 -1
- package/src/utilities/rowProcessor/map.ts +1 -1
- package/src/websockets/builder.ts +77 -0
- package/src/websockets/client.ts +2 -2
- package/src/websockets/grid.ts +44 -44
- package/src/websockets/index.ts +13 -6
- package/src/websockets/websocket.ts +207 -7
- package/tsconfig.build.json +9 -1
- package/tsconfig.json +1 -14
- package/builder/assets/index.07382a47.css +0 -6
- package/builder/assets/index.3d5c50fb.js +0 -1786
- 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 -352
- 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 -45
- 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 -493
- package/dist/integrations/index.js +0 -138
- package/dist/integrations/microsoftSqlServer.js +0 -308
- package/dist/integrations/mongodb.js +0 -630
- package/dist/integrations/mysql.js +0 -291
- package/dist/integrations/oracle.js +0 -415
- package/dist/integrations/postgres.js +0 -335
- 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,193 +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 __rest = (this && this.__rest) || function (s, e) {
|
|
12
|
-
var t = {};
|
|
13
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
14
|
-
t[p] = s[p];
|
|
15
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
16
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
17
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
18
|
-
t[p[i]] = s[p[i]];
|
|
19
|
-
}
|
|
20
|
-
return t;
|
|
21
|
-
};
|
|
22
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
23
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.exportView = exports.destroy = exports.filterEvents = exports.calculationEvents = exports.save = exports.fetch = void 0;
|
|
27
|
-
const viewBuilder_1 = __importDefault(require("./viewBuilder"));
|
|
28
|
-
const fileSystem_1 = require("../../../utilities/fileSystem");
|
|
29
|
-
const exporters_1 = require("./exporters");
|
|
30
|
-
const utils_1 = require("./utils");
|
|
31
|
-
const row_1 = require("../row");
|
|
32
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
33
|
-
const utils_2 = require("../../../db/utils");
|
|
34
|
-
const sdk_1 = __importDefault(require("../../../sdk"));
|
|
35
|
-
const constants_1 = require("../../../constants");
|
|
36
|
-
const utils_3 = require("../row/utils");
|
|
37
|
-
const { cloneDeep, isEqual } = require("lodash");
|
|
38
|
-
function fetch(ctx) {
|
|
39
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
ctx.body = yield (0, utils_1.getViews)();
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
exports.fetch = fetch;
|
|
44
|
-
function save(ctx) {
|
|
45
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
-
const db = backend_core_1.context.getAppDB();
|
|
47
|
-
const _a = ctx.request.body, { originalName } = _a, viewToSave = __rest(_a, ["originalName"]);
|
|
48
|
-
const existingTable = yield db.get(ctx.request.body.tableId);
|
|
49
|
-
const table = cloneDeep(existingTable);
|
|
50
|
-
const groupByField = Object.values(table.schema).find((field) => field.name == viewToSave.groupBy);
|
|
51
|
-
const view = (0, viewBuilder_1.default)(viewToSave, (groupByField === null || groupByField === void 0 ? void 0 : groupByField.type) === constants_1.FieldTypes.ARRAY);
|
|
52
|
-
const viewName = viewToSave.name;
|
|
53
|
-
if (!viewName) {
|
|
54
|
-
ctx.throw(400, "Cannot create view without a name");
|
|
55
|
-
}
|
|
56
|
-
yield (0, utils_1.saveView)(originalName, viewName, view);
|
|
57
|
-
// add views to table document
|
|
58
|
-
if (!table.views)
|
|
59
|
-
table.views = {};
|
|
60
|
-
if (!view.meta.schema) {
|
|
61
|
-
view.meta.schema = table.schema;
|
|
62
|
-
}
|
|
63
|
-
table.views[viewName] = view.meta;
|
|
64
|
-
if (originalName) {
|
|
65
|
-
delete table.views[originalName];
|
|
66
|
-
existingTable.views[viewName] = existingTable.views[originalName];
|
|
67
|
-
}
|
|
68
|
-
yield db.put(table);
|
|
69
|
-
yield handleViewEvents(existingTable.views[viewName], table.views[viewName]);
|
|
70
|
-
ctx.body = Object.assign(Object.assign({}, table.views[viewToSave.name]), { name: viewToSave.name });
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
exports.save = save;
|
|
74
|
-
function calculationEvents(existingView, newView) {
|
|
75
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
const existingCalculation = existingView && existingView.calculation;
|
|
77
|
-
const newCalculation = newView && newView.calculation;
|
|
78
|
-
if (existingCalculation && !newCalculation) {
|
|
79
|
-
yield backend_core_1.events.view.calculationDeleted(existingView);
|
|
80
|
-
}
|
|
81
|
-
if (!existingCalculation && newCalculation) {
|
|
82
|
-
yield backend_core_1.events.view.calculationCreated(newView);
|
|
83
|
-
}
|
|
84
|
-
if (existingCalculation &&
|
|
85
|
-
newCalculation &&
|
|
86
|
-
existingCalculation !== newCalculation) {
|
|
87
|
-
yield backend_core_1.events.view.calculationUpdated(newView);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
exports.calculationEvents = calculationEvents;
|
|
92
|
-
function filterEvents(existingView, newView) {
|
|
93
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
94
|
-
const hasExistingFilters = !!(existingView &&
|
|
95
|
-
existingView.filters &&
|
|
96
|
-
existingView.filters.length);
|
|
97
|
-
const hasNewFilters = !!(newView && newView.filters && newView.filters.length);
|
|
98
|
-
if (hasExistingFilters && !hasNewFilters) {
|
|
99
|
-
yield backend_core_1.events.view.filterDeleted(newView);
|
|
100
|
-
}
|
|
101
|
-
if (!hasExistingFilters && hasNewFilters) {
|
|
102
|
-
yield backend_core_1.events.view.filterCreated(newView);
|
|
103
|
-
}
|
|
104
|
-
if (hasExistingFilters &&
|
|
105
|
-
hasNewFilters &&
|
|
106
|
-
!isEqual(existingView.filters, newView.filters)) {
|
|
107
|
-
yield backend_core_1.events.view.filterUpdated(newView);
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
exports.filterEvents = filterEvents;
|
|
112
|
-
function handleViewEvents(existingView, newView) {
|
|
113
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
114
|
-
if (!existingView) {
|
|
115
|
-
yield backend_core_1.events.view.created(newView);
|
|
116
|
-
}
|
|
117
|
-
else {
|
|
118
|
-
yield backend_core_1.events.view.updated(newView);
|
|
119
|
-
}
|
|
120
|
-
yield calculationEvents(existingView, newView);
|
|
121
|
-
yield filterEvents(existingView, newView);
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
function destroy(ctx) {
|
|
125
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
const db = backend_core_1.context.getAppDB();
|
|
127
|
-
const viewName = decodeURIComponent(ctx.params.viewName);
|
|
128
|
-
const view = yield (0, utils_1.deleteView)(viewName);
|
|
129
|
-
const table = yield db.get(view.meta.tableId);
|
|
130
|
-
delete table.views[viewName];
|
|
131
|
-
yield db.put(table);
|
|
132
|
-
yield backend_core_1.events.view.deleted(view);
|
|
133
|
-
ctx.body = view;
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
exports.destroy = destroy;
|
|
137
|
-
function exportView(ctx) {
|
|
138
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
139
|
-
const viewName = decodeURIComponent(ctx.query.view);
|
|
140
|
-
const view = yield (0, utils_1.getView)(viewName);
|
|
141
|
-
const format = ctx.query.format;
|
|
142
|
-
if (!(0, exporters_1.isFormat)(format)) {
|
|
143
|
-
ctx.throw(400, "Format must be specified, either csv, json or jsonWithSchema");
|
|
144
|
-
}
|
|
145
|
-
if (view) {
|
|
146
|
-
ctx.params.viewName = viewName;
|
|
147
|
-
// Fetch view rows
|
|
148
|
-
ctx.query = {
|
|
149
|
-
group: view.meta.groupBy,
|
|
150
|
-
calculation: view.meta.calculation,
|
|
151
|
-
// @ts-ignore
|
|
152
|
-
stats: !!view.meta.field,
|
|
153
|
-
field: view.meta.field,
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
else {
|
|
157
|
-
// table all_ view
|
|
158
|
-
/* istanbul ignore next */
|
|
159
|
-
ctx.params.viewName = viewName;
|
|
160
|
-
}
|
|
161
|
-
yield (0, row_1.fetchView)(ctx);
|
|
162
|
-
let rows = ctx.body;
|
|
163
|
-
let schema = view && view.meta && view.meta.schema;
|
|
164
|
-
const tableId = ctx.params.tableId || view.meta.tableId;
|
|
165
|
-
const table = yield sdk_1.default.tables.getTable(tableId);
|
|
166
|
-
if (!schema) {
|
|
167
|
-
schema = table.schema;
|
|
168
|
-
}
|
|
169
|
-
let exportRows = (0, utils_3.cleanExportRows)(rows, schema, format, []);
|
|
170
|
-
if (format === exporters_1.Format.CSV) {
|
|
171
|
-
ctx.attachment(`${viewName}.csv`);
|
|
172
|
-
ctx.body = (0, fileSystem_1.apiFileReturn)((0, exporters_1.csv)(Object.keys(schema), exportRows));
|
|
173
|
-
}
|
|
174
|
-
else if (format === exporters_1.Format.JSON) {
|
|
175
|
-
ctx.attachment(`${viewName}.json`);
|
|
176
|
-
ctx.body = (0, fileSystem_1.apiFileReturn)((0, exporters_1.json)(exportRows));
|
|
177
|
-
}
|
|
178
|
-
else if (format === exporters_1.Format.JSON_WITH_SCHEMA) {
|
|
179
|
-
ctx.attachment(`${viewName}.json`);
|
|
180
|
-
ctx.body = (0, fileSystem_1.apiFileReturn)((0, exporters_1.jsonWithSchema)(schema, exportRows));
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
throw "Format not recognised";
|
|
184
|
-
}
|
|
185
|
-
if (viewName.startsWith(utils_2.DocumentType.TABLE)) {
|
|
186
|
-
yield backend_core_1.events.table.exported(table, format);
|
|
187
|
-
}
|
|
188
|
-
else {
|
|
189
|
-
yield backend_core_1.events.view.exported(table, format);
|
|
190
|
-
}
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
|
-
exports.exportView = exportView;
|
|
@@ -1,177 +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.getFromMemoryDoc = exports.getFromDesignDoc = exports.migrateToDesignView = exports.migrateToInMemoryView = exports.deleteView = exports.saveView = exports.getViews = exports.getView = void 0;
|
|
16
|
-
const utils_1 = require("../../../db/utils");
|
|
17
|
-
const environment_1 = __importDefault(require("../../../environment"));
|
|
18
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
19
|
-
const viewBuilder_1 = __importDefault(require("./viewBuilder"));
|
|
20
|
-
function getView(viewName) {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
const db = backend_core_1.context.getAppDB();
|
|
23
|
-
if (environment_1.default.SELF_HOSTED) {
|
|
24
|
-
const designDoc = yield db.get("_design/database");
|
|
25
|
-
return designDoc.views[viewName];
|
|
26
|
-
}
|
|
27
|
-
else {
|
|
28
|
-
// This is a table view, don't read the view from the DB
|
|
29
|
-
if (viewName.startsWith(utils_1.DocumentType.TABLE + utils_1.SEPARATOR)) {
|
|
30
|
-
return null;
|
|
31
|
-
}
|
|
32
|
-
try {
|
|
33
|
-
const viewDoc = yield db.get((0, utils_1.generateMemoryViewID)(viewName));
|
|
34
|
-
return viewDoc.view;
|
|
35
|
-
}
|
|
36
|
-
catch (err) {
|
|
37
|
-
// Return null when PouchDB doesn't found the view
|
|
38
|
-
if (err.status === 404) {
|
|
39
|
-
return null;
|
|
40
|
-
}
|
|
41
|
-
throw err;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
exports.getView = getView;
|
|
47
|
-
function getViews() {
|
|
48
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
-
const db = backend_core_1.context.getAppDB();
|
|
50
|
-
const response = [];
|
|
51
|
-
if (environment_1.default.SELF_HOSTED) {
|
|
52
|
-
const designDoc = yield db.get("_design/database");
|
|
53
|
-
for (let name of Object.keys(designDoc.views)) {
|
|
54
|
-
// Only return custom views, not built ins
|
|
55
|
-
const viewNames = Object.values(utils_1.ViewName);
|
|
56
|
-
if (viewNames.indexOf(name) !== -1) {
|
|
57
|
-
continue;
|
|
58
|
-
}
|
|
59
|
-
response.push(Object.assign({ name }, designDoc.views[name]));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
const views = (yield db.allDocs((0, utils_1.getMemoryViewParams)({
|
|
64
|
-
include_docs: true,
|
|
65
|
-
}))).rows.map(row => row.doc);
|
|
66
|
-
for (let viewDoc of views) {
|
|
67
|
-
response.push(Object.assign({ name: viewDoc.name }, viewDoc.view));
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
return response;
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
exports.getViews = getViews;
|
|
74
|
-
function saveView(originalName, viewName, viewTemplate) {
|
|
75
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
const db = backend_core_1.context.getAppDB();
|
|
77
|
-
if (environment_1.default.SELF_HOSTED) {
|
|
78
|
-
const designDoc = yield db.get("_design/database");
|
|
79
|
-
designDoc.views = Object.assign(Object.assign({}, designDoc.views), { [viewName]: viewTemplate });
|
|
80
|
-
// view has been renamed
|
|
81
|
-
if (originalName) {
|
|
82
|
-
delete designDoc.views[originalName];
|
|
83
|
-
}
|
|
84
|
-
yield db.put(designDoc);
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
const id = (0, utils_1.generateMemoryViewID)(viewName);
|
|
88
|
-
const originalId = originalName ? (0, utils_1.generateMemoryViewID)(originalName) : null;
|
|
89
|
-
const viewDoc = {
|
|
90
|
-
_id: id,
|
|
91
|
-
view: viewTemplate,
|
|
92
|
-
name: viewName,
|
|
93
|
-
tableId: viewTemplate.meta.tableId,
|
|
94
|
-
};
|
|
95
|
-
try {
|
|
96
|
-
const old = yield db.get(id);
|
|
97
|
-
if (originalId) {
|
|
98
|
-
const originalDoc = yield db.get(originalId);
|
|
99
|
-
yield db.remove(originalDoc._id, originalDoc._rev);
|
|
100
|
-
}
|
|
101
|
-
if (old && old._rev) {
|
|
102
|
-
viewDoc._rev = old._rev;
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
catch (err) {
|
|
106
|
-
// didn't exist, just skip
|
|
107
|
-
}
|
|
108
|
-
yield db.put(viewDoc);
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
exports.saveView = saveView;
|
|
113
|
-
function deleteView(viewName) {
|
|
114
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
115
|
-
const db = backend_core_1.context.getAppDB();
|
|
116
|
-
if (environment_1.default.SELF_HOSTED) {
|
|
117
|
-
const designDoc = yield db.get("_design/database");
|
|
118
|
-
const view = designDoc.views[viewName];
|
|
119
|
-
delete designDoc.views[viewName];
|
|
120
|
-
yield db.put(designDoc);
|
|
121
|
-
return view;
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
const id = (0, utils_1.generateMemoryViewID)(viewName);
|
|
125
|
-
const viewDoc = yield db.get(id);
|
|
126
|
-
yield db.remove(viewDoc._id, viewDoc._rev);
|
|
127
|
-
return viewDoc.view;
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
exports.deleteView = deleteView;
|
|
132
|
-
function migrateToInMemoryView(db, viewName) {
|
|
133
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
134
|
-
// delete the view initially
|
|
135
|
-
const designDoc = yield db.get("_design/database");
|
|
136
|
-
// run the view back through the view builder to update it
|
|
137
|
-
const view = (0, viewBuilder_1.default)(designDoc.views[viewName].meta);
|
|
138
|
-
delete designDoc.views[viewName];
|
|
139
|
-
yield db.put(designDoc);
|
|
140
|
-
yield exports.saveView(db, null, viewName, view);
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
exports.migrateToInMemoryView = migrateToInMemoryView;
|
|
144
|
-
function migrateToDesignView(db, viewName) {
|
|
145
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
146
|
-
let view = yield db.get((0, utils_1.generateMemoryViewID)(viewName));
|
|
147
|
-
const designDoc = yield db.get("_design/database");
|
|
148
|
-
designDoc.views[viewName] = (0, viewBuilder_1.default)(view.view.meta);
|
|
149
|
-
yield db.put(designDoc);
|
|
150
|
-
yield db.remove(view._id, view._rev);
|
|
151
|
-
});
|
|
152
|
-
}
|
|
153
|
-
exports.migrateToDesignView = migrateToDesignView;
|
|
154
|
-
function getFromDesignDoc(db, viewName) {
|
|
155
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
156
|
-
const designDoc = yield db.get("_design/database");
|
|
157
|
-
let view = designDoc.views[viewName];
|
|
158
|
-
if (view == null) {
|
|
159
|
-
throw { status: 404, message: "Unable to get view" };
|
|
160
|
-
}
|
|
161
|
-
return view;
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
exports.getFromDesignDoc = getFromDesignDoc;
|
|
165
|
-
function getFromMemoryDoc(db, viewName) {
|
|
166
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
167
|
-
let view = yield db.get((0, utils_1.generateMemoryViewID)(viewName));
|
|
168
|
-
if (view) {
|
|
169
|
-
view = view.view;
|
|
170
|
-
}
|
|
171
|
-
else {
|
|
172
|
-
throw { status: 404, message: "Unable to get view" };
|
|
173
|
-
}
|
|
174
|
-
return view;
|
|
175
|
-
});
|
|
176
|
-
}
|
|
177
|
-
exports.getFromMemoryDoc = getFromMemoryDoc;
|
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const TOKEN_MAP = {
|
|
4
|
-
EQUALS: "===",
|
|
5
|
-
NOT_EQUALS: "!==",
|
|
6
|
-
LT: "<",
|
|
7
|
-
LTE: "<=",
|
|
8
|
-
MT: ">",
|
|
9
|
-
MTE: ">=",
|
|
10
|
-
CONTAINS: "includes",
|
|
11
|
-
AND: "&&",
|
|
12
|
-
OR: "||",
|
|
13
|
-
};
|
|
14
|
-
const CONDITIONS = {
|
|
15
|
-
EMPTY: "EMPTY",
|
|
16
|
-
NOT_EMPTY: "NOT_EMPTY",
|
|
17
|
-
CONTAINS: "CONTAINS",
|
|
18
|
-
};
|
|
19
|
-
function isEmptyExpression(key) {
|
|
20
|
-
return `(
|
|
21
|
-
doc["${key}"] === undefined ||
|
|
22
|
-
doc["${key}"] === null ||
|
|
23
|
-
doc["${key}"] === "" ||
|
|
24
|
-
(Array.isArray(doc["${key}"]) && doc["${key}"].length === 0)
|
|
25
|
-
)`;
|
|
26
|
-
}
|
|
27
|
-
const GROUP_PROPERTY = {
|
|
28
|
-
group: {
|
|
29
|
-
type: "string",
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
const GROUP_PROPERTY_MULTI = {
|
|
33
|
-
group: {
|
|
34
|
-
type: "array",
|
|
35
|
-
},
|
|
36
|
-
};
|
|
37
|
-
const FIELD_PROPERTY = {
|
|
38
|
-
field: {
|
|
39
|
-
type: "string",
|
|
40
|
-
},
|
|
41
|
-
};
|
|
42
|
-
const SCHEMA_MAP = {
|
|
43
|
-
sum: {
|
|
44
|
-
field: "string",
|
|
45
|
-
value: "number",
|
|
46
|
-
},
|
|
47
|
-
count: {
|
|
48
|
-
field: "string",
|
|
49
|
-
value: "number",
|
|
50
|
-
},
|
|
51
|
-
stats: {
|
|
52
|
-
sum: {
|
|
53
|
-
type: "number",
|
|
54
|
-
},
|
|
55
|
-
min: {
|
|
56
|
-
type: "number",
|
|
57
|
-
},
|
|
58
|
-
max: {
|
|
59
|
-
type: "number",
|
|
60
|
-
},
|
|
61
|
-
count: {
|
|
62
|
-
type: "number",
|
|
63
|
-
},
|
|
64
|
-
sumsqr: {
|
|
65
|
-
type: "number",
|
|
66
|
-
},
|
|
67
|
-
avg: {
|
|
68
|
-
type: "number",
|
|
69
|
-
},
|
|
70
|
-
},
|
|
71
|
-
};
|
|
72
|
-
/**
|
|
73
|
-
* Iterates through the array of filters to create a JS
|
|
74
|
-
* expression that gets used in a CouchDB view.
|
|
75
|
-
* @param {Array} filters - an array of filter objects
|
|
76
|
-
* @returns {String} JS Expression
|
|
77
|
-
*/
|
|
78
|
-
function parseFilterExpression(filters) {
|
|
79
|
-
const expression = [];
|
|
80
|
-
let first = true;
|
|
81
|
-
for (let filter of filters) {
|
|
82
|
-
if (!first && filter.conjunction) {
|
|
83
|
-
expression.push(TOKEN_MAP[filter.conjunction]);
|
|
84
|
-
}
|
|
85
|
-
if (filter.condition === CONDITIONS.CONTAINS) {
|
|
86
|
-
expression.push(`doc["${filter.key}"].${TOKEN_MAP[filter.condition]}("${filter.value}")`);
|
|
87
|
-
}
|
|
88
|
-
else if (filter.condition === CONDITIONS.EMPTY) {
|
|
89
|
-
expression.push(isEmptyExpression(filter.key));
|
|
90
|
-
}
|
|
91
|
-
else if (filter.condition === CONDITIONS.NOT_EMPTY) {
|
|
92
|
-
expression.push(`!${isEmptyExpression(filter.key)}`);
|
|
93
|
-
}
|
|
94
|
-
else {
|
|
95
|
-
const value = typeof filter.value == "string" ? `"${filter.value}"` : filter.value;
|
|
96
|
-
expression.push(`doc["${filter.key}"] ${TOKEN_MAP[filter.condition]} ${value}`);
|
|
97
|
-
}
|
|
98
|
-
first = false;
|
|
99
|
-
}
|
|
100
|
-
return expression.join(" ");
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Returns a CouchDB compliant emit() expression that is used to emit the
|
|
104
|
-
* correct key/value pairs for custom views.
|
|
105
|
-
* @param {String?} field - field to use for calculations, if any
|
|
106
|
-
* @param {String?} groupBy - field to group calculation results on, if any
|
|
107
|
-
*/
|
|
108
|
-
function parseEmitExpression(field, groupBy) {
|
|
109
|
-
return `emit(doc["${groupBy || "_id"}"], doc["${field}"]);`;
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* Return a fully parsed CouchDB compliant view definition
|
|
113
|
-
* that will be stored in the design document in the database.
|
|
114
|
-
*
|
|
115
|
-
* @param {Object} viewDefinition - the JSON definition for a custom view.
|
|
116
|
-
* field: field that calculations will be performed on
|
|
117
|
-
* tableId: tableId of the table this view was created from
|
|
118
|
-
* groupBy: field that calculations will be grouped by. Field must be present for this to be useful
|
|
119
|
-
* filters: Array of filter objects containing predicates that are parsed into a JS expression
|
|
120
|
-
* calculation: an optional calculation to be performed over the view data.
|
|
121
|
-
*/
|
|
122
|
-
function default_1({ field, tableId, groupBy, filters = [], calculation }, groupByMulti) {
|
|
123
|
-
// first filter can't have a conjunction
|
|
124
|
-
if (filters && filters.length > 0 && filters[0].conjunction) {
|
|
125
|
-
delete filters[0].conjunction;
|
|
126
|
-
}
|
|
127
|
-
let schema = null, statFilter = null;
|
|
128
|
-
let groupBySchema = groupByMulti ? GROUP_PROPERTY_MULTI : GROUP_PROPERTY;
|
|
129
|
-
if (calculation) {
|
|
130
|
-
schema = Object.assign(Object.assign({}, (groupBy ? groupBySchema : FIELD_PROPERTY)), SCHEMA_MAP[calculation]);
|
|
131
|
-
if (!filters.find(filter => filter.key === field && filter.condition === CONDITIONS.NOT_EMPTY)) {
|
|
132
|
-
statFilter = parseFilterExpression([
|
|
133
|
-
{ key: field, condition: CONDITIONS.NOT_EMPTY },
|
|
134
|
-
]);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
const parsedFilters = parseFilterExpression(filters);
|
|
138
|
-
const filterExpression = parsedFilters ? `&& (${parsedFilters})` : "";
|
|
139
|
-
const emitExpression = parseEmitExpression(field, groupBy);
|
|
140
|
-
const tableExpression = `doc.tableId === "${tableId}"`;
|
|
141
|
-
const coreExpression = statFilter
|
|
142
|
-
? `(${tableExpression} && ${statFilter})`
|
|
143
|
-
: tableExpression;
|
|
144
|
-
const reduction = field && calculation ? { reduce: `_${calculation}` } : {};
|
|
145
|
-
return Object.assign({ meta: {
|
|
146
|
-
field,
|
|
147
|
-
tableId,
|
|
148
|
-
groupBy,
|
|
149
|
-
filters,
|
|
150
|
-
schema,
|
|
151
|
-
calculation,
|
|
152
|
-
}, map: `function (doc) {
|
|
153
|
-
if (${coreExpression} ${filterExpression}) {
|
|
154
|
-
${emitExpression}
|
|
155
|
-
}
|
|
156
|
-
}` }, reduction);
|
|
157
|
-
}
|
|
158
|
-
exports.default = default_1;
|
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
-
});
|
|
33
|
-
};
|
|
34
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
-
};
|
|
37
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
-
exports.trigger = exports.buildSchema = exports.destroy = exports.save = exports.fetch = void 0;
|
|
39
|
-
const utils_1 = require("../../db/utils");
|
|
40
|
-
const triggers = __importStar(require("../../automations/triggers"));
|
|
41
|
-
const backend_core_1 = require("@budibase/backend-core");
|
|
42
|
-
const types_1 = require("@budibase/types");
|
|
43
|
-
const sdk_1 = __importDefault(require("../../sdk"));
|
|
44
|
-
const toJsonSchema = require("to-json-schema");
|
|
45
|
-
const validate = require("jsonschema").validate;
|
|
46
|
-
const AUTOMATION_DESCRIPTION = "Generated from Webhook Schema";
|
|
47
|
-
function fetch(ctx) {
|
|
48
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
-
const db = backend_core_1.context.getAppDB();
|
|
50
|
-
const response = yield db.allDocs((0, utils_1.getWebhookParams)(null, {
|
|
51
|
-
include_docs: true,
|
|
52
|
-
}));
|
|
53
|
-
ctx.body = response.rows.map((row) => row.doc);
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
exports.fetch = fetch;
|
|
57
|
-
function save(ctx) {
|
|
58
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
-
const webhook = yield sdk_1.default.automations.webhook.save(ctx.request.body);
|
|
60
|
-
ctx.body = {
|
|
61
|
-
message: "Webhook created successfully",
|
|
62
|
-
webhook,
|
|
63
|
-
};
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
exports.save = save;
|
|
67
|
-
function destroy(ctx) {
|
|
68
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
69
|
-
ctx.body = yield sdk_1.default.automations.webhook.destroy(ctx.params.id, ctx.params.rev);
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
exports.destroy = destroy;
|
|
73
|
-
function buildSchema(ctx) {
|
|
74
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
75
|
-
yield backend_core_1.context.doInAppContext(ctx.params.instance, () => __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
const db = backend_core_1.context.getAppDB();
|
|
77
|
-
const webhook = (yield db.get(ctx.params.id));
|
|
78
|
-
webhook.bodySchema = toJsonSchema(ctx.request.body);
|
|
79
|
-
// update the automation outputs
|
|
80
|
-
if (webhook.action.type === types_1.WebhookActionType.AUTOMATION) {
|
|
81
|
-
let automation = (yield db.get(webhook.action.target));
|
|
82
|
-
const autoOutputs = automation.definition.trigger.schema.outputs;
|
|
83
|
-
let properties = webhook.bodySchema.properties;
|
|
84
|
-
// reset webhook outputs
|
|
85
|
-
autoOutputs.properties = {
|
|
86
|
-
body: autoOutputs.properties.body,
|
|
87
|
-
};
|
|
88
|
-
for (let prop of Object.keys(properties)) {
|
|
89
|
-
autoOutputs.properties[prop] = {
|
|
90
|
-
type: properties[prop].type,
|
|
91
|
-
description: AUTOMATION_DESCRIPTION,
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
yield db.put(automation);
|
|
95
|
-
}
|
|
96
|
-
ctx.body = yield db.put(webhook);
|
|
97
|
-
}));
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
exports.buildSchema = buildSchema;
|
|
101
|
-
function trigger(ctx) {
|
|
102
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
103
|
-
const prodAppId = backend_core_1.db.getProdAppID(ctx.params.instance);
|
|
104
|
-
yield backend_core_1.context.doInAppContext(prodAppId, () => __awaiter(this, void 0, void 0, function* () {
|
|
105
|
-
try {
|
|
106
|
-
const db = backend_core_1.context.getAppDB();
|
|
107
|
-
const webhook = (yield db.get(ctx.params.id));
|
|
108
|
-
// validate against the schema
|
|
109
|
-
if (webhook.bodySchema) {
|
|
110
|
-
validate(ctx.request.body, webhook.bodySchema);
|
|
111
|
-
}
|
|
112
|
-
const target = yield db.get(webhook.action.target);
|
|
113
|
-
if (webhook.action.type === types_1.WebhookActionType.AUTOMATION) {
|
|
114
|
-
// trigger with both the pure request and then expand it
|
|
115
|
-
// incase the user has produced a schema to bind to
|
|
116
|
-
yield triggers.externalTrigger(target, Object.assign(Object.assign({ body: ctx.request.body }, ctx.request.body), { appId: prodAppId }));
|
|
117
|
-
}
|
|
118
|
-
ctx.status = 200;
|
|
119
|
-
ctx.body = {
|
|
120
|
-
message: "Webhook trigger fired successfully",
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
catch (err) {
|
|
124
|
-
if (err.status === 404) {
|
|
125
|
-
ctx.status = 200;
|
|
126
|
-
ctx.body = {
|
|
127
|
-
message: "Application not deployed yet.",
|
|
128
|
-
};
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}));
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
exports.trigger = trigger;
|