mongodb-dynamic-api 4.2.1 → 4.4.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 +31 -0
- package/package.json +1 -1
- package/src/decorators/disable-cache.decorator.d.ts +3 -0
- package/src/decorators/disable-cache.decorator.js +9 -0
- package/src/decorators/disable-cache.decorator.js.map +1 -0
- package/src/decorators/index.d.ts +1 -0
- package/src/decorators/index.js +1 -0
- package/src/decorators/index.js.map +1 -1
- package/src/dynamic-api.module.js +6 -0
- package/src/dynamic-api.module.js.map +1 -1
- package/src/helpers/mixin-data.helper.d.ts +2 -1
- package/src/helpers/mixin-data.helper.js +12 -1
- package/src/helpers/mixin-data.helper.js.map +1 -1
- package/src/interceptors/dynamic-api-cache.interceptor.d.ts +1 -0
- package/src/interceptors/dynamic-api-cache.interceptor.js +19 -3
- package/src/interceptors/dynamic-api-cache.interceptor.js.map +1 -1
- package/src/interfaces/dynamic-api-controller-options.interface.d.ts +1 -0
- package/src/interfaces/dynamic-api-route-config.interface.d.ts +5 -4
- package/src/interfaces/dynamic-api-service-before-save-callback.interface.d.ts +47 -5
- package/src/interfaces/dynamic-api-service-callback.interface.d.ts +5 -3
- package/src/modules/auth/auth.helper.d.ts +2 -2
- package/src/modules/auth/auth.helper.js.map +1 -1
- package/src/modules/auth/interfaces/auth-options.interface.d.ts +9 -9
- package/src/modules/auth/services/base-auth.service.d.ts +7 -7
- package/src/routes/aggregate/aggregate-controller.mixin.js +3 -1
- package/src/routes/aggregate/aggregate-controller.mixin.js.map +1 -1
- package/src/routes/aggregate/aggregate.helper.d.ts +2 -2
- package/src/routes/aggregate/aggregate.helper.js.map +1 -1
- package/src/routes/aggregate/base-aggregate.service.d.ts +2 -2
- package/src/routes/cache-purge/cache-purge.helper.d.ts +8 -0
- package/src/routes/cache-purge/cache-purge.helper.js +74 -0
- package/src/routes/cache-purge/cache-purge.helper.js.map +1 -0
- package/src/routes/cache-purge/index.d.ts +1 -0
- package/src/routes/cache-purge/index.js +18 -0
- package/src/routes/cache-purge/index.js.map +1 -0
- package/src/routes/create-many/base-create-many.service.d.ts +3 -2
- package/src/routes/create-many/base-create-many.service.js +5 -1
- package/src/routes/create-many/base-create-many.service.js.map +1 -1
- package/src/routes/create-many/create-many.helper.d.ts +2 -2
- package/src/routes/create-many/create-many.helper.js +2 -1
- package/src/routes/create-many/create-many.helper.js.map +1 -1
- package/src/routes/create-many/create-many.module.js +1 -1
- package/src/routes/create-many/create-many.module.js.map +1 -1
- package/src/routes/create-one/base-create-one.service.d.ts +3 -3
- package/src/routes/create-one/create-one.helper.d.ts +2 -2
- package/src/routes/create-one/create-one.helper.js.map +1 -1
- package/src/routes/create-one/create-one.module.js.map +1 -1
- package/src/routes/delete-many/base-delete-many.service.d.ts +3 -0
- package/src/routes/delete-many/base-delete-many.service.js +13 -0
- package/src/routes/delete-many/base-delete-many.service.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 +3 -0
- package/src/routes/delete-one/base-delete-one.service.js +13 -0
- package/src/routes/delete-one/base-delete-one.service.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/base-duplicate-many.service.d.ts +3 -2
- package/src/routes/duplicate-many/base-duplicate-many.service.js +7 -2
- package/src/routes/duplicate-many/base-duplicate-many.service.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many.helper.d.ts +2 -2
- package/src/routes/duplicate-many/duplicate-many.helper.js +2 -1
- package/src/routes/duplicate-many/duplicate-many.helper.js.map +1 -1
- package/src/routes/duplicate-many/duplicate-many.module.js +1 -1
- package/src/routes/duplicate-many/duplicate-many.module.js.map +1 -1
- package/src/routes/duplicate-one/base-duplicate-one.service.d.ts +3 -2
- package/src/routes/duplicate-one/base-duplicate-one.service.js +7 -2
- package/src/routes/duplicate-one/base-duplicate-one.service.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one.helper.d.ts +2 -2
- package/src/routes/duplicate-one/duplicate-one.helper.js +2 -1
- package/src/routes/duplicate-one/duplicate-one.helper.js.map +1 -1
- package/src/routes/duplicate-one/duplicate-one.module.js +1 -1
- package/src/routes/duplicate-one/duplicate-one.module.js.map +1 -1
- package/src/routes/get-many/base-get-many.service.d.ts +2 -2
- package/src/routes/get-many/get-many-controller.mixin.js +3 -1
- package/src/routes/get-many/get-many-controller.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.map +1 -1
- package/src/routes/get-one/base-get-one.service.d.ts +2 -2
- package/src/routes/get-one/get-one-controller.mixin.js +3 -1
- package/src/routes/get-one/get-one-controller.mixin.js.map +1 -1
- package/src/routes/get-one/get-one.helper.d.ts +2 -2
- package/src/routes/get-one/get-one.helper.js.map +1 -1
- package/src/routes/index.d.ts +1 -0
- package/src/routes/index.js +1 -0
- package/src/routes/index.js.map +1 -1
- package/src/routes/replace-one/base-replace-one.service.d.ts +3 -2
- package/src/routes/replace-one/base-replace-one.service.js +14 -3
- package/src/routes/replace-one/base-replace-one.service.js.map +1 -1
- package/src/routes/replace-one/replace-one.helper.d.ts +2 -2
- package/src/routes/replace-one/replace-one.helper.js +2 -1
- package/src/routes/replace-one/replace-one.helper.js.map +1 -1
- package/src/routes/replace-one/replace-one.module.js +1 -1
- package/src/routes/replace-one/replace-one.module.js.map +1 -1
- package/src/routes/update-many/base-update-many.service.d.ts +3 -2
- package/src/routes/update-many/base-update-many.service.js +17 -7
- package/src/routes/update-many/base-update-many.service.js.map +1 -1
- package/src/routes/update-many/update-many.helper.d.ts +2 -2
- package/src/routes/update-many/update-many.helper.js +2 -1
- package/src/routes/update-many/update-many.helper.js.map +1 -1
- package/src/routes/update-many/update-many.module.js +1 -1
- package/src/routes/update-many/update-many.module.js.map +1 -1
- package/src/routes/update-one/base-update-one.service.d.ts +3 -3
- package/src/routes/update-one/update-one.helper.d.ts +2 -2
- package/src/routes/update-one/update-one.helper.js.map +1 -1
- package/src/routes/update-one/update-one.module.js.map +1 -1
- package/src/version.json +1 -1
- package/test/for-root/auth-api-login.e2e-spec.js +63 -0
- package/test/for-root/auth-api-login.e2e-spec.js.map +1 -1
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.BaseDuplicateManyService = void 0;
|
|
4
4
|
const class_transformer_1 = require("class-transformer");
|
|
5
|
+
const lodash_1 = require("lodash");
|
|
5
6
|
const mixins_1 = require("../../mixins");
|
|
6
7
|
const services_1 = require("../../services");
|
|
7
8
|
class BaseDuplicateManyService extends services_1.BaseService {
|
|
@@ -21,7 +22,7 @@ class BaseDuplicateManyService extends services_1.BaseService {
|
|
|
21
22
|
if (!toDuplicateList?.length) {
|
|
22
23
|
this.handleDocumentNotFound();
|
|
23
24
|
}
|
|
24
|
-
const
|
|
25
|
+
const baseDataList = toDuplicateList.map((d) => ({
|
|
25
26
|
...Object.entries(d).reduce((acc, [key, value]) => {
|
|
26
27
|
if ((0, mixins_1.baseEntityKeysToExclude)().includes(key)) {
|
|
27
28
|
return acc;
|
|
@@ -29,7 +30,11 @@ class BaseDuplicateManyService extends services_1.BaseService {
|
|
|
29
30
|
return { ...acc, [key]: value };
|
|
30
31
|
}, {}),
|
|
31
32
|
...partial,
|
|
32
|
-
}))
|
|
33
|
+
}));
|
|
34
|
+
const toCreateList = this.beforeSaveCallback
|
|
35
|
+
? await this.beforeSaveCallback(toDuplicateList, { ids, override: partial ? (0, lodash_1.cloneDeep)(partial) : undefined }, this.callbackMethods)
|
|
36
|
+
: baseDataList;
|
|
37
|
+
const duplicatedList = await this.model.create(toCreateList.map((d) => (0, class_transformer_1.plainToInstance)(this.entity, d)));
|
|
33
38
|
const documents = await this.model.find({ _id: { $in: duplicatedList.map(({ _id }) => _id.toString()) } })
|
|
34
39
|
.lean()
|
|
35
40
|
.exec();
|
|
@@ -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;
|
|
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":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig,
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveListCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DuplicateManyControllerConstructor } from './duplicate-many-controller.interface';
|
|
5
5
|
import { DuplicateManyGatewayConstructor } from './duplicate-many-gateway.interface';
|
|
6
|
-
declare function createDuplicateManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createDuplicateManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveListCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createDuplicateManyController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DuplicateManyControllerConstructor<Entity>;
|
|
8
8
|
declare function createDuplicateManyGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): DuplicateManyGatewayConstructor<Entity>;
|
|
9
9
|
export { createDuplicateManyController, createDuplicateManyGateway, createDuplicateManyServiceProvider };
|
|
@@ -28,12 +28,13 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const base_duplicate_many_service_1 = require("./base-duplicate-many.service");
|
|
29
29
|
const duplicate_many_controller_mixin_1 = require("./duplicate-many-controller.mixin");
|
|
30
30
|
const duplicate_many_gateway_mixin_1 = require("./duplicate-many-gateway.mixin");
|
|
31
|
-
function createDuplicateManyServiceProvider(entity, displayedName, version, callback) {
|
|
31
|
+
function createDuplicateManyServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
32
32
|
let DuplicateManyService = class DuplicateManyService extends base_duplicate_many_service_1.BaseDuplicateManyService {
|
|
33
33
|
constructor(model) {
|
|
34
34
|
super(model);
|
|
35
35
|
this.model = model;
|
|
36
36
|
this.entity = entity;
|
|
37
|
+
this.beforeSaveCallback = beforeSaveCallback;
|
|
37
38
|
this.callback = callback;
|
|
38
39
|
}
|
|
39
40
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ let DuplicateManyModule = DuplicateManyModule_1 = class DuplicateManyModule {
|
|
|
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, duplicate_many_helper_1.createDuplicateManyController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, duplicate_many_helper_1.createDuplicateManyServiceProvider)(entity, displayedName, version, routeConfig.callback);
|
|
20
|
+
const ServiceProvider = (0, duplicate_many_helper_1.createDuplicateManyServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback);
|
|
21
21
|
const hasBroadcast = !!routeConfig.broadcast;
|
|
22
22
|
const gatewayOptions = webSocket
|
|
23
23
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,mEAIiC;AAI1B,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAC9B,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,qDAA6B,EAC9C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,0DAAkC,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"duplicate-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-many/duplicate-many.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,mEAIiC;AAI1B,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAC9B,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,qDAA6B,EAC9C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,0DAAkC,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAoD,CAAC,CAAC;QAEnL,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,qBAAmB;YAC3B,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,kDAA0B,EACxB,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;AAvDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,mBAAmB,CAuD/B"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { Model } from 'mongoose';
|
|
3
|
-
import {
|
|
3
|
+
import { BeforeSaveCallback, BeforeSaveDuplicateContext, AfterSaveCallback } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { DuplicateOneService } from './duplicate-one-service.interface';
|
|
7
7
|
export declare abstract class BaseDuplicateOneService<Entity extends BaseEntity> extends BaseService<Entity> implements DuplicateOneService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly entity: Type<Entity>;
|
|
10
|
-
protected readonly
|
|
10
|
+
protected readonly beforeSaveCallback: BeforeSaveCallback<Entity, BeforeSaveDuplicateContext<Entity>> | undefined;
|
|
11
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
11
12
|
protected constructor(model: Model<Entity>);
|
|
12
13
|
duplicateOne(id: string, partial: Partial<Entity> | undefined): Promise<Entity>;
|
|
13
14
|
}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.BaseDuplicateOneService = void 0;
|
|
4
4
|
const class_transformer_1 = require("class-transformer");
|
|
5
|
+
const lodash_1 = require("lodash");
|
|
5
6
|
const mixins_1 = require("../../mixins");
|
|
6
7
|
const services_1 = require("../../services");
|
|
7
8
|
class BaseDuplicateOneService extends services_1.BaseService {
|
|
@@ -21,7 +22,7 @@ class BaseDuplicateOneService extends services_1.BaseService {
|
|
|
21
22
|
if (!toDuplicate) {
|
|
22
23
|
this.handleDocumentNotFound();
|
|
23
24
|
}
|
|
24
|
-
const
|
|
25
|
+
const baseData = {
|
|
25
26
|
...Object.entries(toDuplicate).reduce((acc, [key, value]) => {
|
|
26
27
|
if ((0, mixins_1.baseEntityKeysToExclude)().includes(key)) {
|
|
27
28
|
return acc;
|
|
@@ -29,7 +30,11 @@ class BaseDuplicateOneService extends services_1.BaseService {
|
|
|
29
30
|
return { ...acc, [key]: value };
|
|
30
31
|
}, {}),
|
|
31
32
|
...partial,
|
|
32
|
-
}
|
|
33
|
+
};
|
|
34
|
+
const toCreate = this.beforeSaveCallback
|
|
35
|
+
? await this.beforeSaveCallback(this.addDocumentId(toDuplicate), { id, override: partial ? (0, lodash_1.cloneDeep)(partial) : undefined }, this.callbackMethods)
|
|
36
|
+
: baseData;
|
|
37
|
+
const { _id } = await this.model.create((0, class_transformer_1.plainToInstance)(this.entity, toCreate));
|
|
33
38
|
const document = await this.model.findOne({ _id }).lean().exec();
|
|
34
39
|
if (this.callback) {
|
|
35
40
|
await this.callback(this.addDocumentId(document), this.callbackMethods);
|
|
@@ -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;
|
|
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,mCAAmC;AAOnC,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;QACjE,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,QAAQ,GAAG,IAAI,CAAC,kBAAkB;gBACtC,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,kBAAS,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,EAC1D,IAAI,CAAC,eAAe,CACrB;gBACD,CAAC,CAAC,QAAQ,CAAC;YAEb,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,CAAC,CAAC;YAC1E,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;AA9DD,0DA8DC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig,
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DuplicateOneControllerConstructor } from './duplicate-one-controller.interface';
|
|
5
5
|
import { DuplicateOneGatewayConstructor } from './duplicate-one-gateway.interface';
|
|
6
|
-
declare function createDuplicateOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createDuplicateOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createDuplicateOneController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DuplicateOneControllerConstructor<Entity>;
|
|
8
8
|
declare function createDuplicateOneGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): DuplicateOneGatewayConstructor<Entity>;
|
|
9
9
|
export { createDuplicateOneController, createDuplicateOneGateway, createDuplicateOneServiceProvider };
|
|
@@ -28,12 +28,13 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const base_duplicate_one_service_1 = require("./base-duplicate-one.service");
|
|
29
29
|
const duplicate_one_controller_mixin_1 = require("./duplicate-one-controller.mixin");
|
|
30
30
|
const duplicate_one_gateway_mixin_1 = require("./duplicate-one-gateway.mixin");
|
|
31
|
-
function createDuplicateOneServiceProvider(entity, displayedName, version, callback) {
|
|
31
|
+
function createDuplicateOneServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
32
32
|
let DuplicateOneService = class DuplicateOneService extends base_duplicate_one_service_1.BaseDuplicateOneService {
|
|
33
33
|
constructor(model) {
|
|
34
34
|
super(model);
|
|
35
35
|
this.model = model;
|
|
36
36
|
this.entity = entity;
|
|
37
|
+
this.beforeSaveCallback = beforeSaveCallback;
|
|
37
38
|
this.callback = callback;
|
|
38
39
|
}
|
|
39
40
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"duplicate-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ let DuplicateOneModule = DuplicateOneModule_1 = class DuplicateOneModule {
|
|
|
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, duplicate_one_helper_1.createDuplicateOneController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, duplicate_one_helper_1.createDuplicateOneServiceProvider)(entity, displayedName, version, routeConfig.callback);
|
|
20
|
+
const ServiceProvider = (0, duplicate_one_helper_1.createDuplicateOneServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback);
|
|
21
21
|
const hasBroadcast = !!routeConfig.broadcast;
|
|
22
22
|
const gatewayOptions = webSocket
|
|
23
23
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duplicate-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,iEAIgC;AAIzB,IAAM,kBAAkB,0BAAxB,MAAM,kBAAkB;IAC7B,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,mDAA4B,EAC7C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,wDAAiC,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"duplicate-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/duplicate-one/duplicate-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,iEAIgC;AAIzB,IAAM,kBAAkB,0BAAxB,MAAM,kBAAkB;IAC7B,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,mDAA4B,EAC7C,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,WAAW,EACX,OAAO,EACP,qBAAqB,CACtB,CAAC;QACF,MAAM,eAAe,GAAG,IAAA,wDAAiC,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAgD,CAAC,CAAC;QAE9K,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,oBAAkB;YAC1B,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,gDAAyB,EACvB,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;AAvDY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,kBAAkB,CAuD9B"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
|
-
import {
|
|
2
|
+
import { AfterSaveCallback } 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
|
-
protected readonly callback:
|
|
8
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
9
9
|
protected constructor(model: Model<Entity>);
|
|
10
10
|
getMany(query?: object): Promise<Entity[]>;
|
|
11
11
|
}
|
|
@@ -15,11 +15,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
15
15
|
exports.GetManyControllerMixin = GetManyControllerMixin;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const builders_1 = require("../../builders");
|
|
18
|
+
const decorators_1 = require("../../decorators");
|
|
18
19
|
const dtos_1 = require("../../dtos");
|
|
19
20
|
const helpers_1 = require("../../helpers");
|
|
20
21
|
const mixins_1 = require("../../mixins");
|
|
21
22
|
function GetManyControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], ...routeConfig }, version) {
|
|
22
|
-
const { routeType, displayedName, description, isPublic, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
|
+
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
24
|
class GetManyQuery extends (dTOs?.query ?? dtos_1.EntityQuery) {
|
|
24
25
|
}
|
|
25
26
|
Object.defineProperty(GetManyQuery, 'name', {
|
|
@@ -58,6 +59,7 @@ function GetManyControllerMixin(entity, controllerOptions, { dTOs, useIntercepto
|
|
|
58
59
|
(0, helpers_1.RouteDecoratorsHelper)(routeDecoratorsBuilder),
|
|
59
60
|
(0, common_1.UseGuards)(GetManyPoliciesGuard),
|
|
60
61
|
(0, common_1.UseInterceptors)(...useInterceptors),
|
|
62
|
+
(0, common_1.SetMetadata)(decorators_1.DISABLE_CACHE_KEY, disableCache),
|
|
61
63
|
__param(0, (0, common_1.Query)()),
|
|
62
64
|
__metadata("design:type", Function),
|
|
63
65
|
__metadata("design:paramtypes", [GetManyQuery]),
|
|
@@ -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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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig,
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } 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:
|
|
6
|
+
declare function createGetManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined): 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 };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAsIS,0DAAuB;AAAE,oDAAoB;AAAE,oEAA4B;AAtIpF,2CAOwB;AACxB,qCAAyC;AACzC,+CAA+C;AAC/C,6CAA0C;AAC1C,mDAAsD;AACtD,uCAAiC;AACjC,iDAAiD;AACjD,iEAA4D;AAC5D,2CAA4C;AAS5C,mEAA6D;AAE7D,2EAAqE;AAErE,qEAA+D;AAG/D,SAAS,4BAA4B,CACnC,MAAoB,EACpB,aAAqB,EACrB,OAA2B,EAC3B,
|
|
1
|
+
{"version":3,"file":"get-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-many/get-many.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
|
-
import {
|
|
2
|
+
import { AfterSaveCallback } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { BaseService } from '../../services';
|
|
5
5
|
import { GetOneService } from './get-one-service.interface';
|
|
6
6
|
export declare abstract class BaseGetOneService<Entity extends BaseEntity> extends BaseService<Entity> implements GetOneService<Entity> {
|
|
7
7
|
protected readonly model: Model<Entity>;
|
|
8
|
-
protected readonly callback:
|
|
8
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
9
9
|
protected constructor(model: Model<Entity>);
|
|
10
10
|
getOne(id: string): Promise<Entity>;
|
|
11
11
|
}
|
|
@@ -15,11 +15,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
15
15
|
exports.GetOneControllerMixin = GetOneControllerMixin;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const builders_1 = require("../../builders");
|
|
18
|
+
const decorators_1 = require("../../decorators");
|
|
18
19
|
const dtos_1 = require("../../dtos");
|
|
19
20
|
const helpers_1 = require("../../helpers");
|
|
20
21
|
const mixins_1 = require("../../mixins");
|
|
21
22
|
function GetOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptors = [], ...routeConfig }, version) {
|
|
22
|
-
const { routeType, displayedName, description, isPublic, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
|
+
const { routeType, displayedName, description, isPublic, disableCache, abilityPredicate, } = (0, helpers_1.getMixinData)(entity, controllerOptions, routeConfig);
|
|
23
24
|
class GetOnePresenter extends (dTOs?.presenter ?? (0, mixins_1.EntityPresenterMixin)(entity)) {
|
|
24
25
|
}
|
|
25
26
|
Object.defineProperty(GetOnePresenter, 'name', {
|
|
@@ -49,6 +50,7 @@ function GetOneControllerMixin(entity, controllerOptions, { dTOs, useInterceptor
|
|
|
49
50
|
(0, helpers_1.RouteDecoratorsHelper)(routeDecoratorsBuilder),
|
|
50
51
|
(0, common_1.UseGuards)(GetOnePoliciesGuard),
|
|
51
52
|
(0, common_1.UseInterceptors)(...useInterceptors),
|
|
53
|
+
(0, common_1.SetMetadata)(decorators_1.DISABLE_CACHE_KEY, disableCache),
|
|
52
54
|
__param(0, (0, common_1.Param)('id')),
|
|
53
55
|
__metadata("design:type", Function),
|
|
54
56
|
__metadata("design:paramtypes", [String]),
|
|
@@ -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":";;;;;;;;;;;;;;
|
|
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,2CAAsF;AACtF,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;YAClC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAE7C,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;;;;sDAQxB;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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig,
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { GetOneControllerConstructor } from './get-one-controller.interface';
|
|
5
5
|
import { GetOneGatewayConstructor } from './get-one-gateway.interface';
|
|
6
|
-
declare function createGetOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createGetOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createGetOneController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): GetOneControllerConstructor<Entity>;
|
|
8
8
|
declare function createGetOneGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): GetOneGatewayConstructor<Entity>;
|
|
9
9
|
export { createGetOneController, createGetOneGateway, createGetOneServiceProvider };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-one/get-one.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAsIS,wDAAsB;AAAE,kDAAmB;AAAE,kEAA2B;AAtIjF,2CAOwB;AACxB,qCAAyC;AACzC,+CAA+C;AAC/C,6CAA0C;AAC1C,mDAAsD;AACtD,uCAAiC;AACjC,iDAAiD;AACjD,iEAA4D;AAC5D,2CAA4C;AAS5C,iEAA2D;AAE3D,yEAAmE;AAEnE,mEAA6D;AAG7D,SAAS,2BAA2B,CAClC,MAAoB,EACpB,aAAqB,EACrB,OAA2B,EAC3B,
|
|
1
|
+
{"version":3,"file":"get-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/get-one/get-one.helper.ts"],"names":[],"mappings":"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"}
|
package/src/routes/index.d.ts
CHANGED
package/src/routes/index.js
CHANGED
|
@@ -15,6 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./aggregate"), exports);
|
|
18
|
+
__exportStar(require("./cache-purge"), exports);
|
|
18
19
|
__exportStar(require("./create-many"), exports);
|
|
19
20
|
__exportStar(require("./create-one"), exports);
|
|
20
21
|
__exportStar(require("./delete-many"), exports);
|
package/src/routes/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/dynamic-api/src/routes/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,gDAA8B;AAC9B,+CAA6B;AAC7B,gDAA8B;AAC9B,+CAA6B;AAC7B,mDAAiC;AACjC,kDAAgC;AAChC,6CAA2B;AAC3B,4CAA0B;AAC1B,gDAA8B;AAC9B,gDAA8B;AAC9B,+CAA6B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/dynamic-api/src/routes/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,gDAA8B;AAC9B,gDAA8B;AAC9B,+CAA6B;AAC7B,gDAA8B;AAC9B,+CAA6B;AAC7B,mDAAiC;AACjC,kDAAgC;AAChC,6CAA2B;AAC3B,4CAA0B;AAC1B,gDAA8B;AAC9B,gDAA8B;AAC9B,+CAA6B"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { Model } from 'mongoose';
|
|
3
|
-
import {
|
|
3
|
+
import { BeforeSaveCallback, BeforeSaveReplaceContext, AfterSaveCallback } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { ReplaceOneService } from './replace-one-service.interface';
|
|
7
7
|
export declare abstract class BaseReplaceOneService<Entity extends BaseEntity> extends BaseService<Entity> implements ReplaceOneService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly entity: Type<Entity>;
|
|
10
|
-
protected readonly
|
|
10
|
+
protected readonly beforeSaveCallback: BeforeSaveCallback<Entity, BeforeSaveReplaceContext<Entity>> | undefined;
|
|
11
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
11
12
|
protected constructor(model: Model<Entity>);
|
|
12
13
|
replaceOne(id: string, partial: Partial<Entity>): Promise<Entity>;
|
|
13
14
|
}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.BaseReplaceOneService = void 0;
|
|
4
4
|
const class_transformer_1 = require("class-transformer");
|
|
5
|
+
const lodash_1 = require("lodash");
|
|
5
6
|
const services_1 = require("../../services");
|
|
6
7
|
class BaseReplaceOneService extends services_1.BaseService {
|
|
7
8
|
constructor(model) {
|
|
@@ -10,11 +11,21 @@ class BaseReplaceOneService extends services_1.BaseService {
|
|
|
10
11
|
}
|
|
11
12
|
async replaceOne(id, partial) {
|
|
12
13
|
try {
|
|
13
|
-
const
|
|
14
|
-
.
|
|
14
|
+
const existingDocument = await this.model
|
|
15
|
+
.findOne({
|
|
15
16
|
_id: id,
|
|
16
17
|
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
17
|
-
}
|
|
18
|
+
})
|
|
19
|
+
.lean()
|
|
20
|
+
.exec();
|
|
21
|
+
if (!existingDocument) {
|
|
22
|
+
this.handleDocumentNotFound();
|
|
23
|
+
}
|
|
24
|
+
const replacement = this.beforeSaveCallback
|
|
25
|
+
? await this.beforeSaveCallback(this.addDocumentId(existingDocument), { id, replacement: (0, lodash_1.cloneDeep)(partial) }, this.callbackMethods)
|
|
26
|
+
: partial;
|
|
27
|
+
const document = await this.model
|
|
28
|
+
.findOneAndReplace({ _id: id }, (0, class_transformer_1.plainToInstance)(this.entity, replacement), {
|
|
18
29
|
new: true,
|
|
19
30
|
setDefaultsOnInsert: true,
|
|
20
31
|
})
|
|
@@ -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;
|
|
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,mCAAmC;AAQnC,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;QACnD,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,WAAW,GAAG,IAAI,CAAC,kBAAkB;gBACzC,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,EACpC,EAAE,EAAE,EAAE,WAAW,EAAE,IAAA,kBAAS,EAAC,OAAO,CAAC,EAAE,EACvC,IAAI,CAAC,eAAe,CACrB;gBACD,CAAC,CAAC,OAAO,CAAC;YAEZ,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,CAAC,CAAC;YAC1E,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;AAlED,sDAkEC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig,
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { ReplaceOneControllerConstructor } from './replace-one-controller.interface';
|
|
5
5
|
import { ReplaceOneGatewayConstructor } from './replace-one-gateway.interface';
|
|
6
|
-
declare function createReplaceOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createReplaceOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createReplaceOneController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): ReplaceOneControllerConstructor<Entity>;
|
|
8
8
|
declare function createReplaceOneGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): ReplaceOneGatewayConstructor<Entity>;
|
|
9
9
|
export { createReplaceOneController, createReplaceOneGateway, createReplaceOneServiceProvider };
|
|
@@ -28,12 +28,13 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const base_replace_one_service_1 = require("./base-replace-one.service");
|
|
29
29
|
const replace_one_controller_mixin_1 = require("./replace-one-controller.mixin");
|
|
30
30
|
const replace_one_gateway_mixin_1 = require("./replace-one-gateway.mixin");
|
|
31
|
-
function createReplaceOneServiceProvider(entity, displayedName, version, callback) {
|
|
31
|
+
function createReplaceOneServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
32
32
|
let ReplaceOneService = class ReplaceOneService extends base_replace_one_service_1.BaseReplaceOneService {
|
|
33
33
|
constructor(model) {
|
|
34
34
|
super(model);
|
|
35
35
|
this.model = model;
|
|
36
36
|
this.entity = entity;
|
|
37
|
+
this.beforeSaveCallback = beforeSaveCallback;
|
|
37
38
|
this.callback = callback;
|
|
38
39
|
}
|
|
39
40
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"replace-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"replace-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,7 +17,7 @@ let ReplaceOneModule = ReplaceOneModule_1 = class ReplaceOneModule {
|
|
|
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, replace_one_helper_1.createReplaceOneController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, replace_one_helper_1.createReplaceOneServiceProvider)(entity, displayedName, version, routeConfig.callback);
|
|
20
|
+
const ServiceProvider = (0, replace_one_helper_1.createReplaceOneServiceProvider)(entity, displayedName, version, routeConfig.callback, routeConfig.beforeSaveCallback);
|
|
21
21
|
const hasBroadcast = !!routeConfig.broadcast;
|
|
22
22
|
const gatewayOptions = webSocket
|
|
23
23
|
? (0, helpers_1.initializeConfigFromOptions)(webSocket)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"replace-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one.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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"replace-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/replace-one/replace-one.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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAgD,CAAC,CAAC;QAE5K,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;AAvDY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,gBAAgB,CAuD5B"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
|
-
import {
|
|
2
|
+
import { BeforeSaveListCallback, BeforeSaveUpdateManyContext, AfterSaveCallback } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { BaseService } from '../../services';
|
|
5
5
|
import { UpdateManyService } from './update-many-service.interface';
|
|
6
6
|
export declare abstract class BaseUpdateManyService<Entity extends BaseEntity> extends BaseService<Entity> implements UpdateManyService<Entity> {
|
|
7
7
|
protected readonly model: Model<Entity>;
|
|
8
|
-
protected readonly
|
|
8
|
+
protected readonly beforeSaveCallback: BeforeSaveListCallback<Entity, BeforeSaveUpdateManyContext<Entity>> | undefined;
|
|
9
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
9
10
|
protected constructor(model: Model<Entity>);
|
|
10
11
|
updateMany(ids: string[], partial: Partial<Entity>): Promise<Entity[]>;
|
|
11
12
|
}
|