@sap/cds 8.9.3 → 9.0.2
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 +122 -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/classes.js +1 -0
- package/lib/core/linked-csn.js +8 -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 +12 -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 +2 -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 -6
- 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/postProcess.js +2 -2
- package/libx/_runtime/common/utils/propagateForeignKeys.js +21 -36
- package/libx/_runtime/common/utils/resolveView.js +106 -142
- 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 +1 -4
- package/libx/odata/utils/normalizeTimeData.js +4 -7
- package/libx/odata/utils/readAfterWrite.js +1 -1
- package/libx/{outbox/OutboxRunner.js → queue/TaskRunner.js} +17 -22
- package/libx/queue/index.js +530 -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
|
@@ -27,39 +27,6 @@ const _isReadOnly = e => {
|
|
|
27
27
|
)
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
-
const Relation = require('./relation')
|
|
31
|
-
|
|
32
|
-
const _exposeRelation = relation => Object.defineProperty({}, '_', { get: () => relation })
|
|
33
|
-
|
|
34
|
-
const _relationHandler = relation => ({
|
|
35
|
-
get: (target, name) => {
|
|
36
|
-
const path = name.split(',')
|
|
37
|
-
const prop = path.join('_')
|
|
38
|
-
if (!target[prop]) {
|
|
39
|
-
if (path.length === 1) {
|
|
40
|
-
// REVISIT: property 'join' must not be used in CSN to make this working
|
|
41
|
-
if (relation._has(prop)) return relation[prop]
|
|
42
|
-
const newRelation = Relation.to(relation, prop)
|
|
43
|
-
if (newRelation) {
|
|
44
|
-
target[prop] = new Proxy(_exposeRelation(newRelation), _relationHandler(newRelation))
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
return target[prop]
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
target[prop] = path.reduce((relation, value) => relation[value] || relation.csn._relations[value], relation)
|
|
51
|
-
target[prop].path = path
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
return target[prop]
|
|
55
|
-
}
|
|
56
|
-
})
|
|
57
|
-
|
|
58
|
-
const _getRelations = e => {
|
|
59
|
-
const newRelation = Relation.to(e)
|
|
60
|
-
return new Proxy(_exposeRelation(newRelation), _relationHandler(newRelation))
|
|
61
|
-
}
|
|
62
|
-
|
|
63
30
|
// NOTE: Please only add things which are relevant to _any_ type,
|
|
64
31
|
// use specialized types otherwise (entity, Association, ...).
|
|
65
32
|
module.exports = class {
|
|
@@ -83,11 +50,6 @@ module.exports = class {
|
|
|
83
50
|
)
|
|
84
51
|
}
|
|
85
52
|
|
|
86
|
-
// REVISIT: Where to put?
|
|
87
|
-
get _relations() {
|
|
88
|
-
return this.own('__relations', () => _getRelations(this))
|
|
89
|
-
}
|
|
90
|
-
|
|
91
53
|
get _foreignKey4() {
|
|
92
54
|
return this.own('__foreignKey4', () => foreignKey4(this))
|
|
93
55
|
}
|
|
@@ -1,13 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
module.exports = {
|
|
8
|
-
MOD_EVENTS,
|
|
9
|
-
WRITE_EVENTS,
|
|
10
|
-
CRUD_EVENTS,
|
|
11
|
-
DRAFT_EVENTS,
|
|
12
|
-
CDS_EVENTS
|
|
13
|
-
}
|
|
1
|
+
exports.MOD_EVENTS = { UPDATE: 1, DELETE: 1, EDIT: 1 }
|
|
2
|
+
exports.WRITE_EVENTS = { CREATE: 1, NEW: 1, PATCH: 1, CANCEL: 1, ...exports.MOD_EVENTS }
|
|
3
|
+
exports.CRUD_EVENTS = { READ: 1, ...exports.WRITE_EVENTS }
|
|
4
|
+
exports.DRAFT_EVENTS = { PATCH: 1, CANCEL: 1, draftActivate: 1, draftPrepare: 1 }
|
|
5
|
+
exports.CDS_EVENTS = { ...exports.CRUD_EVENTS, ...exports.DRAFT_EVENTS }
|
|
@@ -1,6 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
function noah_handler(req) {
|
|
1
|
+
function check_autoexposed(req) {
|
|
4
2
|
if (!req.subject) return
|
|
5
3
|
const root = this.model.definitions[req.subject.ref[0].id || req.subject.ref[0]]
|
|
6
4
|
if (!root) return
|
|
@@ -11,32 +9,20 @@ function noah_handler(req) {
|
|
|
11
9
|
* Draft case is an exception. Direct requests are allowed.
|
|
12
10
|
*/
|
|
13
11
|
if (!root._isDraftEnabled && root['@cds.autoexposed']) {
|
|
14
|
-
if (root['@cds.autoexpose'])
|
|
15
|
-
|
|
16
|
-
req.reject(405, 'ENTITY_IS_AUTOEXPOSE_READONLY', [root.name])
|
|
17
|
-
}
|
|
18
|
-
req.reject(405, 'ENTITY_IS_AUTOEXPOSED', [root.name])
|
|
12
|
+
if (!root['@cds.autoexpose']) return req.reject(405, 'ENTITY_IS_AUTOEXPOSED', [root.name])
|
|
13
|
+
if (req.event !== 'READ') return req.reject(405, 'ENTITY_IS_AUTOEXPOSE_READONLY', [root.name])
|
|
19
14
|
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
req.reject(405, 'ENTITY_IS_AUTOEXPOSE_READONLY', [req.target.name])
|
|
15
|
+
if (req.event !== 'READ' && _isAutoexposed(req.target)) {
|
|
16
|
+
return req.reject(405, 'ENTITY_IS_AUTOEXPOSE_READONLY', [req.target.name])
|
|
23
17
|
}
|
|
24
18
|
}
|
|
25
19
|
|
|
26
20
|
const _isAutoexposed = entity => {
|
|
27
|
-
if (!entity) return
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
// REVISIT: To be deleted after okra is removed
|
|
32
|
-
function okra_handler(req) {
|
|
33
|
-
const isAutoexposed = _isAutoexposed(req.target)
|
|
34
|
-
if (isAutoexposed && req.event !== 'READ') {
|
|
35
|
-
req.reject(405, 'ENTITY_IS_AUTOEXPOSE_READONLY', [req.target.name])
|
|
36
|
-
}
|
|
21
|
+
if (!entity) return
|
|
22
|
+
if (entity['@cds.autoexpose'] && entity['@cds.autoexposed']) return true
|
|
23
|
+
if (entity.name.endsWith('.DraftAdministrativeData')) return true
|
|
37
24
|
}
|
|
38
25
|
|
|
39
|
-
|
|
40
|
-
handler._initial = true
|
|
26
|
+
check_autoexposed._initial = true
|
|
41
27
|
|
|
42
|
-
module.exports =
|
|
28
|
+
module.exports = check_autoexposed
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
const
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
return capability
|
|
1
|
+
const RESTRICTIONS = {
|
|
2
|
+
CREATE: 'InsertRestrictions.Insertable',
|
|
3
|
+
READ: 'ReadRestrictions.Readable',
|
|
4
|
+
READABLE_BY_KEY: 'ReadRestrictions.ReadByKeyRestrictions.Readable',
|
|
5
|
+
UPDATE: 'UpdateRestrictions.Updatable',
|
|
6
|
+
DELETE: 'DeleteRestrictions.Deletable'
|
|
9
7
|
}
|
|
10
8
|
|
|
9
|
+
const _getRestriction = (req, capability, capabilityReadByKey) =>
|
|
10
|
+
capabilityReadByKey !== undefined && req.query.SELECT?.one ? capabilityReadByKey : capability
|
|
11
|
+
|
|
11
12
|
const _getNavigationRestriction = (target, path, annotation, req) => {
|
|
12
|
-
if (!target) return
|
|
13
13
|
if (!Array.isArray(target['@Capabilities.NavigationRestrictions.RestrictedProperties'])) return
|
|
14
14
|
|
|
15
15
|
const [restriction, operation] = annotation.split('.')
|
|
@@ -33,14 +33,15 @@ const _getNav = from => {
|
|
|
33
33
|
return []
|
|
34
34
|
}
|
|
35
35
|
|
|
36
|
-
function
|
|
36
|
+
function check_odata_constraints(req) {
|
|
37
37
|
// TODO: Determine auth-relevant entity
|
|
38
38
|
const annotation = RESTRICTIONS[req.event]
|
|
39
|
+
if (!annotation) return
|
|
40
|
+
if (!req.target) return
|
|
39
41
|
|
|
40
|
-
|
|
42
|
+
const from = req.subject
|
|
43
|
+
if (!from) return //> exit fast
|
|
41
44
|
|
|
42
|
-
const action = annotation.split('.').pop().toLowerCase()
|
|
43
|
-
const from = cqnFrom(req)
|
|
44
45
|
const nav = _getNav(from)
|
|
45
46
|
|
|
46
47
|
let navRestriction
|
|
@@ -61,11 +62,12 @@ function handler(req) {
|
|
|
61
62
|
}
|
|
62
63
|
if (lastTarget && navigation) {
|
|
63
64
|
navRestriction = _getNavigationRestriction(lastTarget, navigation, annotation, req)
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
65
|
+
if (navRestriction === false) {
|
|
66
|
+
// REVISIT: rework exception with using target
|
|
67
|
+
const trgt = `${_localName(lastTarget)}.${navs.join('.')}`
|
|
68
|
+
const action = annotation.split('.').pop().toLowerCase() // REVISIT: .split.pop is an anti pattern !!
|
|
69
|
+
req.reject(405, 'ENTITY_IS_NOT_CRUD_VIA_NAVIGATION', [_localName(req.target), action, trgt])
|
|
70
|
+
}
|
|
69
71
|
}
|
|
70
72
|
}
|
|
71
73
|
|
|
@@ -77,10 +79,11 @@ function handler(req) {
|
|
|
77
79
|
req.target['@Capabilities.' + RESTRICTIONS.READABLE_BY_KEY]
|
|
78
80
|
) === false
|
|
79
81
|
) {
|
|
82
|
+
const action = annotation.split('.').pop().toLowerCase() // REVISIT: .split.pop is an anti pattern !!
|
|
80
83
|
req.reject(405, 'ENTITY_IS_NOT_CRUD', [_localName(req.target), action])
|
|
81
84
|
}
|
|
82
85
|
}
|
|
83
86
|
|
|
84
|
-
|
|
87
|
+
check_odata_constraints._initial = true
|
|
85
88
|
|
|
86
|
-
module.exports =
|
|
89
|
+
module.exports = check_odata_constraints
|
|
@@ -40,7 +40,7 @@ const _getRestrictedExpand = (columns, target, definitions) => {
|
|
|
40
40
|
}
|
|
41
41
|
}
|
|
42
42
|
|
|
43
|
-
function
|
|
43
|
+
function restrict_expand(req) {
|
|
44
44
|
if (!req.query) return
|
|
45
45
|
const restricted = _getRestrictedExpand(
|
|
46
46
|
req.query.SELECT && req.query.SELECT.columns,
|
|
@@ -50,6 +50,6 @@ function handler(req) {
|
|
|
50
50
|
if (restricted) req.reject(400, 'EXPAND_IS_RESTRICTED', [restricted])
|
|
51
51
|
}
|
|
52
52
|
|
|
53
|
-
|
|
53
|
+
restrict_expand._initial = true
|
|
54
54
|
|
|
55
|
-
module.exports =
|
|
55
|
+
module.exports = restrict_expand
|
|
@@ -41,7 +41,7 @@ module.exports = cds.service.impl(function authorization() {
|
|
|
41
41
|
// }
|
|
42
42
|
|
|
43
43
|
// mark entities that depend on ancestor for auth with that ancestor
|
|
44
|
-
const defs = this.model
|
|
44
|
+
const defs = this.model?.definitions
|
|
45
45
|
for (const each of this.entities) {
|
|
46
46
|
for (const k in each.compositions) {
|
|
47
47
|
const c = each.compositions[k]
|
|
@@ -59,8 +59,8 @@ module.exports = cds.service.impl(function authorization() {
|
|
|
59
59
|
}
|
|
60
60
|
|
|
61
61
|
// service-level restrictions (not all requests are dispatched by protocol adapter with its early access check)
|
|
62
|
-
// REVISIT
|
|
63
|
-
if (cds.env.features.service_level_restrictions) this.before('*', serviceHandler)
|
|
62
|
+
// REVISIT cds^10: remove opt-out
|
|
63
|
+
if (cds.env.features.service_level_restrictions !== false && this.definition) this.before('*', serviceHandler)
|
|
64
64
|
|
|
65
65
|
/*
|
|
66
66
|
* @requires
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const { getAuthRelevantEntity } = require('./utils')
|
|
2
2
|
|
|
3
|
-
function
|
|
3
|
+
function check_insertonly(req) {
|
|
4
4
|
const entity = getAuthRelevantEntity(req, this.model, ['@insertonly'])
|
|
5
5
|
if (!entity || !entity['@insertonly']) return
|
|
6
6
|
|
|
@@ -10,6 +10,6 @@ function handler(req) {
|
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
check_insertonly._initial = true
|
|
14
14
|
|
|
15
|
-
module.exports =
|
|
15
|
+
module.exports = check_insertonly
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const { getAuthRelevantEntity } = require('./utils')
|
|
2
|
-
const { WRITE_EVENTS } = require('
|
|
2
|
+
const { WRITE_EVENTS } = require('../../constants/events')
|
|
3
3
|
|
|
4
|
-
function
|
|
4
|
+
function check_readonly(req) {
|
|
5
5
|
// @read-only
|
|
6
6
|
let entity = getAuthRelevantEntity(req, this.model, ['@readonly'])
|
|
7
7
|
entity = entity?.actives || entity
|
|
@@ -10,6 +10,6 @@ function handler(req) {
|
|
|
10
10
|
if (entity['@readonly'] && req.event in WRITE_EVENTS) req.reject(405, 'ENTITY_IS_READ_ONLY', [entity.name])
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
check_readonly._initial = true
|
|
14
14
|
|
|
15
|
-
module.exports =
|
|
15
|
+
module.exports = check_readonly
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const { reject, getRejectReason, getAuthRelevantEntity } = require('./utils')
|
|
2
|
-
const { CRUD_EVENTS } = require('
|
|
2
|
+
const { CRUD_EVENTS } = require('../../constants/events')
|
|
3
3
|
|
|
4
4
|
const _getRequiresAsArray = definition =>
|
|
5
5
|
definition['@requires']
|
|
@@ -8,7 +8,7 @@ const _getRequiresAsArray = definition =>
|
|
|
8
8
|
: [definition['@requires']]
|
|
9
9
|
: false
|
|
10
10
|
|
|
11
|
-
function
|
|
11
|
+
function check_auth_privileges(req) {
|
|
12
12
|
if (req.user._is_privileged) {
|
|
13
13
|
// > skip checks
|
|
14
14
|
return
|
|
@@ -37,6 +37,6 @@ function handler(req) {
|
|
|
37
37
|
reject(req, getRejectReason(req, '@requires', definition))
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
|
|
40
|
+
check_auth_privileges._initial = true
|
|
41
41
|
|
|
42
|
-
module.exports =
|
|
42
|
+
module.exports = check_auth_privileges
|
|
@@ -2,8 +2,8 @@ const cds = require('../../../cds'),
|
|
|
2
2
|
LOG = cds.log('auth')
|
|
3
3
|
|
|
4
4
|
const { reject, getRejectReason, resolveUserAttrs, getAuthRelevantEntity } = require('./utils')
|
|
5
|
-
const { DRAFT_EVENTS, MOD_EVENTS } = require('
|
|
6
|
-
const { getNormalizedPlainRestrictions } = require('./restrictions')
|
|
5
|
+
const { DRAFT_EVENTS, MOD_EVENTS } = require('../../constants/events')
|
|
6
|
+
const { getNormalizedPlainRestrictions, getRestrictions } = require('./restrictions')
|
|
7
7
|
|
|
8
8
|
const _hasRef = xpr => {
|
|
9
9
|
for (const each of xpr) if (each.ref || (each.xpr && _hasRef(each.xpr))) return true
|
|
@@ -164,41 +164,23 @@ const _addRestrictionsToRead = async (req, model, resolvedApplicables) => {
|
|
|
164
164
|
}
|
|
165
165
|
|
|
166
166
|
const _getUnrestrictedCount = async req => {
|
|
167
|
-
const dbtx = cds.tx(req)
|
|
168
|
-
|
|
169
167
|
const target =
|
|
170
168
|
(req.query.UPDATE && req.query.UPDATE.entity) ||
|
|
171
169
|
(req.query.DELETE && req.query.DELETE.from) ||
|
|
172
170
|
(req.query.SELECT && req.query.SELECT.from)
|
|
173
|
-
const selectUnrestricted = SELECT.one(['count(*) as n']).from(target)
|
|
174
|
-
|
|
175
|
-
// REVISIT: remove with cds^9
|
|
176
|
-
if (cds.env.features.compat_restrict_where) {
|
|
177
|
-
const whereUnrestricted =
|
|
178
|
-
(req.query.UPDATE && req.query.UPDATE.where) || (req.query.DELETE && req.query.DELETE.where)
|
|
179
|
-
if (whereUnrestricted) selectUnrestricted.where(whereUnrestricted)
|
|
180
|
-
}
|
|
181
171
|
|
|
182
172
|
// Because of side effects, the statements have to be fired sequentially.
|
|
183
|
-
const { n } = await
|
|
173
|
+
const { n } = await cds.run(SELECT.one(['count(*) as n']).from(target))
|
|
184
174
|
return n
|
|
185
175
|
}
|
|
186
176
|
|
|
187
177
|
const _getRestrictedCount = async (req, model, resolvedApplicables) => {
|
|
188
|
-
const dbtx = cds.tx(req)
|
|
189
|
-
|
|
190
178
|
const target =
|
|
191
179
|
(req.query.UPDATE && req.query.UPDATE.entity) ||
|
|
192
180
|
(req.query.DELETE && req.query.DELETE.from) ||
|
|
193
181
|
(req.query.SELECT && req.query.SELECT.from)
|
|
194
182
|
const selectRestricted = SELECT.one(['count(*) as n']).from(target)
|
|
195
183
|
|
|
196
|
-
// REVISIT: remove with cds^9
|
|
197
|
-
if (cds.env.features.compat_restrict_where) {
|
|
198
|
-
const whereRestricted = (req.query.UPDATE && req.query.UPDATE.where) || (req.query.DELETE && req.query.DELETE.where)
|
|
199
|
-
if (whereRestricted) selectRestricted.where(whereRestricted)
|
|
200
|
-
}
|
|
201
|
-
|
|
202
184
|
if (typeof selectRestricted.SELECT === 'object') {
|
|
203
185
|
selectRestricted.SELECT.from.ref = _addWheresToRef(selectRestricted.SELECT.from.ref, model, resolvedApplicables)
|
|
204
186
|
}
|
|
@@ -206,11 +188,11 @@ const _getRestrictedCount = async (req, model, resolvedApplicables) => {
|
|
|
206
188
|
const restrictionForTarget = _getRestrictionForTarget(resolvedApplicables, req.target)
|
|
207
189
|
if (restrictionForTarget) selectRestricted.where(restrictionForTarget)
|
|
208
190
|
|
|
209
|
-
const { n } = await
|
|
191
|
+
const { n } = await cds.run(selectRestricted)
|
|
210
192
|
return n
|
|
211
193
|
}
|
|
212
194
|
|
|
213
|
-
async function
|
|
195
|
+
async function enforce_auth(req) {
|
|
214
196
|
if (req.user._is_privileged || DRAFT_EVENTS[req.event]) {
|
|
215
197
|
// > skip checks (events in DRAFT_EVENTS are checked in draft handlers via InProcessByUser)
|
|
216
198
|
return
|
|
@@ -233,7 +215,8 @@ async function check_roles(req) {
|
|
|
233
215
|
return
|
|
234
216
|
}
|
|
235
217
|
|
|
236
|
-
|
|
218
|
+
// REVISIT: that (this.getRestrictions||getRestrictions) thing below is for a bad test only!
|
|
219
|
+
let restrictions = (this.getRestrictions || getRestrictions)(definition, req.event, req.user)
|
|
237
220
|
if (restrictions instanceof Promise) restrictions = await restrictions
|
|
238
221
|
|
|
239
222
|
if (!restrictions) {
|
|
@@ -268,7 +251,7 @@ async function check_roles(req) {
|
|
|
268
251
|
}
|
|
269
252
|
|
|
270
253
|
// Instance based authorization for bound actions /functions
|
|
271
|
-
await restrictBoundActionFunctions(req, resolvedApplicables, definition
|
|
254
|
+
await restrictBoundActionFunctions(req, resolvedApplicables, definition)
|
|
272
255
|
|
|
273
256
|
// no modification -> nothing more to do
|
|
274
257
|
if (!MOD_EVENTS[req.event]) return
|
|
@@ -293,12 +276,12 @@ const isBoundToCollection = action =>
|
|
|
293
276
|
action['@cds.odata.bindingparameter.collection'] ||
|
|
294
277
|
(action.params && Object.values(action.params).some(param => param?.items?.type === '$self'))
|
|
295
278
|
|
|
296
|
-
const restrictBoundActionFunctions = async (req, resolvedApplicables, definition
|
|
279
|
+
const restrictBoundActionFunctions = async (req, resolvedApplicables, definition) => {
|
|
297
280
|
if (req.target?.actions?.[req.event] && !isBoundToCollection(req.target.actions[req.event])) {
|
|
298
281
|
// Clone to avoid target modification, which would cause a different query
|
|
299
282
|
const query = req.query ? cds.ql.clone(req.query) : SELECT.one.from(req.subject)
|
|
300
283
|
_addRestrictionsToRead({ query: query, target: req.target }, cds.model, resolvedApplicables)
|
|
301
|
-
const result = await
|
|
284
|
+
const result = await cds.db.run(query)
|
|
302
285
|
if (!result || result.length === 0) {
|
|
303
286
|
// If we got a result, we don't need to check for the existence, hence only in this special case we must determine if `404` or `403`.
|
|
304
287
|
const unrestrictedCount = await _getUnrestrictedCount(req)
|
|
@@ -310,6 +293,6 @@ const restrictBoundActionFunctions = async (req, resolvedApplicables, definition
|
|
|
310
293
|
}
|
|
311
294
|
}
|
|
312
295
|
|
|
313
|
-
|
|
296
|
+
enforce_auth._initial = true
|
|
314
297
|
|
|
315
|
-
module.exports =
|
|
298
|
+
module.exports = enforce_auth
|
|
@@ -7,7 +7,7 @@ const _getRequiresAsArray = definition =>
|
|
|
7
7
|
: [definition['@requires']]
|
|
8
8
|
: false
|
|
9
9
|
|
|
10
|
-
function
|
|
10
|
+
function check_service_level_restrictions(req) {
|
|
11
11
|
if (req.user._is_privileged) {
|
|
12
12
|
// > skip checks
|
|
13
13
|
return
|
|
@@ -19,6 +19,6 @@ function handler(req) {
|
|
|
19
19
|
reject(req, getRejectReason(req, '@requires', this.definition))
|
|
20
20
|
}
|
|
21
21
|
|
|
22
|
-
|
|
22
|
+
check_service_level_restrictions._initial = true
|
|
23
23
|
|
|
24
|
-
module.exports =
|
|
24
|
+
module.exports = check_service_level_restrictions
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const cds = require('../../../cds')
|
|
2
2
|
const LOG = cds.log('app')
|
|
3
3
|
|
|
4
|
-
const { CRUD_EVENTS } = require('
|
|
4
|
+
const { CRUD_EVENTS } = require('../../constants/events')
|
|
5
5
|
|
|
6
6
|
const { getDraftTreeRoot } = require('../../utils/csn')
|
|
7
7
|
|
|
@@ -163,15 +163,6 @@ const _authDependsOnAncestor = (entity, annotations) => {
|
|
|
163
163
|
)
|
|
164
164
|
}
|
|
165
165
|
|
|
166
|
-
const cqnFrom = req => {
|
|
167
|
-
const { query } = req
|
|
168
|
-
if (!query) return
|
|
169
|
-
if (query.SELECT) return query.SELECT.from
|
|
170
|
-
if (query.INSERT) return query.INSERT.into
|
|
171
|
-
if (query.UPDATE) return query.UPDATE.entity
|
|
172
|
-
if (query.DELETE) return query.DELETE.from
|
|
173
|
-
}
|
|
174
|
-
|
|
175
166
|
const getAuthRelevantEntity = (req, model, annotations) => {
|
|
176
167
|
if (!req.target || !(req.event in CRUD_EVENTS)) return
|
|
177
168
|
|
|
@@ -179,7 +170,7 @@ const getAuthRelevantEntity = (req, model, annotations) => {
|
|
|
179
170
|
if (!it) return req.target
|
|
180
171
|
if (it?.kind === 'entity' && req.subject.ref?.length === 1) return it
|
|
181
172
|
|
|
182
|
-
let cqn =
|
|
173
|
+
let cqn = req.subject
|
|
183
174
|
|
|
184
175
|
// REVISIT: needed in draft for some reason
|
|
185
176
|
if (typeof cqn === 'string') cqn = { ref: [cqn] }
|
|
@@ -218,6 +209,5 @@ module.exports = {
|
|
|
218
209
|
reject,
|
|
219
210
|
getRejectReason,
|
|
220
211
|
resolveUserAttrs,
|
|
221
|
-
cqnFrom,
|
|
222
212
|
getAuthRelevantEntity
|
|
223
213
|
}
|
|
@@ -1,58 +1,46 @@
|
|
|
1
1
|
const cds = require('../../cds')
|
|
2
2
|
const { SELECT } = cds.ql
|
|
3
3
|
|
|
4
|
-
const { deepCopy } = require('../utils/copy')
|
|
5
|
-
const { getColumns } = require('../utils/columns')
|
|
6
|
-
const { enhanceStreamResult } = require('../utils/stream')
|
|
7
|
-
const getError = require('../error')
|
|
8
|
-
|
|
9
4
|
const _targetEntityDoesNotExist = async req => {
|
|
10
|
-
const exists = await cds.
|
|
5
|
+
const exists = await cds.run(SELECT.from(req.subject, [1]))
|
|
11
6
|
return exists.length === 0
|
|
12
7
|
}
|
|
13
8
|
|
|
14
|
-
exports
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
})
|
|
21
|
-
}
|
|
22
|
-
if (typeof req.query !== 'string' && req.target && req.target._hasPersistenceSkip) {
|
|
23
|
-
throw getError({
|
|
24
|
-
code: 501,
|
|
25
|
-
message: `Entity "${req.target.name}" is annotated with "@cds.persistence.skip" and cannot be served generically.`
|
|
26
|
-
})
|
|
27
|
-
}
|
|
9
|
+
module.exports = cds.service.impl(function () {
|
|
10
|
+
// prettier-ignore
|
|
11
|
+
this.on(['CREATE', 'READ', 'UPDATE', 'DELETE', 'UPSERT'], '*', async function handle_crud_requests(req) {
|
|
12
|
+
|
|
13
|
+
if (!cds.db)
|
|
14
|
+
return req.reject ('NO_DATABASE_CONNECTION') // REVISIT: error message
|
|
28
15
|
|
|
29
|
-
|
|
30
|
-
|
|
16
|
+
if (!req.query)
|
|
17
|
+
return req.reject (501, 'The request has no query and cannot be served generically.')
|
|
31
18
|
|
|
32
|
-
|
|
19
|
+
if (typeof req.query !== 'string' && req.target?._hasPersistenceSkip)
|
|
20
|
+
return req.reject (501, `Entity "${req.target.name}" is annotated with "@cds.persistence.skip" and cannot be served generically.`)
|
|
33
21
|
|
|
34
22
|
// validate that all elements in path exist on db, if necessary
|
|
35
23
|
// - INSERT has no where clause to do this in one roundtrip
|
|
36
24
|
// - SELECT returns [] -> really empty collection or invalid path?
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const { ref } = (req.query.INSERT && req.query.INSERT.into) || (req.query.SELECT && req.query.SELECT.from) || {}
|
|
40
|
-
// REVISIT: why is copy necessary?
|
|
41
|
-
if (ref && ref.length > 1) pathExistsQuery = SELECT(1).from({ ref: deepCopy(ref.slice(0, -1)) })
|
|
25
|
+
const subject = req.query.INSERT?.into || req.query.SELECT?.from
|
|
26
|
+
const pathExistsQuery = subject?.ref?.length > 1 && SELECT(1).from({ ref: subject.ref.slice(0,-1) })
|
|
42
27
|
|
|
43
28
|
if (req.event === 'CREATE' && pathExistsQuery) {
|
|
29
|
+
// REVISIT: Why dont't we just run the insert and check affected rows?
|
|
44
30
|
const res = await pathExistsQuery
|
|
45
31
|
if (res.length === 0) req.reject(404)
|
|
46
32
|
}
|
|
47
33
|
|
|
48
|
-
if (req.event in { DELETE: 1, UPDATE: 1 } && req.target
|
|
49
|
-
if (req.event === 'DELETE' && !req.target['@odata.singleton.nullable'])
|
|
34
|
+
if (req.event in { DELETE: 1, UPDATE: 1 } && req.target?._isSingleton) {
|
|
35
|
+
if (req.event === 'DELETE' && !req.target['@odata.singleton.nullable'])
|
|
36
|
+
return req.reject (400, 'SINGLETON_NOT_NULLABLE')
|
|
37
|
+
|
|
50
38
|
const selectSingleton = SELECT.one(req.target)
|
|
51
|
-
const keyColumns =
|
|
39
|
+
const keyColumns = [...(req.target.keys||[])].filter(e => !e.isAssociation).map(e => e.name)
|
|
52
40
|
|
|
53
41
|
// if no keys available, select all columns so we can delete the singleton with same content
|
|
54
42
|
if (keyColumns.length) selectSingleton.columns(keyColumns)
|
|
55
|
-
const singleton = await cds.
|
|
43
|
+
const singleton = await cds.run(selectSingleton)
|
|
56
44
|
if (!singleton) req.reject(404)
|
|
57
45
|
|
|
58
46
|
// REVISIT: Workaround for singleton, to get keys into singleton
|
|
@@ -64,13 +52,9 @@ exports.impl = cds.service.impl(function () {
|
|
|
64
52
|
req.query.where(singleton)
|
|
65
53
|
}
|
|
66
54
|
|
|
67
|
-
if (req.event === 'READ' && req.query?.SELECT)
|
|
68
|
-
req.query.SELECT.localized ??= true
|
|
69
|
-
}
|
|
55
|
+
if (req.event === 'READ' && req.query?.SELECT && req.locale) req.query.SELECT.localized ??= true
|
|
70
56
|
|
|
71
|
-
|
|
72
|
-
result = await cds.tx(req).run(req.query, req.data)
|
|
73
|
-
}
|
|
57
|
+
const result = await cds.run (req.query, req.data)
|
|
74
58
|
|
|
75
59
|
if (req.event === 'READ') {
|
|
76
60
|
// do not execute additional select to distinguish between 412 and 404
|
|
@@ -81,12 +65,6 @@ exports.impl = cds.service.impl(function () {
|
|
|
81
65
|
if (res.length === 0) req.reject(404)
|
|
82
66
|
}
|
|
83
67
|
|
|
84
|
-
if (cds.env.features.stream_compat) {
|
|
85
|
-
if (result !== undefined && req.query?._streaming && (result === null || result.pipe)) {
|
|
86
|
-
return { value: result }
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
68
|
return result
|
|
91
69
|
}
|
|
92
70
|
|
|
@@ -106,13 +84,4 @@ exports.impl = cds.service.impl(function () {
|
|
|
106
84
|
|
|
107
85
|
return req.data
|
|
108
86
|
})
|
|
109
|
-
|
|
110
|
-
this.after('READ', '*', async function ([result], req) {
|
|
111
|
-
if (!result) return
|
|
112
|
-
if (cds.env.features.stream_compat) {
|
|
113
|
-
if (req.query?._streaming) {
|
|
114
|
-
await enhanceStreamResult(req, req.query, result, this.model)
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
})
|
|
118
87
|
})
|