mongodb-dynamic-api 4.6.1 → 4.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +24 -0
- package/package.json +5 -5
- package/src/decorators/derived-field.decorator.d.ts +11 -0
- package/src/decorators/derived-field.decorator.js +16 -0
- package/src/decorators/derived-field.decorator.js.map +1 -0
- package/src/decorators/index.d.ts +2 -0
- package/src/decorators/index.js +2 -0
- package/src/decorators/index.js.map +1 -1
- package/src/decorators/protected-field.decorator.d.ts +3 -0
- package/src/decorators/protected-field.decorator.js +13 -0
- package/src/decorators/protected-field.decorator.js.map +1 -0
- package/src/dynamic-api.module.js +1 -0
- package/src/dynamic-api.module.js.map +1 -1
- package/src/helpers/from-user.helper.d.ts +4 -0
- package/src/helpers/from-user.helper.js +20 -0
- package/src/helpers/from-user.helper.js.map +1 -0
- package/src/helpers/index.d.ts +1 -0
- package/src/helpers/index.js +1 -0
- package/src/helpers/index.js.map +1 -1
- package/src/index.d.ts +1 -0
- package/src/index.js +3 -0
- package/src/index.js.map +1 -1
- package/src/interfaces/dynamic-api-global-state.interface.d.ts +1 -0
- package/src/interfaces/dynamic-api-request.interface.d.ts +4 -0
- package/src/interfaces/dynamic-api-request.interface.js +3 -0
- package/src/interfaces/dynamic-api-request.interface.js.map +1 -0
- package/src/interfaces/dynamic-api-route-config.interface.d.ts +3 -1
- package/src/interfaces/index.d.ts +1 -0
- package/src/interfaces/index.js +1 -0
- package/src/interfaces/index.js.map +1 -1
- package/src/mixins/entity-body.mixin.d.ts +3 -1
- package/src/mixins/entity-body.mixin.js +18 -0
- package/src/mixins/entity-body.mixin.js.map +1 -1
- package/src/modules/auth/auth-operation-context.d.ts +5 -0
- package/src/modules/auth/auth-operation-context.js +9 -0
- package/src/modules/auth/auth-operation-context.js.map +1 -0
- package/src/modules/auth/auth.helper.js +1 -0
- package/src/modules/auth/auth.helper.js.map +1 -1
- package/src/modules/auth/index.d.ts +1 -0
- package/src/modules/auth/index.js +1 -0
- package/src/modules/auth/index.js.map +1 -1
- package/src/modules/auth/interfaces/auth-controller.interface.d.ts +1 -1
- package/src/modules/auth/interfaces/auth-gateway.interface.d.ts +1 -1
- package/src/modules/auth/interfaces/auth-options.interface.d.ts +1 -0
- package/src/modules/auth/interfaces/auth-service.interface.d.ts +1 -1
- package/src/modules/auth/mixins/auth-controller.mixin.d.ts +1 -1
- package/src/modules/auth/mixins/auth-controller.mixin.js +23 -7
- package/src/modules/auth/mixins/auth-controller.mixin.js.map +1 -1
- package/src/modules/auth/mixins/auth-gateway.mixin.js +7 -4
- package/src/modules/auth/mixins/auth-gateway.mixin.js.map +1 -1
- package/src/modules/auth/services/base-auth.service.d.ts +2 -1
- package/src/modules/auth/services/base-auth.service.js +5 -0
- package/src/modules/auth/services/base-auth.service.js.map +1 -1
- package/src/routes/aggregate/aggregate-controller.interface.d.ts +3 -2
- package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
- package/src/routes/create-many/base-create-many.service.js +2 -1
- package/src/routes/create-many/base-create-many.service.js.map +1 -1
- package/src/routes/create-many/create-many-controller.interface.d.ts +4 -3
- package/src/routes/create-many/create-many-controller.mixin.d.ts +1 -1
- package/src/routes/create-many/create-many-controller.mixin.js +3 -2
- package/src/routes/create-many/create-many-controller.mixin.js.map +1 -1
- package/src/routes/create-one/base-create-one.service.js +2 -1
- package/src/routes/create-one/base-create-one.service.js.map +1 -1
- package/src/routes/create-one/create-one-controller.interface.d.ts +3 -2
- package/src/routes/create-one/create-one-controller.mixin.d.ts +1 -1
- package/src/routes/create-one/create-one-controller.mixin.js +4 -2
- package/src/routes/create-one/create-one-controller.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many-controller.interface.d.ts +3 -3
- package/src/routes/delete-many/delete-many-controller.mixin.js.map +1 -1
- package/src/routes/delete-one/delete-one-controller.interface.d.ts +3 -3
- package/src/routes/delete-one/delete-one-controller.mixin.js.map +1 -1
- package/src/routes/duplicate-many/base-duplicate-many.service.js +2 -1
- package/src/routes/duplicate-many/base-duplicate-many.service.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-controller.interface.d.ts +3 -2
- package/src/routes/duplicate-many/duplicate-many-controller.mixin.d.ts +1 -1
- package/src/routes/duplicate-many/duplicate-many-controller.mixin.js +4 -2
- package/src/routes/duplicate-many/duplicate-many-controller.mixin.js.map +1 -1
- package/src/routes/duplicate-one/base-duplicate-one.service.js +2 -1
- package/src/routes/duplicate-one/base-duplicate-one.service.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-controller.interface.d.ts +3 -2
- package/src/routes/duplicate-one/duplicate-one-controller.mixin.d.ts +1 -1
- package/src/routes/duplicate-one/duplicate-one-controller.mixin.js +4 -2
- package/src/routes/duplicate-one/duplicate-one-controller.mixin.js.map +1 -1
- package/src/routes/get-many/get-many-controller.interface.d.ts +3 -2
- package/src/routes/get-many/get-many-controller.mixin.js.map +1 -1
- package/src/routes/get-one/get-one-controller.interface.d.ts +3 -2
- package/src/routes/get-one/get-one-controller.mixin.js.map +1 -1
- package/src/routes/replace-one/base-replace-one.service.js +2 -1
- package/src/routes/replace-one/base-replace-one.service.js.map +1 -1
- package/src/routes/replace-one/replace-one-controller.interface.d.ts +3 -2
- package/src/routes/replace-one/replace-one-controller.mixin.d.ts +1 -1
- package/src/routes/replace-one/replace-one-controller.mixin.js +4 -2
- package/src/routes/replace-one/replace-one-controller.mixin.js.map +1 -1
- package/src/routes/update-many/base-update-many.service.js +4 -2
- package/src/routes/update-many/base-update-many.service.js.map +1 -1
- package/src/routes/update-many/update-many-controller.interface.d.ts +3 -2
- package/src/routes/update-many/update-many-controller.mixin.d.ts +1 -1
- package/src/routes/update-many/update-many-controller.mixin.js +4 -2
- package/src/routes/update-many/update-many-controller.mixin.js.map +1 -1
- package/src/routes/update-one/base-update-one.service.js +2 -1
- package/src/routes/update-one/base-update-one.service.js.map +1 -1
- package/src/routes/update-one/update-one-controller.interface.d.ts +3 -2
- package/src/routes/update-one/update-one-controller.mixin.d.ts +1 -1
- package/src/routes/update-one/update-one-controller.mixin.js +4 -2
- package/src/routes/update-one/update-one-controller.mixin.js.map +1 -1
- package/src/services/base/base.service.d.ts +1 -0
- package/src/services/base/base.service.js +21 -1
- package/src/services/base/base.service.js.map +1 -1
- package/src/version.json +1 -1
- package/test/for-feature/derived-fields-protected-from-user.e2e-spec.d.ts +1 -0
- package/test/for-feature/derived-fields-protected-from-user.e2e-spec.js +199 -0
- package/test/for-feature/derived-fields-protected-from-user.e2e-spec.js.map +1 -0
- package/test/for-root/auth-api-basic.e2e-spec.js +3 -1
- package/test/for-root/auth-api-basic.e2e-spec.js.map +1 -1
- package/test/for-root/auth-api-update-account.e2e-spec.d.ts +1 -0
- package/test/for-root/auth-api-update-account.e2e-spec.js +130 -0
- package/test/for-root/auth-api-update-account.e2e-spec.js.map +1 -0
- package/test/for-root/websockets-auth-basic.e2e-spec.js +1 -0
- package/test/for-root/websockets-auth-basic.e2e-spec.js.map +1 -1
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-duplicate-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/base-duplicate-many.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAO1C,yCAAuD;AAEvD,6CAA6C;AAG7C,MAAsB,wBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,GAAa,EAAE,OAAoC,EAAE,IAAc;QACrF,IAAI,CAAC;YACH,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,KAAK;iBACvC,IAAI,CAAC;gBACJ,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE;gBACjB,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAY;iBAChB,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE,CAAC;gBAC7B,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,YAAY,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC/C,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;oBAChD,IACE,IAAA,gCAAuB,GACxB,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;wBAChB,OAAO,GAAG,CAAC;oBACb,CAAC;oBAED,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;gBAClC,CAAC,EAAE,EAAE,CAAC;gBACN,GAAG,OAAO;aACX,CAAC,CAAC,CAAC;YAEJ,MAAM,
|
|
1
|
+
{"version":3,"file":"base-duplicate-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/base-duplicate-many.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAO1C,yCAAuD;AAEvD,6CAA6C;AAG7C,MAAsB,wBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,GAAa,EAAE,OAAoC,EAAE,IAAc;QACrF,IAAI,CAAC;YACH,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,KAAK;iBACvC,IAAI,CAAC;gBACJ,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE;gBACjB,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAY;iBAChB,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE,CAAC;gBAC7B,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,YAAY,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC/C,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;oBAChD,IACE,IAAA,gCAAuB,GACxB,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;wBAChB,OAAO,GAAG,CAAC;oBACb,CAAC;oBAED,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;gBAClC,CAAC,EAAE,EAAE,CAAC;gBACN,GAAG,OAAO;aACX,CAAC,CAAC,CAAC;YAEJ,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB;gBAC3C,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,eAAe,EACf,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,IAAA,mBAAS,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,EAC3D,IAAI,CAAC,eAAe,EACpB,IAAI,CACL;gBACD,CAAC,CAAC,YAAY,CAAC;YAEjB,MAAM,YAAY,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;YAElF,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EACpF,IAAI,CAAC,MAAM,EACX,CAAC,CACF,CAAC,CAAC,CAAC;YACJ,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC;iBACzG,IAAI,EAAY;iBAChB,IAAI,EAAE,CAAC;YAER,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,MAAM,EAAE,CAAC;gBACtC,MAAM,OAAO,CAAC,GAAG,CACf,SAAS,CAAC,GAAG,CACX,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CACtF,CACF,CAAC;YACJ,CAAC;YAED,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YAC9E,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;CACF;AA9ED,4DA8EC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { DynamicApiBroadcastService } from '../../services';
|
|
3
4
|
import { DuplicateManyService } from './duplicate-many-service.interface';
|
|
4
|
-
interface DuplicateManyController<Entity extends BaseEntity, Body =
|
|
5
|
-
duplicateMany(ids: string[], body?: Body, req?:
|
|
5
|
+
interface DuplicateManyController<Entity extends BaseEntity, Body = unknown, Response = unknown> {
|
|
6
|
+
duplicateMany(ids: string[], body?: Body, req?: DynamicApiRequest): Promise<(Entity | Response)[]>;
|
|
6
7
|
}
|
|
7
8
|
type DuplicateManyControllerConstructor<Entity extends BaseEntity> = new (service: DuplicateManyService<Entity>, broadcastService?: DynamicApiBroadcastService) => DuplicateManyController<Entity>;
|
|
8
9
|
export type { DuplicateManyController, DuplicateManyControllerConstructor };
|
|
@@ -2,5 +2,5 @@ import { Type } from '@nestjs/common';
|
|
|
2
2
|
import { DynamicApiControllerOptions, DynamicAPIRouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DuplicateManyControllerConstructor } from './duplicate-many-controller.interface';
|
|
5
|
-
declare function DuplicateManyControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): DuplicateManyControllerConstructor<Entity>;
|
|
5
|
+
declare function DuplicateManyControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, fromUser, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): DuplicateManyControllerConstructor<Entity>;
|
|
6
6
|
export { DuplicateManyControllerMixin };
|
|
@@ -18,7 +18,7 @@ const builders_1 = require("../../builders");
|
|
|
18
18
|
const helpers_1 = require("../../helpers");
|
|
19
19
|
const mixins_1 = require("../../mixins");
|
|
20
20
|
const services_1 = require("../../services");
|
|
21
|
-
function DuplicateManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, ...routeConfig }, version) {
|
|
21
|
+
function DuplicateManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, fromUser, ...routeConfig }, version) {
|
|
22
22
|
const { routeType, displayedName, description, isPublic, abilityPredicate, event, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
23
|
class DuplicateManyBody extends (dTOs?.body ?? (0, mixins_1.EntityBodyMixin)(entity, true)) {
|
|
24
24
|
}
|
|
@@ -51,7 +51,9 @@ function DuplicateManyControllerMixin(entity, controllerOptions, { dTOs, useInte
|
|
|
51
51
|
throw new Error('Invalid query');
|
|
52
52
|
}
|
|
53
53
|
const toEntity = DuplicateManyBody.toEntity;
|
|
54
|
-
const
|
|
54
|
+
const rawPartial = !(0, helpers_1.isEmpty)(body) && toEntity ? toEntity(body) : body;
|
|
55
|
+
const partial = (0, helpers_1.applyFromUser)((0, mixins_1.stripProtectedFields)(rawPartial, this.entity), fromUser, req?.user);
|
|
56
|
+
const list = await this.service.duplicateMany(ids, partial, req?.user);
|
|
55
57
|
const fromEntities = DuplicateManyPresenter.fromEntities;
|
|
56
58
|
const responseData = fromEntities ? fromEntities(list) : list;
|
|
57
59
|
this.broadcastService?.broadcastFromHttp(event, responseData, broadcastConfig);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -31,9 +31,10 @@ class BaseDuplicateOneService extends services_1.BaseService {
|
|
|
31
31
|
}, {}),
|
|
32
32
|
...partial,
|
|
33
33
|
};
|
|
34
|
-
const
|
|
34
|
+
const afterCallback = this.beforeSaveCallback
|
|
35
35
|
? await this.beforeSaveCallback(this.addDocumentId(toDuplicate), { id, override: partial ? (0, helpers_1.cloneDeep)(partial) : undefined }, this.callbackMethods, user)
|
|
36
36
|
: baseData;
|
|
37
|
+
const toCreate = this.applyDerivedFields(afterCallback, 'save');
|
|
37
38
|
const { _id } = await this.model.create((0, class_transformer_1.plainToInstance)(this.entity, toCreate));
|
|
38
39
|
const document = await this.model.findOne({ _id }).lean().exec();
|
|
39
40
|
if (this.callback) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-duplicate-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/base-duplicate-one.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAO1C,yCAAuD;AAEvD,6CAA6C;AAG7C,MAAsB,uBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAU,EAAE,OAAoC,EAAE,IAAc;QACjF,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,KAAK;iBACjC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;aAC7D,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAEV,IAAI,CAAC,WAAW,EAAE,CAAC;gBACjB,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,QAAQ,GAAG;gBACf,GAAG,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;oBAC1D,IAAK,IAAA,gCAAuB,GAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;wBAC1D,OAAO,GAAG,CAAC;oBACb,CAAC;oBAED,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;gBAClC,CAAC,EAAE,EAAE,CAAC;gBACN,GAAG,OAAO;aACX,CAAC;YAEF,MAAM,
|
|
1
|
+
{"version":3,"file":"base-duplicate-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/base-duplicate-one.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAO1C,yCAAuD;AAEvD,6CAA6C;AAG7C,MAAsB,uBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EAAU,EAAE,OAAoC,EAAE,IAAc;QACjF,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,KAAK;iBACjC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;aAC7D,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAEV,IAAI,CAAC,WAAW,EAAE,CAAC;gBACjB,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,QAAQ,GAAG;gBACf,GAAG,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;oBAC1D,IAAK,IAAA,gCAAuB,GAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;wBAC1D,OAAO,GAAG,CAAC;oBACb,CAAC;oBAED,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;gBAClC,CAAC,EAAE,EAAE,CAAC;gBACN,GAAG,OAAO;aACX,CAAC;YAEF,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB;gBAC3C,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAC/B,EAAE,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,IAAA,mBAAS,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,EAC1D,IAAI,CAAC,eAAe,EACpB,IAAI,CACL;gBACD,CAAC,CAAC,QAAQ,CAAC;YAEb,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;YAEhE,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAA,mCAAe,EAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;YAChF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAU,CAAC,IAAI,EAAE,CAAC;YAEzE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YAChF,CAAC;YAED,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YAC9E,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;CACF;AAjED,0DAiEC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { DynamicApiBroadcastService } from '../../services';
|
|
3
4
|
import { DuplicateOneService } from './duplicate-one-service.interface';
|
|
4
|
-
interface DuplicateOneController<Entity extends BaseEntity, Body =
|
|
5
|
-
duplicateOne(id: string, body?: Body, req?:
|
|
5
|
+
interface DuplicateOneController<Entity extends BaseEntity, Body = unknown, Response = unknown> {
|
|
6
|
+
duplicateOne(id: string, body?: Body, req?: DynamicApiRequest): Promise<Entity | Response>;
|
|
6
7
|
}
|
|
7
8
|
type DuplicateOneControllerConstructor<Entity extends BaseEntity> = new (service: DuplicateOneService<Entity>, broadcastService?: DynamicApiBroadcastService) => DuplicateOneController<Entity>;
|
|
8
9
|
export type { DuplicateOneController, DuplicateOneControllerConstructor };
|
|
@@ -2,5 +2,5 @@ import { Type } from '@nestjs/common';
|
|
|
2
2
|
import { DynamicApiControllerOptions, DynamicAPIRouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DuplicateOneControllerConstructor } from './duplicate-one-controller.interface';
|
|
5
|
-
declare function DuplicateOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): DuplicateOneControllerConstructor<Entity>;
|
|
5
|
+
declare function DuplicateOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, fromUser, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): DuplicateOneControllerConstructor<Entity>;
|
|
6
6
|
export { DuplicateOneControllerMixin };
|
|
@@ -19,7 +19,7 @@ const dtos_1 = require("../../dtos");
|
|
|
19
19
|
const helpers_1 = require("../../helpers");
|
|
20
20
|
const mixins_1 = require("../../mixins");
|
|
21
21
|
const services_1 = require("../../services");
|
|
22
|
-
function DuplicateOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, ...routeConfig }, version) {
|
|
22
|
+
function DuplicateOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, fromUser, ...routeConfig }, version) {
|
|
23
23
|
const { routeType, displayedName, description, isPublic, abilityPredicate, event, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
24
24
|
class DuplicateOneBody extends (dTOs?.body ?? (0, mixins_1.EntityBodyMixin)(entity, true)) {
|
|
25
25
|
}
|
|
@@ -50,7 +50,9 @@ function DuplicateOneControllerMixin(entity, controllerOptions, { dTOs, useInter
|
|
|
50
50
|
}
|
|
51
51
|
async duplicateOne(id, body, req) {
|
|
52
52
|
const toEntity = DuplicateOneBody.toEntity;
|
|
53
|
-
const
|
|
53
|
+
const rawPartial = !(0, helpers_1.isEmpty)(body) && toEntity ? toEntity(body) : body;
|
|
54
|
+
const partial = (0, helpers_1.applyFromUser)((0, mixins_1.stripProtectedFields)(rawPartial, this.entity), fromUser, req?.user);
|
|
55
|
+
const entity = await this.service.duplicateOne(id, partial, req?.user);
|
|
54
56
|
const fromEntity = DuplicateOnePresenter.fromEntity;
|
|
55
57
|
const responseData = fromEntity ? fromEntity(entity) : entity;
|
|
56
58
|
this.broadcastService?.broadcastFromHttp(event, [responseData], broadcastConfig);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { GetManyService } from './get-many-service.interface';
|
|
3
|
-
interface GetManyController<Entity extends BaseEntity, Query =
|
|
4
|
-
getMany(query?: Query, req?:
|
|
4
|
+
interface GetManyController<Entity extends BaseEntity, Query = unknown, Response = unknown> {
|
|
5
|
+
getMany(query?: Query, req?: DynamicApiRequest): Promise<(Entity | Response)[]>;
|
|
5
6
|
}
|
|
6
7
|
type GetManyControllerConstructor<Entity extends BaseEntity> = new (service: GetManyService<Entity>) => GetManyController<Entity>;
|
|
7
8
|
export type { GetManyController, GetManyControllerConstructor };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAsGS,wDAAsB;AAtG/B,2CAA+F;AAC/F,6CAAwD;AACxD,iDAAqD;AACrD,qCAAyC;AACzC,2CAAmG;AAEnG,yCAA6E;AAK7E,SAAS,sBAAsB,CAC7B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,gBAAgB,GACjB,GAAG,IAAA,sBAAY,EACd,MAAM,EACN,iBAAiB,EACjB,WAAW,CACZ,CAAC;IAEF,MAAM,YAAa,SAAQ,CAAC,IAAI,EAAE,KAAK,IAAI,kBAAW,CAAC;KAAG;IAE1D,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE,MAAM,EAAE;QAC1C,KAAK,EAAE,UAAU,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,OAAO;QACjE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,gBAAiB,SAAQ,CAC7B,IAAI,EAAE,SAAS,IAAI,IAAA,6BAAoB,EAAC,MAAM,CAAC,CAChD;KAAG;IAEJ,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,MAAM,EAAE;QAC9C,KAAK,EAAE,IAAI,EAAE,SAAS;YACpB,CAAC,CAAC,UAAU,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;YAChE,CAAC,CAAC,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;QAC3D,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,sBAAsB,GAAG,IAAI,iCAAsB,CACvD,SAAS,EACT,MAAM,EACN,WAAW,CAAC,OAAO,EACnB,OAAO,EACP,WAAW,EACX,QAAQ,EACR;QACE,SAAS,EAAE,gBAAgB;KAC5B,CACF,CAAC;IAEF,MAAM,oBAAqB,SAAQ,IAAA,gCAAuB,EACxD,MAAM,EACN,SAAS,EACT,aAAa,EACb,OAAO,EACP,gBAAgB,CACjB;KAAG;IAEJ,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,GAAG,SAAS,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,eAAe;QAC9E,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,qBAAqB;QAGzB,YAA+B,OAA+B;YAA/B,YAAO,GAAP,OAAO,CAAwB;YAF3C,WAAM,GAAG,MAAM,CAAC;QAGnC,CAAC;QAMK,AAAN,KAAK,CAAC,OAAO,CAAU,KAAmB,EAAa,
|
|
1
|
+
{"version":3,"file":"get-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { GetOneService } from './get-one-service.interface';
|
|
3
|
-
interface GetOneController<Entity extends BaseEntity, Response =
|
|
4
|
-
getOne(id: string, req?:
|
|
4
|
+
interface GetOneController<Entity extends BaseEntity, Response = unknown> {
|
|
5
|
+
getOne(id: string, req?: DynamicApiRequest): Promise<Entity | Response>;
|
|
5
6
|
}
|
|
6
7
|
type GetOneControllerConstructor<Entity extends BaseEntity> = new (service: GetOneService<Entity>) => GetOneController<Entity>;
|
|
7
8
|
export type { GetOneController, GetOneControllerConstructor };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-one/get-one-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AA2FS,sDAAqB;AA3F9B,2CAA+F;AAC/F,6CAAwD;AACxD,iDAAqD;AACrD,qCAAyC;AACzC,2CAAmG;AAEnG,yCAA6E;AAK7E,SAAS,qBAAqB,CAC5B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,gBAAgB,GACjB,GAAG,IAAA,sBAAY,EACd,MAAM,EACN,iBAAiB,EACjB,WAAW,CACZ,CAAC;IAEF,MAAM,eAAgB,SAAQ,CAC5B,IAAI,EAAE,SAAS,IAAI,IAAA,6BAAoB,EAAC,MAAM,CAAC,CAChD;KAAG;IAEJ,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE,MAAM,EAAE;QAC7C,KAAK,EAAE,IAAI,EAAE,SAAS;YACpB,CAAC,CAAC,SAAS,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;YAC/D,CAAC,CAAC,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;QAC3D,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,sBAAsB,GAAG,IAAI,iCAAsB,CACvD,SAAS,EACT,MAAM,EACN,WAAW,CAAC,OAAO,EACnB,OAAO,EACP,WAAW,EACX,QAAQ,EACR;QACE,KAAK,EAAE,kBAAW;QAClB,SAAS,EAAE,eAAe;KAC3B,CACF,CAAC;IAEF,MAAM,mBAAoB,SAAQ,IAAA,gCAAuB,EACvD,MAAM,EACN,SAAS,EACT,aAAa,EACb,OAAO,EACP,gBAAgB,CACjB;KAAG;IAEJ,MAAM,oBAAoB;QAGxB,YAA+B,OAA8B;YAA9B,YAAO,GAAP,OAAO,CAAuB;YAF1C,WAAM,GAAG,MAAM,CAAC;QAGnC,CAAC;QAMK,AAAN,KAAK,CAAC,MAAM,CAAc,EAAU,EAAa,
|
|
1
|
+
{"version":3,"file":"get-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-one/get-one-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AA2FS,sDAAqB;AA3F9B,2CAA+F;AAC/F,6CAAwD;AACxD,iDAAqD;AACrD,qCAAyC;AACzC,2CAAmG;AAEnG,yCAA6E;AAK7E,SAAS,qBAAqB,CAC5B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,gBAAgB,GACjB,GAAG,IAAA,sBAAY,EACd,MAAM,EACN,iBAAiB,EACjB,WAAW,CACZ,CAAC;IAEF,MAAM,eAAgB,SAAQ,CAC5B,IAAI,EAAE,SAAS,IAAI,IAAA,6BAAoB,EAAC,MAAM,CAAC,CAChD;KAAG;IAEJ,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE,MAAM,EAAE;QAC7C,KAAK,EAAE,IAAI,EAAE,SAAS;YACpB,CAAC,CAAC,SAAS,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;YAC/D,CAAC,CAAC,GAAG,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,WAAW;QAC3D,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,sBAAsB,GAAG,IAAI,iCAAsB,CACvD,SAAS,EACT,MAAM,EACN,WAAW,CAAC,OAAO,EACnB,OAAO,EACP,WAAW,EACX,QAAQ,EACR;QACE,KAAK,EAAE,kBAAW;QAClB,SAAS,EAAE,eAAe;KAC3B,CACF,CAAC;IAEF,MAAM,mBAAoB,SAAQ,IAAA,gCAAuB,EACvD,MAAM,EACN,SAAS,EACT,aAAa,EACb,OAAO,EACP,gBAAgB,CACjB;KAAG;IAEJ,MAAM,oBAAoB;QAGxB,YAA+B,OAA8B;YAA9B,YAAO,GAAP,OAAO,CAAuB;YAF1C,WAAM,GAAG,MAAM,CAAC;QAGnC,CAAC;QAMK,AAAN,KAAK,CAAC,MAAM,CAAc,EAAU,EAAa,GAAuB;YACtE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;YAExD,MAAM,UAAU,GACd,eACD,CAAC,UAAU,CAAC;YAEb,OAAO,UAAU,CAAC,CAAC,CAAC,UAAU,CAAkB,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QACnE,CAAC;KACF;IATO;QAJL,IAAA,+BAAqB,EAAC,sBAAsB,CAAC;QAC7C,IAAA,kBAAS,EAAC,mBAAmB,CAAC;QAC9B,IAAA,wBAAe,EAAC,GAAG,eAAe,CAAC;QACnC,IAAA,oBAAW,EAAC,8BAAiB,EAAE,YAAY,CAAC;QAC/B,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;QAAc,WAAA,IAAA,gBAAO,GAAE,CAAA;;;;sDAQ/C;IAGH,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,OAAO,IAAA,qBAAW,EAAC,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,YAAY,CAAC,EAAE;QAC3E,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC;AAC9B,CAAC"}
|
|
@@ -21,9 +21,10 @@ class BaseReplaceOneService extends services_1.BaseService {
|
|
|
21
21
|
if (!existingDocument) {
|
|
22
22
|
this.handleDocumentNotFound();
|
|
23
23
|
}
|
|
24
|
-
const
|
|
24
|
+
const afterCallback = this.beforeSaveCallback
|
|
25
25
|
? await this.beforeSaveCallback(this.addDocumentId(existingDocument), { id, replacement: (0, helpers_1.cloneDeep)(partial) }, this.callbackMethods, user)
|
|
26
26
|
: (0, helpers_1.cloneDeep)(partial);
|
|
27
|
+
const replacement = this.applyDerivedFields(afterCallback, 'save');
|
|
27
28
|
const document = await this.model
|
|
28
29
|
.findOneAndReplace({ _id: id }, (0, class_transformer_1.plainToInstance)(this.entity, replacement), {
|
|
29
30
|
new: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-replace-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/base-replace-one.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAQ1C,6CAA6C;AAG7C,MAAsB,qBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU,EAAE,OAAwB,EAAE,IAAc;QACnE,IAAI,CAAC;YACH,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,KAAK;iBACxC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACtB,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,
|
|
1
|
+
{"version":3,"file":"base-replace-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/base-replace-one.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;AACpD,2CAA0C;AAQ1C,6CAA6C;AAG7C,MAAsB,qBACpB,SAAQ,sBAAmB;IAU3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAU,EAAE,OAAwB,EAAE,IAAc;QACnE,IAAI,CAAC;YACH,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,KAAK;iBACxC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACtB,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB;gBAC3C,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,EACpC,EAAE,EAAE,EAAE,WAAW,EAAE,IAAA,mBAAS,EAAC,OAAO,CAAC,EAAE,EACvC,IAAI,CAAC,eAAe,EACpB,IAAI,CACL;gBACD,CAAC,CAAC,IAAA,mBAAS,EAAC,OAAO,CAAC,CAAC;YAEvB,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;YAEnE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK;iBAChC,iBAAiB,CAChB,EAAE,GAAG,EAAE,EAAE,EAAE,EACX,IAAA,mCAAe,EAAC,IAAI,CAAC,MAAM,EAAE,WAAW,CAAC,EACzC;gBACE,GAAG,EAAE,IAAI;gBACT,mBAAmB,EAAE,IAAI;aAC1B,CACF;iBACA,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YAChF,CAAC;YAED,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YAC9E,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;CACF;AArED,sDAqEC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { DynamicApiBroadcastService } from '../../services';
|
|
3
4
|
import { ReplaceOneService } from './replace-one-service.interface';
|
|
4
|
-
interface ReplaceOneController<Entity extends BaseEntity, Body =
|
|
5
|
-
replaceOne(id: string, body: Body, req?:
|
|
5
|
+
interface ReplaceOneController<Entity extends BaseEntity, Body = unknown, Response = unknown> {
|
|
6
|
+
replaceOne(id: string, body: Body, req?: DynamicApiRequest): Promise<Entity | Response>;
|
|
6
7
|
}
|
|
7
8
|
type ReplaceOneControllerConstructor<Entity extends BaseEntity> = new (service: ReplaceOneService<Entity>, broadcastService?: DynamicApiBroadcastService) => ReplaceOneController<Entity>;
|
|
8
9
|
export type { ReplaceOneController, ReplaceOneControllerConstructor };
|
|
@@ -2,5 +2,5 @@ import { Type } from '@nestjs/common';
|
|
|
2
2
|
import { DynamicApiControllerOptions, DynamicAPIRouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { ReplaceOneControllerConstructor } from './replace-one-controller.interface';
|
|
5
|
-
declare function ReplaceOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): ReplaceOneControllerConstructor<Entity>;
|
|
5
|
+
declare function ReplaceOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, fromUser, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): ReplaceOneControllerConstructor<Entity>;
|
|
6
6
|
export { ReplaceOneControllerMixin };
|
|
@@ -19,7 +19,7 @@ const dtos_1 = require("../../dtos");
|
|
|
19
19
|
const helpers_1 = require("../../helpers");
|
|
20
20
|
const mixins_1 = require("../../mixins");
|
|
21
21
|
const services_1 = require("../../services");
|
|
22
|
-
function ReplaceOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, ...routeConfig }, version) {
|
|
22
|
+
function ReplaceOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, fromUser, ...routeConfig }, version) {
|
|
23
23
|
const { routeType, displayedName, description, isPublic, abilityPredicate, event, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
24
24
|
class ReplaceOneBody extends (dTOs?.body ?? (0, mixins_1.EntityBodyMixin)(entity)) {
|
|
25
25
|
}
|
|
@@ -50,7 +50,9 @@ function ReplaceOneControllerMixin(entity, controllerOptions, { dTOs, useInterce
|
|
|
50
50
|
}
|
|
51
51
|
async replaceOne(id, body, req) {
|
|
52
52
|
const toEntity = ReplaceOneBody.toEntity;
|
|
53
|
-
const
|
|
53
|
+
const rawPartial = toEntity ? toEntity(body) : body;
|
|
54
|
+
const partial = (0, helpers_1.applyFromUser)((0, mixins_1.stripProtectedFields)(rawPartial, this.entity), fromUser, req?.user);
|
|
55
|
+
const entity = await this.service.replaceOne(id, partial, req?.user);
|
|
54
56
|
const fromEntity = ReplaceOnePresenter.fromEntity;
|
|
55
57
|
const responseData = fromEntity ? fromEntity(entity) : entity;
|
|
56
58
|
this.broadcastService?.broadcastFromHttp(event, [responseData], broadcastConfig);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"replace-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"replace-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,17 +16,19 @@ class BaseUpdateManyService extends services_1.BaseService {
|
|
|
16
16
|
}
|
|
17
17
|
if (this.beforeSaveCallback) {
|
|
18
18
|
const updates = await this.beforeSaveCallback(toUpdateList, { ids, update: (0, helpers_1.cloneDeep)(partial) }, this.callbackMethods, user);
|
|
19
|
-
|
|
19
|
+
const updatesWithDerived = updates.map((u, index) => this.applyDerivedFields(u, 'save', this.addDocumentId(toUpdateList[index])));
|
|
20
|
+
await Promise.all(updatesWithDerived.map((update, index) => this.model
|
|
20
21
|
.findByIdAndUpdate(toUpdateList[index]._id, update, { new: true })
|
|
21
22
|
.lean()
|
|
22
23
|
.exec()));
|
|
23
24
|
}
|
|
24
25
|
else {
|
|
26
|
+
const partialWithDerived = this.applyDerivedFields(partial, 'save');
|
|
25
27
|
await this.model
|
|
26
28
|
.updateMany({
|
|
27
29
|
_id: { $in: ids },
|
|
28
30
|
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
29
|
-
},
|
|
31
|
+
}, partialWithDerived)
|
|
30
32
|
.lean()
|
|
31
33
|
.exec();
|
|
32
34
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-update-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-many/base-update-many.service.ts"],"names":[],"mappings":";;;AAAA,2CAA0C;AAQ1C,6CAA6C;AAG7C,MAAsB,qBACpB,SAAQ,sBAAmB;IAQ3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,GAAa,EAAE,OAAwB,EAAE,IAAc;QACtE,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,IAAI,EAAY,CAAC,IAAI,EAAE,CAAC;YAC1F,IAAI,YAAY,EAAE,MAAM,KAAK,GAAG,CAAC,MAAM,EAAE,CAAC;gBACxC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAC3C,YAAY,EACZ,EAAE,GAAG,EAAE,MAAM,EAAE,IAAA,mBAAS,EAAC,OAAO,CAAC,EAAE,EACnC,IAAI,CAAC,eAAe,EACpB,IAAI,CACL,CAAC;gBAEF,MAAM,OAAO,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"base-update-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-many/base-update-many.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { DynamicApiBroadcastService } from '../../services';
|
|
3
4
|
import { UpdateManyService } from './update-many-service.interface';
|
|
4
|
-
interface UpdateManyController<Entity extends BaseEntity, Body =
|
|
5
|
-
updateMany(ids: string[], partial: Body, req?:
|
|
5
|
+
interface UpdateManyController<Entity extends BaseEntity, Body = unknown, Response = unknown> {
|
|
6
|
+
updateMany(ids: string[], partial: Body, req?: DynamicApiRequest): Promise<(Entity | Response)[]>;
|
|
6
7
|
}
|
|
7
8
|
type UpdateManyControllerConstructor<Entity extends BaseEntity> = new (service: UpdateManyService<Entity>, broadcastService?: DynamicApiBroadcastService) => UpdateManyController<Entity>;
|
|
8
9
|
export type { UpdateManyController, UpdateManyControllerConstructor };
|
|
@@ -2,5 +2,5 @@ import { Type } from '@nestjs/common';
|
|
|
2
2
|
import { DynamicApiControllerOptions, DynamicAPIRouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { UpdateManyControllerConstructor } from './update-many-controller.interface';
|
|
5
|
-
declare function UpdateManyControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): UpdateManyControllerConstructor<Entity>;
|
|
5
|
+
declare function UpdateManyControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, fromUser, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): UpdateManyControllerConstructor<Entity>;
|
|
6
6
|
export { UpdateManyControllerMixin };
|
|
@@ -18,7 +18,7 @@ const builders_1 = require("../../builders");
|
|
|
18
18
|
const helpers_1 = require("../../helpers");
|
|
19
19
|
const mixins_1 = require("../../mixins");
|
|
20
20
|
const services_1 = require("../../services");
|
|
21
|
-
function UpdateManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, ...routeConfig }, version) {
|
|
21
|
+
function UpdateManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, fromUser, ...routeConfig }, version) {
|
|
22
22
|
const { routeType, displayedName, description, isPublic, abilityPredicate, event, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
23
|
class UpdateManyBody extends (dTOs?.body ?? (0, mixins_1.EntityBodyMixin)(entity, true)) {
|
|
24
24
|
}
|
|
@@ -54,7 +54,9 @@ function UpdateManyControllerMixin(entity, controllerOptions, { dTOs, useInterce
|
|
|
54
54
|
throw new Error('Invalid request body');
|
|
55
55
|
}
|
|
56
56
|
const toEntity = UpdateManyBody.toEntity;
|
|
57
|
-
const
|
|
57
|
+
const rawPartial = toEntity ? toEntity(body) : body;
|
|
58
|
+
const partial = (0, helpers_1.applyFromUser)((0, mixins_1.stripProtectedFields)(rawPartial, this.entity), fromUser, req?.user);
|
|
59
|
+
const list = await this.service.updateMany(ids, partial, req?.user);
|
|
58
60
|
const fromEntities = UpdateManyPresenter.fromEntities;
|
|
59
61
|
const responseData = fromEntities ? fromEntities(list) : list;
|
|
60
62
|
this.broadcastService?.broadcastFromHttp(event, responseData, broadcastConfig);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-many/update-many-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"update-many-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-many/update-many-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -20,9 +20,10 @@ class BaseUpdateOneService extends services_1.BaseService {
|
|
|
20
20
|
if (!document) {
|
|
21
21
|
this.handleDocumentNotFound();
|
|
22
22
|
}
|
|
23
|
-
const
|
|
23
|
+
const afterCallback = this.beforeSaveCallback
|
|
24
24
|
? await this.beforeSaveCallback(this.addDocumentId(document), { id, update: (0, helpers_1.cloneDeep)(partial) }, this.callbackMethods, user)
|
|
25
25
|
: (0, helpers_1.cloneDeep)(partial);
|
|
26
|
+
const update = this.applyDerivedFields(afterCallback, 'save', this.addDocumentId(document));
|
|
26
27
|
const updatedDocument = await this.model
|
|
27
28
|
.findOneAndUpdate({ _id: id }, { $set: update }, { new: true })
|
|
28
29
|
.lean()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-update-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-one/base-update-one.service.ts"],"names":[],"mappings":";;;AAAA,2CAA0C;AAI1C,6CAA6C;AAG7C,MAAsB,oBACpB,SAAQ,sBAAmB;IAS3B,YACqB,KAAoB;QAEvC,KAAK,CAAC,KAAK,CAAC,CAAC;QAFM,UAAK,GAAL,KAAK,CAAe;IAGzC,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,EAAU,EAAE,OAAwB,EAAE,IAAc;QAClE,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK;iBAChC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,
|
|
1
|
+
{"version":3,"file":"base-update-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-one/base-update-one.service.ts"],"names":[],"mappings":";;;AAAA,2CAA0C;AAI1C,6CAA6C;AAG7C,MAAsB,oBACpB,SAAQ,sBAAmB;IAS3B,YACqB,KAAoB;QAEvC,KAAK,CAAC,KAAK,CAAC,CAAC;QAFM,UAAK,GAAL,KAAK,CAAe;IAGzC,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,EAAU,EAAE,OAAwB,EAAE,IAAc;QAClE,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK;iBAChC,OAAO,CAAC;gBACP,GAAG,EAAE,EAAE;gBACP,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CACxD;aACF,CAAC;iBACD,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;YAED,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB;gBAC3C,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAC5B,EAAE,EAAE,EAAE,MAAM,EAAE,IAAA,mBAAS,EAAC,OAAO,CAAC,EAAE,EAClC,IAAI,CAAC,eAAe,EACpB,IAAI,CACL;gBACD,CAAC,CAAC,IAAA,mBAAS,EAAC,OAAO,CAAC,CAAC;YAEvB,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAoB,CAAC,CAAC;YAE/G,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,KAAK;iBACvC,gBAAgB,CACf,EAAE,GAAG,EAAE,EAAE,EAAE,EACX,EAAE,IAAI,EAAE,MAAM,EAAE,EAChB,EAAE,GAAG,EAAE,IAAI,EAAE,CACd;iBACA,IAAI,EAAU;iBACd,IAAI,EAAE,CAAC;YAER,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YACvF,CAAC;YAED,OAAO,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;QAC7C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;CACF;AA9DD,oDA8DC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import { DynamicApiRequest } from '../../interfaces';
|
|
1
2
|
import { BaseEntity } from '../../models';
|
|
2
3
|
import { DynamicApiBroadcastService } from '../../services';
|
|
3
4
|
import { UpdateOneService } from './update-one-service.interface';
|
|
4
|
-
interface UpdateOneController<Entity extends BaseEntity, Body =
|
|
5
|
-
updateOne(id: string, partial: Body, req?:
|
|
5
|
+
interface UpdateOneController<Entity extends BaseEntity, Body = unknown, Response = unknown> {
|
|
6
|
+
updateOne(id: string, partial: Body, req?: DynamicApiRequest): Promise<Entity | Response>;
|
|
6
7
|
}
|
|
7
8
|
type UpdateOneControllerConstructor<Entity extends BaseEntity> = new (service: UpdateOneService<Entity>, broadcastService?: DynamicApiBroadcastService) => UpdateOneController<Entity>;
|
|
8
9
|
export type { UpdateOneController, UpdateOneControllerConstructor };
|
|
@@ -2,5 +2,5 @@ import { Type } from '@nestjs/common';
|
|
|
2
2
|
import { DynamicApiControllerOptions, DynamicAPIRouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { UpdateOneControllerConstructor } from './update-one-controller.interface';
|
|
5
|
-
declare function UpdateOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): UpdateOneControllerConstructor<Entity>;
|
|
5
|
+
declare function UpdateOneControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, controllerOptions: DynamicApiControllerOptions<Entity>, { dTOs, useInterceptors, broadcast: broadcastConfig, fromUser, ...routeConfig }: DynamicAPIRouteConfig<Entity>, version?: string): UpdateOneControllerConstructor<Entity>;
|
|
6
6
|
export { UpdateOneControllerMixin };
|
|
@@ -19,7 +19,7 @@ const dtos_1 = require("../../dtos");
|
|
|
19
19
|
const helpers_1 = require("../../helpers");
|
|
20
20
|
const mixins_1 = require("../../mixins");
|
|
21
21
|
const services_1 = require("../../services");
|
|
22
|
-
function UpdateOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, ...routeConfig }, version) {
|
|
22
|
+
function UpdateOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], broadcast: broadcastConfig, fromUser, ...routeConfig }, version) {
|
|
23
23
|
const { routeType, displayedName, description, isPublic, abilityPredicate, event, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
24
24
|
class UpdateOneBody extends (dTOs?.body ?? (0, mixins_1.EntityBodyMixin)(entity, true)) {
|
|
25
25
|
}
|
|
@@ -53,7 +53,9 @@ function UpdateOneControllerMixin(entity, controllerOptions, { dTOs, useIntercep
|
|
|
53
53
|
throw new Error('Invalid request body');
|
|
54
54
|
}
|
|
55
55
|
const toEntity = UpdateOneBody.toEntity;
|
|
56
|
-
const
|
|
56
|
+
const rawPartial = toEntity ? toEntity(body) : body;
|
|
57
|
+
const partial = (0, helpers_1.applyFromUser)((0, mixins_1.stripProtectedFields)(rawPartial, this.entity), fromUser, req?.user);
|
|
58
|
+
const entity = await this.service.updateOne(id, partial, req?.user);
|
|
57
59
|
const fromEntity = UpdateOnePresenter.fromEntity;
|
|
58
60
|
const responseData = fromEntity ? fromEntity(entity) : entity;
|
|
59
61
|
this.broadcastService?.broadcastFromHttp(event, [responseData], broadcastConfig);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-one/update-one-controller.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"update-one-controller.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/update-one/update-one-controller.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -29,6 +29,7 @@ export declare abstract class BaseService<Entity extends BaseEntity> {
|
|
|
29
29
|
protected deleteManyDocuments<T extends BaseEntity>(entity: Type<T>, ids: string[]): Promise<DeleteResult>;
|
|
30
30
|
protected deleteOneDocument<T extends BaseEntity>(entity: Type<T>, id: string): Promise<DeleteResult>;
|
|
31
31
|
protected buildInstance(document: Entity): Entity;
|
|
32
|
+
protected applyDerivedFields(partial: Partial<Entity>, trigger: 'save' | 'read', existingDoc?: Partial<Entity>): Partial<Entity>;
|
|
32
33
|
protected handleAbilityPredicate(document: Entity, authAbilityPredicate?: AuthAbilityPredicate<Entity>): void;
|
|
33
34
|
protected handleDuplicateKeyError(error: unknown, reThrow?: boolean): void;
|
|
34
35
|
protected handleMongoErrors(error: unknown, reThrow?: boolean): void;
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.BaseService = void 0;
|
|
4
4
|
const common_1 = require("@nestjs/common");
|
|
5
5
|
const class_transformer_1 = require("class-transformer");
|
|
6
|
+
const decorators_1 = require("../../decorators");
|
|
6
7
|
const logger_1 = require("../../logger");
|
|
7
8
|
const dynamic_api_global_state_service_1 = require("../dynamic-api-global-state/dynamic-api-global-state.service");
|
|
8
9
|
class BaseService {
|
|
@@ -122,12 +123,31 @@ class BaseService {
|
|
|
122
123
|
}
|
|
123
124
|
buildInstance(document) {
|
|
124
125
|
const { _id, id, __v, isDeleted, deletedAt, ...rest } = document;
|
|
125
|
-
|
|
126
|
+
const instance = (0, class_transformer_1.plainToInstance)(this.entity, {
|
|
126
127
|
...rest,
|
|
127
128
|
...(_id && !id ? { id: _id?.toString() } : {}),
|
|
128
129
|
...(id ? { id } : {}),
|
|
129
130
|
...(isDeleted ? { deletedAt } : {}),
|
|
130
131
|
});
|
|
132
|
+
return this.applyDerivedFields(instance, 'read');
|
|
133
|
+
}
|
|
134
|
+
applyDerivedFields(partial, trigger, existingDoc) {
|
|
135
|
+
if (!this.entity?.prototype) {
|
|
136
|
+
return partial;
|
|
137
|
+
}
|
|
138
|
+
const keys = Reflect.getMetadata(decorators_1.DERIVED_FIELD_KEYS_METADATA, this.entity.prototype) ?? [];
|
|
139
|
+
if (!keys.length) {
|
|
140
|
+
return partial;
|
|
141
|
+
}
|
|
142
|
+
const snapshot = existingDoc ? { ...existingDoc, ...partial } : { ...partial };
|
|
143
|
+
const result = { ...partial };
|
|
144
|
+
for (const key of keys) {
|
|
145
|
+
const meta = Reflect.getMetadata(decorators_1.DERIVED_FIELD_METADATA, this.entity.prototype, key);
|
|
146
|
+
if (meta && (meta.on === trigger || meta.on === 'both')) {
|
|
147
|
+
result[key] = meta.computeFn(snapshot);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return result;
|
|
131
151
|
}
|
|
132
152
|
handleAbilityPredicate(document, authAbilityPredicate) {
|
|
133
153
|
this.baseServiceLogger.debug('handleAbilityPredicate', {
|