@elsikora/nestjs-crud-automator 1.24.0-dev.1 → 2.0.0-dev.1
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/README.md +213 -163
- package/dist/cjs/class/api/authorization/bootstrap-validation.service.class.d.ts +1 -0
- package/dist/cjs/class/api/authorization/bootstrap-validation.service.class.js +37 -3
- package/dist/cjs/class/api/authorization/bootstrap-validation.service.class.js.map +1 -1
- package/dist/cjs/class/api/authorization/cache-invalidation.service.class.d.ts +7 -0
- package/dist/cjs/class/api/authorization/cache-invalidation.service.class.js +21 -0
- package/dist/cjs/class/api/authorization/cache-invalidation.service.class.js.map +1 -0
- package/dist/cjs/class/api/authorization/guard.class.d.ts +1 -2
- package/dist/cjs/class/api/authorization/guard.class.js +13 -18
- package/dist/cjs/class/api/authorization/guard.class.js.map +1 -1
- package/dist/cjs/class/api/authorization/index.d.ts +1 -0
- package/dist/cjs/class/api/authorization/policy/executor.class.js +1 -2
- package/dist/cjs/class/api/authorization/policy/executor.class.js.map +1 -1
- package/dist/cjs/class/api/authorization/policy/index.d.ts +1 -0
- package/dist/cjs/class/api/authorization/policy/registry.class.d.ts +3 -5
- package/dist/cjs/class/api/authorization/policy/registry.class.js +11 -34
- package/dist/cjs/class/api/authorization/policy/registry.class.js.map +1 -1
- package/dist/cjs/class/api/authorization/policy/subscriber-wrapper.class.d.ts +10 -0
- package/dist/cjs/class/api/authorization/policy/subscriber-wrapper.class.js +23 -0
- package/dist/cjs/class/api/authorization/policy/subscriber-wrapper.class.js.map +1 -0
- package/dist/cjs/class/api/authorization/runtime.class.d.ts +3 -2
- package/dist/cjs/class/api/authorization/runtime.class.js +6 -5
- package/dist/cjs/class/api/authorization/runtime.class.js.map +1 -1
- package/dist/cjs/class/api/authorization/simulator.class.d.ts +2 -0
- package/dist/cjs/class/api/authorization/simulator.class.js +1 -0
- package/dist/cjs/class/api/authorization/simulator.class.js.map +1 -1
- package/dist/cjs/class/api/function/context-storage.class.d.ts +7 -0
- package/dist/cjs/class/api/function/context-storage.class.js +16 -0
- package/dist/cjs/class/api/function/context-storage.class.js.map +1 -0
- package/dist/cjs/class/api/function/custom-runtime.class.d.ts +19 -0
- package/dist/cjs/class/api/function/custom-runtime.class.js +118 -0
- package/dist/cjs/class/api/function/custom-runtime.class.js.map +1 -0
- package/dist/cjs/class/api/function/index.d.ts +1 -0
- package/dist/cjs/class/api/function/transaction-scope.class.d.ts +6 -0
- package/dist/cjs/class/api/function/transaction-scope.class.js +34 -0
- package/dist/cjs/class/api/function/transaction-scope.class.js.map +1 -0
- package/dist/cjs/class/api/index.d.ts +2 -0
- package/dist/cjs/class/api/route-runtime.class.d.ts +21 -0
- package/dist/cjs/class/api/route-runtime.class.js +335 -0
- package/dist/cjs/class/api/route-runtime.class.js.map +1 -0
- package/dist/cjs/class/api/service-base.class.d.ts +9 -7
- package/dist/cjs/class/api/service-base.class.js +16 -6
- package/dist/cjs/class/api/service-base.class.js.map +1 -1
- package/dist/cjs/class/api/subscriber/executor.class.d.ts +7 -6
- package/dist/cjs/class/api/subscriber/executor.class.js +16 -12
- package/dist/cjs/class/api/subscriber/executor.class.js.map +1 -1
- package/dist/cjs/class/api/subscriber/index.d.ts +1 -0
- package/dist/cjs/class/api/subscriber/registry.class.d.ts +5 -2
- package/dist/cjs/class/api/subscriber/registry.class.js +26 -24
- package/dist/cjs/class/api/subscriber/registry.class.js.map +1 -1
- package/dist/cjs/class/api/subscriber/wrapper.class.d.ts +18 -0
- package/dist/cjs/class/api/subscriber/wrapper.class.js +23 -0
- package/dist/cjs/class/api/subscriber/wrapper.class.js.map +1 -0
- package/dist/cjs/class/utility/dto/exception/details/foreign-key-violation.class.js +5 -1
- package/dist/cjs/class/utility/dto/exception/details/foreign-key-violation.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/exception/details/unique-violation.class.js +5 -1
- package/dist/cjs/class/utility/dto/exception/details/unique-violation.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/property/factory/number.class.js +6 -2
- package/dist/cjs/class/utility/dto/property/factory/number.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/property/factory/relation.class.js +5 -1
- package/dist/cjs/class/utility/dto/property/factory/relation.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/strategy/body.class.js +5 -1
- package/dist/cjs/class/utility/dto/strategy/body.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/strategy/query.class.js +5 -1
- package/dist/cjs/class/utility/dto/strategy/query.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/strategy/request.class.js +5 -1
- package/dist/cjs/class/utility/dto/strategy/request.class.js.map +1 -1
- package/dist/cjs/class/utility/dto/strategy/response.class.js +5 -1
- package/dist/cjs/class/utility/dto/strategy/response.class.js.map +1 -1
- package/dist/cjs/constant/decorator/api/method.constant.d.ts +2 -3
- package/dist/cjs/constant/decorator/api/method.constant.js +4 -6
- package/dist/cjs/constant/decorator/api/method.constant.js.map +1 -1
- package/dist/cjs/constant/utility/dto/constant.js +6 -2
- package/dist/cjs/constant/utility/dto/constant.js.map +1 -1
- package/dist/cjs/decorator/api/function/create.decorator.js +51 -24
- package/dist/cjs/decorator/api/function/create.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/custom.decorator.d.ts +9 -0
- package/dist/cjs/decorator/api/function/custom.decorator.js +47 -0
- package/dist/cjs/decorator/api/function/custom.decorator.js.map +1 -0
- package/dist/cjs/decorator/api/function/decorator.js +16 -7
- package/dist/cjs/decorator/api/function/decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/delete.decorator.js +62 -41
- package/dist/cjs/decorator/api/function/delete.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/get/decorator.js +40 -25
- package/dist/cjs/decorator/api/function/get/decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/get/list.decorator.js +40 -25
- package/dist/cjs/decorator/api/function/get/list.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/get/many.decorator.js +40 -25
- package/dist/cjs/decorator/api/function/get/many.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/function/index.d.ts +1 -0
- package/dist/cjs/decorator/api/function/update.decorator.js +62 -41
- package/dist/cjs/decorator/api/function/update.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/index.d.ts +1 -0
- package/dist/cjs/decorator/api/method.decorator.d.ts +5 -6
- package/dist/cjs/decorator/api/method.decorator.js +65 -325
- package/dist/cjs/decorator/api/method.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/boolean.decorator.js +23 -4
- package/dist/cjs/decorator/api/property/boolean.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/date.decorator.js +23 -4
- package/dist/cjs/decorator/api/property/date.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/enum.decorator.js +21 -3
- package/dist/cjs/decorator/api/property/enum.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/number.decorator.js +28 -5
- package/dist/cjs/decorator/api/property/number.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/object.decorator.js +21 -3
- package/dist/cjs/decorator/api/property/object.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/string.decorator.js +25 -8
- package/dist/cjs/decorator/api/property/string.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/property/uuid.decorator.js +26 -4
- package/dist/cjs/decorator/api/property/uuid.decorator.js.map +1 -1
- package/dist/cjs/decorator/api/route-custom.decorator.d.ts +9 -0
- package/dist/cjs/decorator/api/route-custom.decorator.js +101 -0
- package/dist/cjs/decorator/api/route-custom.decorator.js.map +1 -0
- package/dist/cjs/decorator/api/service/decorator.js +28 -23
- package/dist/cjs/decorator/api/service/decorator.js.map +1 -1
- package/dist/cjs/enum/decorator/api/controller/index.d.ts +3 -1
- package/dist/cjs/enum/decorator/api/controller/relation-reference-shape.enum.d.ts +4 -0
- package/dist/cjs/enum/decorator/api/controller/relation-reference-shape.enum.js +8 -0
- package/dist/cjs/enum/decorator/api/controller/relation-reference-shape.enum.js.map +1 -0
- package/dist/cjs/enum/decorator/api/controller/request/index.d.ts +2 -0
- package/dist/cjs/enum/decorator/api/controller/request/target.enum.d.ts +5 -0
- package/dist/cjs/enum/decorator/api/controller/request/target.enum.js +9 -0
- package/dist/cjs/enum/decorator/api/controller/request/target.enum.js.map +1 -0
- package/dist/cjs/enum/decorator/api/controller/{request-transformer-type.enum.js → request/transformer-type.enum.js} +1 -1
- package/dist/cjs/enum/decorator/api/controller/request/transformer-type.enum.js.map +1 -0
- package/dist/cjs/enum/decorator/api/controller/response-target.enum.d.ts +3 -0
- package/dist/cjs/enum/decorator/api/controller/response-target.enum.js +7 -0
- package/dist/cjs/enum/decorator/api/controller/response-target.enum.js.map +1 -0
- package/dist/cjs/enum/decorator/api/dto-type.enum.d.ts +1 -1
- package/dist/cjs/enum/decorator/api/dto-type.enum.js +1 -1
- package/dist/cjs/enum/decorator/api/dto-type.enum.js.map +1 -1
- package/dist/cjs/enum/decorator/api/function-transaction-mode.enum.d.ts +6 -0
- package/dist/cjs/enum/decorator/api/function-transaction-mode.enum.js +10 -0
- package/dist/cjs/enum/decorator/api/function-transaction-mode.enum.js.map +1 -0
- package/dist/cjs/enum/decorator/api/function-type.enum.d.ts +1 -0
- package/dist/cjs/enum/decorator/api/function-type.enum.js +1 -0
- package/dist/cjs/enum/decorator/api/function-type.enum.js.map +1 -1
- package/dist/cjs/enum/decorator/api/index.d.ts +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Observable.js +106 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Observable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Subscriber.js +158 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Subscriber.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Subscription.js +148 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/Subscription.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/config.js +7 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/config.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/lastValueFrom.js +28 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/lastValueFrom.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/observable/from.js +11 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/observable/from.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/observable/innerFrom.js +154 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/observable/innerFrom.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/OperatorSubscriber.js +66 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/OperatorSubscriber.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/observeOn.js +15 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/observeOn.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/subscribeOn.js +13 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/operators/subscribeOn.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleArray.js +23 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleArray.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleAsyncIterable.js +28 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleAsyncIterable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleIterable.js +37 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleIterable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleObservable.js +12 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleObservable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/schedulePromise.js +12 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/schedulePromise.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleReadableStreamLike.js +11 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduleReadableStreamLike.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduled.js +42 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduled/scheduled.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduler/timeoutProvider.js +20 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/scheduler/timeoutProvider.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/symbol/iterator.js +13 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/symbol/iterator.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/symbol/observable.js +6 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/symbol/observable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/EmptyError.js +14 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/EmptyError.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/UnsubscriptionError.js +17 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/UnsubscriptionError.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/arrRemove.js +11 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/arrRemove.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/createErrorClass.js +15 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/createErrorClass.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/errorContext.js +10 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/errorContext.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/executeSchedule.js +22 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/executeSchedule.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/identity.js +8 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/identity.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isArrayLike.js +6 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isArrayLike.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isAsyncIterable.js +10 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isAsyncIterable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isFunction.js +8 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isFunction.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isInteropObservable.js +11 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isInteropObservable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isIterable.js +11 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isIterable.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isPromise.js +10 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isPromise.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isReadableStreamLike.js +44 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/isReadableStreamLike.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/lift.js +26 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/lift.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/noop.js +6 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/noop.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/pipe.js +18 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/pipe.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/reportUnhandledError.js +14 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/reportUnhandledError.js.map +1 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/throwUnobservableError.js +8 -0
- package/dist/cjs/external/rxjs/dist/esm5/internal/util/throwUnobservableError.js.map +1 -0
- package/dist/cjs/external/tslib/tslib.es6.js +125 -0
- package/dist/cjs/external/tslib/tslib.es6.js.map +1 -1
- package/dist/cjs/factory/api-controller.factory.d.ts +1 -0
- package/dist/cjs/factory/api-controller.factory.js +42 -393
- package/dist/cjs/factory/api-controller.factory.js.map +1 -1
- package/dist/cjs/index.js +45 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/interceptor/api-route-runtime.interceptor.d.ts +5 -0
- package/dist/cjs/interceptor/api-route-runtime.interceptor.js +29 -0
- package/dist/cjs/interceptor/api-route-runtime.interceptor.js.map +1 -0
- package/dist/cjs/interface/class/api/authorization/policy/registry.interface.d.ts +1 -0
- package/dist/cjs/interface/class/api/authorization/policy/subscriber/context/interface.d.ts +1 -1
- package/dist/cjs/interface/class/api/function/context/index.d.ts +2 -0
- package/dist/cjs/interface/class/api/function/context/interface.d.ts +10 -0
- package/dist/cjs/interface/class/api/function/context/operations.interface.d.ts +13 -0
- package/dist/cjs/interface/class/api/function/index.d.ts +1 -0
- package/dist/cjs/interface/class/api/index.d.ts +2 -0
- package/dist/cjs/interface/class/api/route/index.d.ts +1 -0
- package/dist/cjs/interface/class/api/route/runtime/context-data.interface.d.ts +10 -0
- package/dist/cjs/interface/class/api/route/runtime/custom-execution-options.interface.d.ts +9 -0
- package/dist/cjs/interface/class/api/route/runtime/generated/execution-options.interface.d.ts +14 -0
- package/dist/cjs/interface/class/api/route/runtime/generated/index.d.ts +2 -0
- package/dist/cjs/interface/class/api/route/runtime/generated/targets.interface.d.ts +12 -0
- package/dist/cjs/interface/class/api/route/runtime/http-request.interface.d.ts +8 -0
- package/dist/cjs/interface/class/api/route/runtime/index.d.ts +4 -0
- package/dist/cjs/interface/class/api/subscriber/function/error-execution-context.interface.d.ts +1 -0
- package/dist/cjs/interface/class/api/subscriber/function/execution/context.interface.d.ts +1 -0
- package/dist/cjs/interface/class/api/subscriber/function.interface.d.ts +4 -0
- package/dist/cjs/interface/class/api/subscriber/route/error-execution-context.interface.d.ts +2 -1
- package/dist/cjs/interface/class/api/subscriber/route/execution/context/data/extended.interface.d.ts +36 -0
- package/dist/cjs/interface/class/api/subscriber/route/execution/context/data/index.d.ts +2 -0
- package/dist/cjs/interface/class/api/subscriber/route/execution/context/data/interface.d.ts +32 -0
- package/dist/cjs/interface/class/api/subscriber/route/execution/context/index.d.ts +2 -0
- package/dist/cjs/interface/class/api/subscriber/route/execution/context/interface.d.ts +11 -0
- package/dist/cjs/interface/class/api/subscriber/route/execution/index.d.ts +1 -2
- package/dist/cjs/interface/class/api/subscriber/route.interface.d.ts +6 -2
- package/dist/cjs/interface/decorator/api/controller/properties/route/authentication.interface.d.ts +1 -1
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/generation.interface.d.ts +5 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/index.d.ts +5 -2
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/interface.d.ts +4 -7
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/index.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/reference.interface.d.ts +5 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/request/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/request/interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/request/load.interface.d.ts +10 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/response/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/response/interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/relations/response/load.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/request/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/request/interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/request/target.interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/response/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/response/interface.d.ts +7 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/response/target.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/security.interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/controller/properties/route/with/dto.interface.d.ts +1 -1
- package/dist/cjs/interface/decorator/api/function/create-executor-properties.interface.d.ts +1 -2
- package/dist/cjs/interface/decorator/api/function/custom-properties.interface.d.ts +9 -0
- package/dist/cjs/interface/decorator/api/function/delete-executor-properties.interface.d.ts +2 -3
- package/dist/cjs/interface/decorator/api/function/get/executor-properties.interface.d.ts +1 -2
- package/dist/cjs/interface/decorator/api/function/get/list-executor-properties.interface.d.ts +1 -2
- package/dist/cjs/interface/decorator/api/function/get/many-executor-properties.interface.d.ts +1 -2
- package/dist/cjs/interface/decorator/api/function/index.d.ts +1 -0
- package/dist/cjs/interface/decorator/api/function/properties.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/function/update-executor-properties.interface.d.ts +2 -3
- package/dist/cjs/interface/decorator/api/index.d.ts +1 -0
- package/dist/cjs/interface/decorator/api/method/index.d.ts +0 -2
- package/dist/cjs/interface/decorator/api/method/properties.interface.d.ts +4 -17
- package/dist/cjs/interface/decorator/api/route/custom-properties.interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/route/documentation-properties.interface.d.ts +5 -0
- package/dist/cjs/interface/decorator/api/route/index.d.ts +7 -0
- package/dist/cjs/interface/decorator/api/route/metadata/index.d.ts +3 -0
- package/dist/cjs/interface/decorator/api/route/metadata/interface.d.ts +15 -0
- package/dist/cjs/interface/decorator/api/route/metadata/resource.interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/route/metadata/route.interface.d.ts +7 -0
- package/dist/cjs/interface/decorator/api/route/response/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/route/response/properties.interface.d.ts +9 -0
- package/dist/cjs/interface/decorator/api/route/response/serialization-properties.interface.d.ts +3 -0
- package/dist/cjs/interface/decorator/api/route/runtime-properties.interface.d.ts +11 -0
- package/dist/cjs/interface/decorator/api/route/security/authentication-properties.interface.d.ts +9 -0
- package/dist/cjs/interface/decorator/api/route/security/authorization-properties.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/route/security/index.d.ts +3 -0
- package/dist/cjs/interface/decorator/api/route/security/properties.interface.d.ts +6 -0
- package/dist/cjs/interface/decorator/api/route/throttling/default-properties.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/route/throttling/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/route/throttling/properties.interface.d.ts +4 -0
- package/dist/cjs/interface/decorator/api/subscriber/function/filter.interface.d.ts +5 -0
- package/dist/cjs/interface/decorator/api/subscriber/function/index.d.ts +2 -0
- package/dist/cjs/interface/decorator/api/subscriber/function/properties.interface.d.ts +7 -0
- package/dist/cjs/interface/decorator/api/subscriber/index.d.ts +2 -2
- package/dist/cjs/interface/decorator/api/subscriber/route-properties.interface.d.ts +4 -0
- package/dist/cjs/module/api/authorization.module.js +18 -1
- package/dist/cjs/module/api/authorization.module.js.map +1 -1
- package/dist/cjs/package.json +0 -1
- package/dist/cjs/type/class/api/subscriber/route/after/create-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/after/delete-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/after/get/context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/after/get/list-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/after/partial-update-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/after/update-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/create-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/delete-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/get/context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/get/list-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/partial-update-context.type.d.ts +2 -2
- package/dist/cjs/type/class/api/subscriber/route/before/update-context.type.d.ts +2 -2
- package/dist/cjs/type/decorator/api/controller/properties/route/base/request/allowed-target.type.d.ts +9 -0
- package/dist/cjs/type/decorator/api/controller/properties/route/base/request/index.d.ts +1 -1
- package/dist/cjs/type/decorator/api/controller/properties/route/base/request/transformers.type.d.ts +7 -7
- package/dist/cjs/type/decorator/api/controller/properties/route/base/response-transformers.type.d.ts +6 -6
- package/dist/cjs/type/decorator/api/controller/transformer-config.type.d.ts +5 -5
- package/dist/cjs/type/decorator/api/function/properties.type.d.ts +5 -3
- package/dist/cjs/type/decorator/api/property/describe/dto/request-properties.type.d.ts +1 -1
- package/dist/cjs/type/decorator/api/property/describe/properties/base/properties.type.d.ts +4 -4
- package/dist/cjs/type/utility/dto/generate/allowed-combination.type.d.ts +4 -4
- package/dist/cjs/utility/api/controller/apply/decorators.utility.js +58 -26
- package/dist/cjs/utility/api/controller/apply/decorators.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/apply/metadata.utility.js +6 -2
- package/dist/cjs/utility/api/controller/apply/metadata.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/get/dto.utility.js +6 -2
- package/dist/cjs/utility/api/controller/get/dto.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/get-list/transform/filter.utility.js +5 -1
- package/dist/cjs/utility/api/controller/get-list/transform/filter.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/handle-request-relations.utility.d.ts +4 -4
- package/dist/cjs/utility/api/controller/handle-request-relations.utility.js +37 -11
- package/dist/cjs/utility/api/controller/handle-request-relations.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/index.d.ts +1 -0
- package/dist/cjs/utility/api/controller/serialize-route-response.utility.d.ts +14 -0
- package/dist/cjs/utility/api/controller/serialize-route-response.utility.js +29 -0
- package/dist/cjs/utility/api/controller/serialize-route-response.utility.js.map +1 -0
- package/dist/cjs/utility/api/controller/transform-data.utility.d.ts +8 -7
- package/dist/cjs/utility/api/controller/transform-data.utility.js +21 -18
- package/dist/cjs/utility/api/controller/transform-data.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/validate-request.utility.d.ts +3 -3
- package/dist/cjs/utility/api/controller/validate-request.utility.js +10 -9
- package/dist/cjs/utility/api/controller/validate-request.utility.js.map +1 -1
- package/dist/cjs/utility/api/controller/write/dto-swagger.utility.js +6 -2
- package/dist/cjs/utility/api/controller/write/dto-swagger.utility.js.map +1 -1
- package/dist/cjs/utility/api/function-transaction.utility.d.ts +20 -0
- package/dist/cjs/utility/api/function-transaction.utility.js +52 -0
- package/dist/cjs/utility/api/function-transaction.utility.js.map +1 -0
- package/dist/cjs/utility/api/index.d.ts +1 -0
- package/dist/cjs/utility/api/route/index.d.ts +1 -0
- package/dist/cjs/utility/api/route/response/index.d.ts +2 -0
- package/dist/cjs/utility/api/route/response/project-relation.utility.d.ts +11 -0
- package/dist/cjs/utility/api/route/response/project-relation.utility.js +75 -0
- package/dist/cjs/utility/api/route/response/project-relation.utility.js.map +1 -0
- package/dist/cjs/utility/api/route/response/serialize.utility.d.ts +11 -0
- package/dist/cjs/utility/api/route/response/serialize.utility.js +26 -0
- package/dist/cjs/utility/api/route/response/serialize.utility.js.map +1 -0
- package/dist/cjs/utility/dto/build-decorator.utility.js +5 -1
- package/dist/cjs/utility/dto/build-decorator.utility.js.map +1 -1
- package/dist/cjs/utility/dto/generate/core.utility.js +5 -1
- package/dist/cjs/utility/dto/generate/core.utility.js.map +1 -1
- package/dist/cjs/utility/dto/generate/dynamic.utility.js +5 -1
- package/dist/cjs/utility/dto/generate/dynamic.utility.js.map +1 -1
- package/dist/cjs/utility/dto/generate/exception.utility.js +5 -1
- package/dist/cjs/utility/dto/generate/exception.utility.js.map +1 -1
- package/dist/cjs/utility/dto/generate/filter-decorator.utility.js +5 -1
- package/dist/cjs/utility/dto/generate/filter-decorator.utility.js.map +1 -1
- package/dist/cjs/utility/dto/generate/get-list-response.utility.js +5 -1
- package/dist/cjs/utility/dto/generate/get-list-response.utility.js.map +1 -1
- package/dist/cjs/utility/dto/get/get-list-query-base-class.utility.js +5 -1
- package/dist/cjs/utility/dto/get/get-list-query-base-class.utility.js.map +1 -1
- package/dist/cjs/utility/dto/handle-date-property.utility.js +5 -1
- package/dist/cjs/utility/dto/handle-date-property.utility.js.map +1 -1
- package/dist/cjs/utility/dto/is/property/should-be-marked.utility.js +7 -3
- package/dist/cjs/utility/dto/is/property/should-be-marked.utility.js.map +1 -1
- package/dist/cjs/utility/dto/is/should-be-generated.utility.js +8 -4
- package/dist/cjs/utility/dto/is/should-be-generated.utility.js.map +1 -1
- package/dist/esm/class/api/authorization/bootstrap-validation.service.class.d.ts +1 -0
- package/dist/esm/class/api/authorization/bootstrap-validation.service.class.js +37 -3
- package/dist/esm/class/api/authorization/bootstrap-validation.service.class.js.map +1 -1
- package/dist/esm/class/api/authorization/cache-invalidation.service.class.d.ts +7 -0
- package/dist/esm/class/api/authorization/cache-invalidation.service.class.js +21 -0
- package/dist/esm/class/api/authorization/cache-invalidation.service.class.js.map +1 -0
- package/dist/esm/class/api/authorization/guard.class.d.ts +1 -2
- package/dist/esm/class/api/authorization/guard.class.js +13 -18
- package/dist/esm/class/api/authorization/guard.class.js.map +1 -1
- package/dist/esm/class/api/authorization/index.d.ts +1 -0
- package/dist/esm/class/api/authorization/policy/executor.class.js +1 -2
- package/dist/esm/class/api/authorization/policy/executor.class.js.map +1 -1
- package/dist/esm/class/api/authorization/policy/index.d.ts +1 -0
- package/dist/esm/class/api/authorization/policy/registry.class.d.ts +3 -5
- package/dist/esm/class/api/authorization/policy/registry.class.js +10 -33
- package/dist/esm/class/api/authorization/policy/registry.class.js.map +1 -1
- package/dist/esm/class/api/authorization/policy/subscriber-wrapper.class.d.ts +10 -0
- package/dist/esm/class/api/authorization/policy/subscriber-wrapper.class.js +21 -0
- package/dist/esm/class/api/authorization/policy/subscriber-wrapper.class.js.map +1 -0
- package/dist/esm/class/api/authorization/runtime.class.d.ts +3 -2
- package/dist/esm/class/api/authorization/runtime.class.js +6 -5
- package/dist/esm/class/api/authorization/runtime.class.js.map +1 -1
- package/dist/esm/class/api/authorization/simulator.class.d.ts +2 -0
- package/dist/esm/class/api/authorization/simulator.class.js +1 -0
- package/dist/esm/class/api/authorization/simulator.class.js.map +1 -1
- package/dist/esm/class/api/function/context-storage.class.d.ts +7 -0
- package/dist/esm/class/api/function/context-storage.class.js +14 -0
- package/dist/esm/class/api/function/context-storage.class.js.map +1 -0
- package/dist/esm/class/api/function/custom-runtime.class.d.ts +19 -0
- package/dist/esm/class/api/function/custom-runtime.class.js +116 -0
- package/dist/esm/class/api/function/custom-runtime.class.js.map +1 -0
- package/dist/esm/class/api/function/index.d.ts +1 -0
- package/dist/esm/class/api/function/transaction-scope.class.d.ts +6 -0
- package/dist/esm/class/api/function/transaction-scope.class.js +32 -0
- package/dist/esm/class/api/function/transaction-scope.class.js.map +1 -0
- package/dist/esm/class/api/index.d.ts +2 -0
- package/dist/esm/class/api/route-runtime.class.d.ts +21 -0
- package/dist/esm/class/api/route-runtime.class.js +333 -0
- package/dist/esm/class/api/route-runtime.class.js.map +1 -0
- package/dist/esm/class/api/service-base.class.d.ts +9 -7
- package/dist/esm/class/api/service-base.class.js +16 -6
- package/dist/esm/class/api/service-base.class.js.map +1 -1
- package/dist/esm/class/api/subscriber/executor.class.d.ts +7 -6
- package/dist/esm/class/api/subscriber/executor.class.js +16 -12
- package/dist/esm/class/api/subscriber/executor.class.js.map +1 -1
- package/dist/esm/class/api/subscriber/index.d.ts +1 -0
- package/dist/esm/class/api/subscriber/registry.class.d.ts +5 -2
- package/dist/esm/class/api/subscriber/registry.class.js +24 -22
- package/dist/esm/class/api/subscriber/registry.class.js.map +1 -1
- package/dist/esm/class/api/subscriber/wrapper.class.d.ts +18 -0
- package/dist/esm/class/api/subscriber/wrapper.class.js +21 -0
- package/dist/esm/class/api/subscriber/wrapper.class.js.map +1 -0
- package/dist/esm/class/utility/dto/exception/details/foreign-key-violation.class.js +5 -1
- package/dist/esm/class/utility/dto/exception/details/foreign-key-violation.class.js.map +1 -1
- package/dist/esm/class/utility/dto/exception/details/unique-violation.class.js +5 -1
- package/dist/esm/class/utility/dto/exception/details/unique-violation.class.js.map +1 -1
- package/dist/esm/class/utility/dto/property/factory/number.class.js +6 -2
- package/dist/esm/class/utility/dto/property/factory/number.class.js.map +1 -1
- package/dist/esm/class/utility/dto/property/factory/relation.class.js +5 -1
- package/dist/esm/class/utility/dto/property/factory/relation.class.js.map +1 -1
- package/dist/esm/class/utility/dto/strategy/body.class.js +5 -1
- package/dist/esm/class/utility/dto/strategy/body.class.js.map +1 -1
- package/dist/esm/class/utility/dto/strategy/query.class.js +5 -1
- package/dist/esm/class/utility/dto/strategy/query.class.js.map +1 -1
- package/dist/esm/class/utility/dto/strategy/request.class.js +5 -1
- package/dist/esm/class/utility/dto/strategy/request.class.js.map +1 -1
- package/dist/esm/class/utility/dto/strategy/response.class.js +5 -1
- package/dist/esm/class/utility/dto/strategy/response.class.js.map +1 -1
- package/dist/esm/constant/decorator/api/method.constant.d.ts +2 -3
- package/dist/esm/constant/decorator/api/method.constant.js +4 -6
- package/dist/esm/constant/decorator/api/method.constant.js.map +1 -1
- package/dist/esm/constant/utility/dto/constant.js +6 -2
- package/dist/esm/constant/utility/dto/constant.js.map +1 -1
- package/dist/esm/decorator/api/function/create.decorator.js +51 -24
- package/dist/esm/decorator/api/function/create.decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/custom.decorator.d.ts +9 -0
- package/dist/esm/decorator/api/function/custom.decorator.js +45 -0
- package/dist/esm/decorator/api/function/custom.decorator.js.map +1 -0
- package/dist/esm/decorator/api/function/decorator.js +16 -7
- package/dist/esm/decorator/api/function/decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/delete.decorator.js +62 -41
- package/dist/esm/decorator/api/function/delete.decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/get/decorator.js +40 -25
- package/dist/esm/decorator/api/function/get/decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/get/list.decorator.js +40 -25
- package/dist/esm/decorator/api/function/get/list.decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/get/many.decorator.js +40 -25
- package/dist/esm/decorator/api/function/get/many.decorator.js.map +1 -1
- package/dist/esm/decorator/api/function/index.d.ts +1 -0
- package/dist/esm/decorator/api/function/update.decorator.js +62 -41
- package/dist/esm/decorator/api/function/update.decorator.js.map +1 -1
- package/dist/esm/decorator/api/index.d.ts +1 -0
- package/dist/esm/decorator/api/method.decorator.d.ts +5 -6
- package/dist/esm/decorator/api/method.decorator.js +66 -326
- package/dist/esm/decorator/api/method.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/boolean.decorator.js +24 -5
- package/dist/esm/decorator/api/property/boolean.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/date.decorator.js +24 -5
- package/dist/esm/decorator/api/property/date.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/enum.decorator.js +22 -4
- package/dist/esm/decorator/api/property/enum.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/number.decorator.js +30 -7
- package/dist/esm/decorator/api/property/number.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/object.decorator.js +22 -4
- package/dist/esm/decorator/api/property/object.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/string.decorator.js +26 -9
- package/dist/esm/decorator/api/property/string.decorator.js.map +1 -1
- package/dist/esm/decorator/api/property/uuid.decorator.js +27 -5
- package/dist/esm/decorator/api/property/uuid.decorator.js.map +1 -1
- package/dist/esm/decorator/api/route-custom.decorator.d.ts +9 -0
- package/dist/esm/decorator/api/route-custom.decorator.js +99 -0
- package/dist/esm/decorator/api/route-custom.decorator.js.map +1 -0
- package/dist/esm/decorator/api/service/decorator.js +28 -23
- package/dist/esm/decorator/api/service/decorator.js.map +1 -1
- package/dist/esm/enum/decorator/api/controller/index.d.ts +3 -1
- package/dist/esm/enum/decorator/api/controller/relation-reference-shape.enum.d.ts +4 -0
- package/dist/esm/enum/decorator/api/controller/relation-reference-shape.enum.js +8 -0
- package/dist/esm/enum/decorator/api/controller/relation-reference-shape.enum.js.map +1 -0
- package/dist/esm/enum/decorator/api/controller/request/index.d.ts +2 -0
- package/dist/esm/enum/decorator/api/controller/request/target.enum.d.ts +5 -0
- package/dist/esm/enum/decorator/api/controller/request/target.enum.js +9 -0
- package/dist/esm/enum/decorator/api/controller/request/target.enum.js.map +1 -0
- package/dist/esm/enum/decorator/api/controller/{request-transformer-type.enum.js → request/transformer-type.enum.js} +1 -1
- package/dist/esm/enum/decorator/api/controller/request/transformer-type.enum.js.map +1 -0
- package/dist/esm/enum/decorator/api/controller/response-target.enum.d.ts +3 -0
- package/dist/esm/enum/decorator/api/controller/response-target.enum.js +7 -0
- package/dist/esm/enum/decorator/api/controller/response-target.enum.js.map +1 -0
- package/dist/esm/enum/decorator/api/dto-type.enum.d.ts +1 -1
- package/dist/esm/enum/decorator/api/dto-type.enum.js +1 -1
- package/dist/esm/enum/decorator/api/dto-type.enum.js.map +1 -1
- package/dist/esm/enum/decorator/api/function-transaction-mode.enum.d.ts +6 -0
- package/dist/esm/enum/decorator/api/function-transaction-mode.enum.js +10 -0
- package/dist/esm/enum/decorator/api/function-transaction-mode.enum.js.map +1 -0
- package/dist/esm/enum/decorator/api/function-type.enum.d.ts +1 -0
- package/dist/esm/enum/decorator/api/function-type.enum.js +1 -0
- package/dist/esm/enum/decorator/api/function-type.enum.js.map +1 -1
- package/dist/esm/enum/decorator/api/index.d.ts +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Observable.js +104 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Observable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Subscriber.js +154 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Subscriber.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Subscription.js +145 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/Subscription.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/config.js +5 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/config.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/lastValueFrom.js +26 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/lastValueFrom.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/observable/from.js +9 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/observable/from.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/observable/innerFrom.js +146 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/observable/innerFrom.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/OperatorSubscriber.js +63 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/OperatorSubscriber.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/observeOn.js +13 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/observeOn.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/subscribeOn.js +11 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/operators/subscribeOn.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleArray.js +21 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleArray.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleAsyncIterable.js +26 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleAsyncIterable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleIterable.js +35 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleIterable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleObservable.js +10 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleObservable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/schedulePromise.js +10 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/schedulePromise.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleReadableStreamLike.js +9 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduleReadableStreamLike.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduled.js +40 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduled/scheduled.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduler/timeoutProvider.js +18 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/scheduler/timeoutProvider.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/symbol/iterator.js +10 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/symbol/iterator.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/symbol/observable.js +4 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/symbol/observable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/EmptyError.js +12 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/EmptyError.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/UnsubscriptionError.js +15 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/UnsubscriptionError.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/arrRemove.js +9 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/arrRemove.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/createErrorClass.js +13 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/createErrorClass.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/errorContext.js +8 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/errorContext.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/executeSchedule.js +20 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/executeSchedule.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/identity.js +6 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/identity.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isArrayLike.js +4 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isArrayLike.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isAsyncIterable.js +8 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isAsyncIterable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isFunction.js +6 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isFunction.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isInteropObservable.js +9 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isInteropObservable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isIterable.js +9 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isIterable.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isPromise.js +8 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isPromise.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isReadableStreamLike.js +41 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/isReadableStreamLike.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/lift.js +23 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/lift.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/noop.js +4 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/noop.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/pipe.js +16 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/pipe.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/reportUnhandledError.js +12 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/reportUnhandledError.js.map +1 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/throwUnobservableError.js +6 -0
- package/dist/esm/external/rxjs/dist/esm5/internal/util/throwUnobservableError.js.map +1 -0
- package/dist/esm/external/tslib/tslib.es6.js +117 -1
- package/dist/esm/external/tslib/tslib.es6.js.map +1 -1
- package/dist/esm/factory/api-controller.factory.d.ts +1 -0
- package/dist/esm/factory/api-controller.factory.js +42 -393
- package/dist/esm/factory/api-controller.factory.js.map +1 -1
- package/dist/esm/index.js +15 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/interceptor/api-route-runtime.interceptor.d.ts +5 -0
- package/dist/esm/interceptor/api-route-runtime.interceptor.js +29 -0
- package/dist/esm/interceptor/api-route-runtime.interceptor.js.map +1 -0
- package/dist/esm/interface/class/api/authorization/policy/registry.interface.d.ts +1 -0
- package/dist/esm/interface/class/api/authorization/policy/subscriber/context/interface.d.ts +1 -1
- package/dist/esm/interface/class/api/function/context/index.d.ts +2 -0
- package/dist/esm/interface/class/api/function/context/interface.d.ts +10 -0
- package/dist/esm/interface/class/api/function/context/operations.interface.d.ts +13 -0
- package/dist/esm/interface/class/api/function/index.d.ts +1 -0
- package/dist/esm/interface/class/api/index.d.ts +2 -0
- package/dist/esm/interface/class/api/route/index.d.ts +1 -0
- package/dist/esm/interface/class/api/route/runtime/context-data.interface.d.ts +10 -0
- package/dist/esm/interface/class/api/route/runtime/custom-execution-options.interface.d.ts +9 -0
- package/dist/esm/interface/class/api/route/runtime/generated/execution-options.interface.d.ts +14 -0
- package/dist/esm/interface/class/api/route/runtime/generated/index.d.ts +2 -0
- package/dist/esm/interface/class/api/route/runtime/generated/targets.interface.d.ts +12 -0
- package/dist/esm/interface/class/api/route/runtime/http-request.interface.d.ts +8 -0
- package/dist/esm/interface/class/api/route/runtime/index.d.ts +4 -0
- package/dist/esm/interface/class/api/subscriber/function/error-execution-context.interface.d.ts +1 -0
- package/dist/esm/interface/class/api/subscriber/function/execution/context.interface.d.ts +1 -0
- package/dist/esm/interface/class/api/subscriber/function.interface.d.ts +4 -0
- package/dist/esm/interface/class/api/subscriber/route/error-execution-context.interface.d.ts +2 -1
- package/dist/esm/interface/class/api/subscriber/route/execution/context/data/extended.interface.d.ts +36 -0
- package/dist/esm/interface/class/api/subscriber/route/execution/context/data/index.d.ts +2 -0
- package/dist/esm/interface/class/api/subscriber/route/execution/context/data/interface.d.ts +32 -0
- package/dist/esm/interface/class/api/subscriber/route/execution/context/index.d.ts +2 -0
- package/dist/esm/interface/class/api/subscriber/route/execution/context/interface.d.ts +11 -0
- package/dist/esm/interface/class/api/subscriber/route/execution/index.d.ts +1 -2
- package/dist/esm/interface/class/api/subscriber/route.interface.d.ts +6 -2
- package/dist/esm/interface/decorator/api/controller/properties/route/authentication.interface.d.ts +1 -1
- package/dist/esm/interface/decorator/api/controller/properties/route/base/generation.interface.d.ts +5 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/index.d.ts +5 -2
- package/dist/esm/interface/decorator/api/controller/properties/route/base/interface.d.ts +4 -7
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/index.d.ts +4 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/reference.interface.d.ts +5 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/request/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/request/interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/request/load.interface.d.ts +10 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/response/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/response/interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/relations/response/load.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/request/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/request/interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/request/target.interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/response/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/response/interface.d.ts +7 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/response/target.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/base/security.interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/controller/properties/route/with/dto.interface.d.ts +1 -1
- package/dist/esm/interface/decorator/api/function/create-executor-properties.interface.d.ts +1 -2
- package/dist/esm/interface/decorator/api/function/custom-properties.interface.d.ts +9 -0
- package/dist/esm/interface/decorator/api/function/delete-executor-properties.interface.d.ts +2 -3
- package/dist/esm/interface/decorator/api/function/get/executor-properties.interface.d.ts +1 -2
- package/dist/esm/interface/decorator/api/function/get/list-executor-properties.interface.d.ts +1 -2
- package/dist/esm/interface/decorator/api/function/get/many-executor-properties.interface.d.ts +1 -2
- package/dist/esm/interface/decorator/api/function/index.d.ts +1 -0
- package/dist/esm/interface/decorator/api/function/properties.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/function/update-executor-properties.interface.d.ts +2 -3
- package/dist/esm/interface/decorator/api/index.d.ts +1 -0
- package/dist/esm/interface/decorator/api/method/index.d.ts +0 -2
- package/dist/esm/interface/decorator/api/method/properties.interface.d.ts +4 -17
- package/dist/esm/interface/decorator/api/route/custom-properties.interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/route/documentation-properties.interface.d.ts +5 -0
- package/dist/esm/interface/decorator/api/route/index.d.ts +7 -0
- package/dist/esm/interface/decorator/api/route/metadata/index.d.ts +3 -0
- package/dist/esm/interface/decorator/api/route/metadata/interface.d.ts +15 -0
- package/dist/esm/interface/decorator/api/route/metadata/resource.interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/route/metadata/route.interface.d.ts +7 -0
- package/dist/esm/interface/decorator/api/route/response/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/route/response/properties.interface.d.ts +9 -0
- package/dist/esm/interface/decorator/api/route/response/serialization-properties.interface.d.ts +3 -0
- package/dist/esm/interface/decorator/api/route/runtime-properties.interface.d.ts +11 -0
- package/dist/esm/interface/decorator/api/route/security/authentication-properties.interface.d.ts +9 -0
- package/dist/esm/interface/decorator/api/route/security/authorization-properties.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/route/security/index.d.ts +3 -0
- package/dist/esm/interface/decorator/api/route/security/properties.interface.d.ts +6 -0
- package/dist/esm/interface/decorator/api/route/throttling/default-properties.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/route/throttling/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/route/throttling/properties.interface.d.ts +4 -0
- package/dist/esm/interface/decorator/api/subscriber/function/filter.interface.d.ts +5 -0
- package/dist/esm/interface/decorator/api/subscriber/function/index.d.ts +2 -0
- package/dist/esm/interface/decorator/api/subscriber/function/properties.interface.d.ts +7 -0
- package/dist/esm/interface/decorator/api/subscriber/index.d.ts +2 -2
- package/dist/esm/interface/decorator/api/subscriber/route-properties.interface.d.ts +4 -0
- package/dist/esm/module/api/authorization.module.js +18 -1
- package/dist/esm/module/api/authorization.module.js.map +1 -1
- package/dist/esm/package.json +0 -1
- package/dist/esm/type/class/api/subscriber/route/after/create-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/after/delete-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/after/get/context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/after/get/list-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/after/partial-update-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/after/update-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/create-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/delete-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/get/context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/get/list-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/partial-update-context.type.d.ts +2 -2
- package/dist/esm/type/class/api/subscriber/route/before/update-context.type.d.ts +2 -2
- package/dist/esm/type/decorator/api/controller/properties/route/base/request/allowed-target.type.d.ts +9 -0
- package/dist/esm/type/decorator/api/controller/properties/route/base/request/index.d.ts +1 -1
- package/dist/esm/type/decorator/api/controller/properties/route/base/request/transformers.type.d.ts +7 -7
- package/dist/esm/type/decorator/api/controller/properties/route/base/response-transformers.type.d.ts +6 -6
- package/dist/esm/type/decorator/api/controller/transformer-config.type.d.ts +5 -5
- package/dist/esm/type/decorator/api/function/properties.type.d.ts +5 -3
- package/dist/esm/type/decorator/api/property/describe/dto/request-properties.type.d.ts +1 -1
- package/dist/esm/type/decorator/api/property/describe/properties/base/properties.type.d.ts +4 -4
- package/dist/esm/type/utility/dto/generate/allowed-combination.type.d.ts +4 -4
- package/dist/esm/utility/api/controller/apply/decorators.utility.js +59 -27
- package/dist/esm/utility/api/controller/apply/decorators.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/apply/metadata.utility.js +6 -2
- package/dist/esm/utility/api/controller/apply/metadata.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/get/dto.utility.js +6 -2
- package/dist/esm/utility/api/controller/get/dto.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/get-list/transform/filter.utility.js +5 -1
- package/dist/esm/utility/api/controller/get-list/transform/filter.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/handle-request-relations.utility.d.ts +4 -4
- package/dist/esm/utility/api/controller/handle-request-relations.utility.js +37 -11
- package/dist/esm/utility/api/controller/handle-request-relations.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/index.d.ts +1 -0
- package/dist/esm/utility/api/controller/serialize-route-response.utility.d.ts +14 -0
- package/dist/esm/utility/api/controller/serialize-route-response.utility.js +27 -0
- package/dist/esm/utility/api/controller/serialize-route-response.utility.js.map +1 -0
- package/dist/esm/utility/api/controller/transform-data.utility.d.ts +8 -7
- package/dist/esm/utility/api/controller/transform-data.utility.js +19 -16
- package/dist/esm/utility/api/controller/transform-data.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/validate-request.utility.d.ts +3 -3
- package/dist/esm/utility/api/controller/validate-request.utility.js +10 -9
- package/dist/esm/utility/api/controller/validate-request.utility.js.map +1 -1
- package/dist/esm/utility/api/controller/write/dto-swagger.utility.js +6 -2
- package/dist/esm/utility/api/controller/write/dto-swagger.utility.js.map +1 -1
- package/dist/esm/utility/api/function-transaction.utility.d.ts +20 -0
- package/dist/esm/utility/api/function-transaction.utility.js +50 -0
- package/dist/esm/utility/api/function-transaction.utility.js.map +1 -0
- package/dist/esm/utility/api/index.d.ts +1 -0
- package/dist/esm/utility/api/route/index.d.ts +1 -0
- package/dist/esm/utility/api/route/response/index.d.ts +2 -0
- package/dist/esm/utility/api/route/response/project-relation.utility.d.ts +11 -0
- package/dist/esm/utility/api/route/response/project-relation.utility.js +73 -0
- package/dist/esm/utility/api/route/response/project-relation.utility.js.map +1 -0
- package/dist/esm/utility/api/route/response/serialize.utility.d.ts +11 -0
- package/dist/esm/utility/api/route/response/serialize.utility.js +24 -0
- package/dist/esm/utility/api/route/response/serialize.utility.js.map +1 -0
- package/dist/esm/utility/dto/build-decorator.utility.js +5 -1
- package/dist/esm/utility/dto/build-decorator.utility.js.map +1 -1
- package/dist/esm/utility/dto/generate/core.utility.js +5 -1
- package/dist/esm/utility/dto/generate/core.utility.js.map +1 -1
- package/dist/esm/utility/dto/generate/dynamic.utility.js +5 -1
- package/dist/esm/utility/dto/generate/dynamic.utility.js.map +1 -1
- package/dist/esm/utility/dto/generate/exception.utility.js +5 -1
- package/dist/esm/utility/dto/generate/exception.utility.js.map +1 -1
- package/dist/esm/utility/dto/generate/filter-decorator.utility.js +5 -1
- package/dist/esm/utility/dto/generate/filter-decorator.utility.js.map +1 -1
- package/dist/esm/utility/dto/generate/get-list-response.utility.js +5 -1
- package/dist/esm/utility/dto/generate/get-list-response.utility.js.map +1 -1
- package/dist/esm/utility/dto/get/get-list-query-base-class.utility.js +5 -1
- package/dist/esm/utility/dto/get/get-list-query-base-class.utility.js.map +1 -1
- package/dist/esm/utility/dto/handle-date-property.utility.js +5 -1
- package/dist/esm/utility/dto/handle-date-property.utility.js.map +1 -1
- package/dist/esm/utility/dto/is/property/should-be-marked.utility.js +7 -3
- package/dist/esm/utility/dto/is/property/should-be-marked.utility.js.map +1 -1
- package/dist/esm/utility/dto/is/should-be-generated.utility.js +8 -4
- package/dist/esm/utility/dto/is/should-be-generated.utility.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/enum/decorator/api/controller/request-transformer-type.enum.js.map +0 -1
- package/dist/cjs/interface/class/api/subscriber/route/execution/context-data.interface.d.ts +0 -82
- package/dist/cjs/interface/class/api/subscriber/route/execution/context.interface.d.ts +0 -29
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/request.interface.d.ts +0 -8
- package/dist/cjs/interface/decorator/api/controller/properties/route/base/response.interface.d.ts +0 -7
- package/dist/cjs/interface/decorator/api/method/authorization.interface.d.ts +0 -3
- package/dist/cjs/interface/decorator/api/method/throttler-properties.interface.d.ts +0 -4
- package/dist/cjs/interface/decorator/api/subscriber/function-properties.interface.d.ts +0 -5
- package/dist/cjs/type/decorator/api/controller/properties/route/base/request/relations.type.d.ts +0 -18
- package/dist/esm/enum/decorator/api/controller/request-transformer-type.enum.js.map +0 -1
- package/dist/esm/interface/class/api/subscriber/route/execution/context-data.interface.d.ts +0 -82
- package/dist/esm/interface/class/api/subscriber/route/execution/context.interface.d.ts +0 -29
- package/dist/esm/interface/decorator/api/controller/properties/route/base/request.interface.d.ts +0 -8
- package/dist/esm/interface/decorator/api/controller/properties/route/base/response.interface.d.ts +0 -7
- package/dist/esm/interface/decorator/api/method/authorization.interface.d.ts +0 -3
- package/dist/esm/interface/decorator/api/method/throttler-properties.interface.d.ts +0 -4
- package/dist/esm/interface/decorator/api/subscriber/function-properties.interface.d.ts +0 -5
- package/dist/esm/type/decorator/api/controller/properties/route/base/request/relations.type.d.ts +0 -18
- /package/dist/cjs/enum/decorator/api/controller/{request-transformer-type.enum.d.ts → request/transformer-type.enum.d.ts} +0 -0
- /package/dist/esm/enum/decorator/api/controller/{request-transformer-type.enum.d.ts → request/transformer-type.enum.d.ts} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simulator.class.js","sources":["../../../../../../src/class/api/authorization/simulator.class.ts"],"sourcesContent":[null],"names":["ApiAuthorizationSimulator","__decorate","Injectable","ApiAuthorizationRuntime"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"simulator.class.js","sources":["../../../../../../src/class/api/authorization/simulator.class.ts"],"sourcesContent":[null],"names":["ApiAuthorizationSimulator","__decorate","Injectable","ApiAuthorizationRuntime"],"mappings":";;;;;;AAWaA,iCAAyB,GAA/B,MAAM,yBAAyB,CAAA;AACD,IAAA,OAAA;AAApC,IAAA,WAAA,CAAoC,OAAgC,EAAA;QAAhC,IAAA,CAAA,OAAO,GAAP,OAAO;IAA4B;IAEhE,MAAM,QAAQ,CAA2B,OAAiT,EAAA;AAChW,QAAA,OAAO,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;YAClC,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,SAAS,EAAE,OAAO,CAAC,SAAS;AAC5B,YAAA,eAAe,EAAE,OAAO,CAAC,eAAe,IAAI,EAAE;YAC9C,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;YAC9C,SAAS,EAAE,OAAO,CAAC,SAAS;AAC5B,SAAA,CAAC;IACH;;AAdYA,iCAAyB,GAAAC,oBAAA,CAAA;AADrC,IAAAC,iBAAU,EAAE;+CAEiCC,qCAAuB,CAAA;AADxD,CAAA,EAAAH,iCAAyB,CAerC;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { IApiBaseEntity } from '../../../interface/api-base-entity.interface';
|
|
2
|
+
import type { IApiFunctionContext } from '../../../interface/class/api/function/index';
|
|
3
|
+
export declare class ApiFunctionContextStorage {
|
|
4
|
+
private static readonly STORAGE;
|
|
5
|
+
static get<E extends IApiBaseEntity>(): IApiFunctionContext<E> | undefined;
|
|
6
|
+
static run<E extends IApiBaseEntity, R>(context: IApiFunctionContext<E>, callback: () => Promise<R>): Promise<R>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var node_async_hooks = require('node:async_hooks');
|
|
4
|
+
|
|
5
|
+
class ApiFunctionContextStorage {
|
|
6
|
+
static STORAGE = new node_async_hooks.AsyncLocalStorage();
|
|
7
|
+
static get() {
|
|
8
|
+
return ApiFunctionContextStorage.STORAGE.getStore();
|
|
9
|
+
}
|
|
10
|
+
static run(context, callback) {
|
|
11
|
+
return ApiFunctionContextStorage.STORAGE.run(context, callback);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
exports.ApiFunctionContextStorage = ApiFunctionContextStorage;
|
|
16
|
+
//# sourceMappingURL=context-storage.class.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-storage.class.js","sources":["../../../../../../src/class/api/function/context-storage.class.ts"],"sourcesContent":[null],"names":["NodeAsyncLocalStorage"],"mappings":";;;;MAOa,yBAAyB,CAAA;AAC7B,IAAA,OAAgB,OAAO,GAA2D,IAAIA,kCAAqB,EAAuC;AAEnJ,IAAA,OAAO,GAAG,GAAA;AAChB,QAAA,OAAO,yBAAyB,CAAC,OAAO,CAAC,QAAQ,EAAwC;IAC1F;AAEO,IAAA,OAAO,GAAG,CAA8B,OAA+B,EAAE,QAA0B,EAAA;QACzG,OAAO,yBAAyB,CAAC,OAAO,CAAC,GAAG,CAAC,OAAyD,EAAE,QAAQ,CAAC;IAClH;;;;;"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { IApiBaseEntity } from '../../../interface/api-base-entity.interface';
|
|
2
|
+
import type { IApiFunctionCustomProperties } from '../../../interface/decorator/api/function/index';
|
|
3
|
+
import type { Repository } from "typeorm";
|
|
4
|
+
import { EApiFunctionTransactionMode } from '../../../enum/decorator/api/index';
|
|
5
|
+
export declare class ApiFunctionCustomRuntime {
|
|
6
|
+
static execute<E extends IApiBaseEntity>(options: {
|
|
7
|
+
functionArguments: Array<unknown>;
|
|
8
|
+
originalMethod: (...arguments_: Array<unknown>) => Promise<unknown>;
|
|
9
|
+
properties: IApiFunctionCustomProperties<E>;
|
|
10
|
+
target: {
|
|
11
|
+
repository: Repository<E>;
|
|
12
|
+
};
|
|
13
|
+
transactionMode: EApiFunctionTransactionMode;
|
|
14
|
+
}): Promise<unknown>;
|
|
15
|
+
private static createContext;
|
|
16
|
+
private static executeErrorSubscribers;
|
|
17
|
+
private static executeWithEventManager;
|
|
18
|
+
private static resolveEventManager;
|
|
19
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var contextStorage_class = require('./context-storage.class.js');
|
|
4
|
+
var executor_class = require('../subscriber/executor.class.js');
|
|
5
|
+
require('../../../enum/decorator/api/action.enum.js');
|
|
6
|
+
require('../../../enum/decorator/api/authentication-type.enum.js');
|
|
7
|
+
require('../../../enum/decorator/api/controller/load-relations-strategy.enum.js');
|
|
8
|
+
require('../../../enum/decorator/api/controller/relation-reference-shape.enum.js');
|
|
9
|
+
require('../../../enum/decorator/api/controller/request/target.enum.js');
|
|
10
|
+
require('../../../enum/decorator/api/controller/request/transformer-type.enum.js');
|
|
11
|
+
require('../../../enum/decorator/api/controller/response-target.enum.js');
|
|
12
|
+
require('../../../enum/decorator/api/dto-type.enum.js');
|
|
13
|
+
var functionTransactionMode_enum = require('../../../enum/decorator/api/function-transaction-mode.enum.js');
|
|
14
|
+
var functionType_enum = require('../../../enum/decorator/api/function-type.enum.js');
|
|
15
|
+
var onType_enum = require('../../../enum/decorator/api/on-type.enum.js');
|
|
16
|
+
require('../../../enum/decorator/api/property/data-type.enum.js');
|
|
17
|
+
require('../../../enum/decorator/api/property/date/identifier.enum.js');
|
|
18
|
+
require('../../../enum/decorator/api/property/date/type.enum.js');
|
|
19
|
+
require('../../../enum/decorator/api/property/desribe-type.enum.js');
|
|
20
|
+
require('../../../enum/decorator/api/property/number-type.enum.js');
|
|
21
|
+
require('../../../enum/decorator/api/property/string-type.enum.js');
|
|
22
|
+
require('../../../enum/decorator/api/route-type.enum.js');
|
|
23
|
+
var exception_utility = require('../../../utility/error/exception.utility.js');
|
|
24
|
+
|
|
25
|
+
class ApiFunctionCustomRuntime {
|
|
26
|
+
static async execute(options) {
|
|
27
|
+
const activeContext = contextStorage_class.ApiFunctionContextStorage.get();
|
|
28
|
+
let eventManager;
|
|
29
|
+
try {
|
|
30
|
+
eventManager = ApiFunctionCustomRuntime.resolveEventManager(options.transactionMode, activeContext);
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
await ApiFunctionCustomRuntime.executeErrorSubscribers(options, undefined, onType_enum.EApiSubscriberOnType.BEFORE_ERROR, error);
|
|
34
|
+
throw error;
|
|
35
|
+
}
|
|
36
|
+
if (options.transactionMode === functionTransactionMode_enum.EApiFunctionTransactionMode.REQUIRED && !eventManager) {
|
|
37
|
+
return await options.target.repository.manager.transaction(async (transactionManager) => await ApiFunctionCustomRuntime.executeWithEventManager({ ...options, eventManager: transactionManager }));
|
|
38
|
+
}
|
|
39
|
+
return await ApiFunctionCustomRuntime.executeWithEventManager({ ...options, eventManager });
|
|
40
|
+
}
|
|
41
|
+
static createContext(options) {
|
|
42
|
+
const repository = options.eventManager?.getRepository(options.properties.entity) ?? options.target.repository;
|
|
43
|
+
return {
|
|
44
|
+
entity: options.properties.entity,
|
|
45
|
+
eventManager: options.eventManager,
|
|
46
|
+
getRepository: (repositoryEntity) => options.eventManager?.getRepository(repositoryEntity) ?? options.target.repository.manager.getRepository(repositoryEntity),
|
|
47
|
+
operations: {
|
|
48
|
+
create: async (properties) => await options.target.create(properties),
|
|
49
|
+
delete: async (criteria) => {
|
|
50
|
+
await options.target.delete(criteria);
|
|
51
|
+
},
|
|
52
|
+
get: async (properties) => await options.target.get(properties),
|
|
53
|
+
getList: async (properties) => await options.target.getList(properties),
|
|
54
|
+
getMany: async (properties) => await options.target.getMany(properties),
|
|
55
|
+
getRepository: (repositoryEntity) => options.eventManager?.getRepository(repositoryEntity) ?? options.target.repository.manager.getRepository(repositoryEntity),
|
|
56
|
+
update: async (criteria, properties) => await options.target.update(criteria, properties),
|
|
57
|
+
},
|
|
58
|
+
repository,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
static async executeErrorSubscribers(options, eventManager, onType, error) {
|
|
62
|
+
const entityInstance = new options.properties.entity();
|
|
63
|
+
const errorExecutionContext = {
|
|
64
|
+
action: options.properties.action,
|
|
65
|
+
DATA: { eventManager, repository: options.target.repository },
|
|
66
|
+
ENTITY: entityInstance,
|
|
67
|
+
FUNCTION_TYPE: functionType_enum.EApiFunctionType.CUSTOM,
|
|
68
|
+
};
|
|
69
|
+
await executor_class.ApiSubscriberExecutor.executeFunctionErrorSubscribers(options.target.constructor, entityInstance, functionType_enum.EApiFunctionType.CUSTOM, onType, errorExecutionContext, error, options.properties.action);
|
|
70
|
+
}
|
|
71
|
+
static async executeWithEventManager(options) {
|
|
72
|
+
const entityInstance = new options.properties.entity();
|
|
73
|
+
const context = ApiFunctionCustomRuntime.createContext(options);
|
|
74
|
+
const executionContext = {
|
|
75
|
+
action: options.properties.action,
|
|
76
|
+
DATA: { eventManager: options.eventManager, repository: options.target.repository },
|
|
77
|
+
ENTITY: entityInstance,
|
|
78
|
+
FUNCTION_TYPE: functionType_enum.EApiFunctionType.CUSTOM,
|
|
79
|
+
result: options.functionArguments,
|
|
80
|
+
};
|
|
81
|
+
let finalArguments;
|
|
82
|
+
try {
|
|
83
|
+
const beforeResult = await executor_class.ApiSubscriberExecutor.executeFunctionSubscribers(options.target.constructor, entityInstance, functionType_enum.EApiFunctionType.CUSTOM, onType_enum.EApiSubscriberOnType.BEFORE, executionContext, options.properties.action);
|
|
84
|
+
finalArguments = beforeResult ?? options.functionArguments;
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
await ApiFunctionCustomRuntime.executeErrorSubscribers(options, options.eventManager, onType_enum.EApiSubscriberOnType.BEFORE_ERROR, error);
|
|
88
|
+
throw error;
|
|
89
|
+
}
|
|
90
|
+
try {
|
|
91
|
+
const result = await contextStorage_class.ApiFunctionContextStorage.run(context, async () => await options.originalMethod.apply(options.target, finalArguments));
|
|
92
|
+
const afterExecutionContext = {
|
|
93
|
+
action: options.properties.action,
|
|
94
|
+
DATA: { eventManager: options.eventManager, repository: options.target.repository },
|
|
95
|
+
ENTITY: entityInstance,
|
|
96
|
+
FUNCTION_TYPE: functionType_enum.EApiFunctionType.CUSTOM,
|
|
97
|
+
result,
|
|
98
|
+
};
|
|
99
|
+
return (await executor_class.ApiSubscriberExecutor.executeFunctionSubscribers(options.target.constructor, entityInstance, functionType_enum.EApiFunctionType.CUSTOM, onType_enum.EApiSubscriberOnType.AFTER, afterExecutionContext, options.properties.action)) ?? result;
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
await ApiFunctionCustomRuntime.executeErrorSubscribers(options, options.eventManager, onType_enum.EApiSubscriberOnType.AFTER_ERROR, error);
|
|
103
|
+
throw error;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
static resolveEventManager(transactionMode, activeContext) {
|
|
107
|
+
if (transactionMode === functionTransactionMode_enum.EApiFunctionTransactionMode.NONE && activeContext?.eventManager) {
|
|
108
|
+
throw exception_utility.ErrorException("ApiFunctionCustom transaction mode NONE cannot run inside an active transaction");
|
|
109
|
+
}
|
|
110
|
+
if (transactionMode === functionTransactionMode_enum.EApiFunctionTransactionMode.MANDATORY && !activeContext?.eventManager) {
|
|
111
|
+
throw exception_utility.ErrorException("ApiFunctionCustom transaction mode MANDATORY requires an active transaction");
|
|
112
|
+
}
|
|
113
|
+
return transactionMode === functionTransactionMode_enum.EApiFunctionTransactionMode.NONE ? undefined : activeContext?.eventManager;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
exports.ApiFunctionCustomRuntime = ApiFunctionCustomRuntime;
|
|
118
|
+
//# sourceMappingURL=custom-runtime.class.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom-runtime.class.js","sources":["../../../../../../src/class/api/function/custom-runtime.class.ts"],"sourcesContent":[null],"names":["ApiFunctionContextStorage","EApiSubscriberOnType","EApiFunctionTransactionMode","EApiFunctionType","ApiSubscriberExecutor","ErrorException"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;MAaa,wBAAwB,CAAA;AAC7B,IAAA,aAAa,OAAO,CAA2B,OAAqP,EAAA;AAC1S,QAAA,MAAM,aAAa,GAAuCA,8CAAyB,CAAC,GAAG,EAAK;AAC5F,QAAA,IAAI,YAAuC;AAE3C,QAAA,IAAI;YACH,YAAY,GAAG,wBAAwB,CAAC,mBAAmB,CAAC,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC;QACpG;QAAE,OAAO,KAAK,EAAE;AACf,YAAA,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,OAAO,EAAE,SAAS,EAAEC,gCAAoB,CAAC,YAAY,EAAE,KAAK,CAAC;AAEpH,YAAA,MAAM,KAAK;QACZ;QAEA,IAAI,OAAO,CAAC,eAAe,KAAKC,wDAA2B,CAAC,QAAQ,IAAI,CAAC,YAAY,EAAE;AACtF,YAAA,OAAO,MAAM,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,kBAAiC,KAAuB,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,EAAE,GAAG,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACpO;AAEA,QAAA,OAAO,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,EAAE,GAAG,OAAO,EAAE,YAAY,EAAE,CAAC;IAC5F;IAEQ,OAAO,aAAa,CAA2B,OAA6H,EAAA;QACnL,MAAM,UAAU,GAAkB,OAAO,CAAC,YAAY,EAAE,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,UAAU;QAE7H,OAAO;AACN,YAAA,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;YACjC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,aAAa,EAAE,CAA2B,gBAA6B,KAAoB,OAAO,CAAC,YAAY,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC;AACrN,YAAA,UAAU,EAAE;AACX,gBAAA,MAAM,EAAE,OAAO,UAA2C,KAAiB,MAAO,OAAO,CAAC,MAAiE,CAAC,MAAM,CAAC,UAAU,CAAC;AAC9K,gBAAA,MAAM,EAAE,OAAO,QAA8E,KAAmB;oBAC/G,MAAO,OAAO,CAAC,MAAkE,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACnG,CAAC;AACD,gBAAA,GAAG,EAAE,OAAO,UAAwC,KAAiB,MAAO,OAAO,CAAC,MAA8D,CAAC,GAAG,CAAC,UAAU,CAAC;AAClK,gBAAA,OAAO,EAAE,OAAO,UAA4C,KAA4C,MAAO,OAAO,CAAC,MAA6F,CAAC,OAAO,CAAC,UAAU,CAAC;AACxO,gBAAA,OAAO,EAAE,OAAO,UAA4C,KAAwB,MAAO,OAAO,CAAC,MAAyE,CAAC,OAAO,CAAC,UAAU,CAAC;gBAChM,aAAa,EAAE,CAA2B,gBAA6B,KAAoB,OAAO,CAAC,YAAY,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC;AACrN,gBAAA,MAAM,EAAE,OAAO,QAA8E,EAAE,UAA2C,KAAiB,MAAO,OAAO,CAAC,MAAoF,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC;AAC3R,aAAA;YACD,UAAU;SACV;IACF;IAEQ,aAAa,uBAAuB,CAA2B,OAA6H,EAAE,YAAuC,EAAE,MAA4B,EAAE,KAAc,EAAA;QAC1R,MAAM,cAAc,GAAM,IAAI,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE;AAEzD,QAAA,MAAM,qBAAqB,GAAkG;AAC5H,YAAA,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;YACjC,IAAI,EAAE,EAAE,YAAY,EAAE,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE;AAC7D,YAAA,MAAM,EAAE,cAAc;YACtB,aAAa,EAAEC,kCAAgB,CAAC,MAAM;SACtC;AAED,QAAA,MAAMC,oCAAqB,CAAC,+BAA+B,CAAC,OAAO,CAAC,MAAM,CAAC,WAAuE,EAAE,cAAc,EAAED,kCAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,qBAAqB,EAAE,KAAc,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC;IACvQ;AAEQ,IAAA,aAAa,uBAAuB,CAA2B,OAAqO,EAAA;QAC3S,MAAM,cAAc,GAAM,IAAI,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE;QACzD,MAAM,OAAO,GAA2B,wBAAwB,CAAC,aAAa,CAAC,OAAO,CAAC;AAEvF,QAAA,MAAM,gBAAgB,GAA6G;AAClI,YAAA,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;AACjC,YAAA,IAAI,EAAE,EAAE,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE;AACnF,YAAA,MAAM,EAAE,cAAc;YACtB,aAAa,EAAEA,kCAAgB,CAAC,MAAM;YACtC,MAAM,EAAE,OAAO,CAAC,iBAAiB;SACjC;AACD,QAAA,IAAI,cAA8B;AAElC,QAAA,IAAI;AACH,YAAA,MAAM,YAAY,GAA+B,MAAMC,oCAAqB,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,WAAuE,EAAE,cAAc,EAAED,kCAAgB,CAAC,MAAM,EAAEF,gCAAoB,CAAC,MAAM,EAAE,gBAAgB,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC;AAClT,YAAA,cAAc,GAAG,YAAY,IAAI,OAAO,CAAC,iBAAiB;QAC3D;QAAE,OAAO,KAAK,EAAE;AACf,YAAA,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,YAAY,EAAEA,gCAAoB,CAAC,YAAY,EAAE,KAAK,CAAC;AAE/H,YAAA,MAAM,KAAK;QACZ;AAEA,QAAA,IAAI;YACH,MAAM,MAAM,GAAY,MAAMD,8CAAyB,CAAC,GAAG,CAAC,OAAO,EAAE,YAA8B,MAAM,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;AAEtK,YAAA,MAAM,qBAAqB,GAAsG;AAChI,gBAAA,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;AACjC,gBAAA,IAAI,EAAE,EAAE,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE;AACnF,gBAAA,MAAM,EAAE,cAAc;gBACtB,aAAa,EAAEG,kCAAgB,CAAC,MAAM;gBACtC,MAAM;aACN;AAED,YAAA,OAAO,CAAC,MAAMC,oCAAqB,CAAC,0BAA0B,CAAC,OAAO,CAAC,MAAM,CAAC,WAAuE,EAAE,cAAc,EAAED,kCAAgB,CAAC,MAAM,EAAEF,gCAAoB,CAAC,KAAK,EAAE,qBAAqB,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,MAAM;QACzR;QAAE,OAAO,KAAK,EAAE;AACf,YAAA,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,YAAY,EAAEA,gCAAoB,CAAC,WAAW,EAAE,KAAK,CAAC;AAE9H,YAAA,MAAM,KAAK;QACZ;IACD;AAEQ,IAAA,OAAO,mBAAmB,CAA2B,eAA4C,EAAE,aAAsC,EAAA;QAChJ,IAAI,eAAe,KAAKC,wDAA2B,CAAC,IAAI,IAAI,aAAa,EAAE,YAAY,EAAE;AACxF,YAAA,MAAMG,gCAAc,CAAC,iFAAiF,CAAC;QACxG;QAEA,IAAI,eAAe,KAAKH,wDAA2B,CAAC,SAAS,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE;AAC9F,YAAA,MAAMG,gCAAc,CAAC,6EAA6E,CAAC;QACpG;AAEA,QAAA,OAAO,eAAe,KAAKH,wDAA2B,CAAC,IAAI,GAAG,SAAS,GAAG,aAAa,EAAE,YAAY;IACtG;AACA;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ApiFunctionTransactionScope } from './transaction-scope.class';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { DataSource, EntityManager } from "typeorm";
|
|
2
|
+
export declare class ApiFunctionTransactionScope {
|
|
3
|
+
static runWithDataSource<R>(dataSource: DataSource, callback: () => Promise<R>): Promise<R>;
|
|
4
|
+
static runWithEntityManager<R>(entityManager: EntityManager, callback: () => Promise<R>): Promise<R>;
|
|
5
|
+
private static createMissingServiceContextError;
|
|
6
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var contextStorage_class = require('./context-storage.class.js');
|
|
4
|
+
|
|
5
|
+
class ApiFunctionTransactionScope {
|
|
6
|
+
static async runWithDataSource(dataSource, callback) {
|
|
7
|
+
return await dataSource.transaction(async (entityManager) => await ApiFunctionTransactionScope.runWithEntityManager(entityManager, callback));
|
|
8
|
+
}
|
|
9
|
+
static async runWithEntityManager(entityManager, callback) {
|
|
10
|
+
const entity = Object;
|
|
11
|
+
const context = {
|
|
12
|
+
entity,
|
|
13
|
+
eventManager: entityManager,
|
|
14
|
+
getRepository: (repositoryEntity) => entityManager.getRepository(repositoryEntity),
|
|
15
|
+
operations: {
|
|
16
|
+
create: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
17
|
+
delete: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
18
|
+
get: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
19
|
+
getList: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
20
|
+
getMany: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
21
|
+
getRepository: (repositoryEntity) => entityManager.getRepository(repositoryEntity),
|
|
22
|
+
update: () => Promise.reject(ApiFunctionTransactionScope.createMissingServiceContextError()),
|
|
23
|
+
},
|
|
24
|
+
repository: entityManager.getRepository(entity),
|
|
25
|
+
};
|
|
26
|
+
return await contextStorage_class.ApiFunctionContextStorage.run(context, callback);
|
|
27
|
+
}
|
|
28
|
+
static createMissingServiceContextError() {
|
|
29
|
+
return new Error("ApiFunctionTransactionScope operations require a decorated service context");
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
exports.ApiFunctionTransactionScope = ApiFunctionTransactionScope;
|
|
34
|
+
//# sourceMappingURL=transaction-scope.class.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-scope.class.js","sources":["../../../../../../src/class/api/function/transaction-scope.class.ts"],"sourcesContent":[null],"names":["ApiFunctionContextStorage"],"mappings":";;;;MAMa,2BAA2B,CAAA;AAChC,IAAA,aAAa,iBAAiB,CAAI,UAAsB,EAAE,QAA0B,EAAA;QAC1F,OAAO,MAAM,UAAU,CAAC,WAAW,CAAC,OAAO,aAA4B,KAAiB,MAAM,2BAA2B,CAAC,oBAAoB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACzK;AAEO,IAAA,aAAa,oBAAoB,CAAI,aAA4B,EAAE,QAA0B,EAAA;QACnG,MAAM,MAAM,GAA6B,MAA6C;AAEtF,QAAA,MAAM,OAAO,GAAwC;YACpD,MAAM;AACN,YAAA,YAAY,EAAE,aAAa;YAC3B,aAAa,EAAE,CAA2B,gBAA6B,KAAoB,aAAa,CAAC,aAAa,CAAC,gBAAgB,CAAC;AACxI,YAAA,UAAU,EAAE;AACX,gBAAA,MAAM,EAAE,MAA+B,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;AACrH,gBAAA,MAAM,EAAE,MAAqB,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;AAC3G,gBAAA,GAAG,EAAE,MAA+B,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;AAClH,gBAAA,OAAO,EAAE,MAAsB,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;AAC7G,gBAAA,OAAO,EAAE,MAAsC,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;gBAC7H,aAAa,EAAE,CAA2B,gBAA6B,KAAoB,aAAa,CAAC,aAAa,CAAC,gBAAgB,CAAC;AACxI,gBAAA,MAAM,EAAE,MAA+B,OAAO,CAAC,MAAM,CAAC,2BAA2B,CAAC,gCAAgC,EAAE,CAAC;AACrH,aAAA;AACD,YAAA,UAAU,EAAE,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC;SAC/C;QAED,OAAO,MAAMA,8CAAyB,CAAC,GAAG,CAAC,OAAO,EAAE,QAAQ,CAAC;IAC9D;AAEQ,IAAA,OAAO,gCAAgC,GAAA;AAC9C,QAAA,OAAO,IAAI,KAAK,CAAC,4EAA4E,CAAC;IAC/F;AACA;;;;"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { IApiBaseEntity } from '../../interface/api-base-entity.interface';
|
|
2
|
+
import type { IApiRouteRuntimeCustomExecutionOptions, IApiRouteRuntimeGeneratedExecutionOptions } from '../../interface/class/api/route/index';
|
|
3
|
+
import type { IApiRouteMetadata, IApiRouteRuntimeProperties } from '../../interface/decorator/api/index';
|
|
4
|
+
import type { TApiControllerMethod } from '../../type/class/controller-method.type';
|
|
5
|
+
import { EApiRouteType } from '../../enum/decorator/api/index';
|
|
6
|
+
export declare class ApiRouteRuntime {
|
|
7
|
+
static executeCustom<E extends IApiBaseEntity, R>(options: IApiRouteRuntimeCustomExecutionOptions<E, R>): Promise<R>;
|
|
8
|
+
static executeCustomRequestRelations<E extends IApiBaseEntity>(controller: TApiControllerMethod<E>, metadata: IApiRouteMetadata<E>, runtimeProperties: IApiRouteRuntimeProperties<E>, body: Partial<E> | undefined): Promise<void>;
|
|
9
|
+
static executeCustomResponseRelations<E extends IApiBaseEntity, R>(controller: TApiControllerMethod<E>, runtimeProperties: IApiRouteRuntimeProperties<E>, response: R): Promise<R>;
|
|
10
|
+
static executeGenerated<E extends IApiBaseEntity, R extends EApiRouteType>(options: IApiRouteRuntimeGeneratedExecutionOptions<E, R>): Promise<unknown>;
|
|
11
|
+
private static executeCustomErrorSubscribers;
|
|
12
|
+
private static executeCustomResponse;
|
|
13
|
+
private static executeGeneratedErrorSubscribers;
|
|
14
|
+
private static executeGeneratedOperation;
|
|
15
|
+
private static executeGeneratedRequestPipeline;
|
|
16
|
+
private static executeGeneratedResponse;
|
|
17
|
+
private static executeGeneratedUpdateOperation;
|
|
18
|
+
private static executeRequestTargets;
|
|
19
|
+
private static loadCustomResponseRelations;
|
|
20
|
+
private static resolvePrimaryKey;
|
|
21
|
+
}
|
|
@@ -0,0 +1,335 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var serviceBase_class = require('./service-base.class.js');
|
|
4
|
+
var executor_class = require('./subscriber/executor.class.js');
|
|
5
|
+
var function_constant = require('../../constant/decorator/api/function.constant.js');
|
|
6
|
+
require('../../enum/decorator/api/action.enum.js');
|
|
7
|
+
require('../../enum/decorator/api/authentication-type.enum.js');
|
|
8
|
+
require('../../enum/decorator/api/controller/load-relations-strategy.enum.js');
|
|
9
|
+
require('../../enum/decorator/api/controller/relation-reference-shape.enum.js');
|
|
10
|
+
var target_enum = require('../../enum/decorator/api/controller/request/target.enum.js');
|
|
11
|
+
require('../../enum/decorator/api/controller/request/transformer-type.enum.js');
|
|
12
|
+
require('../../enum/decorator/api/controller/response-target.enum.js');
|
|
13
|
+
var dtoType_enum = require('../../enum/decorator/api/dto-type.enum.js');
|
|
14
|
+
require('../../enum/decorator/api/function-transaction-mode.enum.js');
|
|
15
|
+
require('../../enum/decorator/api/function-type.enum.js');
|
|
16
|
+
var onType_enum = require('../../enum/decorator/api/on-type.enum.js');
|
|
17
|
+
require('../../enum/decorator/api/property/data-type.enum.js');
|
|
18
|
+
require('../../enum/decorator/api/property/date/identifier.enum.js');
|
|
19
|
+
require('../../enum/decorator/api/property/date/type.enum.js');
|
|
20
|
+
require('../../enum/decorator/api/property/desribe-type.enum.js');
|
|
21
|
+
require('../../enum/decorator/api/property/number-type.enum.js');
|
|
22
|
+
require('../../enum/decorator/api/property/string-type.enum.js');
|
|
23
|
+
var routeType_enum = require('../../enum/decorator/api/route-type.enum.js');
|
|
24
|
+
var filter_utility = require('../../utility/api/controller/get-list/transform/filter.utility.js');
|
|
25
|
+
var dto_utility = require('../../utility/api/controller/get/dto.utility.js');
|
|
26
|
+
var primaryColumn_utility = require('../../utility/api/controller/get/primary-column.utility.js');
|
|
27
|
+
var handleRequestRelations_utility = require('../../utility/api/controller/handle-request-relations.utility.js');
|
|
28
|
+
var serializeRouteResponse_utility = require('../../utility/api/controller/serialize-route-response.utility.js');
|
|
29
|
+
var transformData_utility = require('../../utility/api/controller/transform-data.utility.js');
|
|
30
|
+
var validateRequest_utility = require('../../utility/api/controller/validate-request.utility.js');
|
|
31
|
+
var projectRelation_utility = require('../../utility/api/route/response/project-relation.utility.js');
|
|
32
|
+
var serialize_utility = require('../../utility/api/route/response/serialize.utility.js');
|
|
33
|
+
var applyResult_utility = require('../../utility/authorization/decision/apply-result.utility.js');
|
|
34
|
+
var attachResource_utility = require('../../utility/authorization/decision/attach-resource.utility.js');
|
|
35
|
+
var resolveFromRequest_utility = require('../../utility/authorization/decision/resolve-from-request.utility.js');
|
|
36
|
+
var scopeMergeWhere_utility = require('../../utility/authorization/scope-merge-where.utility.js');
|
|
37
|
+
var exception_utility = require('../../utility/error/exception.utility.js');
|
|
38
|
+
|
|
39
|
+
class ApiRouteRuntime {
|
|
40
|
+
static async executeCustom(options) {
|
|
41
|
+
const action = options.metadata.resource.action;
|
|
42
|
+
const entityInstance = new options.metadata.resource.entity();
|
|
43
|
+
const request = options.executionContext.switchToHttp().getRequest();
|
|
44
|
+
const headers = {};
|
|
45
|
+
for (const [key, value] of Object.entries(request.headers ?? {})) {
|
|
46
|
+
if (typeof value === "string") {
|
|
47
|
+
headers[key] = value;
|
|
48
|
+
}
|
|
49
|
+
else if (Array.isArray(value) && typeof value[0] === "string") {
|
|
50
|
+
headers[key] = value[0];
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
const contextData = {
|
|
54
|
+
authenticationRequest: request,
|
|
55
|
+
headers,
|
|
56
|
+
ip: request.ip ?? "",
|
|
57
|
+
metadata: options.metadata,
|
|
58
|
+
runtimeProperties: options.runtimeProperties,
|
|
59
|
+
};
|
|
60
|
+
const beforeContext = {
|
|
61
|
+
action,
|
|
62
|
+
DATA: contextData,
|
|
63
|
+
ENTITY: entityInstance,
|
|
64
|
+
result: {
|
|
65
|
+
body: request.body,
|
|
66
|
+
parameters: request.params,
|
|
67
|
+
query: request.query,
|
|
68
|
+
},
|
|
69
|
+
ROUTE_TYPE: options.metadata.route.type,
|
|
70
|
+
};
|
|
71
|
+
try {
|
|
72
|
+
const beforeResult = await executor_class.ApiSubscriberExecutor.executeRouteSubscribers(options.executionContext.getClass(), entityInstance, options.metadata.route.type, onType_enum.EApiSubscriberOnType.BEFORE, beforeContext, action);
|
|
73
|
+
if (beforeResult) {
|
|
74
|
+
request.body = beforeResult.body;
|
|
75
|
+
request.params = beforeResult.parameters;
|
|
76
|
+
request.query = beforeResult.query;
|
|
77
|
+
}
|
|
78
|
+
await this.executeRequestTargets(options.metadata, options.runtimeProperties, request, contextData);
|
|
79
|
+
}
|
|
80
|
+
catch (error) {
|
|
81
|
+
await this.executeCustomErrorSubscribers(options, entityInstance, contextData, onType_enum.EApiSubscriberOnType.BEFORE_ERROR, error);
|
|
82
|
+
throw error;
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
const result = await options.operation();
|
|
86
|
+
const transformedResult = await this.executeCustomResponse(options, entityInstance, contextData, result);
|
|
87
|
+
return transformedResult;
|
|
88
|
+
}
|
|
89
|
+
catch (error) {
|
|
90
|
+
await this.executeCustomErrorSubscribers(options, entityInstance, contextData, onType_enum.EApiSubscriberOnType.AFTER_ERROR, error);
|
|
91
|
+
throw error;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
static async executeCustomRequestRelations(controller, metadata, runtimeProperties, body) {
|
|
95
|
+
if (!body) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
await handleRequestRelations_utility.ApiControllerHandleRequestRelations(controller, { entity: metadata.resource.entity}, runtimeProperties.relations?.request, body);
|
|
99
|
+
}
|
|
100
|
+
static async executeCustomResponseRelations(controller, runtimeProperties, response) {
|
|
101
|
+
if (!runtimeProperties.relations?.response?.load?.include) {
|
|
102
|
+
return response;
|
|
103
|
+
}
|
|
104
|
+
if (!(controller.service instanceof serviceBase_class.ApiServiceBase)) {
|
|
105
|
+
throw exception_utility.ErrorException("ApiRouteCustom response relation loading requires a controller service extending ApiServiceBase");
|
|
106
|
+
}
|
|
107
|
+
if (Array.isArray(response)) {
|
|
108
|
+
return (await Promise.all(response.map(async (item) => await this.loadCustomResponseRelations(controller.service, runtimeProperties, item))));
|
|
109
|
+
}
|
|
110
|
+
if (response !== null && typeof response === "object" && "items" in response && Array.isArray(response.items)) {
|
|
111
|
+
const responseObject = response;
|
|
112
|
+
responseObject.items = await Promise.all(responseObject.items.map(async (item) => await this.loadCustomResponseRelations(controller.service, runtimeProperties, item)));
|
|
113
|
+
return response;
|
|
114
|
+
}
|
|
115
|
+
return (await this.loadCustomResponseRelations(controller.service, runtimeProperties, response));
|
|
116
|
+
}
|
|
117
|
+
static async executeGenerated(options) {
|
|
118
|
+
const entityInstance = new options.properties.entity();
|
|
119
|
+
let authorizationDecision = resolveFromRequest_utility.AuthorizationDecisionResolveFromRequest(options.targets.authenticationRequest);
|
|
120
|
+
const beforeContext = {
|
|
121
|
+
DATA: { authorizationDecision, entityMetadata: options.entityMetadata, method: options.method, methodName: options.methodName, properties: options.properties },
|
|
122
|
+
ENTITY: entityInstance,
|
|
123
|
+
result: options.targets,
|
|
124
|
+
ROUTE_TYPE: options.method,
|
|
125
|
+
};
|
|
126
|
+
let beforeResult;
|
|
127
|
+
try {
|
|
128
|
+
beforeResult = await executor_class.ApiSubscriberExecutor.executeRouteSubscribers(options.controller.constructor, entityInstance, options.method, onType_enum.EApiSubscriberOnType.BEFORE, beforeContext);
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
await this.executeGeneratedErrorSubscribers(options, options.targets, entityInstance, beforeContext.DATA, authorizationDecision, onType_enum.EApiSubscriberOnType.BEFORE_ERROR, error);
|
|
132
|
+
throw error;
|
|
133
|
+
}
|
|
134
|
+
const targets = beforeResult ?? options.targets;
|
|
135
|
+
if (beforeResult) {
|
|
136
|
+
authorizationDecision = resolveFromRequest_utility.AuthorizationDecisionResolveFromRequest(targets.authenticationRequest);
|
|
137
|
+
}
|
|
138
|
+
let errorBoundary = onType_enum.EApiSubscriberOnType.BEFORE_ERROR;
|
|
139
|
+
try {
|
|
140
|
+
const result = await this.executeGeneratedOperation(options, targets, authorizationDecision, () => {
|
|
141
|
+
errorBoundary = onType_enum.EApiSubscriberOnType.AFTER_ERROR;
|
|
142
|
+
});
|
|
143
|
+
return await this.executeGeneratedResponse(options, targets, entityInstance, beforeContext.DATA, authorizationDecision, result);
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
await this.executeGeneratedErrorSubscribers(options, targets, entityInstance, beforeContext.DATA, authorizationDecision, errorBoundary, error);
|
|
147
|
+
throw error;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
static async executeCustomErrorSubscribers(options, entityInstance, contextData, onType, error) {
|
|
151
|
+
const action = options.metadata.resource.action;
|
|
152
|
+
const errorContext = {
|
|
153
|
+
action,
|
|
154
|
+
DATA: contextData,
|
|
155
|
+
ENTITY: entityInstance,
|
|
156
|
+
ROUTE_TYPE: options.metadata.route.type,
|
|
157
|
+
};
|
|
158
|
+
await executor_class.ApiSubscriberExecutor.executeRouteErrorSubscribers(options.executionContext.getClass(), entityInstance, options.metadata.route.type, onType, errorContext, error, action);
|
|
159
|
+
}
|
|
160
|
+
static async executeCustomResponse(options, entityInstance, contextData, result) {
|
|
161
|
+
const action = options.metadata.resource.action;
|
|
162
|
+
const responseTarget = { response: projectRelation_utility.ApiRouteProjectRelationResponse(options.runtimeProperties.relations?.response, result) };
|
|
163
|
+
let authorizationDecision = resolveFromRequest_utility.AuthorizationDecisionResolveFromRequest(contextData.authenticationRequest);
|
|
164
|
+
const controllerProperties = {
|
|
165
|
+
entity: options.metadata.resource.entity};
|
|
166
|
+
authorizationDecision = attachResource_utility.AuthorizationDecisionAttachResource(authorizationDecision, responseTarget.response);
|
|
167
|
+
transformData_utility.ApiControllerTransformData(options.runtimeProperties.response, controllerProperties, responseTarget, contextData);
|
|
168
|
+
const afterContext = {
|
|
169
|
+
action,
|
|
170
|
+
DATA: contextData,
|
|
171
|
+
ENTITY: entityInstance,
|
|
172
|
+
result: responseTarget.response,
|
|
173
|
+
ROUTE_TYPE: options.metadata.route.type,
|
|
174
|
+
};
|
|
175
|
+
const afterResult = await executor_class.ApiSubscriberExecutor.executeRouteSubscribers(options.executionContext.getClass(), entityInstance, options.metadata.route.type, onType_enum.EApiSubscriberOnType.AFTER, afterContext, action);
|
|
176
|
+
const finalResult = afterResult ?? responseTarget.response;
|
|
177
|
+
const transformedResult = (await applyResult_utility.AuthorizationDecisionApplyResult(attachResource_utility.AuthorizationDecisionAttachResource(authorizationDecision, finalResult), finalResult));
|
|
178
|
+
return serialize_utility.ApiRouteSerializeResponse(options.metadata, transformedResult);
|
|
179
|
+
}
|
|
180
|
+
static async executeGeneratedErrorSubscribers(options, targets, entityInstance, baseData, authorizationDecision, onType, error) {
|
|
181
|
+
const errorContext = {
|
|
182
|
+
DATA: { ...baseData, authenticationRequest: targets.authenticationRequest, authorizationDecision, body: targets.body, headers: targets.headers, ip: targets.ip, parameters: targets.parameters, query: targets.query },
|
|
183
|
+
ENTITY: entityInstance,
|
|
184
|
+
ROUTE_TYPE: options.method,
|
|
185
|
+
};
|
|
186
|
+
await executor_class.ApiSubscriberExecutor.executeRouteErrorSubscribers(options.controller.constructor, entityInstance, options.method, onType, errorContext, error);
|
|
187
|
+
}
|
|
188
|
+
static async executeGeneratedOperation(options, targets, authorizationDecision, markAfterBoundary) {
|
|
189
|
+
const routeConfig = options.properties.routes[options.method] ?? {};
|
|
190
|
+
switch (options.method) {
|
|
191
|
+
case routeType_enum.EApiRouteType.CREATE: {
|
|
192
|
+
await this.executeGeneratedRequestPipeline(options, targets, [target_enum.EApiControllerRequestTarget.BODY]);
|
|
193
|
+
await handleRequestRelations_utility.ApiControllerHandleRequestRelations(options.controller, options.properties, routeConfig.relations?.request, targets.body ?? {});
|
|
194
|
+
const primaryKey = this.resolvePrimaryKey(targets.body, options.entityMetadata);
|
|
195
|
+
markAfterBoundary();
|
|
196
|
+
const createResponse = await options.controller.service.create((targets.body ?? {}));
|
|
197
|
+
return await options.controller.service.get({
|
|
198
|
+
relations: routeConfig.relations?.response?.load?.include,
|
|
199
|
+
where: scopeMergeWhere_utility.AuthorizationScopeMergeWhere({ [primaryKey.key]: createResponse[primaryKey.key] }, authorizationDecision?.scope?.where),
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
case routeType_enum.EApiRouteType.DELETE: {
|
|
203
|
+
await this.executeGeneratedRequestPipeline(options, targets, [target_enum.EApiControllerRequestTarget.PARAMETERS]);
|
|
204
|
+
const primaryKey = this.resolvePrimaryKey(targets.parameters, options.entityMetadata);
|
|
205
|
+
const requestCriteria = { [primaryKey.key]: primaryKey.value };
|
|
206
|
+
const scopedCriteria = scopeMergeWhere_utility.AuthorizationScopeMergeWhere(requestCriteria, authorizationDecision?.scope?.where);
|
|
207
|
+
markAfterBoundary();
|
|
208
|
+
await options.controller.service.delete(scopedCriteria ?? requestCriteria);
|
|
209
|
+
return undefined;
|
|
210
|
+
}
|
|
211
|
+
case routeType_enum.EApiRouteType.GET: {
|
|
212
|
+
await this.executeGeneratedRequestPipeline(options, targets, [target_enum.EApiControllerRequestTarget.PARAMETERS]);
|
|
213
|
+
const primaryKey = this.resolvePrimaryKey(targets.parameters, options.entityMetadata);
|
|
214
|
+
const requestProperties = {
|
|
215
|
+
relations: routeConfig.relations?.response?.load?.include,
|
|
216
|
+
where: scopeMergeWhere_utility.AuthorizationScopeMergeWhere({ [primaryKey.key]: primaryKey.value }, authorizationDecision?.scope?.where),
|
|
217
|
+
};
|
|
218
|
+
markAfterBoundary();
|
|
219
|
+
return await options.controller.service.get(requestProperties);
|
|
220
|
+
}
|
|
221
|
+
case routeType_enum.EApiRouteType.GET_LIST: {
|
|
222
|
+
await this.executeGeneratedRequestPipeline(options, targets, [target_enum.EApiControllerRequestTarget.QUERY]);
|
|
223
|
+
if (!targets.query) {
|
|
224
|
+
throw exception_utility.ErrorException("Query target is required for GET_LIST routes");
|
|
225
|
+
}
|
|
226
|
+
const query = targets.query;
|
|
227
|
+
const { limit, orderBy, orderDirection, page, ...getListQuery } = query;
|
|
228
|
+
const filter = filter_utility.ApiControllerGetListTransformFilter(getListQuery, options.entityMetadata);
|
|
229
|
+
const scopedFilter = scopeMergeWhere_utility.AuthorizationScopeMergeWhere(filter, authorizationDecision?.scope?.where);
|
|
230
|
+
const requestProperties = {
|
|
231
|
+
relations: routeConfig.relations?.response?.load?.include,
|
|
232
|
+
skip: query.limit * (query.page - 1),
|
|
233
|
+
take: query.limit,
|
|
234
|
+
where: scopedFilter ?? filter,
|
|
235
|
+
};
|
|
236
|
+
if (orderBy) {
|
|
237
|
+
requestProperties.order = { [orderBy]: orderDirection ?? function_constant.FUNCTION_API_DECORATOR_CONSTANT.DEFAULT_FILTER_ORDER_BY_DIRECTION };
|
|
238
|
+
}
|
|
239
|
+
markAfterBoundary();
|
|
240
|
+
return await options.controller.service.getList(requestProperties);
|
|
241
|
+
}
|
|
242
|
+
case routeType_enum.EApiRouteType.PARTIAL_UPDATE: {
|
|
243
|
+
return await this.executeGeneratedUpdateOperation(options, targets, authorizationDecision, routeConfig, markAfterBoundary);
|
|
244
|
+
}
|
|
245
|
+
case routeType_enum.EApiRouteType.UPDATE: {
|
|
246
|
+
return await this.executeGeneratedUpdateOperation(options, targets, authorizationDecision, routeConfig, markAfterBoundary);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
static async executeGeneratedRequestPipeline(options, targets, targetOrder) {
|
|
251
|
+
const routeConfig = options.properties.routes[options.method] ?? {};
|
|
252
|
+
for (const target of targetOrder) {
|
|
253
|
+
if (target === target_enum.EApiControllerRequestTarget.PARAMETERS) {
|
|
254
|
+
transformData_utility.ApiControllerTransformData(routeConfig.request, options.properties, { parameters: targets.parameters }, { authenticationRequest: targets.authenticationRequest, headers: targets.headers, ip: targets.ip });
|
|
255
|
+
await validateRequest_utility.ApiControllerValidateRequest(routeConfig.request?.[target], options.properties, targets.parameters ?? {});
|
|
256
|
+
}
|
|
257
|
+
if (target === target_enum.EApiControllerRequestTarget.QUERY) {
|
|
258
|
+
transformData_utility.ApiControllerTransformData(routeConfig.request, options.properties, { query: targets.query }, { authenticationRequest: targets.authenticationRequest, headers: targets.headers, ip: targets.ip });
|
|
259
|
+
await validateRequest_utility.ApiControllerValidateRequest(routeConfig.request?.[target], options.properties, (targets.query ?? {}));
|
|
260
|
+
}
|
|
261
|
+
if (target === target_enum.EApiControllerRequestTarget.BODY) {
|
|
262
|
+
transformData_utility.ApiControllerTransformData(routeConfig.request, options.properties, { body: targets.body }, { authenticationRequest: targets.authenticationRequest, headers: targets.headers, ip: targets.ip });
|
|
263
|
+
await validateRequest_utility.ApiControllerValidateRequest(routeConfig.request?.[target], options.properties, (targets.body ?? {}));
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
static async executeGeneratedResponse(options, targets, entityInstance, baseData, authorizationDecision, result) {
|
|
268
|
+
const routeConfig = options.properties.routes[options.method] ?? {};
|
|
269
|
+
const responseTarget = { response: result };
|
|
270
|
+
authorizationDecision = attachResource_utility.AuthorizationDecisionAttachResource(authorizationDecision, responseTarget.response);
|
|
271
|
+
transformData_utility.ApiControllerTransformData(routeConfig.response, options.properties, responseTarget, { authenticationRequest: targets.authenticationRequest, headers: targets.headers, ip: targets.ip });
|
|
272
|
+
const afterContext = {
|
|
273
|
+
DATA: { ...baseData, authenticationRequest: targets.authenticationRequest, authorizationDecision, body: targets.body, headers: targets.headers, ip: targets.ip, parameters: targets.parameters, query: targets.query },
|
|
274
|
+
ENTITY: responseTarget.response,
|
|
275
|
+
result: responseTarget.response,
|
|
276
|
+
ROUTE_TYPE: options.method,
|
|
277
|
+
};
|
|
278
|
+
const afterResult = await executor_class.ApiSubscriberExecutor.executeRouteSubscribers(options.controller.constructor, (responseTarget.response ?? entityInstance), options.method, onType_enum.EApiSubscriberOnType.AFTER, afterContext);
|
|
279
|
+
const finalResponse = afterResult ?? responseTarget.response;
|
|
280
|
+
const transformedResponse = await applyResult_utility.AuthorizationDecisionApplyResult(attachResource_utility.AuthorizationDecisionAttachResource(authorizationDecision, finalResponse), finalResponse);
|
|
281
|
+
const dto = dto_utility.ApiControllerGetDto(options.properties, options.entityMetadata, options.method, dtoType_enum.EApiDtoType.RESPONSE, routeConfig);
|
|
282
|
+
return serializeRouteResponse_utility.ApiControllerSerializeRouteResponse(routeConfig, dto, projectRelation_utility.ApiRouteProjectRelationResponse(routeConfig.relations?.response, transformedResponse));
|
|
283
|
+
}
|
|
284
|
+
static async executeGeneratedUpdateOperation(options, targets, authorizationDecision, routeConfig, markAfterBoundary) {
|
|
285
|
+
await this.executeGeneratedRequestPipeline(options, targets, [target_enum.EApiControllerRequestTarget.PARAMETERS, target_enum.EApiControllerRequestTarget.BODY]);
|
|
286
|
+
await handleRequestRelations_utility.ApiControllerHandleRequestRelations(options.controller, options.properties, routeConfig.relations?.request, targets.body ?? {});
|
|
287
|
+
const primaryKey = this.resolvePrimaryKey(targets.parameters, options.entityMetadata);
|
|
288
|
+
const requestCriteria = { [primaryKey.key]: primaryKey.value };
|
|
289
|
+
const scopedCriteria = scopeMergeWhere_utility.AuthorizationScopeMergeWhere(requestCriteria, authorizationDecision?.scope?.where);
|
|
290
|
+
markAfterBoundary();
|
|
291
|
+
const updateResponse = await options.controller.service.update(scopedCriteria ?? requestCriteria, (targets.body ?? {}));
|
|
292
|
+
if (!routeConfig.relations?.response?.load?.include) {
|
|
293
|
+
return updateResponse;
|
|
294
|
+
}
|
|
295
|
+
return await options.controller.service.get({
|
|
296
|
+
relations: routeConfig.relations.response.load.include,
|
|
297
|
+
where: scopeMergeWhere_utility.AuthorizationScopeMergeWhere({ [primaryKey.key]: updateResponse[primaryKey.key] }, authorizationDecision?.scope?.where),
|
|
298
|
+
});
|
|
299
|
+
}
|
|
300
|
+
static async executeRequestTargets(metadata, runtimeProperties, request, contextData) {
|
|
301
|
+
const controllerProperties = {
|
|
302
|
+
entity: metadata.resource.entity};
|
|
303
|
+
transformData_utility.ApiControllerTransformData(runtimeProperties.request, controllerProperties, { parameters: request.params }, contextData);
|
|
304
|
+
await validateRequest_utility.ApiControllerValidateRequest(runtimeProperties.request?.[target_enum.EApiControllerRequestTarget.PARAMETERS], controllerProperties, request.params ?? {});
|
|
305
|
+
transformData_utility.ApiControllerTransformData(runtimeProperties.request, controllerProperties, { query: request.query }, contextData);
|
|
306
|
+
await validateRequest_utility.ApiControllerValidateRequest(runtimeProperties.request?.[target_enum.EApiControllerRequestTarget.QUERY], controllerProperties, (request.query ?? {}));
|
|
307
|
+
transformData_utility.ApiControllerTransformData(runtimeProperties.request, controllerProperties, { body: request.body }, contextData);
|
|
308
|
+
await validateRequest_utility.ApiControllerValidateRequest(runtimeProperties.request?.[target_enum.EApiControllerRequestTarget.BODY], controllerProperties, request.body ?? {});
|
|
309
|
+
}
|
|
310
|
+
static async loadCustomResponseRelations(service, runtimeProperties, response) {
|
|
311
|
+
if (response === null || typeof response !== "object" || !("id" in response)) {
|
|
312
|
+
return response;
|
|
313
|
+
}
|
|
314
|
+
const responseId = response.id;
|
|
315
|
+
if (responseId === undefined || responseId === null) {
|
|
316
|
+
return response;
|
|
317
|
+
}
|
|
318
|
+
return await service.get({
|
|
319
|
+
relations: runtimeProperties.relations?.response?.load?.include,
|
|
320
|
+
where: {
|
|
321
|
+
id: responseId,
|
|
322
|
+
},
|
|
323
|
+
});
|
|
324
|
+
}
|
|
325
|
+
static resolvePrimaryKey(source, entityMetadata) {
|
|
326
|
+
const primaryKey = primaryColumn_utility.ApiControllerGetPrimaryColumn(source ?? {}, entityMetadata);
|
|
327
|
+
if (!primaryKey) {
|
|
328
|
+
throw exception_utility.ErrorException("Primary key not found in entity columns");
|
|
329
|
+
}
|
|
330
|
+
return primaryKey;
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
exports.ApiRouteRuntime = ApiRouteRuntime;
|
|
335
|
+
//# sourceMappingURL=route-runtime.class.js.map
|