@sap/cds 8.9.4 → 9.0.3
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/CHANGELOG.md +121 -680
- package/LICENSE +15 -21
- package/README.md +1 -1
- package/_i18n/i18n_sl.properties +3 -3
- package/_i18n/messages.properties +1 -1
- package/app/index.js +1 -1
- package/bin/serve.js +17 -19
- package/eslint.config.mjs +7 -1
- package/lib/compile/etc/_localized.js +3 -24
- package/lib/compile/etc/yaml.js +6 -15
- package/lib/compile/for/odata.js +2 -2
- package/lib/compile/load.js +15 -4
- package/lib/compile/minify.js +1 -0
- package/lib/compile/to/edm-files.js +4 -33
- package/lib/compile/to/hdbtabledata.js +16 -3
- package/lib/compile/to/sql.js +1 -2
- package/lib/core/linked-csn.js +7 -8
- package/lib/dbs/cds-deploy.js +4 -3
- package/lib/env/cds-env.js +9 -9
- package/lib/env/cds-requires.js +23 -50
- package/lib/env/defaults.js +15 -44
- package/lib/env/schemas/cds-package.js +1 -1
- package/lib/i18n/index.js +1 -0
- package/lib/i18n/locale.js +41 -0
- package/lib/index.js +25 -15
- package/lib/log/cds-error.js +13 -3
- package/lib/log/cds-log.js +43 -18
- package/lib/log/format/aspects/als.js +2 -15
- package/lib/plugins.js +11 -11
- package/lib/ql/CREATE.js +1 -1
- package/lib/ql/DELETE.js +1 -1
- package/lib/ql/DROP.js +1 -1
- package/lib/ql/INSERT.js +9 -18
- package/lib/ql/SELECT.js +12 -19
- package/lib/ql/UPDATE.js +1 -1
- package/lib/ql/UPSERT.js +1 -0
- package/lib/ql/Whereable.js +7 -6
- package/lib/ql/cds-ql.js +0 -12
- package/lib/ql/cds.ql-Query.js +28 -68
- package/lib/ql/cds.ql-infer.js +97 -108
- package/lib/ql/resolve.js +1 -3
- package/lib/req/context.js +5 -4
- package/lib/req/request.js +46 -42
- package/lib/req/response.js +5 -9
- package/lib/req/spawn.js +38 -0
- package/lib/req/validate.js +9 -8
- package/lib/srv/bindings.js +2 -1
- package/lib/srv/cds-connect.js +5 -2
- package/lib/srv/cds-serve.js +0 -2
- package/lib/srv/cds.Service.js +146 -86
- package/lib/srv/middlewares/auth/ias-auth.js +99 -88
- package/lib/srv/middlewares/auth/jwt-auth.js +44 -57
- package/lib/srv/middlewares/cds-context.js +1 -1
- package/lib/srv/middlewares/ctx-model.js +1 -1
- package/lib/srv/middlewares/errors.js +34 -42
- package/lib/srv/protocols/hcql.js +35 -25
- package/lib/srv/protocols/index.js +0 -9
- package/lib/srv/protocols/odata-v4.js +1 -6
- package/lib/srv/srv-dispatch.js +29 -31
- package/lib/srv/srv-handlers.js +14 -46
- package/lib/srv/srv-methods.js +15 -37
- package/lib/srv/srv-tx.js +19 -25
- package/lib/test/cds-test.js +4 -263
- package/lib/utils/cds-utils.js +18 -2
- package/lib/utils/tar.js +6 -8
- package/lib/utils/unit.js +19 -0
- package/libx/_runtime/.eslintrc +1 -1
- package/libx/_runtime/cds-services/util/assert.js +2 -72
- package/libx/_runtime/cds.js +13 -6
- package/libx/_runtime/common/Service.js +33 -75
- package/libx/_runtime/common/aspects/any.js +0 -38
- package/libx/_runtime/common/constants/events.js +5 -13
- package/libx/_runtime/common/generic/auth/autoexpose.js +10 -24
- package/libx/_runtime/common/generic/auth/capabilities.js +23 -20
- package/libx/_runtime/common/generic/auth/expand.js +3 -3
- package/libx/_runtime/common/generic/auth/index.js +3 -3
- package/libx/_runtime/common/generic/auth/insertOnly.js +3 -3
- package/libx/_runtime/common/generic/auth/readOnly.js +4 -4
- package/libx/_runtime/common/generic/auth/requires.js +4 -4
- package/libx/_runtime/common/generic/auth/restrict.js +12 -29
- package/libx/_runtime/common/generic/auth/service.js +3 -3
- package/libx/_runtime/common/generic/auth/utils.js +2 -12
- package/libx/_runtime/common/generic/crud.js +22 -53
- package/libx/_runtime/common/generic/etag.js +18 -31
- package/libx/_runtime/common/generic/input.js +51 -123
- package/libx/_runtime/common/generic/paging.js +4 -4
- package/libx/_runtime/common/generic/sorting.js +8 -19
- package/libx/_runtime/common/generic/stream-only.js +26 -0
- package/libx/_runtime/common/generic/stream.js +16 -48
- package/libx/_runtime/common/generic/temporal.js +15 -7
- package/libx/_runtime/common/utils/binary.js +1 -26
- package/libx/_runtime/common/utils/compareJson.js +1 -2
- package/libx/_runtime/common/utils/cqn.js +15 -14
- package/libx/_runtime/common/utils/differ.js +121 -44
- package/libx/_runtime/common/utils/keys.js +4 -5
- package/libx/_runtime/common/utils/normalizeTimestamp.js +10 -1
- package/libx/_runtime/common/utils/postProcess.js +2 -2
- package/libx/_runtime/common/utils/propagateForeignKeys.js +21 -36
- package/libx/_runtime/common/utils/resolveView.js +105 -141
- package/libx/_runtime/common/utils/rewriteAsterisks.js +45 -12
- package/libx/_runtime/common/utils/streamProp.js +3 -9
- package/libx/_runtime/common/utils/waitingTime.js +13 -1
- package/libx/_runtime/fiori/lean-draft.js +174 -196
- package/libx/_runtime/messaging/common-utils/connections.js +1 -1
- package/libx/_runtime/messaging/enterprise-messaging-utils/EMManagement.js +1 -0
- package/libx/_runtime/messaging/enterprise-messaging-utils/registerEndpoints.js +3 -3
- package/libx/_runtime/messaging/enterprise-messaging.js +2 -2
- package/libx/_runtime/messaging/file-based.js +2 -4
- package/libx/_runtime/messaging/redis-messaging.js +1 -1
- package/libx/_runtime/messaging/service.js +5 -19
- package/libx/_runtime/remote/Service.js +20 -33
- package/libx/_runtime/remote/utils/client.js +7 -25
- package/libx/_runtime/remote/utils/cloudSdkProvider.js +8 -13
- package/libx/_runtime/remote/utils/data.js +3 -34
- package/libx/_runtime/types/api.js +0 -8
- package/libx/_runtime/ucl/Service.js +1 -9
- package/libx/common/utils/path.js +2 -3
- package/libx/common/utils/streaming.js +2 -1
- package/libx/http/HttpRequest.js +13 -0
- package/libx/{odata/middleware → http}/body-parser.js +7 -5
- package/libx/http/location.js +41 -0
- package/libx/http/put.js +36 -0
- package/libx/odata/ODataAdapter.js +25 -59
- package/libx/odata/index.js +10 -23
- package/libx/odata/middleware/batch.js +29 -20
- package/libx/odata/middleware/create.js +6 -13
- package/libx/odata/middleware/delete.js +0 -4
- package/libx/odata/middleware/error.js +83 -27
- package/libx/odata/middleware/metadata.js +14 -25
- package/libx/odata/middleware/operation.js +10 -26
- package/libx/odata/middleware/read.js +10 -18
- package/libx/odata/middleware/stream.js +14 -34
- package/libx/odata/middleware/update.js +17 -26
- package/libx/odata/parse/afterburner.js +20 -16
- package/libx/odata/parse/cqn2odata.js +3 -1
- package/libx/odata/parse/grammar.peggy +221 -114
- package/libx/odata/parse/parser.js +1 -1
- package/libx/odata/utils/index.js +10 -38
- package/libx/odata/utils/metadata.js +10 -8
- package/libx/odata/utils/normalizeTimeData.js +5 -8
- package/libx/odata/utils/readAfterWrite.js +1 -1
- package/libx/{outbox/OutboxRunner.js → queue/TaskRunner.js} +17 -22
- package/libx/queue/index.js +531 -0
- package/libx/rest/RestAdapter.js +43 -82
- package/libx/rest/middleware/create.js +35 -33
- package/libx/rest/middleware/delete.js +9 -7
- package/libx/rest/middleware/error.js +11 -18
- package/libx/rest/middleware/operation.js +44 -137
- package/libx/rest/middleware/parse.js +114 -130
- package/libx/rest/middleware/read.js +23 -21
- package/libx/rest/middleware/update.js +20 -32
- package/libx/rest/middleware/upsert.js +31 -0
- package/libx/rest/pre-processing.js +8 -18
- package/package.json +6 -7
- package/srv/outbox.cds +1 -0
- package/bin/test.js +0 -125
- package/lib/env/plugins.js +0 -18
- package/lib/req/cds-context.js +0 -52
- package/lib/req/locale.js +0 -35
- package/lib/srv/cds.ServiceClient.js +0 -96
- package/lib/srv/cds.ServiceProvider.js +0 -20
- package/lib/srv/protocols/okra.js +0 -22
- package/lib/test/axios.js +0 -63
- package/lib/test/data.js +0 -52
- package/lib/test/expect.js +0 -343
- package/lib/test/reporter.js +0 -176
- package/libx/_runtime/cds-services/adapter/odata-v4/OData.js +0 -275
- package/libx/_runtime/cds-services/adapter/odata-v4/ODataRequest.js +0 -217
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/action.js +0 -101
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/create.js +0 -79
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/debug.js +0 -6
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/delete.js +0 -60
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/error.js +0 -161
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/language.js +0 -7
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/metadata.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/read.js +0 -602
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/request.js +0 -64
- package/libx/_runtime/cds-services/adapter/odata-v4/handlers/update.js +0 -238
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/ExpressionToCQN.js +0 -327
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/applyToCQN.js +0 -243
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/boundToCQN.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/createToCQN.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/deleteToCQN.js +0 -36
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/expandToCQN.js +0 -250
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/index.js +0 -81
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/orderByToCQN.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/readToCQN.js +0 -389
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/searchToCQN.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/selectToCQN.js +0 -35
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/updateToCQN.js +0 -38
- package/libx/_runtime/cds-services/adapter/odata-v4/odata-to-cqn/utils.js +0 -217
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/FeatureSupport.js +0 -70
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/FullQualifiedName.js +0 -94
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlAction.js +0 -139
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlActionImport.js +0 -82
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlAliasInfo.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlAnnotation.js +0 -104
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlAnnotations.js +0 -71
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlComplexType.js +0 -133
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEntityContainer.js +0 -142
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEntityContainerInfo.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEntitySet.js +0 -107
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEntityType.js +0 -177
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEnumMember.js +0 -61
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlEnumType.js +0 -105
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlFunction.js +0 -149
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlFunctionImport.js +0 -105
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlInclude.js +0 -68
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlIncludeAnnotation.js +0 -71
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlJsonProvider.js +0 -1365
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlNavigationProperty.js +0 -190
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlNavigationPropertyBinding.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlOnDelete.js +0 -70
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlParameter.js +0 -227
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlProperty.js +0 -250
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlPropertyRef.js +0 -49
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlProvider.js +0 -190
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlReference.js +0 -97
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlReferentialConstraint.js +0 -60
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlReturnType.js +0 -216
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlSchema.js +0 -328
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlSingleton.js +0 -84
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlTerm.js +0 -320
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/CsdlTypeDefinition.js +0 -193
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlAnnotationExpression.js +0 -73
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlAnnotationPathExpression.js +0 -33
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlApplyExpression.js +0 -105
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlArithmeticExpression.js +0 -72
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlBinaryExpression.js +0 -110
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlCastExpression.js +0 -188
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlCollectionExpression.js +0 -48
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlConstantExpression.js +0 -116
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlIfExpression.js +0 -62
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlIsOfExpression.js +0 -200
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlLabeledElementExpression.js +0 -42
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlLabeledElementReferenceExpression.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlModelElementPathExpression.js +0 -29
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlNavigationPropertyPathExpression.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlNegationExpression.js +0 -27
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlNotExpression.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlNullExpression.js +0 -18
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlPathExpression.js +0 -32
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlPropertyPathExpression.js +0 -32
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlPropertyValueExpression.js +0 -55
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlRecordExpression.js +0 -54
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlUnknownExpression.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/csdl/annotationExpression/CsdlUrlRefExpression.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/AbstractEdmBindingTarget.js +0 -163
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/AbstractEdmFaceted.js +0 -136
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/AbstractEdmOperation.js +0 -205
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/AbstractEdmOperationImport.js +0 -126
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/AbstractEdmStructuredType.js +0 -275
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/Edm.js +0 -775
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmAction.js +0 -15
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmActionImport.js +0 -39
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmAnnotation.js +0 -106
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmAnnotations.js +0 -57
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmComplexType.js +0 -48
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmEntityContainer.js +0 -455
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmEntitySet.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmEntityType.js +0 -119
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmEnumMember.js +0 -69
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmEnumType.js +0 -117
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmFunction.js +0 -39
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmFunctionImport.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmInclude.js +0 -65
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmIncludeAnnotation.js +0 -48
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmKeyPropertyRef.js +0 -79
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmNavigationProperty.js +0 -182
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmNavigationPropertyBinding.js +0 -46
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmOnDelete.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmParameter.js +0 -22
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmPrimitiveType.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmPrimitiveTypeKind.js +0 -70
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmProperty.js +0 -39
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmProvider.js +0 -399
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmReference.js +0 -88
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmReferentialConstraint.js +0 -71
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmReturnType.js +0 -14
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmSchema.js +0 -355
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmSingleton.js +0 -15
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmTerm.js +0 -75
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmType.js +0 -95
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmTypeDefinition.js +0 -121
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmTypeFactory.js +0 -28
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/EdmVocabularyTermType.js +0 -41
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/KeyFactory.js +0 -67
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/Target.js +0 -56
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/TransientStructuredType.js +0 -244
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/AnnotationExpressionFactory.js +0 -130
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmAnnotationExpression.js +0 -28
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmAnnotationPathExpression.js +0 -42
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmApplyExpression.js +0 -85
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmArithmeticExpression.js +0 -92
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmBinaryExpression.js +0 -96
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmCastExpression.js +0 -129
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmCollectionExpression.js +0 -52
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmConstantExpression.js +0 -83
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmIfExpression.js +0 -103
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmIsOfExpression.js +0 -125
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmLabeledElementExpression.js +0 -83
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmLabeledElementReferenceExpression.js +0 -41
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmModelElementPathExpression.js +0 -35
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmNavigationPropertyPathExpression.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmNegationExpression.js +0 -70
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmNotExpression.js +0 -75
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmNullExpression.js +0 -50
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmPathExpression.js +0 -38
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmPropertyPathExpression.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmPropertyValueExpression.js +0 -72
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmRecordExpression.js +0 -100
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmUnknownExpression.js +0 -72
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/edm/annotationExpression/EdmUrlRefExpression.js +0 -73
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/AbstractError.js +0 -82
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/IllegalArgumentError.js +0 -58
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/IllegalCallError.js +0 -21
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/NotImplementedError.js +0 -19
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/UriQueryOptionSemanticError.js +0 -49
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/UriSemanticError.js +0 -48
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/errors/UriSyntaxError.js +0 -65
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/format/ContentTypeInfo.js +0 -105
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/format/JsonContentTypeInfo.js +0 -83
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/format/JsonFormat.js +0 -141
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/format/RepresentationKind.js +0 -251
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/http/HttpHeader.js +0 -42
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/http/HttpHeaderReader.js +0 -318
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/http/HttpMethod.js +0 -25
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/http/HttpStatusCode.js +0 -52
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/http/Preferences.js +0 -32
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/index.js +0 -69
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/logging/LoggerFacade.js +0 -183
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/AliasExpression.js +0 -47
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/ApplyParser.js +0 -946
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/BinaryExpression.js +0 -124
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/ExpandItem.js +0 -76
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/ExpandParser.js +0 -384
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/Expression.js +0 -46
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/ExpressionParser.js +0 -1988
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/FilterParser.js +0 -34
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/FunctionParameterParser.js +0 -106
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/KeyPredicateParser.js +0 -155
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/KeyValueParser.js +0 -213
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/LiteralExpression.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/MemberExpression.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/MethodExpression.js +0 -146
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/OrderByItem.js +0 -53
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/OrderByParser.js +0 -69
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/ResourcePathParser.js +0 -848
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/SearchParser.js +0 -127
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/SelectItem.js +0 -80
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/SelectParser.js +0 -294
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/TypeLiteralExpression.js +0 -28
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UnaryExpression.js +0 -64
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriHelper.js +0 -65
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriInfo.js +0 -165
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriParameter.js +0 -107
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriParser.js +0 -350
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriResource.js +0 -602
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/UriTokenizer.js +0 -1156
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/AggregateExpression.js +0 -164
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/AggregateTransformation.js +0 -38
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/BottomTopTransformation.js +0 -93
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/ComputeExpression.js +0 -52
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/ComputeTransformation.js +0 -38
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/ConcatTransformation.js +0 -38
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/CustomFunctionTransformation.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/ExpandTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/FilterTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/GroupByItem.js +0 -71
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/GroupByTransformation.js +0 -58
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/IdentityTransformation.js +0 -17
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/OrderByTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/SearchTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/SkipTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/TopTransformation.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/apply/Transformation.js +0 -53
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/uri/info.md +0 -116
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/utils/PrimitiveValueDecoder.js +0 -667
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/utils/PrimitiveValueEncoder.js +0 -349
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/utils/ValueConverter.js +0 -545
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/validator/ParameterValidator.js +0 -124
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-commons/validator/ValueValidator.js +0 -743
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/ServiceFactory.js +0 -234
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchContext.js +0 -351
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchErrorInfo.js +0 -61
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchExitHandler.js +0 -239
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchProcessor.js +0 -281
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchValidator.js +0 -133
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/batch/BatchedRequestExecutor.js +0 -92
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/ComponentManager.js +0 -63
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/Context.js +0 -96
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/Dispatcher.js +0 -147
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/OdataRequest.js +0 -458
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/OdataRequestInBatch.js +0 -147
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/OdataResponse.js +0 -314
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/OdataResponseInBatch.js +0 -83
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/PlainHttpRequest.js +0 -175
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/PlainHttpResponse.js +0 -106
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/RequestContract.js +0 -111
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/ResponseContract.js +0 -111
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/ResponseHeaderSetter.js +0 -240
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/Service.js +0 -417
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/core/ServiceResolutions.js +0 -24
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/ApplicationHttpReader.js +0 -157
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/BatchJsonDeserializer.js +0 -171
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/BatchRequestListBuilder.js +0 -196
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/Cache.js +0 -154
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/ContentDeserializer.js +0 -222
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/DataReader.js +0 -220
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/DeserializerFactory.js +0 -240
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/HeaderReader.js +0 -133
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/LineReader.js +0 -61
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/MultipartReader.js +0 -419
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/PartReader.js +0 -99
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/Reader.js +0 -52
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/deserializer/ResourceJsonDeserializer.js +0 -673
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/ApplicationError.js +0 -108
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/BadRequestError.js +0 -21
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/ConflictError.js +0 -11
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/DeserializationError.js +0 -19
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/InternalServerError.js +0 -20
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/MethodNotAllowedError.js +0 -17
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/NotAcceptableError.js +0 -21
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/NotFoundError.js +0 -33
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/PreconditionFailedError.js +0 -11
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/PreconditionRequiredError.js +0 -11
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/SerializationError.js +0 -19
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/errors/UnauthorizedError.js +0 -17
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/AcceptTypeInfo.js +0 -86
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/CharsetInfo.js +0 -76
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/FormatDescription.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/FormatManager.js +0 -91
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/RequestContentNegotiator.js +0 -62
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/format/ResponseContentNegotiator.js +0 -321
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/handler/BatchHandler.js +0 -36
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/handler/MetadataHandler.js +0 -21
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/handler/ServiceHandler.js +0 -25
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/CustomPreference.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/HeaderInfo.js +0 -79
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/HttpHeader.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/HttpHeaderReader.js +0 -452
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/HttpStatusCode.js +0 -117
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/Preferences.js +0 -222
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/http/PreferencesApplied.js +0 -199
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/index.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/Command.js +0 -31
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/CommandExecutor.js +0 -94
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/CommandFactory.js +0 -203
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ConditionalRequestControlCommand.js +0 -52
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ConditionalRequestPreValidationCommand.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ContentNegotiatorCommand.js +0 -70
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/DebugContentNegotiatorCommand.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/DebugDeserializingCommand.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/DebugSerializingCommand.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/DeserializingCommand.js +0 -69
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/DispatcherCommand.js +0 -95
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ErrorContentNegotiatorCommand.js +0 -44
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ErrorSerializingCommand.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/EventListenerCommand.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/LocaleNegotiatorCommand.js +0 -56
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/OdataVersionValidationCommand.js +0 -41
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/OperationValidationCommand.js +0 -34
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/ParsePreferHeaderCommand.js +0 -47
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/PresetResponseHeadersCommand.js +0 -47
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/QueryOptionsParserCommand.js +0 -43
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/QueryOptionsValidationCommand.js +0 -62
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/RequestContentValidationCommand.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/SendResponseCommand.js +0 -37
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/SerializingCommand.js +0 -159
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/SetResponseHeadersCommand.js +0 -90
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/SetStatuscodeCommand.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/invocation/UriParserCommand.js +0 -47
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/logging/DebugLogger.js +0 -97
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ApplicationHttpWriter.js +0 -65
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/BatchJsonSerializer.js +0 -46
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/BatchMultipartSerializer.js +0 -113
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ContextURLFactory.js +0 -405
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/DebugHtmlSerializer.js +0 -302
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/DebugJsonSerializer.js +0 -515
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ErrorJsonSerializer.js +0 -47
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ErrorSerializer.js +0 -39
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ErrorXmlSerializer.js +0 -98
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ExpressionTreeImage.js +0 -404
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/MetadataXmlSerializer.js +0 -1416
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/MultipartWriter.js +0 -202
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/NextLinkSerializer.js +0 -330
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ResourceJsonSerializer.js +0 -1220
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/SerializerFactory.js +0 -484
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/ServiceJsonSerializer.js +0 -89
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/TrustedResourceJsonSerializer.js +0 -612
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/serializer/debugview.html +0 -157
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/utils/BufferedWriter.js +0 -59
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/utils/ExpandHelper.js +0 -96
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/utils/MetadataCache.js +0 -136
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/utils/PerformanceMonitor.js +0 -221
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/utils/UriHelper.js +0 -157
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/validator/ConditionalRequestValidator.js +0 -79
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/validator/OperationValidator.js +0 -199
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/validator/RequestValidator.js +0 -392
- package/libx/_runtime/cds-services/adapter/odata-v4/okra/odata-server/validator/VersionValidator.js +0 -62
- package/libx/_runtime/cds-services/adapter/odata-v4/to.js +0 -51
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/data.js +0 -331
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/handlerUtils.js +0 -159
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/metaInfo.js +0 -404
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/oDataConfiguration.js +0 -55
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/omitValues.js +0 -86
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/readAfterWrite.js +0 -107
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/request.js +0 -64
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/result.js +0 -385
- package/libx/_runtime/cds-services/adapter/odata-v4/utils/stream.js +0 -12
- package/libx/_runtime/cds-services/util/errors.js +0 -15
- package/libx/_runtime/common/aspects/relation.js +0 -40
- package/libx/_runtime/common/composition/data.js +0 -370
- package/libx/_runtime/common/composition/delete.js +0 -313
- package/libx/_runtime/common/composition/index.js +0 -22
- package/libx/_runtime/common/composition/insert.js +0 -108
- package/libx/_runtime/common/composition/tree.js +0 -275
- package/libx/_runtime/common/composition/update.js +0 -354
- package/libx/_runtime/common/composition/utils.js +0 -95
- package/libx/_runtime/common/error/constants.js +0 -20
- package/libx/_runtime/common/error/entry.js +0 -36
- package/libx/_runtime/common/error/frontend.js +0 -199
- package/libx/_runtime/common/error/index.js +0 -12
- package/libx/_runtime/common/error/log.js +0 -35
- package/libx/_runtime/common/error/standardError.js +0 -11
- package/libx/_runtime/common/error/utils.js +0 -18
- package/libx/_runtime/common/generic/auth/constants.js +0 -17
- package/libx/_runtime/common/generic/put.js +0 -85
- package/libx/_runtime/common/utils/columns.js +0 -177
- package/libx/_runtime/common/utils/compareJsonOLD.js +0 -280
- package/libx/_runtime/common/utils/cqn2cqn4sql.js +0 -1039
- package/libx/_runtime/common/utils/data.js +0 -16
- package/libx/_runtime/common/utils/dollar.js +0 -27
- package/libx/_runtime/common/utils/generateOnCond.js +0 -127
- package/libx/_runtime/common/utils/onlyKeysRemain.js +0 -10
- package/libx/_runtime/common/utils/path.js +0 -20
- package/libx/_runtime/common/utils/quotingStyles.js +0 -29
- package/libx/_runtime/common/utils/restrictions.js +0 -67
- package/libx/_runtime/common/utils/search2cqn4sql.js +0 -37
- package/libx/_runtime/common/utils/searchToLike.js +0 -56
- package/libx/_runtime/common/utils/stream.js +0 -103
- package/libx/_runtime/common/utils/ucsn.js +0 -119
- package/libx/_runtime/common/utils/union.js +0 -31
- package/libx/_runtime/common/utils/unionCqnTemplate.js +0 -174
- package/libx/_runtime/db/Service.js +0 -93
- package/libx/_runtime/db/data-conversion/post-processing.js +0 -175
- package/libx/_runtime/db/expand/expand-v2.js +0 -147
- package/libx/_runtime/db/expand/expandCQNToJoin.js +0 -1775
- package/libx/_runtime/db/expand/index.js +0 -13
- package/libx/_runtime/db/expand/rawToExpanded.js +0 -250
- package/libx/_runtime/db/generic/create.js +0 -30
- package/libx/_runtime/db/generic/delete.js +0 -18
- package/libx/_runtime/db/generic/index.js +0 -25
- package/libx/_runtime/db/generic/input.js +0 -227
- package/libx/_runtime/db/generic/read.js +0 -16
- package/libx/_runtime/db/generic/rewrite.js +0 -68
- package/libx/_runtime/db/generic/structured.js +0 -92
- package/libx/_runtime/db/generic/update.js +0 -97
- package/libx/_runtime/db/generic/virtual.js +0 -83
- package/libx/_runtime/db/query/delete.js +0 -39
- package/libx/_runtime/db/query/index.js +0 -13
- package/libx/_runtime/db/query/insert.js +0 -21
- package/libx/_runtime/db/query/read.js +0 -97
- package/libx/_runtime/db/query/run.js +0 -30
- package/libx/_runtime/db/query/update.js +0 -94
- package/libx/_runtime/db/result/InsertResult.js +0 -87
- package/libx/_runtime/db/sql-builder/BaseBuilder.js +0 -65
- package/libx/_runtime/db/sql-builder/CreateBuilder.js +0 -212
- package/libx/_runtime/db/sql-builder/DeleteBuilder.js +0 -87
- package/libx/_runtime/db/sql-builder/DropBuilder.js +0 -63
- package/libx/_runtime/db/sql-builder/ExpressionBuilder.js +0 -345
- package/libx/_runtime/db/sql-builder/FunctionBuilder.js +0 -232
- package/libx/_runtime/db/sql-builder/InsertBuilder.js +0 -494
- package/libx/_runtime/db/sql-builder/ReferenceBuilder.js +0 -135
- package/libx/_runtime/db/sql-builder/SelectBuilder.js +0 -482
- package/libx/_runtime/db/sql-builder/UpdateBuilder.js +0 -207
- package/libx/_runtime/db/sql-builder/UpsertBuilder.js +0 -25
- package/libx/_runtime/db/sql-builder/annotations.js +0 -50
- package/libx/_runtime/db/sql-builder/arrayed.js +0 -4
- package/libx/_runtime/db/sql-builder/dataTypes.js +0 -59
- package/libx/_runtime/db/sql-builder/dollar.js +0 -37
- package/libx/_runtime/db/sql-builder/index.js +0 -28
- package/libx/_runtime/db/sql-builder/sqlFactory.js +0 -104
- package/libx/_runtime/db/utils/coloredTxCommands.js +0 -7
- package/libx/_runtime/db/utils/columns.js +0 -41
- package/libx/_runtime/db/utils/deep.js +0 -71
- package/libx/_runtime/db/utils/generateAliases.js +0 -160
- package/libx/_runtime/db/utils/localized.js +0 -77
- package/libx/_runtime/db/utils/normalizeTimeData.js +0 -98
- package/libx/_runtime/db/utils/stream.js +0 -41
- package/libx/_runtime/hana/Service.js +0 -173
- package/libx/_runtime/hana/conversion.js +0 -73
- package/libx/_runtime/hana/customBuilder/CustomCreateBuilder.js +0 -11
- package/libx/_runtime/hana/customBuilder/CustomDeleteBuilder.js +0 -17
- package/libx/_runtime/hana/customBuilder/CustomDropBuilder.js +0 -12
- package/libx/_runtime/hana/customBuilder/CustomExpressionBuilder.js +0 -23
- package/libx/_runtime/hana/customBuilder/CustomFunctionBuilder.js +0 -34
- package/libx/_runtime/hana/customBuilder/CustomReferenceBuilder.js +0 -38
- package/libx/_runtime/hana/customBuilder/CustomSelectBuilder.js +0 -90
- package/libx/_runtime/hana/customBuilder/index.js +0 -11
- package/libx/_runtime/hana/driver.js +0 -205
- package/libx/_runtime/hana/dynatrace.js +0 -130
- package/libx/_runtime/hana/execute.js +0 -429
- package/libx/_runtime/hana/localized.js +0 -39
- package/libx/_runtime/hana/pool.js +0 -186
- package/libx/_runtime/hana/search.js +0 -20
- package/libx/_runtime/hana/search2Contains.js +0 -106
- package/libx/_runtime/hana/search2cqn4sql.js +0 -98
- package/libx/_runtime/hana/streaming.js +0 -248
- package/libx/_runtime/messaging/Outbox.js +0 -15
- package/libx/_runtime/sqlite/Service.js +0 -153
- package/libx/_runtime/sqlite/conversion.js +0 -47
- package/libx/_runtime/sqlite/convertAssocToOneManaged.js +0 -60
- package/libx/_runtime/sqlite/convertDraftAdminPathExpression.js +0 -74
- package/libx/_runtime/sqlite/customBuilder/CustomExpressionBuilder.js +0 -24
- package/libx/_runtime/sqlite/customBuilder/CustomFunctionBuilder.js +0 -102
- package/libx/_runtime/sqlite/customBuilder/CustomSelectBuilder.js +0 -16
- package/libx/_runtime/sqlite/customBuilder/CustomUpsertBuilder.js +0 -47
- package/libx/_runtime/sqlite/customBuilder/index.js +0 -49
- package/libx/_runtime/sqlite/execute.js +0 -345
- package/libx/_runtime/sqlite/localized.js +0 -49
- package/libx/outbox/index.js +0 -307
|
@@ -1,370 +0,0 @@
|
|
|
1
|
-
const { getCompositionTree } = require('./tree')
|
|
2
|
-
const ctUtils = require('./utils')
|
|
3
|
-
const { getEntityNameFromUpdateCQN } = require('../utils/cqn')
|
|
4
|
-
const { ensureNoDraftsSuffix } = require('../utils/draft')
|
|
5
|
-
const { cqn2cqn4sql } = require('../utils/cqn2cqn4sql')
|
|
6
|
-
const cds = require('../../cds')
|
|
7
|
-
const { DRAFT_COLUMNS_MAP } = require('../constants/draft')
|
|
8
|
-
const { SELECT } = cds.ql
|
|
9
|
-
|
|
10
|
-
const CHUNK_SIZE = cds.env.features.chunk_deep ?? Number.MAX_VALUE
|
|
11
|
-
|
|
12
|
-
/*
|
|
13
|
-
* own utils
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
const _isSameEntityInWhere = (where, target, persistentObj) => {
|
|
17
|
-
for (let i = 0; i < where.length; i++) {
|
|
18
|
-
if (where[i].xpr) {
|
|
19
|
-
const res = _isSameEntityInWhere(where[i].xpr, target, persistentObj)
|
|
20
|
-
if (!res) return res
|
|
21
|
-
continue
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (!where[i] || !where[i].ref || !target.elements[where[i].ref]) {
|
|
25
|
-
continue
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const key = where[i].ref
|
|
29
|
-
const val = where[i + 2].val
|
|
30
|
-
const sign = where[i + 1]
|
|
31
|
-
|
|
32
|
-
if (target.elements[key].key && key in persistentObj && sign === '=' && val !== persistentObj[key]) {
|
|
33
|
-
return false
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
return true
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const _isSameEntity = (cqn, req) => {
|
|
41
|
-
const where = cqn.UPDATE.where || []
|
|
42
|
-
const persistentObj = Array.isArray(req._.partialPersistentState)
|
|
43
|
-
? req._.partialPersistentState[0]
|
|
44
|
-
: req._.partialPersistentState
|
|
45
|
-
|
|
46
|
-
if (!persistentObj) {
|
|
47
|
-
// If no data was found we don't know if it is the same entity
|
|
48
|
-
return false
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const target = cds.ql.resolve.table(req.target)
|
|
52
|
-
if (target.name !== (cqn.UPDATE.entity.ref && cqn.UPDATE.entity.ref[0]) && target.name !== cqn.UPDATE.entity) {
|
|
53
|
-
return false
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return _isSameEntityInWhere(where, target, persistentObj)
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
const _getLinksOfCompTree = compositionTree => {
|
|
60
|
-
const links = []
|
|
61
|
-
|
|
62
|
-
for (const link of [...compositionTree.backLinks, ...compositionTree.customBackLinks]) {
|
|
63
|
-
links.push(link.entityKey)
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
for (const compElement of compositionTree.compositionElements || []) {
|
|
67
|
-
for (const link of [...compElement.backLinks, ...compElement.customBackLinks]) {
|
|
68
|
-
links.push(link.targetKey)
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
return links
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
const _whereKeys = keySet => {
|
|
76
|
-
if (!keySet.length || !Object.keys(keySet[0]).length) return []
|
|
77
|
-
|
|
78
|
-
const keys0 = Object.keys(keySet[0])
|
|
79
|
-
const keys = { list: keys0.map(pk => ({ ref: [pk] })) }
|
|
80
|
-
const values = {
|
|
81
|
-
list: keySet.map(row => ({
|
|
82
|
-
list: keys0.map(k => ({ val: row[k] }))
|
|
83
|
-
}))
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
return [keys, 'in', values]
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
const _parentKey = (element, key) => {
|
|
90
|
-
let links = [...element.customBackLinks, ...element.backLinks]
|
|
91
|
-
if (element.is2one && links.some(l => l.for2one)) links = links.filter(l => l.for2one)
|
|
92
|
-
|
|
93
|
-
return links.reduce((parentKey, customBackLink) => {
|
|
94
|
-
// TODO: why Object.prototype.hasOwnProperty?
|
|
95
|
-
parentKey[customBackLink.entityKey] = Object.prototype.hasOwnProperty.call(key, customBackLink.targetKey)
|
|
96
|
-
? key[customBackLink.targetKey]
|
|
97
|
-
: customBackLink.targetVal
|
|
98
|
-
|
|
99
|
-
// nested
|
|
100
|
-
if (!parentKey[customBackLink.entityKey]) {
|
|
101
|
-
const splitted = customBackLink.targetKey.split('_')
|
|
102
|
-
let current
|
|
103
|
-
let joined = ''
|
|
104
|
-
while (splitted.length > 1) {
|
|
105
|
-
if (joined) joined += '_'
|
|
106
|
-
joined += splitted.shift()
|
|
107
|
-
if (Object.prototype.hasOwnProperty.call(key, joined)) current = key[joined]
|
|
108
|
-
}
|
|
109
|
-
if (current) parentKey[customBackLink.entityKey] = current[splitted[0]]
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
return parentKey
|
|
113
|
-
}, {})
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
const _findWhere = (data, where) => {
|
|
117
|
-
return data.filter(entry => {
|
|
118
|
-
return Object.keys(where).every(key => {
|
|
119
|
-
if (Buffer.isBuffer(entry[key]) && Buffer.isBuffer(where[key])) {
|
|
120
|
-
return Buffer.compare(entry[key], where[key]) === 0
|
|
121
|
-
}
|
|
122
|
-
return where[key] === entry[key]
|
|
123
|
-
})
|
|
124
|
-
})
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
const _keys = (entity, data) => data.map(entry => ctUtils.key(entity, entry))
|
|
128
|
-
|
|
129
|
-
const _parentKeys = (element, keys) => {
|
|
130
|
-
return keys.map(key => _parentKey(element, key)).filter(ele => Object.keys(ele).length)
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
const _subData = (data, prop) =>
|
|
134
|
-
data &&
|
|
135
|
-
data.reduce((result, entry) => {
|
|
136
|
-
if (prop in entry) {
|
|
137
|
-
const elementValue = ctUtils.val(entry[prop])
|
|
138
|
-
for (const val of ctUtils.array(elementValue)) result.push(val)
|
|
139
|
-
}
|
|
140
|
-
return result
|
|
141
|
-
}, [])
|
|
142
|
-
|
|
143
|
-
const _getWhereObj = (row, links) => {
|
|
144
|
-
return links.reduce((res, currentLink) => {
|
|
145
|
-
if (Object.prototype.hasOwnProperty.call(row, currentLink.targetKey) && row[currentLink.targetKey] !== null)
|
|
146
|
-
res[currentLink.entityKey] = row[currentLink.targetKey]
|
|
147
|
-
else if (currentLink.targetVal !== undefined) res[currentLink.entityKey] = currentLink.targetVal
|
|
148
|
-
return res
|
|
149
|
-
}, {})
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
const _subWhere = (result, element) => {
|
|
153
|
-
let where
|
|
154
|
-
let links = [...element.backLinks, ...element.customBackLinks]
|
|
155
|
-
|
|
156
|
-
if (element.is2one && links.some(l => l.for2one)) links = links.filter(l => l.for2one)
|
|
157
|
-
|
|
158
|
-
if (result.length && links && links.length > 0) {
|
|
159
|
-
where = {}
|
|
160
|
-
const keys0 = Object.keys(_getWhereObj(result[0], links))
|
|
161
|
-
|
|
162
|
-
if (keys0.length) {
|
|
163
|
-
const keys = { list: keys0.map(pk => ({ ref: [pk] })) }
|
|
164
|
-
|
|
165
|
-
for (let i = 0; i < result.length; i += CHUNK_SIZE) {
|
|
166
|
-
const values = {
|
|
167
|
-
list: result.slice(i, i + CHUNK_SIZE).map(row => ({
|
|
168
|
-
list: keys0.map(k => {
|
|
169
|
-
return { val: _getWhereObj(row, links)[k] }
|
|
170
|
-
})
|
|
171
|
-
}))
|
|
172
|
-
}
|
|
173
|
-
where[i] = [keys, 'in', values]
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
return where
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
const _mergeResults = (result, selectData, root, model, compositionTree, entityName) => {
|
|
182
|
-
if (root) {
|
|
183
|
-
return [...selectData, ...result]
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
const parent = model.definitions[compositionTree.target] || model.definitions[entityName]
|
|
187
|
-
const assoc = (parent && parent.elements[compositionTree.name]) || {}
|
|
188
|
-
|
|
189
|
-
return selectData.map(selectEntry => {
|
|
190
|
-
if (assoc.is2one) {
|
|
191
|
-
selectEntry[compositionTree.name] = selectEntry[compositionTree.name] || {}
|
|
192
|
-
} else if (assoc.is2many) {
|
|
193
|
-
selectEntry[compositionTree.name] = selectEntry[compositionTree.name] || []
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
const newData = _findWhere(result, _parentKey(compositionTree, selectEntry))
|
|
197
|
-
if (assoc.is2one) {
|
|
198
|
-
if (newData[0]) selectEntry[compositionTree.name] = Object.assign(selectEntry[compositionTree.name], newData[0])
|
|
199
|
-
else selectEntry[compositionTree.name] = null
|
|
200
|
-
} else if (assoc.is2many) {
|
|
201
|
-
const entry = selectEntry[compositionTree.name]
|
|
202
|
-
for (const val of newData) entry.push(val)
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
return selectEntry
|
|
206
|
-
})
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
const _columns = (entity, data, compositionTree, selectAllColumns, draft) => {
|
|
210
|
-
const backLinkKeys = _getLinksOfCompTree(compositionTree)
|
|
211
|
-
const columns = []
|
|
212
|
-
|
|
213
|
-
for (const elementName in entity.elements) {
|
|
214
|
-
const element = entity.elements[elementName]
|
|
215
|
-
if (element.virtual || element.isAssociation) continue
|
|
216
|
-
if (!draft && elementName in DRAFT_COLUMNS_MAP) continue
|
|
217
|
-
|
|
218
|
-
if (
|
|
219
|
-
selectAllColumns ||
|
|
220
|
-
element.key ||
|
|
221
|
-
backLinkKeys.includes(element.name) ||
|
|
222
|
-
(Array.isArray(data) && data.find(entry => element.name in entry))
|
|
223
|
-
) {
|
|
224
|
-
columns.push({ ref: [element.name] })
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
return columns
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
const _select = ({
|
|
232
|
-
model,
|
|
233
|
-
entityName,
|
|
234
|
-
draft,
|
|
235
|
-
alias,
|
|
236
|
-
compositionTree,
|
|
237
|
-
data,
|
|
238
|
-
selectAllColumns,
|
|
239
|
-
where,
|
|
240
|
-
parentKeys,
|
|
241
|
-
orderBy,
|
|
242
|
-
singleton
|
|
243
|
-
}) => {
|
|
244
|
-
const entity = model.definitions[entityName]
|
|
245
|
-
const from = ctUtils.addDraftSuffix(draft, entity.name)
|
|
246
|
-
const selectCQN = SELECT.from(from)
|
|
247
|
-
if (alias) selectCQN.SELECT.from.as = alias
|
|
248
|
-
selectCQN.SELECT.columns = _columns(entity, data, compositionTree, selectAllColumns, draft)
|
|
249
|
-
if (where) selectCQN.SELECT.where = where
|
|
250
|
-
else if (parentKeys) selectCQN.SELECT.where = _whereKeys(parentKeys)
|
|
251
|
-
if (orderBy) selectCQN.SELECT.orderBy = orderBy
|
|
252
|
-
if (singleton) selectCQN.SELECT.limit = { rows: { val: 1 } }
|
|
253
|
-
// REVISIT: remove once SELECT builder does flattening!
|
|
254
|
-
return cqn2cqn4sql(selectCQN, model)
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
const _selectDeepUpdateData = async args => {
|
|
258
|
-
const { model, compositionTree, entityName, data, root, selectData, tx, selectAllColumns, where, parentKeys } = args
|
|
259
|
-
let result = []
|
|
260
|
-
|
|
261
|
-
if (!where && parentKeys && parentKeys.length && Object.keys(parentKeys[0]).length) {
|
|
262
|
-
const keys0 = Object.keys(parentKeys[0])
|
|
263
|
-
const keys = { list: keys0.map(pk => ({ ref: [pk] })) }
|
|
264
|
-
for (let i = 0; i < parentKeys.length; i += CHUNK_SIZE) {
|
|
265
|
-
const values = {
|
|
266
|
-
list: parentKeys.slice(i, i + CHUNK_SIZE).map(row => ({ list: keys0.map(k => ({ val: row[k] })) }))
|
|
267
|
-
}
|
|
268
|
-
const _args = { ...args, where: [keys, 'in', values], parentKeys: undefined }
|
|
269
|
-
const selectCQN = _select(_args)
|
|
270
|
-
result = result.concat(await tx.run(selectCQN))
|
|
271
|
-
}
|
|
272
|
-
} else if (where && !Array.isArray(where)) {
|
|
273
|
-
for (let w of Object.values(where)) {
|
|
274
|
-
const _args = { ...args, where: w }
|
|
275
|
-
const selectCQN = _select(_args)
|
|
276
|
-
result = result.concat(await tx.run(selectCQN))
|
|
277
|
-
}
|
|
278
|
-
} else {
|
|
279
|
-
const selectCQN = _select(args)
|
|
280
|
-
result = await tx.run(selectCQN)
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
if (!result.length) return Promise.resolve(result)
|
|
284
|
-
|
|
285
|
-
const keys = _keys(model.definitions[entityName], result)
|
|
286
|
-
await Promise.all(
|
|
287
|
-
compositionTree.compositionElements.map(element => {
|
|
288
|
-
if (element.skipPersistence) return Promise.resolve()
|
|
289
|
-
if (data !== undefined && !data.find(entry => element.name in entry) && !(selectAllColumns && result.length))
|
|
290
|
-
return Promise.resolve()
|
|
291
|
-
const subs = {
|
|
292
|
-
compositionTree: element,
|
|
293
|
-
entityName: element.source,
|
|
294
|
-
data: _subData(data, element.name),
|
|
295
|
-
where: _subWhere(result, element),
|
|
296
|
-
selectData: result,
|
|
297
|
-
parentKeys: _parentKeys(element, keys),
|
|
298
|
-
orderBy: false,
|
|
299
|
-
root: false
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
subs.data = subs.data.filter(d => d) // REVISIT: remove null elements
|
|
303
|
-
return _selectDeepUpdateData({ ...args, ...subs })
|
|
304
|
-
})
|
|
305
|
-
)
|
|
306
|
-
|
|
307
|
-
return _mergeResults(result, selectData || [], root, model, compositionTree, entityName)
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
// if a view has an orderBy with renamed field, we need to resolve it
|
|
311
|
-
const _resolveOrderBy = (orderBy, transitions) => {
|
|
312
|
-
// no resolved entity found
|
|
313
|
-
if (!transitions?.length) return
|
|
314
|
-
|
|
315
|
-
// if there are no renamed fields, no need to resolve
|
|
316
|
-
if (!transitions[0].mapping.size) return
|
|
317
|
-
if (orderBy) orderBy.map(el => (el.ref[0] = transitions[0].mapping.get(el.ref[0]).ref[0]))
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
/*
|
|
321
|
-
* exports
|
|
322
|
-
*/
|
|
323
|
-
|
|
324
|
-
const selectDeepUpdateData = (service, model, req, selectAllColumns = false) => {
|
|
325
|
-
const query = req.query
|
|
326
|
-
|
|
327
|
-
// REVISIT this should be done somewhere before, so it is not done twice for deep updates
|
|
328
|
-
// REVISIT: this is done (better) in the new db-services
|
|
329
|
-
const sqlQuery = cqn2cqn4sql(query, model)
|
|
330
|
-
|
|
331
|
-
if (req && _isSameEntity(sqlQuery, req)) {
|
|
332
|
-
return Promise.resolve(req._.partialPersistentState)
|
|
333
|
-
}
|
|
334
|
-
|
|
335
|
-
const from = getEntityNameFromUpdateCQN(sqlQuery)
|
|
336
|
-
const alias = sqlQuery.UPDATE.entity.as
|
|
337
|
-
// if parts of (another) query are re-used make sure to get your own copy
|
|
338
|
-
const where = cds.clone(sqlQuery.UPDATE.where) || []
|
|
339
|
-
const entityName = ensureNoDraftsSuffix(from)
|
|
340
|
-
const draft = entityName !== from
|
|
341
|
-
const orderBy = req?.target?.query?.SELECT?.orderBy ? cds.clone(req?.target?.query?.SELECT?.orderBy) : null
|
|
342
|
-
_resolveOrderBy(orderBy, sqlQuery.UPDATE._transitions)
|
|
343
|
-
const data = Object.assign({}, sqlQuery.UPDATE.data || {}, query.UPDATE.with || {})
|
|
344
|
-
const compositionTree = getCompositionTree({
|
|
345
|
-
definitions: model.definitions,
|
|
346
|
-
rootEntityName: entityName, // REVISIT: drafts are resolved too eagerly
|
|
347
|
-
resolveViews: !draft,
|
|
348
|
-
service
|
|
349
|
-
})
|
|
350
|
-
|
|
351
|
-
return _selectDeepUpdateData({
|
|
352
|
-
tx: cds.tx(req),
|
|
353
|
-
model,
|
|
354
|
-
compositionTree,
|
|
355
|
-
entityName,
|
|
356
|
-
data: [data],
|
|
357
|
-
where,
|
|
358
|
-
orderBy,
|
|
359
|
-
draft,
|
|
360
|
-
singleton: req?.target?._isSingleton,
|
|
361
|
-
alias,
|
|
362
|
-
selectAllColumns,
|
|
363
|
-
root: true,
|
|
364
|
-
service
|
|
365
|
-
})
|
|
366
|
-
}
|
|
367
|
-
|
|
368
|
-
module.exports = {
|
|
369
|
-
selectDeepUpdateData
|
|
370
|
-
}
|
|
@@ -1,313 +0,0 @@
|
|
|
1
|
-
const cds = require('../../cds')
|
|
2
|
-
|
|
3
|
-
const { getCompositionTree } = require('./tree')
|
|
4
|
-
const ctUtils = require('./utils')
|
|
5
|
-
|
|
6
|
-
const { ensureNoDraftsSuffix } = require('../utils/draft')
|
|
7
|
-
const { getEntityNameFromDeleteCQN } = require('../utils/cqn')
|
|
8
|
-
const { cqn2cqn4sql } = require('../utils/cqn2cqn4sql')
|
|
9
|
-
const { getComp2oneParents } = require('../utils/csn')
|
|
10
|
-
const getColumns = require('../../db/utils/columns')
|
|
11
|
-
|
|
12
|
-
/*
|
|
13
|
-
* own utils
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
// Poor man's alias algorithm
|
|
17
|
-
// REVISIT: Extract and adapt the alias functionality from `expandCQNToJoin.js`: _adaptWhereOrderBy
|
|
18
|
-
const _recursivelyAliasRefs = (something, newAlias, oldAlias, subselect = false) => {
|
|
19
|
-
if (Array.isArray(something)) return something.map(s => _recursivelyAliasRefs(s, newAlias, oldAlias, subselect))
|
|
20
|
-
if (typeof something === 'object') {
|
|
21
|
-
if (something.ref) {
|
|
22
|
-
something = { ref: [...something.ref] }
|
|
23
|
-
if (oldAlias && something.ref[0] === oldAlias) something.ref[0] = newAlias
|
|
24
|
-
else if (!subselect) something.ref.unshift(newAlias)
|
|
25
|
-
} else {
|
|
26
|
-
something = Object.assign({}, something)
|
|
27
|
-
for (const key in something) {
|
|
28
|
-
if (key === 'from' || key === 'val') continue // Workaround: Deep delete to be rewritten
|
|
29
|
-
something[key] = _recursivelyAliasRefs(something[key], newAlias, oldAlias, subselect || key === 'SELECT')
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return something
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function _getSubWhereAndEntities(element, parentWhere, draft, level = 0, compositionTree = {}) {
|
|
37
|
-
const allBackLinks = [...element.backLinks, ...element.customBackLinks]
|
|
38
|
-
let entity1, entity2
|
|
39
|
-
const linksForWhere = allBackLinks.length ? allBackLinks : element.links
|
|
40
|
-
|
|
41
|
-
const subWhere = linksForWhere.reduce((result, backLink) => {
|
|
42
|
-
// exclude static values from subwhere
|
|
43
|
-
if (backLink.entityKey && !backLink.targetKey && backLink.targetVal !== undefined) {
|
|
44
|
-
return result
|
|
45
|
-
}
|
|
46
|
-
if (result.length > 0) {
|
|
47
|
-
result.push('and')
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
entity1 = {
|
|
51
|
-
alias: `ALIAS${level + 1}`,
|
|
52
|
-
entityName: ctUtils.addDraftSuffix(draft, element.source),
|
|
53
|
-
propertyName: backLink.entityKey
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const res1 = backLink.entityKey ? { ref: [entity1.alias, entity1.propertyName] } : { val: backLink.entityVal }
|
|
57
|
-
|
|
58
|
-
entity2 = {
|
|
59
|
-
alias: `ALIAS${level}`,
|
|
60
|
-
entityName: ctUtils.addDraftSuffix(draft, element.target || element.source),
|
|
61
|
-
propertyName: backLink.targetKey
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const res2 = backLink.targetKey ? { ref: [entity2.alias, entity2.propertyName] } : { val: backLink.targetVal }
|
|
65
|
-
|
|
66
|
-
result.push(res1, '=', res2)
|
|
67
|
-
return result
|
|
68
|
-
}, [])
|
|
69
|
-
|
|
70
|
-
const where = []
|
|
71
|
-
if (!subWhere.length) return { where, entity1, entity2 }
|
|
72
|
-
|
|
73
|
-
let whereKeys = _getWhereKeys(allBackLinks, entity1)
|
|
74
|
-
const staticWhereValues = _getStaticWhere(allBackLinks, entity1)
|
|
75
|
-
if (whereKeys.length === 0 && element.links.length === 1) {
|
|
76
|
-
// add is null check for each unused backlink
|
|
77
|
-
for (const ce of compositionTree.compositionElements || []) {
|
|
78
|
-
if (ce.source !== element.source) continue
|
|
79
|
-
if (ce.name === element.name) continue
|
|
80
|
-
const wk = _getWhereKeys([...ce.backLinks, ...ce.customBackLinks], entity1, 'null')
|
|
81
|
-
if (whereKeys.length === 0) whereKeys = wk
|
|
82
|
-
else whereKeys.push('and', ...wk)
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
if (whereKeys.length > 0) {
|
|
87
|
-
where.push({ xpr: [...whereKeys] }, 'and')
|
|
88
|
-
}
|
|
89
|
-
if (staticWhereValues.length > 0) {
|
|
90
|
-
where.push({ xpr: [...staticWhereValues] }, 'and')
|
|
91
|
-
}
|
|
92
|
-
where.push('exists', {
|
|
93
|
-
SELECT: {
|
|
94
|
-
columns: [{ val: 1, as: '_exists' }],
|
|
95
|
-
from: { ref: [entity2.entityName], as: entity2.alias },
|
|
96
|
-
where: parentWhere && parentWhere.length ? [{ xpr: [...parentWhere] }, 'and', { xpr: [...subWhere] }] : subWhere
|
|
97
|
-
}
|
|
98
|
-
})
|
|
99
|
-
|
|
100
|
-
return {
|
|
101
|
-
where,
|
|
102
|
-
entity1,
|
|
103
|
-
entity2
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
function _getWhereKeys(allBackLinks, entity1, is) {
|
|
108
|
-
return allBackLinks.reduce((result, backLink) => {
|
|
109
|
-
// exclude static keys
|
|
110
|
-
if (backLink.entityKey && !backLink.targetKey && backLink.targetVal !== undefined) {
|
|
111
|
-
return result
|
|
112
|
-
}
|
|
113
|
-
if (result.length > 0) {
|
|
114
|
-
result.push('or')
|
|
115
|
-
}
|
|
116
|
-
if (backLink.entityKey && is) {
|
|
117
|
-
result.push({ ref: [entity1.alias, backLink.entityKey] }, 'is ' + is)
|
|
118
|
-
} else if (backLink.entityVal !== undefined) {
|
|
119
|
-
// static values should not be included
|
|
120
|
-
result.pop()
|
|
121
|
-
}
|
|
122
|
-
return result
|
|
123
|
-
}, [])
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
function _getStaticWhere(allBackLinks, entity1) {
|
|
127
|
-
return allBackLinks.reduce((result, backLink) => {
|
|
128
|
-
if (result.length > 0) {
|
|
129
|
-
result.push('and')
|
|
130
|
-
}
|
|
131
|
-
if (backLink.entityKey && !backLink.targetKey && backLink.targetVal !== undefined) {
|
|
132
|
-
result.push({ ref: [entity1.alias, backLink.entityKey] }, '=', { val: backLink.targetVal })
|
|
133
|
-
}
|
|
134
|
-
return result
|
|
135
|
-
}, [])
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const _addToCQNs = (cqns, subCQN, element, model, level) => {
|
|
139
|
-
// REVISIT:
|
|
140
|
-
// The compiler generates foreign-key constraints (if features.assert_integrity === 'db')
|
|
141
|
-
// and enables DELETE CASCADE. For these cases, the runtime doesn't need to delete compositions
|
|
142
|
-
// manually, it's done by the database itself.
|
|
143
|
-
// However, there are cases (unmanaged compositions), where this doesn't happen.
|
|
144
|
-
// As a first step, the runtime will delete _all_ compositions regardless of the database.
|
|
145
|
-
// In the future, the runtime can enable the deletion of only those compositions
|
|
146
|
-
// which wouldn't be deleted by the database.
|
|
147
|
-
cqns[level] = cqns[level] || []
|
|
148
|
-
cqns[level].push(subCQN)
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
// unofficial config!
|
|
152
|
-
const DEEP_DELETE_MAX_RECURSION_DEPTH =
|
|
153
|
-
(cds.env.features.recursion_depth && Number(cds.env.features.recursion_depth)) || 2
|
|
154
|
-
|
|
155
|
-
const _addSubCascadeDeleteCQN = (model, compositionTree, parentWhere, level, cqns, draft, elementMap = new Map()) => {
|
|
156
|
-
for (const element of compositionTree.compositionElements) {
|
|
157
|
-
if (element.skipPersistence) continue
|
|
158
|
-
|
|
159
|
-
const fqn = compositionTree.source + ':' + element.name
|
|
160
|
-
const seen = elementMap.get(fqn)
|
|
161
|
-
if (seen && seen >= DEEP_DELETE_MAX_RECURSION_DEPTH) {
|
|
162
|
-
// recursion -> abort
|
|
163
|
-
continue
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
// REVISIT: sometimes element.target is undefined which leads to self join
|
|
167
|
-
if (!element.target) element.target = compositionTree.source
|
|
168
|
-
|
|
169
|
-
const { entity1, where } = _getSubWhereAndEntities(element, parentWhere, draft, level, compositionTree)
|
|
170
|
-
if (where.length) {
|
|
171
|
-
const subCQN = { DELETE: { from: { ref: [entity1.entityName], as: entity1.alias }, where: where } }
|
|
172
|
-
|
|
173
|
-
_addToCQNs(cqns, subCQN, element, model, level)
|
|
174
|
-
|
|
175
|
-
// Make a copy and do not share the same map among brother compositions
|
|
176
|
-
// as we're only interested in deep recursions, not wide recursions.
|
|
177
|
-
const newElementMap = new Map(elementMap)
|
|
178
|
-
newElementMap.set(fqn, (seen && seen + 1) || 1)
|
|
179
|
-
_addSubCascadeDeleteCQN(model, element, subCQN.DELETE.where, level + 1, cqns, draft, newElementMap)
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
return cqns
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/*
|
|
187
|
-
* exports
|
|
188
|
-
*/
|
|
189
|
-
|
|
190
|
-
const hasDeepDelete = (model, cqn) => {
|
|
191
|
-
const from = getEntityNameFromDeleteCQN(cqn)
|
|
192
|
-
if (!from) return false
|
|
193
|
-
|
|
194
|
-
// hidden flag for DELETEs on draft root, we have a separate mechanism that deletes the rows using the DraftUUID
|
|
195
|
-
// Hence, we do not need a deep delete in that case.
|
|
196
|
-
if (cqn._suppressDeepDelete) return false
|
|
197
|
-
|
|
198
|
-
const entity = model.definitions[ensureNoDraftsSuffix(from)]
|
|
199
|
-
|
|
200
|
-
if (entity) return !!Object.keys(entity.elements || {}).find(k => entity.elements[k].isComposition)
|
|
201
|
-
|
|
202
|
-
return false
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
const resolveNavigationTarget = (cqn, ref, model) => {
|
|
206
|
-
const lastTransition = cqn.UPDATE._transitions && cqn.UPDATE._transitions[cqn.UPDATE._transitions.length - 1]
|
|
207
|
-
const target = lastTransition
|
|
208
|
-
? lastTransition.target
|
|
209
|
-
: model.definitions[(cqn.UPDATE.entity.ref && cqn.UPDATE.entity.ref[0]) || cqn.UPDATE.entity]
|
|
210
|
-
let elementName = ref[ref.length - 1].id || ref[ref.length - 1]
|
|
211
|
-
const resolved = lastTransition && lastTransition.mapping && lastTransition.mapping.get(elementName)
|
|
212
|
-
if (resolved) elementName = resolved.ref[0]
|
|
213
|
-
return { target, elementName }
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
const _getDataFromOncond = (onCond, parent) => {
|
|
217
|
-
return onCond.reduce((res, e) => {
|
|
218
|
-
if (e.xpr) {
|
|
219
|
-
return Object.assign(res, _getDataFromOncond(e.xpr, parent))
|
|
220
|
-
}
|
|
221
|
-
if (!e.ref || e.ref[0] !== '$$parent') return res
|
|
222
|
-
const fk = e.ref.slice(1).join('_')
|
|
223
|
-
if (!parent.keys[fk]) res[fk] = null
|
|
224
|
-
return res
|
|
225
|
-
}, {})
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
const getSetNullParentForeignKeyCQNs = async (model, req, dbQuery) => {
|
|
229
|
-
const cqns = []
|
|
230
|
-
const query = dbQuery || req.query
|
|
231
|
-
// REVISIT: req._tx should not be used like that!
|
|
232
|
-
const origQuery = (req.tx.isDatabaseService && req._ && req._.query) || req.query
|
|
233
|
-
if (!dbQuery && origQuery && origQuery.DELETE && origQuery.DELETE.from.ref && origQuery.DELETE.from.ref.length > 1) {
|
|
234
|
-
// delete via 2one navigation => parent is known => no need to SELECT
|
|
235
|
-
const ref = origQuery.DELETE.from.ref
|
|
236
|
-
const cqn = cqn2cqn4sql(UPDATE.entity({ ref: ref.slice(0, ref.length - 1) }), model)
|
|
237
|
-
const { target: parent, elementName } = resolveNavigationTarget(cqn, ref, model)
|
|
238
|
-
const element = parent.elements[elementName]
|
|
239
|
-
if (element && element.isComposition && element.is2one) {
|
|
240
|
-
const onCond = element && parent._relations[element.name].join('$$whatever', '$$parent')
|
|
241
|
-
const data = _getDataFromOncond(onCond, parent)
|
|
242
|
-
cqn.data(data)
|
|
243
|
-
cqn.__4delete = true
|
|
244
|
-
if (Object.keys(data).length) cqns.push(cqn)
|
|
245
|
-
}
|
|
246
|
-
} else if (query.DELETE.where && query.DELETE.where.length) {
|
|
247
|
-
// direct or internal request => parent is uknown => need to SELECT
|
|
248
|
-
const entityName = getEntityNameFromDeleteCQN(query)
|
|
249
|
-
const target = model.definitions[entityName]
|
|
250
|
-
const comp2oneParents = getComp2oneParents(target, model)
|
|
251
|
-
for (const element of comp2oneParents) {
|
|
252
|
-
const parent = element.parent
|
|
253
|
-
const onCond = parent._relations[element.name].join('$$child', '$$parent')
|
|
254
|
-
const data = _getDataFromOncond(onCond, parent)
|
|
255
|
-
const columns = getColumns(parent, { _4db: true, onlyKeys: true }).map(c => ({ ref: ['$$parent', c.name] }))
|
|
256
|
-
const as = query.DELETE.from.as || (query.DELETE.from.ref && query.DELETE.from.ref[0]) || query.DELETE.from
|
|
257
|
-
const selectCQN = SELECT.from(`${parent.name} as $$parent`)
|
|
258
|
-
.join(`${element.target} as $$child`)
|
|
259
|
-
.on(onCond)
|
|
260
|
-
.columns(columns)
|
|
261
|
-
.where(_recursivelyAliasRefs(query.DELETE.where, '$$child', as))
|
|
262
|
-
const results = await cds.tx(req).run(selectCQN)
|
|
263
|
-
if (results.length && Object.keys(data).length) {
|
|
264
|
-
const cqn = UPDATE.entity(parent).data(data)
|
|
265
|
-
for (const result of results) {
|
|
266
|
-
const where = []
|
|
267
|
-
for (const col of columns) {
|
|
268
|
-
if (where.length) where.push('and')
|
|
269
|
-
const ref = col.ref.slice(1)
|
|
270
|
-
where.push({ ref }, '=', { val: result[ref[0]] })
|
|
271
|
-
}
|
|
272
|
-
cqn.UPDATE.where = where
|
|
273
|
-
cqn.__4delete = true
|
|
274
|
-
cqns.push(cqn)
|
|
275
|
-
}
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
return cqns
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
const getDeepDeleteCQNs = async (model, req, dbQuery) => {
|
|
283
|
-
const query = dbQuery || req.query
|
|
284
|
-
const from = getEntityNameFromDeleteCQN(query)
|
|
285
|
-
if (!from) return [[query]]
|
|
286
|
-
|
|
287
|
-
const entityName = ensureNoDraftsSuffix(from)
|
|
288
|
-
// REVISIT: baaad check!
|
|
289
|
-
const draft = entityName !== from
|
|
290
|
-
const compositionTree = getCompositionTree({
|
|
291
|
-
definitions: model.definitions,
|
|
292
|
-
rootEntityName: entityName,
|
|
293
|
-
resolveViews: !draft,
|
|
294
|
-
service: cds.db
|
|
295
|
-
})
|
|
296
|
-
const parentWhere = _recursivelyAliasRefs(
|
|
297
|
-
query.DELETE.where,
|
|
298
|
-
'ALIAS0',
|
|
299
|
-
query.DELETE.from.as || (query.DELETE.from.ref && query.DELETE.from.ref[0]) || query.DELETE.from
|
|
300
|
-
)
|
|
301
|
-
const setNullUpdates =
|
|
302
|
-
(model.definitions[entityName].own('__oneCompositionParents') &&
|
|
303
|
-
(await getSetNullParentForeignKeyCQNs(model, req, dbQuery))) ||
|
|
304
|
-
[]
|
|
305
|
-
const subCascadeDeletes = _addSubCascadeDeleteCQN(model, compositionTree, parentWhere, 0, [], draft)
|
|
306
|
-
return [[query], ...subCascadeDeletes, setNullUpdates].reverse()
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
module.exports = {
|
|
310
|
-
hasDeepDelete,
|
|
311
|
-
getDeepDeleteCQNs,
|
|
312
|
-
getSetNullParentForeignKeyCQNs
|
|
313
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
const { getCompositionTree } = require('./tree')
|
|
2
|
-
const { hasDeepInsert, getDeepInsertCQNs } = require('./insert')
|
|
3
|
-
const { hasDeepUpdate, getDeepUpdateCQNs } = require('./update')
|
|
4
|
-
const { hasDeepDelete, getDeepDeleteCQNs, getSetNullParentForeignKeyCQNs } = require('./delete')
|
|
5
|
-
const { selectDeepUpdateData } = require('./data')
|
|
6
|
-
|
|
7
|
-
module.exports = {
|
|
8
|
-
// tree
|
|
9
|
-
getCompositionTree,
|
|
10
|
-
// insert
|
|
11
|
-
hasDeepInsert,
|
|
12
|
-
getDeepInsertCQNs,
|
|
13
|
-
// update
|
|
14
|
-
hasDeepUpdate,
|
|
15
|
-
getDeepUpdateCQNs,
|
|
16
|
-
// delete
|
|
17
|
-
hasDeepDelete,
|
|
18
|
-
getDeepDeleteCQNs,
|
|
19
|
-
getSetNullParentForeignKeyCQNs,
|
|
20
|
-
// data
|
|
21
|
-
selectDeepUpdateData
|
|
22
|
-
}
|