mongodb-dynamic-api 4.7.0 → 4.9.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 +23 -0
- package/README.md +1 -0
- package/package.json +2 -1
- package/src/guards/base-policies.guard.d.ts +3 -1
- package/src/guards/base-policies.guard.js +2 -2
- package/src/guards/base-policies.guard.js.map +1 -1
- package/src/helpers/mixin-data.helper.d.ts +3 -2
- package/src/helpers/mixin-data.helper.js +2 -1
- package/src/helpers/mixin-data.helper.js.map +1 -1
- package/src/index.d.ts +2 -0
- package/src/index.js +2 -0
- package/src/index.js.map +1 -1
- package/src/interfaces/dynamic-api-ability.interface.d.ts +2 -1
- package/src/interfaces/dynamic-api-cascade-config.interface.d.ts +9 -0
- package/src/interfaces/dynamic-api-cascade-config.interface.js +3 -0
- package/src/interfaces/dynamic-api-cascade-config.interface.js.map +1 -0
- package/src/interfaces/dynamic-api-presence.interface.d.ts +22 -0
- package/src/interfaces/dynamic-api-presence.interface.js +6 -0
- package/src/interfaces/dynamic-api-presence.interface.js.map +1 -0
- package/src/interfaces/dynamic-api-route-config.interface.d.ts +6 -2
- package/src/interfaces/dynamic-api-service-before-save-callback.interface.d.ts +4 -1
- package/src/interfaces/dynamic-api-service-callback.interface.d.ts +26 -1
- package/src/interfaces/index.d.ts +2 -0
- package/src/interfaces/index.js +2 -0
- package/src/interfaces/index.js.map +1 -1
- package/src/mixins/policies-guard.mixin.d.ts +9 -3
- package/src/mixins/policies-guard.mixin.js +5 -2
- package/src/mixins/policies-guard.mixin.js.map +1 -1
- package/src/modules/presence/adapters/in-memory-presence.adapter.d.ts +10 -0
- package/src/modules/presence/adapters/in-memory-presence.adapter.js +64 -0
- package/src/modules/presence/adapters/in-memory-presence.adapter.js.map +1 -0
- package/src/modules/presence/adapters/redis-presence.adapter.d.ts +17 -0
- package/src/modules/presence/adapters/redis-presence.adapter.js +80 -0
- package/src/modules/presence/adapters/redis-presence.adapter.js.map +1 -0
- package/src/modules/presence/index.d.ts +5 -0
- package/src/modules/presence/index.js +22 -0
- package/src/modules/presence/index.js.map +1 -0
- package/src/modules/presence/presence.controller.d.ts +6 -0
- package/src/modules/presence/presence.controller.js +55 -0
- package/src/modules/presence/presence.controller.js.map +1 -0
- package/src/modules/presence/presence.gateway.d.ts +13 -0
- package/src/modules/presence/presence.gateway.js +79 -0
- package/src/modules/presence/presence.gateway.js.map +1 -0
- package/src/modules/presence/presence.module.d.ts +5 -0
- package/src/modules/presence/presence.module.js +50 -0
- package/src/modules/presence/presence.module.js.map +1 -0
- package/src/routes/aggregate/aggregate-controller.mixin.js +2 -2
- package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate-gateway.mixin.js +2 -2
- package/src/routes/aggregate/aggregate-gateway.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate.helper.d.ts +2 -2
- package/src/routes/aggregate/aggregate.helper.js +3 -1
- package/src/routes/aggregate/aggregate.helper.js.map +1 -1
- package/src/routes/aggregate/aggregate.module.js +1 -1
- package/src/routes/aggregate/aggregate.module.js.map +1 -1
- package/src/routes/aggregate/base-aggregate.service.d.ts +3 -1
- package/src/routes/aggregate/base-aggregate.service.js +6 -1
- package/src/routes/aggregate/base-aggregate.service.js.map +1 -1
- package/src/routes/create-many/create-many-gateway.mixin.js +1 -1
- package/src/routes/create-many/create-many-gateway.mixin.js.map +1 -1
- package/src/routes/create-one/create-one-gateway.mixin.js +1 -1
- package/src/routes/create-one/create-one-gateway.mixin.js.map +1 -1
- package/src/routes/delete-many/base-delete-many.service.d.ts +3 -1
- package/src/routes/delete-many/base-delete-many.service.js +22 -9
- package/src/routes/delete-many/base-delete-many.service.js.map +1 -1
- package/src/routes/delete-many/delete-many-gateway.mixin.js +1 -1
- package/src/routes/delete-many/delete-many-gateway.mixin.js.map +1 -1
- package/src/routes/delete-many/delete-many.helper.d.ts +2 -2
- package/src/routes/delete-many/delete-many.helper.js +3 -1
- package/src/routes/delete-many/delete-many.helper.js.map +1 -1
- package/src/routes/delete-many/delete-many.module.js +1 -1
- package/src/routes/delete-many/delete-many.module.js.map +1 -1
- package/src/routes/delete-one/base-delete-one.service.d.ts +4 -1
- package/src/routes/delete-one/base-delete-one.service.js +30 -9
- package/src/routes/delete-one/base-delete-one.service.js.map +1 -1
- package/src/routes/delete-one/delete-one-gateway.mixin.js +1 -1
- package/src/routes/delete-one/delete-one-gateway.mixin.js.map +1 -1
- package/src/routes/delete-one/delete-one.helper.d.ts +2 -2
- package/src/routes/delete-one/delete-one.helper.js +3 -1
- package/src/routes/delete-one/delete-one.helper.js.map +1 -1
- package/src/routes/delete-one/delete-one.module.js +1 -1
- package/src/routes/delete-one/delete-one.module.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js +1 -1
- package/src/routes/duplicate-many/duplicate-many-gateway.mixin.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js +1 -1
- package/src/routes/duplicate-one/duplicate-one-gateway.mixin.js.map +1 -1
- package/src/routes/get-many/base-get-many.service.d.ts +3 -1
- package/src/routes/get-many/base-get-many.service.js +5 -1
- package/src/routes/get-many/base-get-many.service.js.map +1 -1
- package/src/routes/get-many/get-many-controller.mixin.js +2 -2
- package/src/routes/get-many/get-many-controller.mixin.js.map +1 -1
- package/src/routes/get-many/get-many-gateway.mixin.js +2 -2
- package/src/routes/get-many/get-many-gateway.mixin.js.map +1 -1
- package/src/routes/get-many/get-many.helper.d.ts +2 -2
- package/src/routes/get-many/get-many.helper.js +3 -1
- package/src/routes/get-many/get-many.helper.js.map +1 -1
- package/src/routes/get-many/get-many.module.js +1 -1
- package/src/routes/get-many/get-many.module.js.map +1 -1
- package/src/routes/get-one/get-one-gateway.mixin.js +1 -1
- package/src/routes/get-one/get-one-gateway.mixin.js.map +1 -1
- package/src/routes/replace-one/replace-one-gateway.mixin.js +1 -1
- package/src/routes/replace-one/replace-one-gateway.mixin.js.map +1 -1
- package/src/routes/update-many/update-many-gateway.mixin.js +1 -1
- package/src/routes/update-many/update-many-gateway.mixin.js.map +1 -1
- package/src/routes/update-one/update-one-gateway.mixin.js +1 -1
- package/src/routes/update-one/update-one-gateway.mixin.js.map +1 -1
- package/src/services/base/base.service.d.ts +5 -1
- package/src/services/base/base.service.js +36 -0
- package/src/services/base/base.service.js.map +1 -1
- package/src/version.json +1 -1
- package/test/for-feature/ability-predicate-filter.e2e-spec.d.ts +1 -0
- package/test/for-feature/ability-predicate-filter.e2e-spec.js +106 -0
- package/test/for-feature/ability-predicate-filter.e2e-spec.js.map +1 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.d.ts +1 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.js +304 -0
- package/test/for-feature/cascade-and-before-delete.e2e-spec.js.map +1 -0
- package/test/for-feature/presence.e2e-spec.d.ts +1 -0
- package/test/for-feature/presence.e2e-spec.js +169 -0
- package/test/for-feature/presence.e2e-spec.js.map +1 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.d.ts +1 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.js +263 -0
- package/test/for-feature/raw-update-callback-methods.e2e-spec.js.map +1 -0
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
2
|
import { DeletePresenter } from '../../dtos';
|
|
3
|
-
import { BeforeSaveDeleteManyCallback, BeforeSaveDeleteManyContext, AfterSaveCallback } from '../../interfaces';
|
|
3
|
+
import { BeforeSaveDeleteManyCallback, BeforeSaveDeleteManyContext, BeforeDeleteManyCallback, AfterSaveCallback, CascadeConfig } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { DeleteManyService } from './delete-many-service.interface';
|
|
7
7
|
export declare abstract class BaseDeleteManyService<Entity extends BaseEntity> extends BaseService<Entity> implements DeleteManyService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly beforeSaveCallback: BeforeSaveDeleteManyCallback<Entity, BeforeSaveDeleteManyContext> | undefined;
|
|
10
|
+
protected readonly beforeDeleteCallback: BeforeDeleteManyCallback<Entity, BeforeSaveDeleteManyContext> | undefined;
|
|
10
11
|
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
12
|
+
protected readonly cascade: CascadeConfig[] | undefined;
|
|
11
13
|
protected constructor(model: Model<Entity>);
|
|
12
14
|
deleteMany(ids: string[], user?: unknown): Promise<DeletePresenter>;
|
|
13
15
|
}
|
|
@@ -10,24 +10,33 @@ class BaseDeleteManyService extends services_1.BaseService {
|
|
|
10
10
|
this.model = model;
|
|
11
11
|
}
|
|
12
12
|
async deleteMany(ids, user) {
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
let documents = [];
|
|
14
|
+
if (this.beforeDeleteCallback ?? this.beforeSaveCallback) {
|
|
15
|
+
documents = await this.model
|
|
15
16
|
.find({
|
|
16
17
|
_id: { $in: ids },
|
|
17
18
|
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
18
19
|
})
|
|
19
20
|
.lean()
|
|
20
21
|
.exec();
|
|
21
|
-
|
|
22
|
-
|
|
22
|
+
await this.beforeDeleteCallback?.(documents, { ids }, this.callbackMethods, user);
|
|
23
|
+
await this.beforeSaveCallback?.(documents, { ids }, this.callbackMethods, user);
|
|
24
|
+
}
|
|
25
|
+
let deletedCount = 0;
|
|
26
|
+
try {
|
|
27
|
+
if (!documents.length && this.callback) {
|
|
28
|
+
documents = await this.model
|
|
29
|
+
.find({
|
|
30
|
+
_id: { $in: ids },
|
|
31
|
+
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
32
|
+
})
|
|
33
|
+
.lean()
|
|
34
|
+
.exec();
|
|
23
35
|
}
|
|
24
36
|
let op;
|
|
25
37
|
if (this.isSoftDeletable) {
|
|
26
38
|
const deleted = await this.model
|
|
27
|
-
.updateMany({
|
|
28
|
-
_id: { $in: ids },
|
|
29
|
-
isDeleted: false,
|
|
30
|
-
}, { $set: { isDeleted: true, deletedAt: Date.now() } })
|
|
39
|
+
.updateMany({ _id: { $in: ids }, isDeleted: false }, { $set: { isDeleted: true, deletedAt: Date.now() } })
|
|
31
40
|
.exec();
|
|
32
41
|
op = { deletedCount: deleted.modifiedCount };
|
|
33
42
|
}
|
|
@@ -37,11 +46,15 @@ class BaseDeleteManyService extends services_1.BaseService {
|
|
|
37
46
|
if (this.callback && documents?.length) {
|
|
38
47
|
await Promise.all(documents.map((document) => this.callback(this.addDocumentId(document), this.callbackMethods, user)));
|
|
39
48
|
}
|
|
40
|
-
|
|
49
|
+
deletedCount = op.deletedCount;
|
|
41
50
|
}
|
|
42
51
|
catch (error) {
|
|
43
52
|
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount: 0 });
|
|
44
53
|
}
|
|
54
|
+
if (this.cascade?.length && deletedCount > 0) {
|
|
55
|
+
await this.executeCascade(ids, this.cascade, this.isSoftDeletable);
|
|
56
|
+
}
|
|
57
|
+
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount });
|
|
45
58
|
}
|
|
46
59
|
}
|
|
47
60
|
exports.BaseDeleteManyService = BaseDeleteManyService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-delete-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/base-delete-many.service.ts"],"names":[],"mappings":";;;AAAA,yDAAoD;AAEpD,qCAA6C;
|
|
1
|
+
{"version":3,"file":"base-delete-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/base-delete-many.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -31,7 +31,7 @@ function DeleteManyGatewayMixin(entity, controllerOptions, { dTOs, useIntercepto
|
|
|
31
31
|
: `DeleteResultResponse`,
|
|
32
32
|
writable: false,
|
|
33
33
|
});
|
|
34
|
-
class DeleteManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
34
|
+
class DeleteManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
35
35
|
}
|
|
36
36
|
class BaseDeleteManyGateway extends gateways_1.BaseGateway {
|
|
37
37
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"delete-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteManyCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteManyCallback, BeforeDeleteManyCallback, BeforeSaveDeleteManyContext, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions, CascadeConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DeleteManyGatewayConstructor } from '../delete-many';
|
|
5
5
|
import { DeleteManyControllerConstructor } from './delete-many-controller.interface';
|
|
6
|
-
declare function createDeleteManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteManyCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createDeleteManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteManyCallback<Entity> | undefined, beforeDeleteCallback?: BeforeDeleteManyCallback<Entity, BeforeSaveDeleteManyContext> | undefined, cascade?: CascadeConfig[] | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createDeleteManyController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DeleteManyControllerConstructor<Entity>;
|
|
8
8
|
declare function createDeleteManyGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): DeleteManyGatewayConstructor<Entity>;
|
|
9
9
|
export { createDeleteManyController, createDeleteManyGateway, createDeleteManyServiceProvider };
|
|
@@ -28,14 +28,16 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const delete_many_1 = require("../delete-many");
|
|
29
29
|
const base_delete_many_service_1 = require("./base-delete-many.service");
|
|
30
30
|
const delete_many_controller_mixin_1 = require("./delete-many-controller.mixin");
|
|
31
|
-
function createDeleteManyServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
31
|
+
function createDeleteManyServiceProvider(entity, displayedName, version, callback, beforeSaveCallback, beforeDeleteCallback, cascade) {
|
|
32
32
|
let DeleteManyService = class DeleteManyService extends base_delete_many_service_1.BaseDeleteManyService {
|
|
33
33
|
constructor(model) {
|
|
34
34
|
super(model);
|
|
35
35
|
this.model = model;
|
|
36
36
|
this.entity = entity;
|
|
37
37
|
this.beforeSaveCallback = beforeSaveCallback;
|
|
38
|
+
this.beforeDeleteCallback = beforeDeleteCallback;
|
|
38
39
|
this.callback = callback;
|
|
40
|
+
this.cascade = cascade;
|
|
39
41
|
}
|
|
40
42
|
};
|
|
41
43
|
DeleteManyService = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"delete-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ let DeleteManyModule = DeleteManyModule_1 = class DeleteManyModule {
|
|
|
17
17
|
static forFeature(databaseModule, entity, controllerOptions, routeConfig, version, validationPipeOptions, webSocket, extraImports, extraProviders, extraControllers) {
|
|
18
18
|
const displayedName = (0, helpers_1.getDisplayedName)(controllerOptions.apiTag, entity.name, routeConfig.subPath);
|
|
19
19
|
const controller = (0, delete_many_helper_1.createDeleteManyController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, delete_many_helper_1.createDeleteManyServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback);
|
|
20
|
+
const ServiceProvider = (0, delete_many_helper_1.createDeleteManyServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback, routeConfig.beforeDeleteCallback, routeConfig.cascade);
|
|
21
21
|
const hasBroadcast = !!routeConfig.broadcast;
|
|
22
22
|
const gatewayOptions = webSocket
|
|
23
23
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,6DAI8B;AAIvB,IAAM,gBAAgB,wBAAtB,MAAM,gBAAgB;IAC3B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,+CAA0B,EAC3C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,oDAA+B,
|
|
1
|
+
{"version":3,"file":"delete-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-many/delete-many.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,6DAI8B;AAIvB,IAAM,gBAAgB,wBAAtB,MAAM,gBAAgB;IAC3B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,+CAA0B,EAC3C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,oDAA+B,EACrD,MAAM,EACN,aAAa,EACb,OAAO,EACP,WAAW,CAAC,QAAQ,EACpB,WAAW,CAAC,kBAA0D,EACtE,WAAW,CAAC,oBAAqF,EACjG,WAAW,CAAC,OAAO,CACpB,CAAC;QAEF,MAAM,YAAY,GAAG,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC;QAC7C,MAAM,cAAc,GAAG,SAAS;YAC9B,CAAC,CAAC,IAAA,qCAA2B,EAAC,SAAS,CAAC;YACxC,CAAC,CAAC,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAkB,gBAAgB,CAAC,IAAI,IAAI,CAAC;QAG1E,OAAO;YACL,MAAM,EAAE,kBAAgB;YACxB,OAAO,EAAE,CAAC,cAAc,EAAE,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;YAClD,WAAW,EAAE,CAAC,UAAU,EAAE,GAAG,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC;YACtD,SAAS,EAAE;gBACT,eAAe;gBACf,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,qCAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACrD,GAAG,CACD,cAAc,CAAC,CAAC,CAAC;oBACf,IAAA,4CAAuB,EACrB,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,EACrB,cAAc,CACf;iBACF,CAAC,CAAC,CAAC,EAAE,CACP;gBACD,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;aAC1B;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AA/DY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,gBAAgB,CA+D5B"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
2
|
import { DeletePresenter } from '../../dtos';
|
|
3
|
-
import { BeforeSaveDeleteCallback, BeforeSaveDeleteContext, AfterSaveCallback } from '../../interfaces';
|
|
3
|
+
import { BeforeSaveDeleteCallback, BeforeSaveDeleteContext, BeforeDeleteCallback, AfterSaveCallback, CascadeConfig } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { DeleteOneService } from './delete-one-service.interface';
|
|
7
7
|
export declare abstract class BaseDeleteOneService<Entity extends BaseEntity> extends BaseService<Entity> implements DeleteOneService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly beforeSaveCallback: BeforeSaveDeleteCallback<Entity, BeforeSaveDeleteContext> | undefined;
|
|
10
|
+
protected readonly beforeDeleteCallback: BeforeDeleteCallback<Entity, BeforeSaveDeleteContext> | undefined;
|
|
10
11
|
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
12
|
+
protected readonly cascade: CascadeConfig[] | undefined;
|
|
11
13
|
protected constructor(model: Model<Entity>);
|
|
12
14
|
deleteOne(id: string, user?: unknown): Promise<DeletePresenter>;
|
|
15
|
+
private invokePreHooks;
|
|
13
16
|
}
|
|
@@ -10,24 +10,32 @@ class BaseDeleteOneService extends services_1.BaseService {
|
|
|
10
10
|
this.model = model;
|
|
11
11
|
}
|
|
12
12
|
async deleteOne(id, user) {
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
let document = null;
|
|
14
|
+
if (this.beforeDeleteCallback ?? this.beforeSaveCallback) {
|
|
15
|
+
document = await this.model
|
|
15
16
|
.findOne({
|
|
16
17
|
_id: id,
|
|
17
18
|
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
18
19
|
})
|
|
19
20
|
.lean()
|
|
20
21
|
.exec();
|
|
21
|
-
|
|
22
|
-
|
|
22
|
+
}
|
|
23
|
+
await this.invokePreHooks(id, document, user);
|
|
24
|
+
let deletedCount = 0;
|
|
25
|
+
try {
|
|
26
|
+
if (!document && this.callback) {
|
|
27
|
+
document = await this.model
|
|
28
|
+
.findOne({
|
|
29
|
+
_id: id,
|
|
30
|
+
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
31
|
+
})
|
|
32
|
+
.lean()
|
|
33
|
+
.exec();
|
|
23
34
|
}
|
|
24
35
|
let op;
|
|
25
36
|
if (this.isSoftDeletable) {
|
|
26
37
|
const deleted = await this.model
|
|
27
|
-
.updateOne({
|
|
28
|
-
_id: id,
|
|
29
|
-
isDeleted: false,
|
|
30
|
-
}, { $set: { isDeleted: true, deletedAt: Date.now() } })
|
|
38
|
+
.updateOne({ _id: id, isDeleted: false }, { $set: { isDeleted: true, deletedAt: Date.now() } })
|
|
31
39
|
.exec();
|
|
32
40
|
op = { deletedCount: deleted.modifiedCount };
|
|
33
41
|
}
|
|
@@ -37,11 +45,24 @@ class BaseDeleteOneService extends services_1.BaseService {
|
|
|
37
45
|
if (this.callback && document) {
|
|
38
46
|
await this.callback(this.addDocumentId(document), this.callbackMethods, user);
|
|
39
47
|
}
|
|
40
|
-
|
|
48
|
+
deletedCount = op.deletedCount;
|
|
41
49
|
}
|
|
42
50
|
catch (error) {
|
|
43
51
|
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount: 0 });
|
|
44
52
|
}
|
|
53
|
+
if (this.cascade?.length && deletedCount > 0) {
|
|
54
|
+
await this.executeCascade([id], this.cascade, this.isSoftDeletable);
|
|
55
|
+
}
|
|
56
|
+
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount });
|
|
57
|
+
}
|
|
58
|
+
async invokePreHooks(id, document, user) {
|
|
59
|
+
const entity = document ? this.addDocumentId(document) : undefined;
|
|
60
|
+
if (this.beforeDeleteCallback) {
|
|
61
|
+
await this.beforeDeleteCallback(entity, { id }, this.callbackMethods, user);
|
|
62
|
+
}
|
|
63
|
+
if (this.beforeSaveCallback) {
|
|
64
|
+
await this.beforeSaveCallback(entity, { id }, this.callbackMethods, user);
|
|
65
|
+
}
|
|
45
66
|
}
|
|
46
67
|
}
|
|
47
68
|
exports.BaseDeleteOneService = BaseDeleteOneService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-delete-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/base-delete-one.service.ts"],"names":[],"mappings":";;;AAAA,yDAAoD;AAEpD,qCAA6C;
|
|
1
|
+
{"version":3,"file":"base-delete-one.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/base-delete-one.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -31,7 +31,7 @@ function DeleteOneGatewayMixin(entity, controllerOptions, { dTOs, useInterceptor
|
|
|
31
31
|
: `DeleteResultResponse`,
|
|
32
32
|
writable: false,
|
|
33
33
|
});
|
|
34
|
-
class DeleteOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
34
|
+
class DeleteOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
35
35
|
}
|
|
36
36
|
class BaseDeleteOneGateway extends gateways_1.BaseGateway {
|
|
37
37
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"delete-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAmGS,sDAAqB;AAnG9B,2CAA8E;AAE9E,mDAAiG;AACjG,qCAA0D;AAC1D,2CAA4D;AAC5D,6CAA6C;AAC7C,yCAA8C;AAC9C,2CAA4E;AAE5E,yCAAwD;AAKxD,SAAS,qBAAqB,CAC5B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,SAAS,EAAE,eAAe,EAAE,GAAG,WAAW,EAAiC,EACzG,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,QAAQ,EACR,KAAK,EACL,gBAAgB,GACjB,GAAG,IAAA,sBAAY,EACd,MAAM,EACN,iBAAiB,EACjB,WAAW,EACX,IAAI,CACL,CAAC;IAEF,MAAM,iBAAkB,SAAQ,CAC9B,IAAI,EAAE,SAAS,IAAI,sBAAe,CACnC;KAAG;IAEJ,MAAM,CAAC,cAAc,CAAC,iBAAiB,EAAE,MAAM,EAAE;QAC/C,KAAK,EAAE,IAAI,EAAE,SAAS;YACpB,CAAC,CAAC,YAAY,aAAa,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,UAAU;YACjE,CAAC,CAAC,sBAAsB;QAC1B,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,MAAM,sBAAuB,SAAQ,IAAA,iCAAwB,EAC3D,MAAM,EACN,SAAS,EACT,KAAK,EACL,OAAO,EACP,EAAE,gBAAgB,EAAE,QAAQ,EAAE,CAC/B;KAAG;IAEJ,MAAM,oBAAqB,SAAQ,sBAAmB;QAGpD,YACqB,OAAiC,EACjC,UAAsB;YAEzC,KAAK,CAAC,UAAU,CAAC,CAAC;YAHC,YAAO,GAAP,OAAO,CAA0B;YACjC,eAAU,GAAV,UAAU,CAAY;YAJxB,WAAM,GAAG,MAAM,CAAC;QAOnC,CAAC;QAMK,AAAN,KAAK,CAAC,SAAS,CACM,MAA8B,EAClC,IAAiB;YAEhC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC;gBACd,MAAM,IAAI,wBAAW,CAAC,sBAAsB,CAAC,CAAC;YAChD,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;YAEzE,MAAM,gBAAgB,GACpB,iBACD,CAAC,gBAAgB,CAAC;YAEnB,MAAM,YAAY,GAAG,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,CAAoB,YAAY,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;YAEzG,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAY,CAAC,EAAE,eAAe,CAAC,CAAC;YAEpF,OAAO;gBACL,KAAK;gBACL,IAAI,EAAE,YAAY;aACnB,CAAC;QACJ,CAAC;KACF;IAvBO;QAJL,IAAA,mBAAU,EAAC,IAAI,qCAA2B,EAAE,CAAC;QAC7C,IAAA,kBAAS,EAAC,IAAI,uBAAc,CAAC,QAAQ,CAAC,EAAE,sBAAsB,CAAC;QAC/D,IAAA,wBAAe,EAAC,GAAG,eAAe,CAAC;QACnC,IAAA,6BAAgB,EAAC,KAAK,CAAC;QAErB,WAAA,IAAA,4BAAe,GAAE,CAAA;QACjB,WAAA,IAAA,wBAAW,GAAE,CAAA;;iDAAO,kBAAW;;yDAoBjC;IAGH,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,OAAO,IAAA,qBAAW,EAAC,SAAS,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE;QACzE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC;AAC9B,CAAC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteCallback, BeforeDeleteCallback, BeforeSaveDeleteContext, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions, CascadeConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DeleteOneControllerConstructor } from './delete-one-controller.interface';
|
|
5
5
|
import { DeleteOneGatewayConstructor } from './delete-one-gateway.interface';
|
|
6
|
-
declare function createDeleteOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createDeleteOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteCallback<Entity> | undefined, beforeDeleteCallback?: BeforeDeleteCallback<Entity, BeforeSaveDeleteContext> | undefined, cascade?: CascadeConfig[] | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createDeleteOneController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DeleteOneControllerConstructor<Entity>;
|
|
8
8
|
declare function createDeleteOneGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): DeleteOneGatewayConstructor<Entity>;
|
|
9
9
|
export { createDeleteOneController, createDeleteOneGateway, createDeleteOneServiceProvider };
|
|
@@ -28,14 +28,16 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const base_delete_one_service_1 = require("./base-delete-one.service");
|
|
29
29
|
const delete_one_controller_mixin_1 = require("./delete-one-controller.mixin");
|
|
30
30
|
const delete_one_gateway_mixin_1 = require("./delete-one-gateway.mixin");
|
|
31
|
-
function createDeleteOneServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
31
|
+
function createDeleteOneServiceProvider(entity, displayedName, version, callback, beforeSaveCallback, beforeDeleteCallback, cascade) {
|
|
32
32
|
let DeleteOneService = class DeleteOneService extends base_delete_one_service_1.BaseDeleteOneService {
|
|
33
33
|
constructor(model) {
|
|
34
34
|
super(model);
|
|
35
35
|
this.model = model;
|
|
36
36
|
this.entity = entity;
|
|
37
37
|
this.beforeSaveCallback = beforeSaveCallback;
|
|
38
|
+
this.beforeDeleteCallback = beforeDeleteCallback;
|
|
38
39
|
this.callback = callback;
|
|
40
|
+
this.cascade = cascade;
|
|
39
41
|
}
|
|
40
42
|
};
|
|
41
43
|
DeleteOneService = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"delete-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ let DeleteOneModule = DeleteOneModule_1 = class DeleteOneModule {
|
|
|
17
17
|
static forFeature(databaseModule, entity, controllerOptions, routeConfig, version, validationPipeOptions, webSocket, extraImports, extraProviders, extraControllers) {
|
|
18
18
|
const displayedName = (0, helpers_1.getDisplayedName)(controllerOptions.apiTag, entity.name, routeConfig.subPath);
|
|
19
19
|
const controller = (0, delete_one_helper_1.createDeleteOneController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, delete_one_helper_1.createDeleteOneServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback);
|
|
20
|
+
const ServiceProvider = (0, delete_one_helper_1.createDeleteOneServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback, routeConfig.beforeDeleteCallback, routeConfig.cascade);
|
|
21
21
|
const hasBroadcast = !!routeConfig.broadcast;
|
|
22
22
|
const gatewayOptions = webSocket
|
|
23
23
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,2DAI6B;AAItB,IAAM,eAAe,uBAArB,MAAM,eAAe;IAC1B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,6CAAyB,EAC1C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,kDAA8B,
|
|
1
|
+
{"version":3,"file":"delete-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/delete-one/delete-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,2DAI6B;AAItB,IAAM,eAAe,uBAArB,MAAM,eAAe;IAC1B,MAAM,CAAC,UAAU,CACf,cAA6B,EAC7B,MAAoB,EACpB,iBAAsD,EACtD,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,SAAsC,EACtC,YAAwC,EACxC,cAA4C,EAC5C,gBAAgD;QAEhD,MAAM,aAAa,GAAG,IAAA,0BAAgB,EAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;QAEnG,MAAM,UAAU,GAAG,IAAA,6CAAyB,EAC1C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,kDAA8B,EACpD,MAAM,EACN,aAAa,EACb,OAAO,EACP,WAAW,CAAC,QAAQ,EACpB,WAAW,CAAC,kBAAsD,EAClE,WAAW,CAAC,oBAA6E,EACzF,WAAW,CAAC,OAAO,CACpB,CAAC;QAEF,MAAM,YAAY,GAAG,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC;QAC7C,MAAM,cAAc,GAAG,SAAS;YAC9B,CAAC,CAAC,IAAA,qCAA2B,EAAC,SAAS,CAAC;YACxC,CAAC,CAAC,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAkB,gBAAgB,CAAC,IAAI,IAAI,CAAC;QAG1E,OAAO;YACL,MAAM,EAAE,iBAAe;YACvB,OAAO,EAAE,CAAC,cAAc,EAAE,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;YAClD,WAAW,EAAE,CAAC,UAAU,EAAE,GAAG,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC;YACtD,SAAS,EAAE;gBACT,eAAe;gBACf,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,qCAA0B,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACrD,GAAG,CACD,cAAc,CAAC,CAAC,CAAC;oBACf,IAAA,0CAAsB,EACpB,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,EACrB,cAAc,CACf;iBACF,CAAC,CAAC,CAAC,EAAE,CACP;gBACD,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;aAC1B;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AA/DY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,eAAe,CA+D3B"}
|
|
@@ -36,7 +36,7 @@ function DuplicateManyGatewayMixin(entity, controllerOptions, { dTOs, useInterce
|
|
|
36
36
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
37
37
|
writable: false,
|
|
38
38
|
});
|
|
39
|
-
class GetManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
39
|
+
class GetManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
40
40
|
}
|
|
41
41
|
class BaseDuplicateManyGateway extends gateways_1.BaseGateway {
|
|
42
42
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -36,7 +36,7 @@ function DuplicateOneGatewayMixin(entity, controllerOptions, { dTOs, useIntercep
|
|
|
36
36
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
37
37
|
writable: false,
|
|
38
38
|
});
|
|
39
|
-
class DuplicateOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
39
|
+
class DuplicateOnePoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic }) {
|
|
40
40
|
}
|
|
41
41
|
class BaseDuplicateOneGateway extends gateways_1.BaseGateway {
|
|
42
42
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-one-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
|
-
import { AfterSaveCallback } from '../../interfaces';
|
|
2
|
+
import { AbilityPredicate, AfterSaveCallback, PredicateBehavior } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { BaseService } from '../../services';
|
|
5
5
|
import { GetManyService } from './get-many-service.interface';
|
|
6
6
|
export declare abstract class BaseGetManyService<Entity extends BaseEntity> extends BaseService<Entity> implements GetManyService<Entity> {
|
|
7
7
|
protected readonly model: Model<Entity>;
|
|
8
8
|
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
9
|
+
protected readonly abilityPredicate: AbilityPredicate<Entity> | undefined;
|
|
10
|
+
protected readonly predicateBehavior: PredicateBehavior | undefined;
|
|
9
11
|
protected constructor(model: Model<Entity>);
|
|
10
12
|
getMany(query?: object, user?: unknown): Promise<Entity[]>;
|
|
11
13
|
}
|
|
@@ -18,7 +18,11 @@ class BaseGetManyService extends services_1.BaseService {
|
|
|
18
18
|
if (this.callback && documents.length) {
|
|
19
19
|
await Promise.all(documents.map((document) => this.callback(this.addDocumentId(document), this.callbackMethods, user)));
|
|
20
20
|
}
|
|
21
|
-
|
|
21
|
+
const instances = documents.map((d) => this.buildInstance(d));
|
|
22
|
+
if (this.predicateBehavior === 'filter' && this.abilityPredicate) {
|
|
23
|
+
return instances.filter((instance) => this.abilityPredicate(instance, user));
|
|
24
|
+
}
|
|
25
|
+
return instances;
|
|
22
26
|
}
|
|
23
27
|
}
|
|
24
28
|
exports.BaseGetManyService = BaseGetManyService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-get-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/base-get-many.service.ts"],"names":[],"mappings":";;;AAGA,6CAA6C;AAG7C,MAAsB,kBACpB,SAAQ,sBAAmB;
|
|
1
|
+
{"version":3,"file":"base-get-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/base-get-many.service.ts"],"names":[],"mappings":";;;AAGA,6CAA6C;AAG7C,MAAsB,kBACpB,SAAQ,sBAAmB;IAM3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAc,EAAE,IAAc;QAC1C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK;aACjC,IAAI,CAAC;YACJ,GAAG,CACD,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CACjD;YACD,GAAG,CACD,KAAK,IAAI,EAAE,CACZ;SACF,CAAC;aACD,IAAI,EAAY;aAChB,IAAI,EAAE,CAAC;QAER,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,MAAM,EAAE,CAAC;YACtC,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;QACJ,CAAC;QAED,MAAM,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9D,IAAI,IAAI,CAAC,iBAAiB,KAAK,QAAQ,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACjE,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AAxCD,gDAwCC"}
|
|
@@ -20,7 +20,7 @@ const dtos_1 = require("../../dtos");
|
|
|
20
20
|
const helpers_1 = require("../../helpers");
|
|
21
21
|
const mixins_1 = require("../../mixins");
|
|
22
22
|
function GetManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], ...routeConfig }, version) {
|
|
23
|
-
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
|
+
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, predicateBehavior, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
24
24
|
class GetManyQuery extends (dTOs?.query ?? dtos_1.EntityQuery) {
|
|
25
25
|
}
|
|
26
26
|
Object.defineProperty(GetManyQuery, 'name', {
|
|
@@ -38,7 +38,7 @@ function GetManyControllerMixin(entity, controllerOptions, { dTOs, useIntercepto
|
|
|
38
38
|
const routeDecoratorsBuilder = new builders_1.RouteDecoratorsBuilder(routeType, entity, routeConfig.subPath, version, description, isPublic, {
|
|
39
39
|
presenter: GetManyPresenter,
|
|
40
40
|
});
|
|
41
|
-
class GetManyPoliciesGuard extends (0, mixins_1.RoutePoliciesGuardMixin)(entity, routeType, displayedName, version, abilityPredicate) {
|
|
41
|
+
class GetManyPoliciesGuard extends (0, mixins_1.RoutePoliciesGuardMixin)(entity, routeType, displayedName, version, abilityPredicate, undefined, predicateBehavior) {
|
|
42
42
|
}
|
|
43
43
|
Object.defineProperty(GetManyPoliciesGuard, 'name', {
|
|
44
44
|
value: `${routeType}${displayedName}${(0, helpers_1.addVersionSuffix)(version)}PoliciesGuard`,
|
|
@@ -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":";;;;;;;;;;;;;;
|
|
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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"}
|
|
@@ -22,7 +22,7 @@ const guards_1 = require("../../guards");
|
|
|
22
22
|
const helpers_1 = require("../../helpers");
|
|
23
23
|
const mixins_1 = require("../../mixins");
|
|
24
24
|
function GetManyGatewayMixin(entity, controllerOptions, { dTOs, useInterceptors = [], ...routeConfig }, version) {
|
|
25
|
-
const { routeType, displayedName, isPublic, event, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig, true);
|
|
25
|
+
const { routeType, displayedName, isPublic, event, abilityPredicate, predicateBehavior, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig, true);
|
|
26
26
|
class GetManyData extends (dTOs?.query ?? dtos_1.EntityQuery) {
|
|
27
27
|
}
|
|
28
28
|
Object.defineProperty(GetManyData, 'name', {
|
|
@@ -37,7 +37,7 @@ function GetManyGatewayMixin(entity, controllerOptions, { dTOs, useInterceptors
|
|
|
37
37
|
: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Response`,
|
|
38
38
|
writable: false,
|
|
39
39
|
});
|
|
40
|
-
class GetManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, abilityPredicate, isPublic) {
|
|
40
|
+
class GetManyPoliciesGuard extends (0, mixins_1.SocketPoliciesGuardMixin)(entity, routeType, event, version, { abilityPredicate, isPublic, predicateBehavior }) {
|
|
41
41
|
}
|
|
42
42
|
class BaseGetManyGateway extends gateways_1.BaseGateway {
|
|
43
43
|
constructor(service, jwtService) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many-gateway.mixin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAkGS,kDAAmB;AAlG5B,2CAA8E;AAE9E,mDAAoF;AACpF,qCAAyC;AACzC,2CAA4D;AAC5D,6CAA6C;AAC7C,yCAA8C;AAC9C,2CAA4E;AAE5E,yCAA8E;AAK9E,SAAS,mBAAmB,CAC1B,MAAoB,EACpB,iBAAsD,EACtD,EAAE,IAAI,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,WAAW,EAAiC,EAC7E,OAAgB;IAEhB,MAAM,EACJ,SAAS,EACT,aAAa,EACb,QAAQ,EACR,KAAK,EACL,gBAAgB,
|
|
1
|
+
{"version":3,"file":"get-many-gateway.mixin.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many-gateway.mixin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AbilityPredicate, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions, PredicateBehavior } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { GetManyControllerConstructor } from './get-many-controller.interface';
|
|
5
5
|
import { GetManyGatewayConstructor } from './get-many-gateway.interface';
|
|
6
|
-
declare function createGetManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createGetManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, abilityPredicate?: AbilityPredicate<Entity>, predicateBehavior?: PredicateBehavior): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createGetManyController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): GetManyControllerConstructor<Entity>;
|
|
8
8
|
declare function createGetManyGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): GetManyGatewayConstructor<Entity>;
|
|
9
9
|
export { createGetManyController, createGetManyGateway, createGetManyServiceProvider };
|
|
@@ -27,13 +27,15 @@ const helpers_1 = require("../../helpers");
|
|
|
27
27
|
const base_get_many_service_1 = require("./base-get-many.service");
|
|
28
28
|
const get_many_controller_mixin_1 = require("./get-many-controller.mixin");
|
|
29
29
|
const get_many_gateway_mixin_1 = require("./get-many-gateway.mixin");
|
|
30
|
-
function createGetManyServiceProvider(entity, displayedName, version, callback) {
|
|
30
|
+
function createGetManyServiceProvider(entity, displayedName, version, callback, abilityPredicate, predicateBehavior) {
|
|
31
31
|
let GetManyService = class GetManyService extends base_get_many_service_1.BaseGetManyService {
|
|
32
32
|
constructor(model) {
|
|
33
33
|
super(model);
|
|
34
34
|
this.model = model;
|
|
35
35
|
this.entity = entity;
|
|
36
36
|
this.callback = callback;
|
|
37
|
+
this.abilityPredicate = abilityPredicate;
|
|
38
|
+
this.predicateBehavior = predicateBehavior;
|
|
37
39
|
}
|
|
38
40
|
};
|
|
39
41
|
GetManyService = __decorate([
|