@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,9 +1,9 @@
|
|
|
1
1
|
const PROCESSING = 'processing'
|
|
2
2
|
const LOCKED = 'locked'
|
|
3
3
|
const QUEUED = 'queued'
|
|
4
|
-
const
|
|
4
|
+
const PLANNED = 'planned'
|
|
5
5
|
|
|
6
|
-
class
|
|
6
|
+
module.exports = class TaskRunner {
|
|
7
7
|
constructor() {
|
|
8
8
|
this.states = new Map()
|
|
9
9
|
}
|
|
@@ -33,8 +33,6 @@ class OutboxRunner {
|
|
|
33
33
|
}
|
|
34
34
|
|
|
35
35
|
run({ name, tenant }, cb) {
|
|
36
|
-
const scheduled = this._getStateProp(SCHEDULED, { name, tenant })
|
|
37
|
-
if (scheduled) return // maybe make that configurable, we can also 'refresh' the current try
|
|
38
36
|
const processingState = this._getStateProp(PROCESSING, { name, tenant })
|
|
39
37
|
if (processingState === LOCKED) {
|
|
40
38
|
this._setStateProp(PROCESSING, QUEUED, { name, tenant })
|
|
@@ -45,13 +43,21 @@ class OutboxRunner {
|
|
|
45
43
|
return cb()
|
|
46
44
|
}
|
|
47
45
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
const
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
46
|
+
// Allows to plan, the shortest time wins
|
|
47
|
+
plan({ name, tenant, waitingTime }, cb) {
|
|
48
|
+
const newDate = Date.now() + waitingTime
|
|
49
|
+
const alreadyPlanned = this._getStateProp(PLANNED, { name, tenant })
|
|
50
|
+
if (!alreadyPlanned || alreadyPlanned.date > newDate) {
|
|
51
|
+
if (alreadyPlanned) clearInterval(alreadyPlanned.timer)
|
|
52
|
+
this._setStateProp(
|
|
53
|
+
PLANNED,
|
|
54
|
+
{
|
|
55
|
+
date: newDate,
|
|
56
|
+
timer: setTimeout(() => (this._setStateProp(PLANNED, undefined, { name, tenant }), cb()), waitingTime)
|
|
57
|
+
},
|
|
58
|
+
{ name, tenant }
|
|
59
|
+
)
|
|
60
|
+
}
|
|
55
61
|
}
|
|
56
62
|
|
|
57
63
|
end({ name, tenant }, cb) {
|
|
@@ -61,15 +67,4 @@ class OutboxRunner {
|
|
|
61
67
|
return cb()
|
|
62
68
|
}
|
|
63
69
|
}
|
|
64
|
-
|
|
65
|
-
success({ name, tenant }) {
|
|
66
|
-
const timer = this._getStateProp(SCHEDULED, { name, tenant })
|
|
67
|
-
if (timer) {
|
|
68
|
-
// once successful, we don't want to have another scheduled run
|
|
69
|
-
clearTimeout(timer)
|
|
70
|
-
this._setStateProp(SCHEDULED, undefined, { name, tenant })
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
70
|
}
|
|
74
|
-
|
|
75
|
-
module.exports = OutboxRunner
|
|
@@ -0,0 +1,530 @@
|
|
|
1
|
+
const cds = require('../_runtime/cds')
|
|
2
|
+
const LOG = cds.log('persistent-queue|queue|persistent-outbox|outbox')
|
|
3
|
+
|
|
4
|
+
const { inspect } = require('util')
|
|
5
|
+
|
|
6
|
+
const TaskRunner = require('./TaskRunner')
|
|
7
|
+
const taskRunner = new TaskRunner()
|
|
8
|
+
|
|
9
|
+
const { expBkfFix: waitingTime } = require('../_runtime/common/utils/waitingTime')
|
|
10
|
+
|
|
11
|
+
const PROCESSING = 'processing'
|
|
12
|
+
const INTERNAL_USER = 'cds.internal.user'
|
|
13
|
+
|
|
14
|
+
const $taskProcessorRegistered = Symbol('task processor registered')
|
|
15
|
+
const $queued = Symbol('queued')
|
|
16
|
+
const $unqueued = Symbol('unqueued')
|
|
17
|
+
const $stored_reqs = Symbol('stored_reqs')
|
|
18
|
+
const $error = Symbol('error')
|
|
19
|
+
|
|
20
|
+
const _get100NanosecondTimestampISOString = (offset = 0) => {
|
|
21
|
+
const [now, nanoseconds] = [new Date(Date.now() + offset), process.hrtime()[1]]
|
|
22
|
+
return now.toISOString().replace('Z', `${nanoseconds}`.padStart(9, '0').substring(3, 7) + 'Z')
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const _getTasksEntity = () => {
|
|
26
|
+
const tasksDbName = 'cds.outbox.Messages'
|
|
27
|
+
const tasksEntity = cds.model.definitions[tasksDbName]
|
|
28
|
+
if (!tasksEntity) throw new Error(`The entity '${tasksDbName}' is missing but needed for persistent tasks.`)
|
|
29
|
+
return tasksEntity
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// REVISIT: Is this always a reliable way to identify the provider tenant?
|
|
33
|
+
// Are there scenarios where the credentials have a different format?
|
|
34
|
+
const _isProviderTenant = tenant =>
|
|
35
|
+
(cds.requires.auth && cds.requires.auth.credentials && cds.requires.auth.credentials.identityzoneid === tenant) ||
|
|
36
|
+
cds.requires.multitenancy.t0 === tenant
|
|
37
|
+
|
|
38
|
+
const _hasPersistentQueue = tenant => {
|
|
39
|
+
if (cds.requires.multitenancy && tenant && _isProviderTenant(tenant)) return false // no persistence for provider account
|
|
40
|
+
return true
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const _safeJSONParse = string => {
|
|
44
|
+
try {
|
|
45
|
+
return string && JSON.parse(string)
|
|
46
|
+
} catch {
|
|
47
|
+
// Don't throw
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Note: This function can also run for each tenant on startup
|
|
52
|
+
//
|
|
53
|
+
// tx1: Fetch messages which are not in process and are not locked (SELECT FOR UPDATE)
|
|
54
|
+
// tx1: Set those which are processable (not 'processing' or timed out) to 'processing'
|
|
55
|
+
// Process messages (in parallel or sequentially)
|
|
56
|
+
// tx2 (legacyLocking: tx1): Update/Delete messages based on outcome, set status to null
|
|
57
|
+
//
|
|
58
|
+
const processTasks = (service, tenant, _opts = {}) => {
|
|
59
|
+
const opts = Object.assign({ attempt: 0 }, _opts)
|
|
60
|
+
if (!opts.parallel) opts.chunkSize = 1
|
|
61
|
+
|
|
62
|
+
const name = service.name
|
|
63
|
+
const tasksEntity = _getTasksEntity()
|
|
64
|
+
|
|
65
|
+
let letAppCrash = false
|
|
66
|
+
|
|
67
|
+
const __done = () => {
|
|
68
|
+
if (letAppCrash) cds.exit(1)
|
|
69
|
+
taskRunner.end({ name, tenant }, () => processTasks(service, tenant, opts))
|
|
70
|
+
}
|
|
71
|
+
const _done = () => {
|
|
72
|
+
if (!opts.legacyLocking) __done()
|
|
73
|
+
// else will be handled in spawn
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
return taskRunner.run({ name, tenant }, () => {
|
|
77
|
+
const config = tenant ? { tenant, user: cds.User.privileged } : { user: cds.User.privileged }
|
|
78
|
+
config.after = 1 // make sure spawn puts its cb on the `timer` queue (via setTimeout), which is also used by `taskRunner`
|
|
79
|
+
|
|
80
|
+
const _begin = opts.legacyLocking ? cds.spawn.bind(cds) : cb => cb()
|
|
81
|
+
const _end = opts.legacyLocking ? s => s.on('done', __done) : () => {}
|
|
82
|
+
const _tx = opts.legacyLocking ? cb => cb() : cds.tx.bind(cds)
|
|
83
|
+
|
|
84
|
+
const spawn = _begin(async () => {
|
|
85
|
+
let selectedTasks
|
|
86
|
+
const currTime = Date.now()
|
|
87
|
+
const _timeout = cds.utils._unit.time2ms(opts.timeout)
|
|
88
|
+
|
|
89
|
+
let currMinWaitingTime
|
|
90
|
+
|
|
91
|
+
const _setWaitingTime = time => {
|
|
92
|
+
if (currMinWaitingTime === undefined) currMinWaitingTime = time
|
|
93
|
+
else currMinWaitingTime = Math.min(currMinWaitingTime, time)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const tasksQuery = SELECT.from(tasksEntity)
|
|
97
|
+
.where({ target: name })
|
|
98
|
+
.orderBy(opts.parallel ? ['status', 'timestamp', 'ID'] : ['timestamp', 'status', 'ID'])
|
|
99
|
+
.limit(opts.chunkSize)
|
|
100
|
+
.forUpdate()
|
|
101
|
+
if (opts.maxAttempts) tasksQuery.where({ attempts: { '<': opts.maxAttempts } })
|
|
102
|
+
if (opts.parallel) {
|
|
103
|
+
tasksQuery.SELECT.forUpdate.ignoreLocked = true
|
|
104
|
+
const shifted = new Date(Math.max(0, currTime - _timeout)).toISOString()
|
|
105
|
+
tasksQuery.where({ status: null, or: { lastAttemptTimestamp: { '<': shifted } } })
|
|
106
|
+
// Note: If there are messages which are not yet timed out, but will hang eventually,
|
|
107
|
+
// there will be no scheduled processing. One could remove that filter, but
|
|
108
|
+
// it would (in the worst case) select <chunkSize> messages which are all in process
|
|
109
|
+
// and not yet timed out, hence only <chunkSize> messages could be processed at any given time.
|
|
110
|
+
}
|
|
111
|
+
LOG._debug && LOG.debug(`${name}: Fetch messages`)
|
|
112
|
+
try {
|
|
113
|
+
// Use dedicated transaction to fetch relevant messages
|
|
114
|
+
// and _immediately_ set their status to 'processing' and commit
|
|
115
|
+
// thus keeping the database lock as short as possible
|
|
116
|
+
selectedTasks = await _tx(async () => {
|
|
117
|
+
const selectedTasks = await tasksQuery
|
|
118
|
+
const shifted = currTime - _timeout
|
|
119
|
+
const processableTasks = []
|
|
120
|
+
|
|
121
|
+
// filter those which must not be processed
|
|
122
|
+
for (const t of selectedTasks) {
|
|
123
|
+
// break at the first one which is in the future (they're ordered by timestamp)
|
|
124
|
+
const taskTimestamp = new Date(t.timestamp).getTime()
|
|
125
|
+
const _waitingTimePlanned = taskTimestamp - currTime
|
|
126
|
+
if (_waitingTimePlanned > 0) {
|
|
127
|
+
_setWaitingTime(_waitingTimePlanned)
|
|
128
|
+
break // everything afterwards is even further in the future
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// ignore those which should have a longer waiting time
|
|
132
|
+
// remember the minimum waiting time to retrigger the processing (will be compared to failed messages later)
|
|
133
|
+
const lastAttemptTimestamp = t.lastAttemptTimestamp && new Date(t.lastAttemptTimestamp).getTime()
|
|
134
|
+
if (lastAttemptTimestamp && t.attempts) {
|
|
135
|
+
const _alreadyWaited = currTime - lastAttemptTimestamp
|
|
136
|
+
const _shouldHaveWaited = waitingTime(t.attempts)
|
|
137
|
+
const _remainingTime = _shouldHaveWaited - _alreadyWaited
|
|
138
|
+
if (_remainingTime > 0) {
|
|
139
|
+
_setWaitingTime(_remainingTime)
|
|
140
|
+
continue
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
if (t.status === null || new Date(t.lastAttemptTimestamp).getTime() < shifted) processableTasks.push(t)
|
|
144
|
+
}
|
|
145
|
+
// Note: There's also no scheduling for tasks which are not yet timed out.
|
|
146
|
+
if (!processableTasks.length) return [] // all in process
|
|
147
|
+
// prettier-ignore
|
|
148
|
+
LOG._debug && LOG.debug(`${name}: Process ${processableTasks.length} ${processableTasks.length > 1 ? 'messages' : 'message'}`)
|
|
149
|
+
if (!opts.legacyLocking) {
|
|
150
|
+
await UPDATE(tasksEntity)
|
|
151
|
+
.set({ status: PROCESSING })
|
|
152
|
+
.where({ ID: { in: processableTasks.filter(t => t.status === null).map(t => t.ID) } })
|
|
153
|
+
}
|
|
154
|
+
return processableTasks
|
|
155
|
+
})
|
|
156
|
+
} catch (e) {
|
|
157
|
+
// could potentially be a timeout
|
|
158
|
+
const _waitingTime = waitingTime(opts.attempt)
|
|
159
|
+
// prettier-ignore
|
|
160
|
+
LOG.error(`${name}: Message retrieval failed`, e, `Retry${_waitingTime > 0 ? ` in ${Math.round(_waitingTime / 1000)} s` : ''}`)
|
|
161
|
+
taskRunner.plan(
|
|
162
|
+
{
|
|
163
|
+
name,
|
|
164
|
+
tenant,
|
|
165
|
+
waitingTime: _waitingTime
|
|
166
|
+
},
|
|
167
|
+
() => processTasks(service, tenant, { ...opts, attempt: opts.attempt + 1 })
|
|
168
|
+
)
|
|
169
|
+
return _done()
|
|
170
|
+
}
|
|
171
|
+
const tasksGen = function* () {
|
|
172
|
+
for (const task of selectedTasks) {
|
|
173
|
+
const _msg = _safeJSONParse(task.msg)
|
|
174
|
+
const context = _msg.context || {}
|
|
175
|
+
const userId = _msg[INTERNAL_USER]
|
|
176
|
+
if (_msg.query) {
|
|
177
|
+
const q = (_msg.query = cds.ql(_msg.query))
|
|
178
|
+
q.bind(service)
|
|
179
|
+
_msg.target = cds.infer.target(q)
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
const msg = _msg._fromSend ? new cds.Request(_msg) : new cds.Event(_msg)
|
|
183
|
+
delete msg._fromSend
|
|
184
|
+
delete msg[INTERNAL_USER]
|
|
185
|
+
const user = new cds.User.Privileged(userId)
|
|
186
|
+
context.user = user
|
|
187
|
+
if (!msg) continue
|
|
188
|
+
const res = {
|
|
189
|
+
ID: task.ID,
|
|
190
|
+
msg,
|
|
191
|
+
context,
|
|
192
|
+
attempts: task.attempts || 0
|
|
193
|
+
}
|
|
194
|
+
yield res
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
const toBeDeleted = []
|
|
199
|
+
const toBeUpdated = []
|
|
200
|
+
const toBeCreated = []
|
|
201
|
+
|
|
202
|
+
// Remember the failed message with the minimum current attempts (-> determines when the next processing shall be planned)
|
|
203
|
+
let minAttemptFailed
|
|
204
|
+
try {
|
|
205
|
+
const _handleWithErr = async task => {
|
|
206
|
+
try {
|
|
207
|
+
// REVISIT: Shouldn't that work like a standard inbound adapter? I.e. either of:
|
|
208
|
+
// - cds._with({...}, ()=> srv.dispatch(task.msg)) // instead of srv.handle(task.msg)
|
|
209
|
+
// - cds.tx({...}, ()=> srv.dispatch(task.msg)) // instead of srv.handle(task.msg)
|
|
210
|
+
// Problem: If task involves db, dedicated transactions will block on SQLite if an outer transaction is open
|
|
211
|
+
const _run = opts.legacyLocking && cds.db?.kind === 'sqlite' ? cds._with : service.tx.bind(service)
|
|
212
|
+
const result = await _run({ ...task.context, tenant }, async () => {
|
|
213
|
+
return opts.handle ? await opts.handle.call(service, task.msg) : await service.handle(task.msg)
|
|
214
|
+
})
|
|
215
|
+
task.results = result
|
|
216
|
+
toBeDeleted.push(task)
|
|
217
|
+
} catch (e) {
|
|
218
|
+
if (!minAttemptFailed) minAttemptFailed = task.attempts
|
|
219
|
+
else minAttemptFailed = Math.min(minAttemptFailed, task.attempts)
|
|
220
|
+
task[$error] = e
|
|
221
|
+
if (cds.error.isSystemError(e)) {
|
|
222
|
+
LOG.error(`${service.name}: Programming error detected:`, e)
|
|
223
|
+
task.updateData = { attempts: opts.maxAttempts }
|
|
224
|
+
toBeUpdated.push(task)
|
|
225
|
+
throw new Error(`${service.name}: Programming error detected.`)
|
|
226
|
+
}
|
|
227
|
+
if (e.unrecoverable) {
|
|
228
|
+
LOG.error(`${service.name}: Unrecoverable error:`, e)
|
|
229
|
+
if (opts.maxAttempts) {
|
|
230
|
+
task.updateData = { attempts: opts.maxAttempts }
|
|
231
|
+
toBeUpdated.push(task)
|
|
232
|
+
} else toBeDeleted.push(task)
|
|
233
|
+
} else {
|
|
234
|
+
LOG.error(`${service.name}: Emit failed:`, e)
|
|
235
|
+
task.updateData = { attempts: task.attempts + 1 }
|
|
236
|
+
toBeUpdated.push(task)
|
|
237
|
+
return false
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
const tasks = tasksGen()
|
|
242
|
+
// REVISIT: Maybe we can also support handleMany and provide the iterator (for batch processing)
|
|
243
|
+
if (opts.parallel) {
|
|
244
|
+
const res = await Promise.allSettled([...tasks].map(_handleWithErr))
|
|
245
|
+
const errors = res.filter(r => r.status === 'rejected').map(r => r.reason)
|
|
246
|
+
if (errors.length) {
|
|
247
|
+
throw new Error(`${service.name}: Programming errors detected.`)
|
|
248
|
+
}
|
|
249
|
+
} else {
|
|
250
|
+
// In principle, this branch is not needed as for `parallel == false`, there's only one chunk at a time,
|
|
251
|
+
// hence the `Promise.allSettled` above would be sufficient.
|
|
252
|
+
// Let's keep it if we want to change it in the future.
|
|
253
|
+
for (const task of tasks) {
|
|
254
|
+
if ((await _handleWithErr(task)) === false) break
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
} catch (e) {
|
|
258
|
+
LOG.error(e)
|
|
259
|
+
letAppCrash = true
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
const queries = []
|
|
263
|
+
if (toBeDeleted.length)
|
|
264
|
+
queries.push(
|
|
265
|
+
DELETE.from(tasksEntity).where(
|
|
266
|
+
'ID in',
|
|
267
|
+
toBeDeleted.map(msg => msg.ID)
|
|
268
|
+
)
|
|
269
|
+
)
|
|
270
|
+
|
|
271
|
+
// There can be tasks which are not updated / deleted, their status must be set back to `null`
|
|
272
|
+
const updateTasks = selectedTasks.filter(
|
|
273
|
+
task => !toBeDeleted.some(t => t.ID === task.ID) && !toBeUpdated.some(t => t.ID === task.ID)
|
|
274
|
+
)
|
|
275
|
+
if (updateTasks.length) {
|
|
276
|
+
queries.push(
|
|
277
|
+
UPDATE(tasksEntity)
|
|
278
|
+
.where({ ID: { in: updateTasks.map(t => t.ID) } })
|
|
279
|
+
.set({ status: null })
|
|
280
|
+
)
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
for (const each of toBeUpdated) {
|
|
284
|
+
if (toBeDeleted.some(d => d.ID === each.ID)) continue
|
|
285
|
+
each.updateData.status = null
|
|
286
|
+
if (opts.storeLastError !== false) each.updateData.lastError = inspect(each[$error])
|
|
287
|
+
if (each.updateData.lastError && typeof each.updateData.lastError !== 'string') {
|
|
288
|
+
each.updateData.lastError = inspect(each.updateData.lastError)
|
|
289
|
+
}
|
|
290
|
+
queries.push(UPDATE(tasksEntity).where({ ID: each.ID }).set(each.updateData))
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
const _newMsgFrom = msg => {
|
|
294
|
+
const _fromSend = msg instanceof cds.Request
|
|
295
|
+
const newMsg = { ...msg }
|
|
296
|
+
newMsg._fromSend = _fromSend
|
|
297
|
+
if (!newMsg.queue) return newMsg
|
|
298
|
+
if (!newMsg.queue.after && !newMsg.queue.every) return newMsg
|
|
299
|
+
newMsg.queue = { ...newMsg.queue }
|
|
300
|
+
delete newMsg.queue.every
|
|
301
|
+
delete newMsg.queue.after
|
|
302
|
+
return newMsg
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
const _failed = task => {
|
|
306
|
+
const msg = _newMsgFrom(task.msg)
|
|
307
|
+
msg.event = msg.event + '/#failed'
|
|
308
|
+
const _errorToObj = error => {
|
|
309
|
+
if (typeof error === 'string') return { message: error }
|
|
310
|
+
return {
|
|
311
|
+
name: error.name,
|
|
312
|
+
message: error.message,
|
|
313
|
+
stack: error.stack,
|
|
314
|
+
code: error.code,
|
|
315
|
+
...error
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
msg.results = _errorToObj(task[$error])
|
|
319
|
+
if (service.handlers.on.some(h => h.for(msg)) || service.handlers.after.some(h => h.for(msg))) {
|
|
320
|
+
toBeCreated.push(_createTask(service.name, msg, task.context, opts))
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
const _succeeded = task => {
|
|
325
|
+
const msg = _newMsgFrom(task.msg)
|
|
326
|
+
msg.event = msg.event + '/#succeeded'
|
|
327
|
+
if (service.handlers.on.some(h => h.for(msg)) || service.handlers.after.some(h => h.for(msg))) {
|
|
328
|
+
toBeCreated.push(_createTask(service.name, msg, task.context, opts))
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
for (const task of toBeDeleted) {
|
|
333
|
+
// invoke succeeded handlers
|
|
334
|
+
if (!task.msg.event.endsWith('/#succeeded') && !task.msg.event.endsWith('/#failed')) {
|
|
335
|
+
if (!task.error) {
|
|
336
|
+
// skip programming errors & unrecoverable without maxAttempts
|
|
337
|
+
_succeeded(task)
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
// handle `every`
|
|
342
|
+
if (task.msg.queue?.every) {
|
|
343
|
+
const _m = { ...task.msg }
|
|
344
|
+
_m._fromSend = task.msg instanceof cds.Request
|
|
345
|
+
const _task = _createTask(service.name, _m, task.context, opts)
|
|
346
|
+
_task.timestamp = _get100NanosecondTimestampISOString(task.msg.queue.every)
|
|
347
|
+
toBeCreated.push(_task)
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
// invoke failed handlers (only if max attempts is reached)
|
|
351
|
+
for (const task of toBeUpdated) {
|
|
352
|
+
if (
|
|
353
|
+
!task.msg.event.endsWith('/#succeeded') &&
|
|
354
|
+
!task.msg.event.endsWith('/#failed') &&
|
|
355
|
+
opts.maxAttempts &&
|
|
356
|
+
task.updateData.attempts >= opts.maxAttempts
|
|
357
|
+
) {
|
|
358
|
+
_failed(task)
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
if (toBeCreated.length) queries.push(INSERT.into(tasksEntity).entries(toBeCreated))
|
|
363
|
+
|
|
364
|
+
if (queries.length) {
|
|
365
|
+
await _tx(() => Promise.all(queries))
|
|
366
|
+
// prettier-ignore
|
|
367
|
+
LOG._debug && LOG.debug(`${name}: Messages modified (-${toBeDeleted.length}, ~${toBeUpdated.length + updateTasks.length}, +${toBeCreated.length})`)
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
if (letAppCrash) return _done()
|
|
371
|
+
|
|
372
|
+
if (toBeUpdated.length) {
|
|
373
|
+
LOG.error(`${name}: Some messages could not be processed`)
|
|
374
|
+
_setWaitingTime(waitingTime(minAttemptFailed + 1))
|
|
375
|
+
}
|
|
376
|
+
if (toBeDeleted.length === opts.chunkSize || toBeCreated.length) {
|
|
377
|
+
_setWaitingTime(0)
|
|
378
|
+
}
|
|
379
|
+
if (currMinWaitingTime !== undefined) {
|
|
380
|
+
// prettier-ignore
|
|
381
|
+
LOG._debug && LOG.debug(`${name}: Process${currMinWaitingTime > 0 ? ` in ${Math.round(currMinWaitingTime / 1000)} s` : ''}`)
|
|
382
|
+
taskRunner.plan(
|
|
383
|
+
{
|
|
384
|
+
name,
|
|
385
|
+
tenant,
|
|
386
|
+
waitingTime: currMinWaitingTime
|
|
387
|
+
},
|
|
388
|
+
() => processTasks(service, tenant, opts)
|
|
389
|
+
)
|
|
390
|
+
return _done()
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
LOG._debug && LOG.debug(`${name}: Done`)
|
|
394
|
+
return _done()
|
|
395
|
+
}, config)
|
|
396
|
+
_end(spawn)
|
|
397
|
+
})
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
const registerTaskProcessor = (name, context) => {
|
|
401
|
+
const registry = context[$taskProcessorRegistered] || (context[$taskProcessorRegistered] = new Set())
|
|
402
|
+
if (!registry.has(name)) {
|
|
403
|
+
registry.add(name)
|
|
404
|
+
return true
|
|
405
|
+
}
|
|
406
|
+
return false
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
const _createTask = (name, msg, context, taskOpts) => {
|
|
410
|
+
const _msg = { [INTERNAL_USER]: context.user.id }
|
|
411
|
+
const _newContext = {}
|
|
412
|
+
for (const key in context) {
|
|
413
|
+
if (!taskOpts.ignoredContext.includes(key)) _newContext[key] = context[key]
|
|
414
|
+
}
|
|
415
|
+
_msg.context = _newContext
|
|
416
|
+
|
|
417
|
+
if (msg._fromSend || msg.reply) _msg._fromSend = true // send or emit?
|
|
418
|
+
for (const prop of ['inbound', 'event', 'data', 'headers', 'queue', 'results']) {
|
|
419
|
+
if (msg[prop]) _msg[prop] = msg[prop]
|
|
420
|
+
}
|
|
421
|
+
if (msg.query) {
|
|
422
|
+
_msg.query = typeof msg.query.flat === 'function' ? msg.query.flat() : msg.query
|
|
423
|
+
delete _msg.query._target
|
|
424
|
+
delete _msg.query.__target
|
|
425
|
+
delete _msg.query.target
|
|
426
|
+
}
|
|
427
|
+
const taskMsg = {
|
|
428
|
+
ID: cds.utils.uuid(),
|
|
429
|
+
target: name,
|
|
430
|
+
timestamp: _get100NanosecondTimestampISOString(msg.queue?.after), // needs to be different for each emit
|
|
431
|
+
msg: JSON.stringify(_msg)
|
|
432
|
+
}
|
|
433
|
+
return taskMsg
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
const writeInQueue = async (name, msg, context, taskOpts) => {
|
|
437
|
+
const taskMsg = _createTask(name, msg, context, taskOpts)
|
|
438
|
+
const tasksEntity = _getTasksEntity()
|
|
439
|
+
LOG._debug && LOG.debug(`${name}: Write message to queue`)
|
|
440
|
+
return INSERT.into(tasksEntity).entries(taskMsg)
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
exports.unqueued = function unqueued(srv) {
|
|
444
|
+
return srv[$unqueued] || srv
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
exports.queued = function queued(srv, customOpts) {
|
|
448
|
+
// queue max. once
|
|
449
|
+
if (!new.target) {
|
|
450
|
+
const former = srv[$queued]
|
|
451
|
+
if (former) return former
|
|
452
|
+
}
|
|
453
|
+
|
|
454
|
+
const originalSrv = srv[$unqueued] || srv
|
|
455
|
+
const queuedSrv = Object.create(originalSrv)
|
|
456
|
+
queuedSrv[$unqueued] = originalSrv
|
|
457
|
+
|
|
458
|
+
if (!new.target) Object.defineProperty(srv, $queued, { value: queuedSrv })
|
|
459
|
+
|
|
460
|
+
let requiresOpts = cds.requires.queue
|
|
461
|
+
if (cds.requires.outbox !== undefined) {
|
|
462
|
+
cds.utils.deprecated({ old: 'cds.requires.outbox', use: 'cds.requires.queue' })
|
|
463
|
+
requiresOpts = cds.requires.outbox ? Object.assign({}, requiresOpts, cds.requires.outbox) : false
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
let serviceOpts = srv.options?.queued ?? srv.options?.outboxed
|
|
467
|
+
if (srv.options?.outbox !== undefined) {
|
|
468
|
+
// REVISIT: cds.utils.deprecated({ old: 'cds.requires.<srv>.outbox', use: 'cds.requires.<srv>.queued or cds.requires.<srv>.outboxed' })
|
|
469
|
+
serviceOpts = srv.options.outbox ? Object.assign({}, serviceOpts, srv.options.outbox) : false
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
if (typeof requiresOpts === 'string') requiresOpts = { kind: requiresOpts }
|
|
473
|
+
if (typeof serviceOpts === 'string') serviceOpts = { kind: serviceOpts }
|
|
474
|
+
|
|
475
|
+
const queueOpts = Object.assign(
|
|
476
|
+
{},
|
|
477
|
+
(typeof requiresOpts === 'object' && requiresOpts) || {},
|
|
478
|
+
(typeof serviceOpts === 'object' && serviceOpts) || {},
|
|
479
|
+
customOpts || {}
|
|
480
|
+
)
|
|
481
|
+
|
|
482
|
+
queuedSrv.outboxed = queueOpts // Store effective outbox configuration (e.g. used in telemetry)
|
|
483
|
+
|
|
484
|
+
queuedSrv.handle = async function (req) {
|
|
485
|
+
const context = req.context || cds.context
|
|
486
|
+
if (
|
|
487
|
+
(queueOpts.kind === 'persistent-queue' || queueOpts.kind === 'persistent-outbox') &&
|
|
488
|
+
_hasPersistentQueue(context.tenant)
|
|
489
|
+
) {
|
|
490
|
+
// returns true if not yet registered
|
|
491
|
+
if (registerTaskProcessor(srv.name, context)) {
|
|
492
|
+
// NOTE: What if there are different queue options for the same service?!
|
|
493
|
+
// There could be tasks for srv1 with { maxAttempts: 1 }
|
|
494
|
+
// and tasks for srv1 with { maxAttempts: 9 }.
|
|
495
|
+
// How would they be processed? I'd rather not have dedicated
|
|
496
|
+
// service names or store serialized options for each task.
|
|
497
|
+
context.on('succeeded', () => processTasks(originalSrv, context.tenant, queueOpts))
|
|
498
|
+
}
|
|
499
|
+
await writeInQueue(srv.name, req, context, queueOpts)
|
|
500
|
+
return
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
if (!context[$stored_reqs]) {
|
|
504
|
+
context[$stored_reqs] = []
|
|
505
|
+
context.on('succeeded', async () => {
|
|
506
|
+
// REVISIT: Also allow maxAttempts for in-memory queue?
|
|
507
|
+
for (const _req of context[$stored_reqs]) {
|
|
508
|
+
try {
|
|
509
|
+
if (_req.reply) await originalSrv.send(_req)
|
|
510
|
+
else await originalSrv.emit(_req)
|
|
511
|
+
} catch (e) {
|
|
512
|
+
LOG.error('Emit failed', { event: _req.event, cause: e })
|
|
513
|
+
if (cds.error.isSystemError(e)) {
|
|
514
|
+
await cds.shutdown(e)
|
|
515
|
+
return
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
}
|
|
519
|
+
delete context[$stored_reqs]
|
|
520
|
+
})
|
|
521
|
+
}
|
|
522
|
+
context[$stored_reqs].push(req)
|
|
523
|
+
}
|
|
524
|
+
|
|
525
|
+
queuedSrv.flush = function flush(tenant = cds.context?.tenant, opts) {
|
|
526
|
+
return processTasks(originalSrv, tenant, Object.assign({}, queueOpts, opts))
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
return queuedSrv
|
|
530
|
+
}
|