@sap/cds 8.9.4 → 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 +113 -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 +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 +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 -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 +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 +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
|
@@ -1,8 +1,106 @@
|
|
|
1
1
|
const cds = require('../../../index.js')
|
|
2
2
|
const LOG = cds.log('auth')
|
|
3
3
|
|
|
4
|
-
|
|
4
|
+
const {
|
|
5
|
+
createSecurityContext,
|
|
6
|
+
IdentityService,
|
|
7
|
+
errors: { ValidationError }
|
|
8
|
+
} = require('./xssec')
|
|
5
9
|
|
|
10
|
+
module.exports = function ias_auth(config) {
|
|
11
|
+
// cds.env.requires.auth.known_claims is not an official config!
|
|
12
|
+
const { kind, credentials, config: serviceConfig = {}, known_claims = KNOWN_CLAIMS } = config
|
|
13
|
+
const skipped_attrs = known_claims.reduce((a, x) => ((a[x] = 1), a), {})
|
|
14
|
+
|
|
15
|
+
if (!credentials)
|
|
16
|
+
throw new Error(
|
|
17
|
+
`Authentication kind "${kind}" configured, but no IAS instance bound to application. ` +
|
|
18
|
+
'Either bind an IAS instance, or switch to an authentication kind that does not require a binding.'
|
|
19
|
+
)
|
|
20
|
+
|
|
21
|
+
const auth_service = new IdentityService(credentials, serviceConfig)
|
|
22
|
+
const user_factory = get_user_factory(credentials, skipped_attrs)
|
|
23
|
+
|
|
24
|
+
/*
|
|
25
|
+
* re validation:
|
|
26
|
+
* if the request goes to the cert url, then we should validate the token.
|
|
27
|
+
* however, this requires header "x-forwarded-client-cert" which requires additional configuration in the approuter ("forwardAuthCertificates: true").
|
|
28
|
+
* also, we currently get the non-cert route attached to the application as well (-> adjust "cds add mta"?), for which validation would always fail.
|
|
29
|
+
* by default, the approuter is configured to use the non-cert route ("url: ~{srv-url}" instead of "url: ~{srv-cert-url}").
|
|
30
|
+
* if the developer explicitely changes to the cert route, then we can expect him/her to also configure cert forwarding.
|
|
31
|
+
* hence, if there is no explicit validation configuration by the app, we can and should create a service with validation enabled and use if for the cert route.
|
|
32
|
+
* this way, we validate if possible with the least amount of custom configuration.
|
|
33
|
+
*/
|
|
34
|
+
|
|
35
|
+
const should_validate =
|
|
36
|
+
process.env.VCAP_APPLICATION &&
|
|
37
|
+
JSON.parse(process.env.VCAP_APPLICATION).application_uris?.some(uri => uri.match(/\.cert\./))
|
|
38
|
+
const validation_enabled = serviceConfig.validation?.x5t?.enabled || serviceConfig.validation?.proofToken?.enabled
|
|
39
|
+
|
|
40
|
+
let validating_auth_service
|
|
41
|
+
if (should_validate && !validation_enabled) {
|
|
42
|
+
const _serviceConfig = { ...serviceConfig }
|
|
43
|
+
_serviceConfig.validation = { x5t: { enabled: true }, proofToken: { enabled: true } }
|
|
44
|
+
validating_auth_service = new IdentityService(credentials, _serviceConfig)
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return async function ias_auth(req, _, next) {
|
|
48
|
+
if (!req.headers.authorization) return next()
|
|
49
|
+
|
|
50
|
+
try {
|
|
51
|
+
const _auth_service =
|
|
52
|
+
validating_auth_service && req.host.match(/\.cert\./) ? validating_auth_service : auth_service
|
|
53
|
+
const securityContext = await createSecurityContext(_auth_service, { req })
|
|
54
|
+
const tokenInfo = securityContext.token
|
|
55
|
+
const ctx = cds.context
|
|
56
|
+
ctx.user = user_factory(tokenInfo)
|
|
57
|
+
ctx.tenant = tokenInfo.getZoneId()
|
|
58
|
+
req.authInfo = securityContext //> compat req.authInfo
|
|
59
|
+
} catch (e) {
|
|
60
|
+
if (e instanceof ValidationError) {
|
|
61
|
+
LOG.warn('Unauthenticated request: ', e)
|
|
62
|
+
return next(401)
|
|
63
|
+
}
|
|
64
|
+
LOG.error('Error while authenticating user: ', e)
|
|
65
|
+
return next(500)
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
next()
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
function get_user_factory(credentials, skipped_attrs) {
|
|
73
|
+
return function user_factory(tokenInfo) {
|
|
74
|
+
const payload = tokenInfo.getPayload()
|
|
75
|
+
|
|
76
|
+
const clientid = tokenInfo.getClientId()
|
|
77
|
+
if (clientid === payload.sub) {
|
|
78
|
+
//> grant_type === client_credentials or x509
|
|
79
|
+
const roles = { 'system-user': 1 }
|
|
80
|
+
if (Array.isArray(payload.ias_apis)) payload.ias_apis.forEach(r => (roles[r] = 1))
|
|
81
|
+
if (clientid === credentials.clientid) roles['internal-user'] = 1
|
|
82
|
+
else delete roles['internal-user']
|
|
83
|
+
return new cds.User({ id: 'system', roles, tokenInfo })
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// add all unknown attributes to req.user.attr in order to keep public API small
|
|
87
|
+
const attr = {}
|
|
88
|
+
for (const key in payload) {
|
|
89
|
+
if (key in skipped_attrs)
|
|
90
|
+
continue // REVISIT: Why do we need to do that?
|
|
91
|
+
else attr[key] = payload[key]
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
// REVISIT: just don't such things, please! -> We're just piling up tech dept through tons of unoficcial long tail APIs like that!
|
|
95
|
+
// REVISIT: looks like wrong direction to me, btw
|
|
96
|
+
// same api as xsuaa-auth for easier migration
|
|
97
|
+
if (attr.user_name) attr.logonName = attr.user_name
|
|
98
|
+
if (attr.given_name) attr.givenName = attr.given_name
|
|
99
|
+
if (attr.family_name) attr.familyName = attr.family_name
|
|
100
|
+
|
|
101
|
+
return new cds.User({ id: payload.sub, attr, tokenInfo })
|
|
102
|
+
}
|
|
103
|
+
}
|
|
6
104
|
|
|
7
105
|
// REVISIT: Why do we need to know and do that?
|
|
8
106
|
const KNOWN_CLAIMS = Object.values({
|
|
@@ -39,90 +137,3 @@ const KNOWN_CLAIMS = Object.values({
|
|
|
39
137
|
// own
|
|
40
138
|
APP_TENANT_ID: 'app_tid'
|
|
41
139
|
})
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
module.exports = function ias_auth(config) {
|
|
45
|
-
// cds.env.requires.auth.known_claims is not an official config!
|
|
46
|
-
const { kind, credentials, known_claims = KNOWN_CLAIMS } = config
|
|
47
|
-
const skipped_attrs = known_claims.reduce((a,x) => { a[x] = 1; return a }, {})
|
|
48
|
-
|
|
49
|
-
if (!credentials) throw new Error(
|
|
50
|
-
`Authentication kind "${kind}" configured, but no IAS instance bound to application. ` +
|
|
51
|
-
'Either bind an IAS instance, or switch to an authentication kind that does not require a binding.'
|
|
52
|
-
)
|
|
53
|
-
|
|
54
|
-
function getUser(tokenInfo) {
|
|
55
|
-
const payload = tokenInfo.getPayload()
|
|
56
|
-
|
|
57
|
-
const clientid = tokenInfo.getClientId()
|
|
58
|
-
if (clientid === payload.sub) { //> grant_type === client_credentials or x509
|
|
59
|
-
const roles = { 'system-user': 1 }
|
|
60
|
-
if (Array.isArray(payload.ias_apis)) payload.ias_apis.forEach(r => (roles[r] = 1))
|
|
61
|
-
if (clientid === credentials.clientid) roles['internal-user'] = 1
|
|
62
|
-
else delete roles['internal-user']
|
|
63
|
-
return new cds.User({ id: 'system', roles, tokenInfo })
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// add all unknown attributes to req.user.attr in order to keep public API small
|
|
67
|
-
const attr = {}
|
|
68
|
-
for (const key in payload) {
|
|
69
|
-
if (key in skipped_attrs) continue // REVISIT: Why do we need to do that?
|
|
70
|
-
else attr[key] = payload[key]
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// REVISIT: just don't such things, please! -> We're just piling up tech dept through tons of unoficcial long tail APIs like that!
|
|
74
|
-
// REVISIT: looks like wrong direction to me, btw
|
|
75
|
-
// same api as xsuaa-auth for easier migration
|
|
76
|
-
if (attr.user_name) attr.logonName = attr.user_name
|
|
77
|
-
if (attr.given_name) attr.givenName = attr.given_name
|
|
78
|
-
if (attr.family_name) attr.familyName = attr.family_name
|
|
79
|
-
|
|
80
|
-
return new cds.User({ id: payload.sub, attr, tokenInfo })
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// NOTE: Use named function for better stack traces... for the actual middleware, of course, not that much for the factory!
|
|
84
|
-
|
|
85
|
-
if (xssec.v3 && cds.env.features.xssec_compat !== true) { // no official flag!
|
|
86
|
-
let { createSecurityContext, IdentityService, errors: { ValidationError } } = xssec
|
|
87
|
-
const authService = new IdentityService(credentials)
|
|
88
|
-
|
|
89
|
-
return async function ias_auth (req, _, next) {
|
|
90
|
-
if (!req.headers.authorization) return next()
|
|
91
|
-
try {
|
|
92
|
-
const secContext = await createSecurityContext(authService, { req })
|
|
93
|
-
const tokenInfo = secContext.token
|
|
94
|
-
const ctx = cds.context
|
|
95
|
-
ctx.user = getUser(tokenInfo)
|
|
96
|
-
ctx.tenant = tokenInfo.getZoneId()
|
|
97
|
-
req.authInfo = secContext //> compat req.authInfo
|
|
98
|
-
} catch(e) {
|
|
99
|
-
if (e instanceof ValidationError) {
|
|
100
|
-
LOG.warn("Unauthenticated request: ", e);
|
|
101
|
-
return next(401)
|
|
102
|
-
}
|
|
103
|
-
LOG.error("Error while authenticating user: ", e);
|
|
104
|
-
return next(500)
|
|
105
|
-
}
|
|
106
|
-
next()
|
|
107
|
-
}
|
|
108
|
-
} else { // TODO: Remove with cds 9
|
|
109
|
-
xssec = xssec.v3 || xssec
|
|
110
|
-
return function ias_auth (req, _, next) {
|
|
111
|
-
if (!req.headers.authorization) return next()
|
|
112
|
-
const token = req.headers.authorization.slice(7) // skip /^bearer /
|
|
113
|
-
xssec.createSecurityContext(token, credentials, 'IAS', function (err, securityContext, tokenInfo) {
|
|
114
|
-
|
|
115
|
-
if (err) LOG.warn('User could not be authenticated due to error:', err)
|
|
116
|
-
if (!securityContext) {
|
|
117
|
-
return next(401)
|
|
118
|
-
}
|
|
119
|
-
else req.authInfo = securityContext //> compat req.authInfo
|
|
120
|
-
|
|
121
|
-
const ctx = cds.context
|
|
122
|
-
ctx.user = getUser(tokenInfo)
|
|
123
|
-
ctx.tenant = tokenInfo.getZoneId()
|
|
124
|
-
next()
|
|
125
|
-
})
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
@@ -1,27 +1,60 @@
|
|
|
1
1
|
const cds = require('../../../index.js')
|
|
2
2
|
const LOG = cds.log('auth')
|
|
3
3
|
|
|
4
|
-
|
|
4
|
+
const {
|
|
5
|
+
createSecurityContext,
|
|
6
|
+
XsuaaService,
|
|
7
|
+
errors: { ValidationError }
|
|
8
|
+
} = require('./xssec')
|
|
5
9
|
|
|
6
10
|
module.exports = function jwt_auth(config) {
|
|
7
|
-
const { kind, credentials } = config
|
|
11
|
+
const { kind, credentials, config: serviceConfig = {} } = config
|
|
12
|
+
|
|
13
|
+
if (!credentials)
|
|
14
|
+
throw new Error(
|
|
15
|
+
`Authentication kind "${kind}" configured, but no XSUAA instance bound to application. ` +
|
|
16
|
+
'Either bind an XSUAA instance, or switch to an authentication kind that does not require a binding.'
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
const auth_service = new XsuaaService(credentials, serviceConfig)
|
|
20
|
+
const user_factory = get_user_factory(credentials, credentials.xsappname, kind)
|
|
21
|
+
|
|
22
|
+
return async function jwt_auth(req, _, next) {
|
|
23
|
+
if (!req.headers.authorization) return next()
|
|
24
|
+
|
|
25
|
+
try {
|
|
26
|
+
const securityContext = await createSecurityContext(auth_service, { req })
|
|
27
|
+
const tokenInfo = securityContext.token
|
|
28
|
+
const ctx = cds.context
|
|
29
|
+
ctx.user = user_factory(tokenInfo)
|
|
30
|
+
ctx.tenant = tokenInfo.getZoneId()
|
|
31
|
+
req.authInfo = securityContext //> compat req.authInfo
|
|
32
|
+
} catch (e) {
|
|
33
|
+
if (e instanceof ValidationError) {
|
|
34
|
+
LOG.warn('Unauthenticated request: ', e)
|
|
35
|
+
return next(401)
|
|
36
|
+
}
|
|
37
|
+
LOG.error('Error while authenticating user: ', e)
|
|
38
|
+
return next(500)
|
|
39
|
+
}
|
|
8
40
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
)
|
|
41
|
+
next()
|
|
42
|
+
}
|
|
43
|
+
}
|
|
13
44
|
|
|
14
|
-
|
|
45
|
+
function get_user_factory(credentials, xsappname, kind) {
|
|
46
|
+
xsappname = xsappname + '.'
|
|
15
47
|
|
|
16
|
-
function
|
|
48
|
+
return function user_factory(tokenInfo) {
|
|
17
49
|
const payload = tokenInfo.getPayload()
|
|
18
50
|
|
|
19
51
|
let id = payload.user_name
|
|
20
52
|
|
|
21
53
|
const roles = {}
|
|
22
54
|
for (let scope of payload.scope) {
|
|
23
|
-
let role = scope.
|
|
24
|
-
if (role in { 'internal-user': 1, 'system-user': 1 })
|
|
55
|
+
let role = scope.replace(xsappname, '') // Roles = scope names w/o xsappname...
|
|
56
|
+
if (role in { 'internal-user': 1, 'system-user': 1 })
|
|
57
|
+
continue // Disallow setting system roles from external
|
|
25
58
|
else roles[role] = 1
|
|
26
59
|
}
|
|
27
60
|
|
|
@@ -32,7 +65,7 @@ module.exports = function jwt_auth(config) {
|
|
|
32
65
|
if (tokenInfo.getClientId() === credentials.clientid) roles['internal-user'] = 1
|
|
33
66
|
}
|
|
34
67
|
|
|
35
|
-
const attr = { ...
|
|
68
|
+
const attr = { ...payload['xs.user.attributes'] }
|
|
36
69
|
if (kind === 'xsuaa') {
|
|
37
70
|
attr.logonName = payload.user_name
|
|
38
71
|
attr.givenName = payload.given_name
|
|
@@ -42,50 +75,4 @@ module.exports = function jwt_auth(config) {
|
|
|
42
75
|
|
|
43
76
|
return new cds.User({ id, roles, attr, tokenInfo })
|
|
44
77
|
}
|
|
45
|
-
if (xssec.v3 && cds.env.features.xssec_compat !== true) { // no official flag!
|
|
46
|
-
const { createSecurityContext, XsuaaService, errors: { ValidationError } } = xssec
|
|
47
|
-
const authService = new XsuaaService(credentials)
|
|
48
|
-
|
|
49
|
-
return async function jwt_auth(req, _, next) {
|
|
50
|
-
if (!req.headers.authorization) return next()
|
|
51
|
-
|
|
52
|
-
try {
|
|
53
|
-
const secContext = await createSecurityContext(authService, { req })
|
|
54
|
-
const tokenInfo = secContext.token
|
|
55
|
-
const ctx = cds.context
|
|
56
|
-
ctx.user = getUser(tokenInfo)
|
|
57
|
-
ctx.tenant = tokenInfo.getZoneId()
|
|
58
|
-
req.authInfo = secContext //> compat req.authInfo
|
|
59
|
-
} catch(e) {
|
|
60
|
-
if(e instanceof ValidationError) {
|
|
61
|
-
LOG.warn("Unauthenticated request: ", e);
|
|
62
|
-
return next(401)
|
|
63
|
-
}
|
|
64
|
-
LOG.error("Error while authenticating user: ", e);
|
|
65
|
-
return next(500)
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
next()
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
} else {
|
|
72
|
-
xssec = xssec.v3 || xssec
|
|
73
|
-
|
|
74
|
-
// NOTE: Use named function for better stack traces... for the actual middleware, of course, not that much for the factory!
|
|
75
|
-
return function jwt_auth (req, _, next) {
|
|
76
|
-
if (!req.headers.authorization) return next()
|
|
77
|
-
const token = req.headers.authorization.slice(7) // skip /^bearer /
|
|
78
|
-
xssec.createSecurityContext(token, credentials, function (err, securityContext, tokenInfo) {
|
|
79
|
-
|
|
80
|
-
if (err) LOG.warn('User could not be authenticated due to error:', err)
|
|
81
|
-
if (!securityContext) return next(401)
|
|
82
|
-
else req.authInfo = securityContext //> compat req.authInfo
|
|
83
|
-
|
|
84
|
-
const ctx = cds.context
|
|
85
|
-
ctx.user = getUser(tokenInfo)
|
|
86
|
-
ctx.tenant = tokenInfo.getZoneId()
|
|
87
|
-
next()
|
|
88
|
-
})
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
78
|
}
|
|
@@ -12,6 +12,6 @@ module.exports = () => {
|
|
|
12
12
|
const id = req.headers[corr_id] ??= req.headers[crippled_corr_id] || req.headers[req_id] || req.headers[vr_id] || uuid()
|
|
13
13
|
const ctx = EventContext.for ({ id, http: { req, res } })
|
|
14
14
|
res.set ('X-Correlation-ID', id) // Note: we use capitalized style here as that's common standard in HTTP world
|
|
15
|
-
cds.
|
|
15
|
+
cds._with (ctx, next)
|
|
16
16
|
}
|
|
17
17
|
}
|
|
@@ -9,7 +9,7 @@ module.exports = ()=> {
|
|
|
9
9
|
if (req.baseUrl.startsWith('/-/')) return next() //> our own tech services cannot be extended
|
|
10
10
|
const ctx = cds.context
|
|
11
11
|
if (ctx.tenant || ctx.features?.given) try {
|
|
12
|
-
ctx.model =
|
|
12
|
+
ctx.model = await model4 (ctx.tenant, ctx.features)
|
|
13
13
|
} catch (e) {
|
|
14
14
|
LOG.error(e)
|
|
15
15
|
return res.status(503) .json ({ // REVISIT: we should throw a simple error, nothing else! -> this is overly OData-specific!
|
|
@@ -1,55 +1,47 @@
|
|
|
1
|
-
const
|
|
2
|
-
|
|
3
|
-
const production = process.env.NODE_ENV === 'production'
|
|
4
|
-
const cds = require('../..')
|
|
1
|
+
const cds = require('../..'), {i18n} = cds
|
|
5
2
|
const LOG = cds.log('error')
|
|
6
|
-
const
|
|
3
|
+
const internals = /\n +at .*(?:node_modules\/express|node:).*/gm
|
|
4
|
+
const is_test = typeof global.it === 'function'
|
|
7
5
|
|
|
8
6
|
module.exports = () => {
|
|
9
|
-
|
|
10
|
-
return
|
|
11
|
-
if (isStandardError(error) && cds.env.server.shutdown_on_uncaught_errors) {
|
|
12
|
-
cds.log().error('❗️Uncaught', error)
|
|
13
|
-
await cds.shutdown(error)
|
|
14
|
-
return
|
|
15
|
-
}
|
|
7
|
+
/** @param {import('express').Response} res */
|
|
8
|
+
return function http_error (err, req, res, next) { // eslint-disable-line no-unused-vars
|
|
16
9
|
|
|
17
10
|
// In case of 401 require login if available by auth strategy
|
|
18
|
-
if (typeof
|
|
19
|
-
if (
|
|
20
|
-
|
|
21
|
-
//
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
}
|
|
11
|
+
if (typeof err === 'number') err = { code: err }
|
|
12
|
+
if (err.code == 401 && req._login) return req._login()
|
|
13
|
+
|
|
14
|
+
// Shutdown on uncaught errors, which could be critical programming errors
|
|
15
|
+
if (!is_test && cds.env.server.shutdown_on_uncaught_errors)
|
|
16
|
+
if (cds.error.isSystemError(err))
|
|
17
|
+
return cds.shutdown(err)
|
|
18
|
+
|
|
19
|
+
// Prepare status and a serializable error object
|
|
20
|
+
let { statusCode:sc, status = sc || Number(err.code) || 500, message, toJSON, ...rest } = err // eslint-disable-line no-unused-vars
|
|
21
|
+
let error = { message, ...rest, __proto__:err } // toJSON is inherited from __proto__:err
|
|
22
|
+
res.status(status)
|
|
23
|
+
|
|
24
|
+
// Log the error, with cleansed stack trace
|
|
25
|
+
if (err.stack) Object.defineProperty (err, 'stack', { value: err.stack.replace (internals,'') })
|
|
26
|
+
const log = status < 500 ? LOG.warn : LOG.error
|
|
27
|
+
log (status, '-', error) // TODO: don't log validation errors as errors
|
|
33
28
|
|
|
29
|
+
// Already sent a response? => done
|
|
34
30
|
if (res.headersSent) return
|
|
35
31
|
|
|
36
|
-
//
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
})
|
|
42
|
-
} else {
|
|
43
|
-
Object.defineProperties(error, {
|
|
44
|
-
message: { enumerable: true },
|
|
45
|
-
stack: { enumerable: true }
|
|
46
|
-
})
|
|
32
|
+
// In case of 5xx errors in production don't reveal details to clients
|
|
33
|
+
let PROD = process.env.NODE_ENV === 'production' || process.env.CDS_ENV === 'prod'
|
|
34
|
+
if (PROD && status >= 500 && error.$sanitize !== false) error = {
|
|
35
|
+
message: i18n.messages.at(status, cds.context.locale) || 'Internal Server Error',
|
|
36
|
+
code: String(status), // toJSON is intentionally gone
|
|
47
37
|
}
|
|
48
38
|
|
|
49
|
-
//
|
|
50
|
-
|
|
39
|
+
// Errors can come with a custom $response() method to control how the
|
|
40
|
+
// error response shall be structured; default: { error: { ... } }
|
|
41
|
+
// E.g., SCIM doesn't wrap the error => err.$response = err => err
|
|
42
|
+
let response = err.$response?.call(error,error) || { error }
|
|
51
43
|
|
|
52
|
-
//
|
|
53
|
-
|
|
44
|
+
// Finally send the error response
|
|
45
|
+
return res.json (response)
|
|
54
46
|
}
|
|
55
47
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
const cds = require('../../index'), {inspect} = cds.utils
|
|
2
2
|
const express = require('express')
|
|
3
3
|
const LOG = cds.log('hcql')
|
|
4
|
+
const PROD = process.env.NODE_ENV === 'production'
|
|
4
5
|
|
|
5
6
|
class HCQLAdapter extends require('./http') {
|
|
6
7
|
|
|
7
8
|
get router() {
|
|
8
9
|
|
|
9
|
-
const srv = this.service
|
|
10
10
|
const router = super.router
|
|
11
11
|
.get ('/\\$csn', this.schema.bind(this)) //> return the CSN as schema
|
|
12
12
|
.use (express.json(this.body_parser_options)) //> for application/json -> cqn
|
|
@@ -14,29 +14,27 @@ class HCQLAdapter extends require('./http') {
|
|
|
14
14
|
|
|
15
15
|
// Route for custom actions and functions ...
|
|
16
16
|
const action = this.action.bind(this)
|
|
17
|
-
router.param('action', (
|
|
17
|
+
router.param('action', (r,_,next,a) => a in this.service.actions ? next() : next('route'))
|
|
18
18
|
router.route('/:action')
|
|
19
19
|
.post (action)
|
|
20
20
|
.get (action)
|
|
21
21
|
.all ((req,res,next) => next(501))
|
|
22
22
|
|
|
23
23
|
// Route for REST-style convenience shortcuts with queries in URL + body ...
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
.delete ($(({entity,id}) => DELETE.from (entity, id)))
|
|
39
|
-
}
|
|
24
|
+
const $ = cb => (req,_,next) => { req.body = cb(req.params,req); next() }
|
|
25
|
+
PROD || router.route('/:entity/:id?')
|
|
26
|
+
.get ($(({entity,id,tail}, req) => {
|
|
27
|
+
if (entity.includes(' ')) [,entity,tail] = /^(\w+)( .*)?/.exec(entity)
|
|
28
|
+
if (id?.includes(' ')) [,id,tail] = /^(\w+)( .*)/.exec(id)
|
|
29
|
+
let q = SELECT.from (entity,id), body = req.body
|
|
30
|
+
if (body) Object.assign (q.SELECT, ql_fragment(body))
|
|
31
|
+
if (tail) Object.assign (q.SELECT, ql_fragment(tail))
|
|
32
|
+
return q
|
|
33
|
+
}))
|
|
34
|
+
.post ($(({entity}, {query,body}) => INSERT.into (entity) .entries ({...query,...body})))
|
|
35
|
+
.put ($(({entity,id}, {query,body}) => UPDATE (entity,id) .with ({...query,...body})))
|
|
36
|
+
.patch ($(({entity,id}, {query,body}) => UPDATE (entity,id) .with ({...query,...body})))
|
|
37
|
+
.delete ($(({entity,id}) => DELETE.from (entity, id)))
|
|
40
38
|
|
|
41
39
|
// The ultimate handler for CRUD requests
|
|
42
40
|
router.use (this.crud.bind(this))
|
|
@@ -48,7 +46,7 @@ class HCQLAdapter extends require('./http') {
|
|
|
48
46
|
* Handle requests to custom actions and functions.
|
|
49
47
|
*/
|
|
50
48
|
action (req, res, next) {
|
|
51
|
-
return this.service.send (req.action, { ...req.query, ...req.body })
|
|
49
|
+
return this.service.send (req.params.action, { ...req.query, ...req.body })
|
|
52
50
|
.then (results => this.reply (results, res))
|
|
53
51
|
.catch (next)
|
|
54
52
|
}
|
|
@@ -71,11 +69,6 @@ class HCQLAdapter extends require('./http') {
|
|
|
71
69
|
*/
|
|
72
70
|
query4 (/** @type express.Request */ req) {
|
|
73
71
|
let q = req.body = cds.ql(req.body) || this.error (400, 'Invalid query', { query: req.body })
|
|
74
|
-
// assert valid target entity
|
|
75
|
-
if (q.target?._unresolved && this.service.definition) {
|
|
76
|
-
q.target = q._target = this.service.entities [q.target.name]
|
|
77
|
-
|| this.error (404, `'${q.target.name}' is not an entity served by '${this.service.name}'.`, { query:q })
|
|
78
|
-
}
|
|
79
72
|
// handle request headers
|
|
80
73
|
if (q.SELECT) {
|
|
81
74
|
if (req.get('Accept-Language')) q.SELECT.localized = true
|
|
@@ -83,7 +76,17 @@ class HCQLAdapter extends require('./http') {
|
|
|
83
76
|
}
|
|
84
77
|
// got a valid query
|
|
85
78
|
if (LOG._debug) LOG.debug (inspect(q))
|
|
86
|
-
return q
|
|
79
|
+
return this.valid(q)
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Checks whether the service actually serves the target entity.
|
|
84
|
+
*/
|
|
85
|
+
valid (query) {
|
|
86
|
+
if (!this.service.definition) return query
|
|
87
|
+
let target = cds.infer.target (query, this.service)
|
|
88
|
+
if (target._unresolved) throw this.error (400, `${target.name} is not an entity served by '${this.service.name}'.`, { query })
|
|
89
|
+
return query
|
|
87
90
|
}
|
|
88
91
|
|
|
89
92
|
/**
|
|
@@ -116,4 +119,11 @@ class HCQLAdapter extends require('./http') {
|
|
|
116
119
|
}
|
|
117
120
|
}
|
|
118
121
|
|
|
122
|
+
const ql_fragment = x => {
|
|
123
|
+
if (x.length) {
|
|
124
|
+
x = SELECT (`from x ${x}`).SELECT
|
|
125
|
+
delete x.from
|
|
126
|
+
}
|
|
127
|
+
return x
|
|
128
|
+
}
|
|
119
129
|
module.exports = HCQLAdapter
|
|
@@ -127,15 +127,6 @@ class Protocols {
|
|
|
127
127
|
return endpoints //.length ? endpoints : null
|
|
128
128
|
}
|
|
129
129
|
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* For compatibility with old @sap/cds-dk versions <= 7.4.0
|
|
133
|
-
* @deprecated Use def.protocols instead
|
|
134
|
-
*/
|
|
135
|
-
protocol4 (def) {
|
|
136
|
-
return def.protocols?.odata ? ['odata'] : []
|
|
137
|
-
}
|
|
138
|
-
|
|
139
130
|
/**
|
|
140
131
|
* Rarely used, e.g., by compile.to.openapi:
|
|
141
132
|
* NOT PUBLIC API, hence not documented.
|
package/lib/srv/srv-dispatch.js
CHANGED
|
@@ -20,14 +20,11 @@ exports.dispatch = async function dispatch (req) { //NOSONAR
|
|
|
20
20
|
q => this.dispatch ({ query:q, context: req.context, __proto__:req })
|
|
21
21
|
))
|
|
22
22
|
|
|
23
|
-
// Ensure target and fqns
|
|
24
|
-
|
|
25
|
-
if (typeof req.query === 'object') {
|
|
26
|
-
if (req.query._target !== req.target) Object.defineProperty (req.query,'_target',{ value:req.target, configurable:true, writable:true })
|
|
27
|
-
if (!req.query._srv) Object.defineProperty (req.query,'_srv',{ value:this, configurable:true, writable:true })
|
|
28
|
-
}
|
|
23
|
+
// Ensure inferred target and fqns
|
|
24
|
+
_ensure_target (this,req)
|
|
29
25
|
|
|
30
|
-
|
|
26
|
+
// Actually handle the request
|
|
27
|
+
return this.handle (req)
|
|
31
28
|
}
|
|
32
29
|
|
|
33
30
|
|
|
@@ -64,7 +61,6 @@ exports.handle = async function handle (req) {
|
|
|
64
61
|
const x = await each.handler.call (srv,r,next)
|
|
65
62
|
if (x !== undefined) return r.reply(x)
|
|
66
63
|
if (r.results) return r.results
|
|
67
|
-
if (srv._implicit_next) return next()
|
|
68
64
|
}()
|
|
69
65
|
if (req.errors) throw req.reject()
|
|
70
66
|
}
|
|
@@ -86,33 +82,35 @@ const _is_array = Array.isArray
|
|
|
86
82
|
const _dummy = ()=>{} // REVISIT: required for some messaging tests which obviously still expect and call next()
|
|
87
83
|
|
|
88
84
|
const _ensure_target = (srv,req) => {
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
85
|
+
|
|
86
|
+
// Requests with query
|
|
87
|
+
if (typeof req.query === 'object') {
|
|
88
|
+
const q = req.query = cds.ql(req.query)
|
|
89
|
+
if (!q._subject) return // REVISIT: this is for attic code which sends strange req.query = {}
|
|
90
|
+
if (!q._srv) q.bind (srv) // ensure req.query to be an instance of cds.ql.Query
|
|
91
|
+
if (!req.target) {
|
|
92
|
+
if (srv.namespace && q._subject.ref) _ensure_fqn (q._subject.ref,0, srv)
|
|
93
|
+
req.target = cds.infer.target(q)
|
|
94
|
+
}
|
|
95
|
+
if (q._target !== req.target) q._target = req.target
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
// Requests without query
|
|
99
|
+
else if (!req.target && srv.namespace) {
|
|
100
|
+
let p = req._.path || req._.entity
|
|
101
|
+
if (p) _ensure_fqn (req,'path', srv, p[0] === '/' ? p.slice(1) : p)
|
|
102
|
+
if (srv.model?.definitions[req.path]) req.target = srv.model.definitions[req.path]
|
|
97
103
|
}
|
|
98
|
-
const defs = srv.model?.definitions || {}
|
|
99
|
-
req.target = typeof q === 'object' ? cds.infer(q,defs) : defs[req.path]
|
|
100
104
|
}
|
|
101
105
|
|
|
102
|
-
const _ensure_fqn = (x,p,srv,
|
|
103
|
-
if (
|
|
104
|
-
if (
|
|
105
|
-
if (
|
|
106
|
-
if (srv.
|
|
107
|
-
if (srv.model && from in srv.model.definitions) return
|
|
108
|
-
if (from.startsWith(srv.namespace)) return
|
|
109
|
-
if (from.endsWith('_drafts')) return // REVISIT: rather fix test/fiori/localized-draft.test.js ?
|
|
110
|
-
else x[p] = `${srv.namespace}.${from}`
|
|
111
|
-
} else if (from.ref) {
|
|
112
|
-
const [head] = from.ref
|
|
113
|
-
head.id ? _ensure_fqn(head,'id',srv) : _ensure_fqn(from.ref,0,srv)
|
|
114
|
-
if (x.where) for (let y of x.where) if (y.SELECT) _ensure_fqn(y.SELECT,'from',srv)
|
|
106
|
+
const _ensure_fqn = (x,p,srv, name = x[p]) => {
|
|
107
|
+
if (name.id) return _ensure_fqn (name,'id', srv, name.id)
|
|
108
|
+
if (srv.model) {
|
|
109
|
+
if (name in srv.model.definitions) return // already an fqn
|
|
110
|
+
if (name in srv.entities) return x[p] = srv.entities[name].name
|
|
115
111
|
}
|
|
112
|
+
if (srv.isDatabaseService) return // db services allow unknown entities, e.g. 'sqlite.schema'
|
|
113
|
+
if (!name.startsWith(srv.namespace+'.')) x[p] = `${srv.namespace}.${name}`
|
|
116
114
|
}
|
|
117
115
|
|
|
118
116
|
const _unhandled = (srv,req) => {
|