@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,345 +0,0 @@
|
|
|
1
|
-
const { SQLITE_TYPE_CONVERSION_MAP } = require('./conversion')
|
|
2
|
-
const CustomBuilder = require('./customBuilder')
|
|
3
|
-
const { sqlFactory } = require('../db/sql-builder/')
|
|
4
|
-
const { getPostProcessMapper, postProcess } = require('../db/data-conversion/post-processing')
|
|
5
|
-
const { createJoinCQNFromExpanded, hasExpand, rawToExpanded, expandV2 } = require('../db/expand')
|
|
6
|
-
const { Readable } = require('stream')
|
|
7
|
-
|
|
8
|
-
const cds = require('../cds')
|
|
9
|
-
const LOG = cds.log('sqlite|db|sql')
|
|
10
|
-
// && {_debug:true, debug(sql){ cds._debug && console.log(sql+';\n') }} //> please keep that for debugging stakeholder tests
|
|
11
|
-
const coloredTxCommands = require('../db/utils/coloredTxCommands')
|
|
12
|
-
const { convertStream } = require('../db/utils/stream')
|
|
13
|
-
const { inspect } = require('util')
|
|
14
|
-
|
|
15
|
-
const SANITIZE_VALUES = process.env.NODE_ENV === 'production' && cds.env.log.sanitize_values !== false
|
|
16
|
-
|
|
17
|
-
/*
|
|
18
|
-
* capture stack trace on the way to exec to know origin
|
|
19
|
-
* -> very expensive
|
|
20
|
-
* -> only if DEBUG (which should not be used in production)
|
|
21
|
-
*/
|
|
22
|
-
const DEBUG = cds.debug('sqlite')
|
|
23
|
-
const _exec = DEBUG
|
|
24
|
-
? (dbc, op, ...args) => {
|
|
25
|
-
const callback = args[args.length - 1]
|
|
26
|
-
const captured = {}
|
|
27
|
-
Error.captureStackTrace(captured, _exec)
|
|
28
|
-
args[args.length - 1] = function (err) {
|
|
29
|
-
if (err) {
|
|
30
|
-
err.message += ' in: \n' + args[0]
|
|
31
|
-
err.query = args[0]
|
|
32
|
-
if (args.length > 2) err.values = SANITIZE_VALUES ? ['***'] : args[1]
|
|
33
|
-
err.stack =
|
|
34
|
-
err.message +
|
|
35
|
-
captured.stack
|
|
36
|
-
.slice(5)
|
|
37
|
-
.replace(/at( _exec)? /, 'at SQLite.' + op + ' ')
|
|
38
|
-
.replace(/\s+at new Promise .*\n.*/, '')
|
|
39
|
-
}
|
|
40
|
-
callback.apply(this, arguments)
|
|
41
|
-
}
|
|
42
|
-
return dbc[op](...args)
|
|
43
|
-
}
|
|
44
|
-
: (dbc, op, ...args) => {
|
|
45
|
-
const callback = args[args.length - 1]
|
|
46
|
-
args[args.length - 1] = function (err) {
|
|
47
|
-
if (err) {
|
|
48
|
-
err.message += ' in: \n' + args[0]
|
|
49
|
-
err.query = args[0]
|
|
50
|
-
if (args.length > 2) err.values = SANITIZE_VALUES ? ['***'] : args[1]
|
|
51
|
-
}
|
|
52
|
-
callback.apply(this, arguments)
|
|
53
|
-
}
|
|
54
|
-
return dbc[op](...args)
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
function _executeSimpleSQL(dbc, sql, values) {
|
|
58
|
-
LOG._debug &&
|
|
59
|
-
LOG.debug(coloredTxCommands[sql] || sql, Array.isArray(values) ? (SANITIZE_VALUES ? ['***'] : values) : '')
|
|
60
|
-
|
|
61
|
-
return new Promise((resolve, reject) => {
|
|
62
|
-
_exec(dbc, 'run', sql, values, function (err) {
|
|
63
|
-
if (err) return reject(err)
|
|
64
|
-
resolve(this.changes)
|
|
65
|
-
})
|
|
66
|
-
})
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
function executeSelectSQL(dbc, sql, values, isOne, postMapper) {
|
|
70
|
-
LOG._debug && LOG.debug(sql, SANITIZE_VALUES ? ['***'] : values)
|
|
71
|
-
|
|
72
|
-
return new Promise((resolve, reject) => {
|
|
73
|
-
_exec(dbc, isOne ? 'get' : 'all', sql, values, (err, result) => {
|
|
74
|
-
if (err) return reject(err)
|
|
75
|
-
resolve(result)
|
|
76
|
-
})
|
|
77
|
-
}).then(result => postProcess(result, postMapper))
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
function _processExpand(model, dbc, cqn, user, locale, txTimestamp) {
|
|
81
|
-
const queries = []
|
|
82
|
-
const expandQueries = createJoinCQNFromExpanded(cqn, model, locale)
|
|
83
|
-
|
|
84
|
-
for (const cqn of expandQueries.queries) {
|
|
85
|
-
cqn._conversionMapper = getPostProcessMapper(SQLITE_TYPE_CONVERSION_MAP, model, cqn)
|
|
86
|
-
|
|
87
|
-
// REVISIT
|
|
88
|
-
// Why is the post processing in expand different?
|
|
89
|
-
const { sql, values } = sqlFactory(cqn, { user, now: txTimestamp, customBuilder: CustomBuilder }, model)
|
|
90
|
-
queries.push(executeSelectSQL(dbc, sql, values, false))
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return rawToExpanded(expandQueries, queries, cqn.SELECT.one, cqn._target)
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
function executeSelectCQN(model, dbc, query, user, locale, txTimestamp) {
|
|
97
|
-
if (hasExpand(query)) {
|
|
98
|
-
// expand: '**' or '*3' is handled by new impl
|
|
99
|
-
if (
|
|
100
|
-
query.SELECT.columns.some(c => c.expand && typeof c.expand[0] === 'string' && /^\*{1}[\d|*]+/.test(c.expand[0]))
|
|
101
|
-
) {
|
|
102
|
-
return expandV2(model, dbc, query, user, locale, txTimestamp, executeSelectCQN)
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return _processExpand(model, dbc, query, user, locale, txTimestamp)
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
const { sql, values = [] } = sqlFactory(
|
|
109
|
-
query,
|
|
110
|
-
{
|
|
111
|
-
user,
|
|
112
|
-
customBuilder: CustomBuilder,
|
|
113
|
-
now: txTimestamp || { sql: "strftime('%Y-%m-%dT%H:%M:%fZ','now')" }, // '2012-12-03T07:16:23.574Z'
|
|
114
|
-
locale
|
|
115
|
-
},
|
|
116
|
-
model
|
|
117
|
-
)
|
|
118
|
-
|
|
119
|
-
return executeSelectSQL(
|
|
120
|
-
dbc,
|
|
121
|
-
sql,
|
|
122
|
-
values,
|
|
123
|
-
query.SELECT.one,
|
|
124
|
-
getPostProcessMapper(SQLITE_TYPE_CONVERSION_MAP, model, query)
|
|
125
|
-
)
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
function executeDeleteCQN(model, dbc, cqn, user, locale, txTimestamp) {
|
|
129
|
-
const { sql, values = [] } = sqlFactory(
|
|
130
|
-
cqn,
|
|
131
|
-
{
|
|
132
|
-
user,
|
|
133
|
-
customBuilder: CustomBuilder,
|
|
134
|
-
now: txTimestamp || { sql: "strftime('%Y-%m-%dT%H:%M:%fZ','now')" } // '2012-12-03T07:16:23.574Z'
|
|
135
|
-
},
|
|
136
|
-
model
|
|
137
|
-
)
|
|
138
|
-
|
|
139
|
-
return _executeSimpleSQL(dbc, sql, values)
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
const _executeBulkInsertSQL = (dbc, sql, values) =>
|
|
143
|
-
new Promise((resolve, reject) => {
|
|
144
|
-
if (!Array.isArray(values)) {
|
|
145
|
-
return reject(new Error(`Cannot execute SQL statement. Invalid values provided: ${inspect(values)}`))
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
LOG._debug && LOG.debug(sql, SANITIZE_VALUES ? ['***'] : values)
|
|
149
|
-
const stmt = _exec(dbc, 'prepare', sql, err => {
|
|
150
|
-
if (err) return reject(err)
|
|
151
|
-
|
|
152
|
-
// REVISIT: better?
|
|
153
|
-
if (dbc._closed) return reject(new Error('Transaction is already closed'))
|
|
154
|
-
|
|
155
|
-
if (!Array.isArray(values[0])) values = [values]
|
|
156
|
-
|
|
157
|
-
// guarantee order through counters in closure
|
|
158
|
-
let i = 0
|
|
159
|
-
let n = values.length
|
|
160
|
-
let isFinalized = false
|
|
161
|
-
const results = Array(n)
|
|
162
|
-
values.forEach(each => {
|
|
163
|
-
const k = i
|
|
164
|
-
i++
|
|
165
|
-
stmt.run(each, function (err) {
|
|
166
|
-
if (err) {
|
|
167
|
-
if (!isFinalized) {
|
|
168
|
-
isFinalized = true
|
|
169
|
-
stmt.finalize()
|
|
170
|
-
return reject(err)
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
// InsertResult needs an object per row with its values
|
|
175
|
-
results[k] = { lastID: this.lastID, affectedRows: 1, values: each }
|
|
176
|
-
n--
|
|
177
|
-
if (n === 0) {
|
|
178
|
-
if (!isFinalized) {
|
|
179
|
-
isFinalized = true
|
|
180
|
-
stmt.finalize()
|
|
181
|
-
resolve(results)
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
})
|
|
185
|
-
})
|
|
186
|
-
})
|
|
187
|
-
})
|
|
188
|
-
|
|
189
|
-
function executePlainSQL(dbc, sql, values, isOne, postMapper) {
|
|
190
|
-
// support named binding parameters
|
|
191
|
-
if (values && typeof values === 'object' && !Array.isArray(values)) {
|
|
192
|
-
values = new Proxy(values, {
|
|
193
|
-
getOwnPropertyDescriptor: (o, p) => Object.getOwnPropertyDescriptor(o, p.slice(1)),
|
|
194
|
-
get: (o, p) => o[p.slice(1)],
|
|
195
|
-
ownKeys: o => Reflect.ownKeys(o).map(k => `:${k}`)
|
|
196
|
-
})
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
if (/^\s*(select|pragma)/i.test(sql)) {
|
|
200
|
-
return executeSelectSQL(dbc, sql, values, isOne, postMapper)
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
if (/^\s*insert/i.test(sql) || /^\s*upsert/i.test(sql)) {
|
|
204
|
-
return executeInsertSQL(dbc, sql, values)
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
return _executeSimpleSQL(dbc, sql, values && Array.isArray(values[0]) ? values[0] : values)
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
function executeInsertSQL(dbc, sql, values, query) {
|
|
211
|
-
// Only bulk inserts will have arrays in arrays
|
|
212
|
-
if (Array.isArray(values[0])) {
|
|
213
|
-
if (values.length > 1) {
|
|
214
|
-
return _executeBulkInsertSQL(dbc, sql, values)
|
|
215
|
-
} else {
|
|
216
|
-
values = values[0]
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
LOG._debug && LOG.debug(sql, SANITIZE_VALUES ? ['***'] : values)
|
|
221
|
-
|
|
222
|
-
return new Promise((resolve, reject) => {
|
|
223
|
-
_exec(dbc, 'run', sql, values, function (err) {
|
|
224
|
-
if (err) return reject(err)
|
|
225
|
-
|
|
226
|
-
// InsertResult needs an object per row with its values
|
|
227
|
-
if (query && values.length > 0) {
|
|
228
|
-
// > single row via cqn
|
|
229
|
-
resolve([{ lastID: this.lastID, affectedRows: 1, values }])
|
|
230
|
-
} else {
|
|
231
|
-
// > plain sql or INSERT into SELECT
|
|
232
|
-
resolve([{ lastID: this.lastID, affectedRows: this.changes }])
|
|
233
|
-
}
|
|
234
|
-
})
|
|
235
|
-
})
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
// REVISIT: optimize - now sub-arrays are called sequentially
|
|
239
|
-
async function _convertStreamValues(values) {
|
|
240
|
-
let any
|
|
241
|
-
for (let i = 0; i < values.length; i++) {
|
|
242
|
-
const v = values[i]
|
|
243
|
-
if (v instanceof Readable) {
|
|
244
|
-
any = values[i] = new Promise(resolve => {
|
|
245
|
-
const chunks = []
|
|
246
|
-
v.on('data', chunk => chunks.push(chunk))
|
|
247
|
-
v.on('end', () => resolve(Buffer.concat(chunks)))
|
|
248
|
-
v.on('error', () => {
|
|
249
|
-
v.removeAllListeners('error')
|
|
250
|
-
v.push(null)
|
|
251
|
-
})
|
|
252
|
-
})
|
|
253
|
-
} else if (Array.isArray(v)) {
|
|
254
|
-
values[i] = await _convertStreamValues(v)
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
return any ? Promise.all(values) : values
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
async function executeInsertCQN(model, dbc, query, user, locale, txTimestamp) {
|
|
261
|
-
const { sql, values = [] } = sqlFactory(
|
|
262
|
-
query,
|
|
263
|
-
{
|
|
264
|
-
user,
|
|
265
|
-
customBuilder: CustomBuilder,
|
|
266
|
-
now: txTimestamp || { sql: "strftime('%Y-%m-%dT%H:%M:%fZ','now')" } // '2012-12-03T07:16:23.574Z'
|
|
267
|
-
},
|
|
268
|
-
model
|
|
269
|
-
)
|
|
270
|
-
const vals = await _convertStreamValues(values)
|
|
271
|
-
return executeInsertSQL(dbc, sql, vals, query)
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
async function executeUpdateCQN(model, dbc, cqn, user, locale, txTimestamp) {
|
|
275
|
-
const { sql, values = [] } = sqlFactory(
|
|
276
|
-
cqn,
|
|
277
|
-
{
|
|
278
|
-
user,
|
|
279
|
-
customBuilder: CustomBuilder,
|
|
280
|
-
now: txTimestamp || { sql: "strftime('%Y-%m-%dT%H:%M:%fZ','now')" } // '2012-12-03T07:16:23.574Z'
|
|
281
|
-
},
|
|
282
|
-
model
|
|
283
|
-
)
|
|
284
|
-
const vals = await _convertStreamValues(values)
|
|
285
|
-
return executePlainSQL(dbc, sql, vals)
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
// e. g. DROP, CREATE TABLE
|
|
289
|
-
function executeGenericCQN(model, dbc, cqn, user, locale, txTimestamp) {
|
|
290
|
-
const { sql, values } = sqlFactory(
|
|
291
|
-
cqn,
|
|
292
|
-
{
|
|
293
|
-
user,
|
|
294
|
-
customBuilder: CustomBuilder,
|
|
295
|
-
now: txTimestamp || { sql: "strftime('%Y-%m-%dT%H:%M:%fZ','now')" } // '2012-12-03T07:16:23.574Z'
|
|
296
|
-
},
|
|
297
|
-
model
|
|
298
|
-
)
|
|
299
|
-
|
|
300
|
-
return executePlainSQL(dbc, sql, values)
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
// REVISIT: consider deleting this function after removing stream_compat
|
|
304
|
-
async function executeSelectStreamCQN({ model, dbc, query, user, locale, txTimestamp }) {
|
|
305
|
-
let result = await executeSelectCQN(model, dbc, query, user, locale, txTimestamp)
|
|
306
|
-
|
|
307
|
-
if (result == null || result.length === 0) {
|
|
308
|
-
return
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
if (!cds.env.features.stream_compat) {
|
|
312
|
-
convertStream(query.SELECT.columns, query.target, result, query.SELECT.one)
|
|
313
|
-
return result
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
// REVISIT: following code to be deleted after cds.env.features.stream_compat is removed
|
|
317
|
-
if (Array.isArray(result)) result = result[0]
|
|
318
|
-
let [key, val] = Object.entries(result)[0]
|
|
319
|
-
if (val === null) {
|
|
320
|
-
return null
|
|
321
|
-
}
|
|
322
|
-
if (typeof val === 'number') {
|
|
323
|
-
val = val.toString()
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
const stream_ = new Readable()
|
|
327
|
-
stream_.push(val)
|
|
328
|
-
stream_.push(null)
|
|
329
|
-
|
|
330
|
-
result.value = stream_
|
|
331
|
-
delete result[key]
|
|
332
|
-
|
|
333
|
-
return result
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
module.exports = {
|
|
337
|
-
delete: executeDeleteCQN,
|
|
338
|
-
insert: executeInsertCQN,
|
|
339
|
-
update: executeUpdateCQN,
|
|
340
|
-
select: executeSelectCQN,
|
|
341
|
-
stream: executeSelectStreamCQN,
|
|
342
|
-
convert: convertStream,
|
|
343
|
-
cqn: executeGenericCQN,
|
|
344
|
-
sql: executePlainSQL
|
|
345
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
const { ensureUnlocalized } = require('../common/utils/draft')
|
|
2
|
-
const { redirect } = require('../db/utils/localized')
|
|
3
|
-
const cds = require('../cds')
|
|
4
|
-
const LOG = cds.log('sqlite|db|sql')
|
|
5
|
-
|
|
6
|
-
if (cds.env.i18n && Array.isArray(cds.env.i18n.for_sqlite) && !cds.env.i18n.for_sqlite.length) {
|
|
7
|
-
LOG._warn && LOG.warn('No language configuration found in cds.env.i18n.for_sqlite')
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const _translations = cds.env.i18n.for_sqlite.reduce((all, l) => ((all[l] = true), all), {})
|
|
11
|
-
|
|
12
|
-
// REVISIT: this is actually configurable
|
|
13
|
-
// there is no localized.en.<name>
|
|
14
|
-
const getLocalize = (locale, model) => name => {
|
|
15
|
-
if (name.endsWith('_drafts')) return name
|
|
16
|
-
|
|
17
|
-
// if we get here via onReadDraft, target is already localized
|
|
18
|
-
// because of subrequest using SELECT.from as new target
|
|
19
|
-
const target = model.definitions[ensureUnlocalized(name)]
|
|
20
|
-
if (target?.['@cds.localized'] === false) return name
|
|
21
|
-
|
|
22
|
-
const view = model.definitions[`localized${locale in _translations ? '.' + locale : ''}.${name}`]
|
|
23
|
-
return view?.name || name
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const sqliteLocalized = function (req) {
|
|
27
|
-
const { query } = req
|
|
28
|
-
|
|
29
|
-
// do simple checks upfront and exit early
|
|
30
|
-
if (!query || typeof query === 'string') return
|
|
31
|
-
if (!query.SELECT) return
|
|
32
|
-
if (!this.model) return
|
|
33
|
-
if (!req.locale) return
|
|
34
|
-
|
|
35
|
-
// suppress localization by instruction
|
|
36
|
-
if (query.SELECT.localized === false) return
|
|
37
|
-
|
|
38
|
-
// suppress localization for pure counts
|
|
39
|
-
const columns = query.SELECT.columns
|
|
40
|
-
if (columns && columns.length === 1 && columns[0].func === 'count') return
|
|
41
|
-
|
|
42
|
-
// suppress localization in "select for update" n/a for sqlite
|
|
43
|
-
|
|
44
|
-
redirect(query, getLocalize(req.locale, this.model))
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
sqliteLocalized._initial = true
|
|
48
|
-
|
|
49
|
-
module.exports = sqliteLocalized
|
package/libx/outbox/index.js
DELETED
|
@@ -1,307 +0,0 @@
|
|
|
1
|
-
const cds = require('../_runtime/cds')
|
|
2
|
-
const LOG = cds.log('persistent-outbox')
|
|
3
|
-
|
|
4
|
-
const { inspect } = require('util')
|
|
5
|
-
|
|
6
|
-
const OutboxRunner = require('./OutboxRunner')
|
|
7
|
-
const outboxRunner = new OutboxRunner()
|
|
8
|
-
|
|
9
|
-
const waitingTime = require('../_runtime/common/utils/waitingTime')
|
|
10
|
-
const { isStandardError } = require('../_runtime/common/error/standardError')
|
|
11
|
-
|
|
12
|
-
const cdsUser = 'cds.internal.user'
|
|
13
|
-
const $messageProcessorRegistered = Symbol('message processor registered')
|
|
14
|
-
const $outboxed = Symbol('outboxed')
|
|
15
|
-
const $unboxed = Symbol('unboxed')
|
|
16
|
-
const $stored_reqs = Symbol('stored_reqs')
|
|
17
|
-
|
|
18
|
-
const _get100NanosecondTimestampISOString = () => {
|
|
19
|
-
const [now, nanoseconds] = [new Date(), process.hrtime()[1]]
|
|
20
|
-
return now.toISOString().replace('Z', `${nanoseconds}`.padStart(9, '0').substring(3, 7) + 'Z')
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const _getMessagesEntity = () => {
|
|
24
|
-
const messagesDbName = 'cds.outbox.Messages'
|
|
25
|
-
const messagesEntity = cds.model.definitions[messagesDbName]
|
|
26
|
-
if (!messagesEntity)
|
|
27
|
-
throw new Error(`The entity '${messagesDbName}' is missing but needed for the persistent outbox.`)
|
|
28
|
-
return messagesEntity
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// REVISIT: Is this always a reliable way to identify the provider tenant?
|
|
32
|
-
// Are there scenarios where the credentials have a different format?
|
|
33
|
-
const _isProviderTenant = tenant =>
|
|
34
|
-
cds.requires.auth && cds.requires.auth.credentials && cds.requires.auth.credentials.identityzoneid === tenant || cds.requires.multitenancy.t0 === tenant
|
|
35
|
-
|
|
36
|
-
const hasPersistentOutbox = tenant => {
|
|
37
|
-
if (!cds.requires.outbox || cds.requires.outbox.kind !== 'persistent-outbox') return false
|
|
38
|
-
if (cds.requires.multitenancy && tenant && _isProviderTenant(tenant)) return false // no persistence for provider account
|
|
39
|
-
return true
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
const _safeJSONParse = string => {
|
|
43
|
-
try {
|
|
44
|
-
return string && JSON.parse(string)
|
|
45
|
-
} catch {
|
|
46
|
-
// Don't throw
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// Note: This function can also run for each tenant on startup
|
|
51
|
-
const processMessages = async (service, tenant, _opts = {}) => {
|
|
52
|
-
const opts = Object.assign({ attempt: 0 }, _opts)
|
|
53
|
-
const name = service.name
|
|
54
|
-
const messagesEntity = _getMessagesEntity()
|
|
55
|
-
|
|
56
|
-
outboxRunner.run({ name, tenant }, () => {
|
|
57
|
-
let letAppCrash = false
|
|
58
|
-
const config = tenant ? { tenant, user: cds.User.privileged } : { user: cds.User.privileged }
|
|
59
|
-
config.after = 1 // make sure spawn puts its cb on the `timer` queue (via setTimeout), which is also used by `outboxRunner`
|
|
60
|
-
const spawn = cds.spawn(async () => {
|
|
61
|
-
let messages
|
|
62
|
-
try {
|
|
63
|
-
const messagesQuery = SELECT.from(messagesEntity)
|
|
64
|
-
.where({ target: name })
|
|
65
|
-
.orderBy(['timestamp', 'ID'])
|
|
66
|
-
.limit(opts.chunkSize)
|
|
67
|
-
.forUpdate()
|
|
68
|
-
if (opts.maxAttempts) messagesQuery.where({ attempts: { '<': opts.maxAttempts } })
|
|
69
|
-
if (opts.parallel) messagesQuery.SELECT.forUpdate.ignoreLocked = true
|
|
70
|
-
messages = await messagesQuery
|
|
71
|
-
} catch (e) {
|
|
72
|
-
// could potentially be a timeout
|
|
73
|
-
const _waitingTime = waitingTime(opts.attempt)
|
|
74
|
-
LOG.error(`${name}: Message retrieval failed`, e, `Retrying in ${Math.round(_waitingTime / 1000)} s`)
|
|
75
|
-
outboxRunner.schedule(
|
|
76
|
-
{
|
|
77
|
-
name,
|
|
78
|
-
tenant,
|
|
79
|
-
waitingTime: _waitingTime
|
|
80
|
-
},
|
|
81
|
-
() => processMessages(service, tenant, { ...opts, attempt: opts.attempt + 1 })
|
|
82
|
-
)
|
|
83
|
-
return
|
|
84
|
-
}
|
|
85
|
-
let currMaxAttempts = 0
|
|
86
|
-
const messagesGen = function* () {
|
|
87
|
-
for (const _message of messages) {
|
|
88
|
-
const _msg = _safeJSONParse(_message.msg)
|
|
89
|
-
const userId = _msg[cdsUser]
|
|
90
|
-
const msg = _msg._fromSend ? new cds.Request(_msg) : new cds.Event(_msg)
|
|
91
|
-
delete msg._fromSend
|
|
92
|
-
Object.defineProperty(msg, '_fromOutbox', { value: true, enumerable: false })
|
|
93
|
-
delete msg[cdsUser]
|
|
94
|
-
currMaxAttempts = Math.max(_message.attempts || 0, currMaxAttempts)
|
|
95
|
-
const user = new cds.User.Privileged(userId)
|
|
96
|
-
if (!msg) continue
|
|
97
|
-
const res = {
|
|
98
|
-
ID: _message.ID,
|
|
99
|
-
msg,
|
|
100
|
-
user
|
|
101
|
-
}
|
|
102
|
-
yield res
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
const toBeDeleted = []
|
|
107
|
-
const toBeUpdated = []
|
|
108
|
-
try {
|
|
109
|
-
const _handleWithErr = async ({ msg, user, ID }) => {
|
|
110
|
-
try {
|
|
111
|
-
await cds._context.run({ user, tenant }, async () => {
|
|
112
|
-
if (opts.handle) await opts.handle.call(service, msg)
|
|
113
|
-
else await service.handle(msg)
|
|
114
|
-
})
|
|
115
|
-
toBeDeleted.push(ID)
|
|
116
|
-
} catch (e) {
|
|
117
|
-
if (isStandardError(e)) {
|
|
118
|
-
LOG.error(`${service.name}: Programming error detected:`, e)
|
|
119
|
-
toBeDeleted.push(ID)
|
|
120
|
-
throw new Error(`${service.name}: Programming error detected.`)
|
|
121
|
-
}
|
|
122
|
-
if (e.unrecoverable) {
|
|
123
|
-
LOG.error(`${service.name}: Unrecoverable error:`, e)
|
|
124
|
-
if (opts.maxAttempts) {
|
|
125
|
-
const _msg = { ID, attempts: opts.maxAttempts }
|
|
126
|
-
if (opts.storeLastError !== false) _msg.lastError = e
|
|
127
|
-
toBeUpdated.push(_msg)
|
|
128
|
-
} else toBeDeleted.push(ID)
|
|
129
|
-
} else {
|
|
130
|
-
LOG.error(`${service.name}: Emit failed:`, e)
|
|
131
|
-
const _msg = { ID }
|
|
132
|
-
if (opts.storeLastError !== false) _msg.lastError = e
|
|
133
|
-
toBeUpdated.push(_msg)
|
|
134
|
-
return false
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
const messages = messagesGen()
|
|
139
|
-
// REVISIT: Maybe we can also support handleMany and provide the iterator (for batch processing)
|
|
140
|
-
if (opts.parallel) {
|
|
141
|
-
const first = messages.next()?.value // First try to see if message can be emitted
|
|
142
|
-
if (!(first && (await _handleWithErr(first)) === false)) { // No need to process the rest if the first emit failed
|
|
143
|
-
const res = await Promise.allSettled([...messages].map(_handleWithErr))
|
|
144
|
-
const errors = res.filter(r => r.status === 'rejected').map(r => r.reason)
|
|
145
|
-
if (errors.length) {
|
|
146
|
-
throw new Error(`${service.name}: Programming errors detected.`)
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
} else {
|
|
150
|
-
for (const msg of messages) {
|
|
151
|
-
if ((await _handleWithErr(msg)) === false) break
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
} catch {
|
|
155
|
-
letAppCrash = true
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
const queries = []
|
|
159
|
-
const _waitingTime = waitingTime(currMaxAttempts)
|
|
160
|
-
if (toBeDeleted.length) queries.push(DELETE.from(messagesEntity).where('ID in', toBeDeleted))
|
|
161
|
-
if (toBeUpdated.length) {
|
|
162
|
-
for (const toBeUpdatedMsg of toBeUpdated) {
|
|
163
|
-
if (toBeDeleted.includes(toBeUpdatedMsg.ID)) continue
|
|
164
|
-
const data = {
|
|
165
|
-
attempts: { '+=': 1 }
|
|
166
|
-
}
|
|
167
|
-
Object.assign(data, toBeUpdatedMsg)
|
|
168
|
-
if (data.lastError && typeof data.lastError !== 'string') data.lastError = inspect(data.lastError)
|
|
169
|
-
queries.push(UPDATE(messagesEntity).where({ ID: toBeUpdatedMsg.ID }).set(data))
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
await Promise.all(queries)
|
|
174
|
-
|
|
175
|
-
if (letAppCrash) return
|
|
176
|
-
|
|
177
|
-
if (toBeUpdated.length) {
|
|
178
|
-
LOG.error(`${name}: Some messages could not be emitted, retrying in ${Math.round(_waitingTime / 1000)} s`)
|
|
179
|
-
return outboxRunner.schedule(
|
|
180
|
-
{
|
|
181
|
-
name,
|
|
182
|
-
tenant,
|
|
183
|
-
waitingTime: _waitingTime
|
|
184
|
-
},
|
|
185
|
-
() => processMessages(service, tenant, opts)
|
|
186
|
-
)
|
|
187
|
-
}
|
|
188
|
-
outboxRunner.success({ name, tenant })
|
|
189
|
-
if (toBeDeleted.length === opts.chunkSize) {
|
|
190
|
-
processMessages(service, tenant, opts) // We only processed max. opts.chunkSize, so there might be more
|
|
191
|
-
} else {
|
|
192
|
-
LOG._debug && LOG.debug(`${name}: All messages processed`)
|
|
193
|
-
}
|
|
194
|
-
}, config)
|
|
195
|
-
spawn.on('done', () => {
|
|
196
|
-
if (letAppCrash) cds.exit(1)
|
|
197
|
-
outboxRunner.end({ name, tenant }, () => processMessages(service, tenant, opts))
|
|
198
|
-
})
|
|
199
|
-
})
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
const registerMessageProcessor = (name, context) => {
|
|
203
|
-
const registry = context[$messageProcessorRegistered] || (context[$messageProcessorRegistered] = new Set())
|
|
204
|
-
if (!registry.has(name)) {
|
|
205
|
-
registry.add(name)
|
|
206
|
-
return true
|
|
207
|
-
}
|
|
208
|
-
return false
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
const _createMessage = (name, msg, context) => {
|
|
212
|
-
const _msg = { [cdsUser]: context.user.id }
|
|
213
|
-
if (msg._fromSend || msg.reply) _msg._fromSend = true // send or emit?
|
|
214
|
-
if (msg.inbound) _msg.inbound = msg.inbound
|
|
215
|
-
if (msg.event) _msg.event = msg.event
|
|
216
|
-
if (msg.data) _msg.data = msg.data
|
|
217
|
-
if (msg.headers) _msg.headers = msg.headers
|
|
218
|
-
if (msg.query) _msg.query = msg.query
|
|
219
|
-
const outboxMsg = {
|
|
220
|
-
ID: cds.utils.uuid(),
|
|
221
|
-
target: name,
|
|
222
|
-
timestamp: _get100NanosecondTimestampISOString(), // needs to be different for each emit
|
|
223
|
-
msg: JSON.stringify(_msg)
|
|
224
|
-
}
|
|
225
|
-
return outboxMsg
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
const writeInOutbox = async (name, msg, context) => {
|
|
229
|
-
const outboxMsg = _createMessage(name, msg, context)
|
|
230
|
-
const messagesEntity = _getMessagesEntity()
|
|
231
|
-
return cds.tx(context).run(INSERT.into(messagesEntity).entries(outboxMsg))
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
function unboxed(srv) {
|
|
235
|
-
return srv[$unboxed] || srv
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
function outboxed(srv, customOpts) {
|
|
239
|
-
// outbox max. once
|
|
240
|
-
if (!new.target) {
|
|
241
|
-
const former = srv[$outboxed]
|
|
242
|
-
if (former) return former
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
const originalSrv = srv[$unboxed] || srv
|
|
246
|
-
const outboxedSrv = Object.create(originalSrv)
|
|
247
|
-
outboxedSrv[$unboxed] = originalSrv
|
|
248
|
-
|
|
249
|
-
if (!new.target) Object.defineProperty(srv, $outboxed, { value: outboxedSrv })
|
|
250
|
-
|
|
251
|
-
let requiresOpts = cds.requires.outbox
|
|
252
|
-
let serviceOpts = srv.options?.outbox
|
|
253
|
-
|
|
254
|
-
if (typeof requiresOpts === 'string') requiresOpts = { kind: requiresOpts }
|
|
255
|
-
if (typeof serviceOpts === 'string') serviceOpts = { kind: serviceOpts }
|
|
256
|
-
|
|
257
|
-
const outboxOpts = Object.assign(
|
|
258
|
-
{},
|
|
259
|
-
(typeof requiresOpts === 'object' && requiresOpts) || {},
|
|
260
|
-
(typeof serviceOpts === 'object' && serviceOpts) || {},
|
|
261
|
-
customOpts || {}
|
|
262
|
-
)
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
outboxedSrv.handle = async function (req) {
|
|
266
|
-
const context = req.context || cds.context
|
|
267
|
-
if (outboxOpts.kind === 'persistent-outbox' && hasPersistentOutbox(context.tenant)) {
|
|
268
|
-
// returns true if not yet registered
|
|
269
|
-
if (registerMessageProcessor(srv.name, context)) {
|
|
270
|
-
// NOTE: What if there are different outbox options for the same service?!
|
|
271
|
-
// There could be messages for srv1 with { maxAttempts: 1 }
|
|
272
|
-
// and messages for srv1 with { maxAttempts: 9 }.
|
|
273
|
-
// How would they be processed? I'd rather not have dedicated
|
|
274
|
-
// service names or store serialized options for each message.
|
|
275
|
-
context.on('succeeded', () => processMessages(originalSrv, context.tenant, outboxOpts))
|
|
276
|
-
}
|
|
277
|
-
await writeInOutbox(srv.name, req, context)
|
|
278
|
-
return
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
if (!context[$stored_reqs]) {
|
|
282
|
-
context[$stored_reqs] = []
|
|
283
|
-
context.on('succeeded', async () => {
|
|
284
|
-
// REVISIT: Also allow maxAttempts for in-memory outbox?
|
|
285
|
-
for (const _req of context[$stored_reqs]) {
|
|
286
|
-
try {
|
|
287
|
-
if (_req.reply) await originalSrv.send(_req)
|
|
288
|
-
else await originalSrv.emit(_req)
|
|
289
|
-
} catch (e) {
|
|
290
|
-
LOG.error('Emit failed', { event: _req.event, cause: e })
|
|
291
|
-
if (isStandardError(e)) {
|
|
292
|
-
cds.log().error('❗️Uncaught', e)
|
|
293
|
-
await cds.shutdown(e)
|
|
294
|
-
return
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
delete context[$stored_reqs]
|
|
299
|
-
})
|
|
300
|
-
}
|
|
301
|
-
context[$stored_reqs].push(req)
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
return outboxedSrv
|
|
305
|
-
}
|
|
306
|
-
|
|
307
|
-
module.exports = { outboxed, unboxed }
|