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
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { PipelineStage } from 'mongodb-pipeline-builder';
|
|
3
3
|
import { Model } from 'mongoose';
|
|
4
|
-
import {
|
|
4
|
+
import { AfterSaveCallback } from '../../interfaces';
|
|
5
5
|
import { BaseEntity } from '../../models';
|
|
6
6
|
import { BaseService } from '../../services';
|
|
7
7
|
import { AggregateService } from './aggregate-service.interface';
|
|
8
8
|
export declare abstract class BaseAggregateService<Entity extends BaseEntity> extends BaseService<Entity> implements AggregateService<Entity> {
|
|
9
9
|
protected readonly model: Model<Entity>;
|
|
10
10
|
protected readonly entity: Type<Entity>;
|
|
11
|
-
protected readonly callback:
|
|
11
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
12
12
|
protected constructor(model: Model<Entity>);
|
|
13
13
|
aggregate(pipeline: PipelineStage[]): Promise<{
|
|
14
14
|
list: Entity[];
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Type } from '@nestjs/common';
|
|
2
|
+
import { DynamicApiControllerOptions } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
declare class CachePurgePresenter {
|
|
5
|
+
purged: boolean;
|
|
6
|
+
}
|
|
7
|
+
declare function createCachePurgeController<Entity extends BaseEntity>(entity: Type<Entity>, { path, apiTag, version, isPublic }: DynamicApiControllerOptions<Entity>): Type;
|
|
8
|
+
export { CachePurgePresenter, createCachePurgeController };
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.CachePurgePresenter = void 0;
|
|
16
|
+
exports.createCachePurgeController = createCachePurgeController;
|
|
17
|
+
const cache_manager_1 = require("@nestjs/cache-manager");
|
|
18
|
+
const common_1 = require("@nestjs/common");
|
|
19
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
20
|
+
const decorators_1 = require("../../decorators");
|
|
21
|
+
const dynamic_api_module_1 = require("../../dynamic-api.module");
|
|
22
|
+
class CachePurgePresenter {
|
|
23
|
+
}
|
|
24
|
+
exports.CachePurgePresenter = CachePurgePresenter;
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, swagger_1.ApiProperty)({ type: Boolean }),
|
|
27
|
+
__metadata("design:type", Boolean)
|
|
28
|
+
], CachePurgePresenter.prototype, "purged", void 0);
|
|
29
|
+
function createCachePurgeController(entity, { path, apiTag, version, isPublic }) {
|
|
30
|
+
const tag = apiTag || entity.name;
|
|
31
|
+
const isAuthEnabled = dynamic_api_module_1.DynamicApiModule.state.get('isAuthEnabled');
|
|
32
|
+
let CachePurgeController = class CachePurgeController {
|
|
33
|
+
constructor(cacheManager) {
|
|
34
|
+
this.cacheManager = cacheManager;
|
|
35
|
+
}
|
|
36
|
+
async purgeCache() {
|
|
37
|
+
await this.cacheManager.clear();
|
|
38
|
+
return { purged: true };
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, common_1.Delete)('cache'),
|
|
43
|
+
__metadata("design:type", Function),
|
|
44
|
+
__metadata("design:paramtypes", []),
|
|
45
|
+
__metadata("design:returntype", Promise)
|
|
46
|
+
], CachePurgeController.prototype, "purgeCache", null);
|
|
47
|
+
CachePurgeController = __decorate([
|
|
48
|
+
(0, common_1.Controller)({ path, version }),
|
|
49
|
+
(0, swagger_1.ApiTags)(tag),
|
|
50
|
+
(0, common_1.UseInterceptors)(common_1.ClassSerializerInterceptor),
|
|
51
|
+
__param(0, (0, common_1.Inject)(cache_manager_1.CACHE_MANAGER)),
|
|
52
|
+
__metadata("design:paramtypes", [Object])
|
|
53
|
+
], CachePurgeController);
|
|
54
|
+
const descriptor = Object.getOwnPropertyDescriptor(CachePurgeController.prototype, 'purgeCache');
|
|
55
|
+
(0, swagger_1.ApiOperation)({
|
|
56
|
+
operationId: `purgeCache${tag}${version ? 'V' + version : ''}`,
|
|
57
|
+
summary: `Purge cache for ${tag}`,
|
|
58
|
+
})(CachePurgeController.prototype, 'purgeCache', descriptor);
|
|
59
|
+
(0, swagger_1.ApiResponse)({
|
|
60
|
+
type: CachePurgePresenter,
|
|
61
|
+
})(CachePurgeController.prototype, 'purgeCache', descriptor);
|
|
62
|
+
if (isPublic) {
|
|
63
|
+
(0, decorators_1.Public)()(CachePurgeController.prototype, 'purgeCache', descriptor);
|
|
64
|
+
}
|
|
65
|
+
else if (isAuthEnabled) {
|
|
66
|
+
(0, swagger_1.ApiBearerAuth)()(CachePurgeController.prototype, 'purgeCache', descriptor);
|
|
67
|
+
}
|
|
68
|
+
Object.defineProperty(CachePurgeController, 'name', {
|
|
69
|
+
value: `CachePurge${tag}${version ? 'V' + version : ''}Controller`,
|
|
70
|
+
writable: false,
|
|
71
|
+
});
|
|
72
|
+
return CachePurgeController;
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=cache-purge.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache-purge.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/cache-purge/cache-purge.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAoE8B,gEAA0B;AApExD,yDAAsD;AACtD,2CAOwB;AACxB,6CAAiG;AAEjG,iDAA0C;AAC1C,iEAA4D;AAI5D,MAAM,mBAAmB;CAGxB;AAiDQ,kDAAmB;AAlD1B;IADC,IAAA,qBAAW,EAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;;mDACf;AAGlB,SAAS,0BAA0B,CACjC,MAAoB,EACpB,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAuC;IAExE,MAAM,GAAG,GAAG,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC;IAClC,MAAM,aAAa,GAAG,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAElE,IAGM,oBAAoB,GAH1B,MAGM,oBAAoB;QACxB,YAC0C,YAAmB;YAAnB,iBAAY,GAAZ,YAAY,CAAO;QAC1D,CAAC;QAGE,AAAN,KAAK,CAAC,UAAU;YACd,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;YAChC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;KACF,CAAA;IAJO;QADL,IAAA,eAAM,EAAC,OAAO,CAAC;;;;0DAIf;IATG,oBAAoB;QAHzB,IAAA,mBAAU,EAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;QAC7B,IAAA,iBAAO,EAAC,GAAG,CAAC;QACZ,IAAA,wBAAe,EAAC,mCAA0B,CAAC;QAGvC,WAAA,IAAA,eAAM,EAAC,6BAAa,CAAC,CAAA;;OAFpB,oBAAoB,CAUzB;IAED,MAAM,UAAU,GAAG,MAAM,CAAC,wBAAwB,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IAEjG,IAAA,sBAAY,EAAC;QACX,WAAW,EAAE,aAAa,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;QAC9D,OAAO,EAAE,mBAAmB,GAAG,EAAE;KAClC,CAAC,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IAE7D,IAAA,qBAAW,EAAC;QACV,IAAI,EAAE,mBAAmB;KAC1B,CAAC,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IAE7D,IAAI,QAAQ,EAAE,CAAC;QACb,IAAA,mBAAM,GAAE,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IACrE,CAAC;SAAM,IAAI,aAAa,EAAE,CAAC;QACzB,IAAA,uBAAa,GAAE,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IAC5E,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,aAAa,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,YAAY;QAClE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC;AAC9B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './cache-purge.helper';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./cache-purge.helper"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/cache-purge/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { Model } from 'mongoose';
|
|
3
|
-
import {
|
|
3
|
+
import { BeforeSaveCreateManyContext, BeforeSaveListCallback, AfterSaveCallback } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { CreateManyService } from './create-many-service.interface';
|
|
7
7
|
export declare abstract class BaseCreateManyService<Entity extends BaseEntity> extends BaseService<Entity> implements CreateManyService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly entity: Type<Entity>;
|
|
10
|
-
protected readonly
|
|
10
|
+
protected readonly beforeSaveCallback: BeforeSaveListCallback<Entity, BeforeSaveCreateManyContext<Entity>> | undefined;
|
|
11
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
11
12
|
protected constructor(model: Model<Entity>);
|
|
12
13
|
createMany(partials: Partial<Entity>[]): Promise<Entity[]>;
|
|
13
14
|
}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.BaseCreateManyService = 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 BaseCreateManyService extends services_1.BaseService {
|
|
7
8
|
constructor(model) {
|
|
@@ -10,7 +11,10 @@ class BaseCreateManyService extends services_1.BaseService {
|
|
|
10
11
|
}
|
|
11
12
|
async createMany(partials) {
|
|
12
13
|
try {
|
|
13
|
-
const
|
|
14
|
+
const toCreate = this.beforeSaveCallback
|
|
15
|
+
? await this.beforeSaveCallback(undefined, { toCreate: (0, lodash_1.cloneDeep)(partials) }, this.callbackMethods)
|
|
16
|
+
: partials;
|
|
17
|
+
const created = await this.model.create(toCreate.map((p) => (0, class_transformer_1.plainToInstance)(this.entity, p)));
|
|
14
18
|
const documents = await this.model
|
|
15
19
|
.find({ _id: { $in: created.map(({ _id }) => _id.toString()) } })
|
|
16
20
|
.lean()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-create-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/base-create-many.service.ts"],"names":[],"mappings":";;;AACA,yDAAoD;
|
|
1
|
+
{"version":3,"file":"base-create-many.service.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/base-create-many.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,QAA2B;QAC1C,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB;gBACtC,CAAC,CAAC,MAAM,IAAI,CAAC,kBAAkB,CAC7B,SAAS,EACT,EAAE,QAAQ,EAAE,IAAA,kBAAS,EAAC,QAAQ,CAAC,EAAE,EACjC,IAAI,CAAC,eAAe,CACrB;gBACD,CAAC,CAAC,QAAQ,CAAC;YAEb,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CACrC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CACrD,CAAC;YACF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK;iBACjC,IAAI,CAAC,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC;iBAChE,IAAI,EAAE;iBACN,IAAI,EAAE,CAAC;YAER,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC,MAAM,EAAE,CAAC;gBACtC,MAAM,OAAO,CAAC,GAAG,CACf,SAAS,CAAC,GAAG,CACX,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAkB,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,CAC1F,CACF,CAAC;YACJ,CAAC;YAED,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAW,CAAC,CAAC,CAAC;QAC/D,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;CACF;AA/CD,sDA+CC"}
|
|
@@ -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 { CreateManyControllerConstructor } from './create-many-controller.interface';
|
|
5
5
|
import { CreateManyGatewayConstructor } from './create-many-gateway.interface';
|
|
6
|
-
declare function createCreateManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createCreateManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveListCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createCreateManyController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): CreateManyControllerConstructor<Entity>;
|
|
8
8
|
declare function createCreateManyGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): CreateManyGatewayConstructor<Entity>;
|
|
9
9
|
export { createCreateManyController, createCreateManyGateway, createCreateManyServiceProvider };
|
|
@@ -28,12 +28,13 @@ const services_1 = require("../../services");
|
|
|
28
28
|
const base_create_many_service_1 = require("./base-create-many.service");
|
|
29
29
|
const create_many_controller_mixin_1 = require("./create-many-controller.mixin");
|
|
30
30
|
const create_many_gateway_mixin_1 = require("./create-many-gateway.mixin");
|
|
31
|
-
function createCreateManyServiceProvider(entity, displayedName, version, callback) {
|
|
31
|
+
function createCreateManyServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
32
32
|
let CreateManyService = class CreateManyService extends base_create_many_service_1.BaseCreateManyService {
|
|
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":"create-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"create-many.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-many.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AA4IS,gEAA0B;AAAE,0DAAuB;AAAE,0EAA+B;AA5I7F,2CAQwB;AACxB,qCAAyC;AACzC,+CAA+C;AAC/C,6CAA0C;AAC1C,mDAAsD;AACtD,uCAAiC;AACjC,iDAAiD;AACjD,iEAA4D;AAC5D,2CAA4C;AAS5C,6CAA4D;AAC5D,yEAAmE;AAEnE,iFAA2E;AAE3E,2EAAqE;AAGrE,SAAS,+BAA+B,CACtC,MAAoB,EACpB,aAAqB,EACrB,OAA2B,EAC3B,QAA+C,EAC/C,kBAA8D;IAE9D,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,gDAA6B;QAK3D,YAKE,KAAuC;YAEvC,KAAK,CAAC,KAAK,CAAC,CAAC;YAFM,UAAK,GAAL,KAAK,CAAe;YATtB,WAAM,GAAG,MAAM,CAAC;YAChB,uBAAkB,GAAG,kBAAkB,CAAC;YACxC,aAAQ,GAAG,QAAQ,CAAC;QAUvC,CAAC;KACF,CAAA;IAdK,iBAAiB;QAMlB,WAAA,IAAA,sBAAW,EACV,MAAM,CAAC,IAAI,EACX,qCAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAC7C,CAAA;yCACyB,gBAAK;OAV7B,iBAAiB,CActB;IAED,MAAM,CAAC,cAAc,CAAC,iBAAiB,EAAE,MAAM,EAAE;QAC/C,KAAK,EAAE,IAAA,qBAAW,EAAC,YAAY,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC;QACnE,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO;QACL,OAAO,EAAE,IAAA,qBAAW,EAAC,YAAY,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC;QACrE,QAAQ,EAAE,iBAAiB;KAC5B,CAAC;AACJ,CAAC;AAED,SAAS,0BAA0B,CACjC,MAAoB,EACpB,aAAqB,EACrB,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,iBAAiB,EAAuC,EACnF,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C;IAE7C,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,iBAAiB,CAAC;IAE3C,IAIM,oBAAoB,GAJ1B,MAIM,oBAAqB,SAAQ,IAAA,wDAAyB,EAC1D,MAAM,EACN,iBAAiB,EACjB,WAAW,EACX,OAAO,CACR;QACC,YAEqB,OAAkC,EAElC,gBAA6C;YAEhE,KAAK,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC;YAJd,YAAO,GAAP,OAAO,CAA2B;YAElC,qBAAgB,GAAhB,gBAAgB,CAA6B;QAGlE,CAAC;KACF,CAAA;IAdK,oBAAoB;QAJzB,IAAA,mBAAU,EAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;QAC7B,IAAA,iBAAO,EAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC;QAC9B,IAAA,0BAAa,EAAC,qBAAqB,CAAC;QACpC,IAAA,wBAAe,EAAC,mCAA0B,EAAE,GAAG,eAAe,CAAC;QAQ3D,WAAA,IAAA,eAAM,EAAC,IAAA,qBAAW,EAAC,YAAY,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAA;QAEpE,WAAA,IAAA,iBAAQ,GAAE,CAAA;QAAE,WAAA,IAAA,eAAM,EAAC,qCAA0B,CAAC,CAAA;iDACT,qCAA0B;OAV9D,oBAAoB,CAczB;IAED,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,MAAM,EAAE;QAClD,KAAK,EAAE,GAAG,IAAA,qBAAW,EAAC,YAAY,EAAE,aAAa,EAAE,OAAO,EAAE,YAAY,CAAC,EAAE;QAC3E,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,oBAAoB,CAAC;AAC9B,CAAC;AAED,SAAS,uBAAuB,CAC9B,MAAoB,EACpB,aAAqB,EACrB,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,iBAAiB,EAAuC,EACnF,WAA0C,EAC1C,OAAgB,EAChB,qBAA6C,EAC7C,iBAAiC,EAAE;IAEnC,IAGM,iBAAiB,GAHvB,MAGM,iBAAkB,SAAQ,IAAA,kDAAsB,EACpD,MAAM,EACN,iBAAiB,EACjB,WAAW,EACX,OAAO,CACR;QACC,YAEqB,OAAkC,EAClC,UAAsB;YAEzC,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;YAHR,YAAO,GAAP,OAAO,CAA2B;YAClC,eAAU,GAAV,UAAU,CAAY;QAG3C,CAAC;KACF,CAAA;IAbK,iBAAiB;QAHtB,IAAA,6BAAgB,EAAC,cAAc,CAAC;QAChC,IAAA,0BAAa,EAAC,qBAAqB,CAAC;QACpC,IAAA,wBAAe,EAAC,mCAA0B,EAAE,GAAG,eAAe,CAAC;QAQ3D,WAAA,IAAA,eAAM,EAAC,IAAA,qBAAW,EAAC,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAA;iDAE1C,gBAAU;OATvC,iBAAiB,CAatB;IAED,MAAM,CAAC,cAAc,CAAC,iBAAiB,EAAE,MAAM,EAAE;QAC/C,KAAK,EAAE,GAAG,IAAA,qBAAW,EAAC,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE;QAC5E,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,iBAAiB,CAAC;AAC3B,CAAC"}
|
|
@@ -17,7 +17,7 @@ let CreateManyModule = CreateManyModule_1 = class CreateManyModule {
|
|
|
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, create_many_helper_1.createCreateManyController)(entity, displayedName, controllerOptions, routeConfig, version, validationPipeOptions);
|
|
20
|
-
const ServiceProvider = (0, create_many_helper_1.createCreateManyServiceProvider)(entity, displayedName, version, routeConfig.callback);
|
|
20
|
+
const ServiceProvider = (0, create_many_helper_1.createCreateManyServiceProvider)(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":"create-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"create-many.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-many/create-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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAoD,CAAC,CAAC;QAEhL,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,12 +1,12 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
|
-
import {
|
|
2
|
+
import { BeforeSaveCallback, BeforeSaveCreateContext, AfterSaveCallback } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { BaseService } from '../../services';
|
|
5
5
|
import { CreateOneService } from './create-one-service.interface';
|
|
6
6
|
export declare abstract class BaseCreateOneService<Entity extends BaseEntity> extends BaseService<Entity> implements CreateOneService<Entity> {
|
|
7
7
|
protected readonly model: Model<Entity>;
|
|
8
|
-
protected readonly beforeSaveCallback:
|
|
9
|
-
protected readonly callback:
|
|
8
|
+
protected readonly beforeSaveCallback: BeforeSaveCallback<Entity, BeforeSaveCreateContext<Entity>> | undefined;
|
|
9
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
10
10
|
protected constructor(model: Model<Entity>);
|
|
11
11
|
createOne(partial: Partial<Entity>): Promise<Entity>;
|
|
12
12
|
}
|
|
@@ -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 { CreateOneControllerConstructor } from './create-one-controller.interface';
|
|
5
5
|
import { CreateOneGatewayConstructor } from './create-one-gateway.interface';
|
|
6
|
-
declare function createCreateOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback:
|
|
6
|
+
declare function createCreateOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveCallback<Entity> | undefined): DynamicAPIServiceProvider;
|
|
7
7
|
declare function createCreateOneController<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): CreateOneControllerConstructor<Entity>;
|
|
8
8
|
declare function createCreateOneGateway<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, { useInterceptors, ...controllerOptions }: DynamicApiControllerOptions<Entity>, routeConfig: DynamicAPIRouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions, gatewayOptions?: GatewayOptions): CreateOneGatewayConstructor<Entity>;
|
|
9
9
|
export { createCreateOneController, createCreateOneGateway, createCreateOneServiceProvider };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one.helper.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AA2IS,8DAAyB;AAAE,wDAAsB;AAAE,wEAA8B;AA3I1F,2CAQwB;AACxB,qCAAyC;AACzC,+CAA+C;AAC/C,6CAA0C;AAC1C,mDAAsD;AACtD,uCAAiC;AACjC,iDAAiD;AACjD,iEAA4D;AAC5D,2CAA4C;AAQ5C,6CAA4D;AAC5D,uEAAiE;AAEjE,+EAAyE;AAEzE,yEAAmE;AAGnE,SAAS,8BAA8B,CACrC,MAAoB,EACpB,aAAqB,EACrB,OAA2B,EAC3B,
|
|
1
|
+
{"version":3,"file":"create-one.helper.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,2DAAwH;AAIjH,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,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,
|
|
1
|
+
{"version":3,"file":"create-one.module.js","sourceRoot":"","sources":["../../../../libs/dynamic-api/src/routes/create-one/create-one.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoG;AAEpG,iEAA4D;AAC5D,2CAA8E;AAG9E,6CAA4D;AAC5D,2DAAwH;AAIjH,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,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAgD,CACnH,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;AAzDY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,eAAe,CAyD3B"}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
2
|
import { DeletePresenter } from '../../dtos';
|
|
3
|
+
import { BeforeSaveDeleteManyCallback, BeforeSaveDeleteManyContext, AfterSaveCallback } from '../../interfaces';
|
|
3
4
|
import { BaseEntity } from '../../models';
|
|
4
5
|
import { BaseService } from '../../services';
|
|
5
6
|
import { DeleteManyService } from './delete-many-service.interface';
|
|
6
7
|
export declare abstract class BaseDeleteManyService<Entity extends BaseEntity> extends BaseService<Entity> implements DeleteManyService<Entity> {
|
|
7
8
|
protected readonly model: Model<Entity>;
|
|
9
|
+
protected readonly beforeSaveCallback: BeforeSaveDeleteManyCallback<Entity, BeforeSaveDeleteManyContext> | undefined;
|
|
10
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
8
11
|
protected constructor(model: Model<Entity>);
|
|
9
12
|
deleteMany(ids: string[]): Promise<DeletePresenter>;
|
|
10
13
|
}
|
|
@@ -11,6 +11,16 @@ class BaseDeleteManyService extends services_1.BaseService {
|
|
|
11
11
|
}
|
|
12
12
|
async deleteMany(ids) {
|
|
13
13
|
try {
|
|
14
|
+
const documents = await this.model
|
|
15
|
+
.find({
|
|
16
|
+
_id: { $in: ids },
|
|
17
|
+
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
18
|
+
})
|
|
19
|
+
.lean()
|
|
20
|
+
.exec();
|
|
21
|
+
if (this.beforeSaveCallback) {
|
|
22
|
+
await this.beforeSaveCallback(documents, { ids }, this.callbackMethods);
|
|
23
|
+
}
|
|
14
24
|
let op;
|
|
15
25
|
if (this.isSoftDeletable) {
|
|
16
26
|
const deleted = await this.model
|
|
@@ -24,6 +34,9 @@ class BaseDeleteManyService extends services_1.BaseService {
|
|
|
24
34
|
else {
|
|
25
35
|
op = await this.model.deleteMany({ _id: { $in: ids } }).exec();
|
|
26
36
|
}
|
|
37
|
+
if (this.callback && documents?.length) {
|
|
38
|
+
await Promise.all(documents.map((document) => this.callback(this.addDocumentId(document), this.callbackMethods)));
|
|
39
|
+
}
|
|
27
40
|
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount: op.deletedCount });
|
|
28
41
|
}
|
|
29
42
|
catch (error) {
|
|
@@ -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":";;;AAAA,yDAAoD;AAEpD,qCAA6C;AAQ7C,6CAA6C;AAG7C,MAAsB,qBACpB,SAAQ,sBAAmB;IAS3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,GAAa;QAC5B,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK;iBAC/B,IAAI,CAAC;gBACJ,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE;gBACjB,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;aAC7D,CAAC;iBACD,IAAI,EAAY;iBAChB,IAAI,EAAE,CAAC;YAEV,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,MAAM,IAAI,CAAC,kBAAkB,CAC3B,SAAS,EACT,EAAE,GAAG,EAAE,EACP,IAAI,CAAC,eAAe,CACrB,CAAC;YACJ,CAAC;YAED,IAAI,EAAgB,CAAC;YAErB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACzB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK;qBAC/B,UAAU,CACT;oBACE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE;oBACjB,SAAS,EAAE,KAAK;iBACjB,EACD,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,CACrD;qBACA,IAAI,EAAE,CAAC;gBAER,EAAE,GAAG,EAAE,YAAY,EAAE,OAAO,CAAC,aAAa,EAAE,CAAC;YAC/C,CAAC;iBAAM,CAAC;gBACN,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;YACjE,CAAC;YAED,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,MAAM,EAAE,CAAC;gBACvC,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,CAAC,CAChF,CACF,CAAC;YACJ,CAAC;YAED,OAAO,IAAA,mCAAe,EAAC,sBAAe,EAAE,EAAE,YAAY,EAAE,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC;QAC7E,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,OAAO,IAAA,mCAAe,EAAC,sBAAe,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;CACF;AA/DD,sDA+DC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteManyCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } 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): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createDeleteManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteManyCallback<Entity> | 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,12 +28,14 @@ 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) {
|
|
31
|
+
function createDeleteManyServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
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
|
+
this.beforeSaveCallback = beforeSaveCallback;
|
|
38
|
+
this.callback = callback;
|
|
37
39
|
}
|
|
38
40
|
};
|
|
39
41
|
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);
|
|
20
|
+
const ServiceProvider = (0, delete_many_helper_1.createDeleteManyServiceProvider)(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":"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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;
|
|
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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAA0D,CAAC,CAAC;QAEtL,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,10 +1,13 @@
|
|
|
1
1
|
import { Model } from 'mongoose';
|
|
2
2
|
import { DeletePresenter } from '../../dtos';
|
|
3
|
+
import { BeforeSaveDeleteCallback, BeforeSaveDeleteContext, AfterSaveCallback } from '../../interfaces';
|
|
3
4
|
import { BaseEntity } from '../../models';
|
|
4
5
|
import { BaseService } from '../../services';
|
|
5
6
|
import { DeleteOneService } from './delete-one-service.interface';
|
|
6
7
|
export declare abstract class BaseDeleteOneService<Entity extends BaseEntity> extends BaseService<Entity> implements DeleteOneService<Entity> {
|
|
7
8
|
protected readonly model: Model<Entity>;
|
|
9
|
+
protected readonly beforeSaveCallback: BeforeSaveDeleteCallback<Entity, BeforeSaveDeleteContext> | undefined;
|
|
10
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
8
11
|
protected constructor(model: Model<Entity>);
|
|
9
12
|
deleteOne(id: string): Promise<DeletePresenter>;
|
|
10
13
|
}
|
|
@@ -11,6 +11,16 @@ class BaseDeleteOneService extends services_1.BaseService {
|
|
|
11
11
|
}
|
|
12
12
|
async deleteOne(id) {
|
|
13
13
|
try {
|
|
14
|
+
const document = await this.model
|
|
15
|
+
.findOne({
|
|
16
|
+
_id: id,
|
|
17
|
+
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
18
|
+
})
|
|
19
|
+
.lean()
|
|
20
|
+
.exec();
|
|
21
|
+
if (this.beforeSaveCallback) {
|
|
22
|
+
await this.beforeSaveCallback(document ? this.addDocumentId(document) : undefined, { id }, this.callbackMethods);
|
|
23
|
+
}
|
|
14
24
|
let op;
|
|
15
25
|
if (this.isSoftDeletable) {
|
|
16
26
|
const deleted = await this.model
|
|
@@ -24,6 +34,9 @@ class BaseDeleteOneService extends services_1.BaseService {
|
|
|
24
34
|
else {
|
|
25
35
|
op = await this.model.deleteOne({ _id: id }).exec();
|
|
26
36
|
}
|
|
37
|
+
if (this.callback && document) {
|
|
38
|
+
await this.callback(this.addDocumentId(document), this.callbackMethods);
|
|
39
|
+
}
|
|
27
40
|
return (0, class_transformer_1.plainToInstance)(dtos_1.DeletePresenter, { deletedCount: op.deletedCount });
|
|
28
41
|
}
|
|
29
42
|
catch (error) {
|
|
@@ -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":";;;AAAA,yDAAoD;AAEpD,qCAA6C;AAQ7C,6CAA6C;AAG7C,MAAsB,oBACpB,SAAQ,sBAAmB;IAS3B,YAAyC,KAAoB;QAC3D,KAAK,CAAC,KAAK,CAAC,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAe;IAE7D,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,EAAU;QACxB,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK;iBAC9B,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,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,MAAM,IAAI,CAAC,kBAAkB,CAC3B,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,EACnD,EAAE,EAAE,EAAE,EACN,IAAI,CAAC,eAAe,CACrB,CAAC;YACJ,CAAC;YAED,IAAI,EAAgB,CAAC;YAErB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACzB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK;qBAC/B,SAAS,CACR;oBACE,GAAG,EAAE,EAAE;oBACP,SAAS,EAAE,KAAK;iBACjB,EACD,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,CACrD;qBACA,IAAI,EAAE,CAAC;gBAER,EAAE,GAAG,EAAE,YAAY,EAAE,OAAO,CAAC,aAAa,EAAE,CAAC;YAC/C,CAAC;iBAAM,CAAC;gBACN,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;YACtD,CAAC;YAED,IAAI,IAAI,CAAC,QAAQ,IAAI,QAAQ,EAAE,CAAC;gBAC9B,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;YAC1E,CAAC;YAED,OAAO,IAAA,mCAAe,EAAC,sBAAe,EAAE,EAAE,YAAY,EAAE,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC;QAC7E,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,OAAO,IAAA,mCAAe,EAAC,sBAAe,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;CACF;AA3DD,oDA2DC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, DynamicAPIServiceProvider, GatewayOptions } from '../../interfaces';
|
|
2
|
+
import { DynamicApiControllerOptions, DynamicAPIRouteConfig, BeforeSaveDeleteCallback, AfterSaveCallback, DynamicAPIServiceProvider, GatewayOptions } 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): DynamicAPIServiceProvider;
|
|
6
|
+
declare function createDeleteOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, displayedName: string, version: string | undefined, callback: AfterSaveCallback<Entity> | undefined, beforeSaveCallback: BeforeSaveDeleteCallback<Entity> | 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,12 +28,14 @@ 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) {
|
|
31
|
+
function createDeleteOneServiceProvider(entity, displayedName, version, callback, beforeSaveCallback) {
|
|
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
|
+
this.beforeSaveCallback = beforeSaveCallback;
|
|
38
|
+
this.callback = callback;
|
|
37
39
|
}
|
|
38
40
|
};
|
|
39
41
|
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);
|
|
20
|
+
const ServiceProvider = (0, delete_one_helper_1.createDeleteOneServiceProvider)(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":"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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;
|
|
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,EAAC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,kBAAsD,CAAC,CAAC;QAEjL,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;AAvDY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,eAAe,CAuD3B"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { Type } from '@nestjs/common';
|
|
2
2
|
import { Model } from 'mongoose';
|
|
3
|
-
import {
|
|
3
|
+
import { BeforeSaveDuplicateManyContext, BeforeSaveListCallback, AfterSaveCallback } from '../../interfaces';
|
|
4
4
|
import { BaseEntity } from '../../models';
|
|
5
5
|
import { BaseService } from '../../services';
|
|
6
6
|
import { DuplicateManyService } from './duplicate-many-service.interface';
|
|
7
7
|
export declare abstract class BaseDuplicateManyService<Entity extends BaseEntity> extends BaseService<Entity> implements DuplicateManyService<Entity> {
|
|
8
8
|
protected readonly model: Model<Entity>;
|
|
9
9
|
protected readonly entity: Type<Entity>;
|
|
10
|
-
protected readonly
|
|
10
|
+
protected readonly beforeSaveCallback: BeforeSaveListCallback<Entity, BeforeSaveDuplicateManyContext<Entity>> | undefined;
|
|
11
|
+
protected readonly callback: AfterSaveCallback<Entity> | undefined;
|
|
11
12
|
protected constructor(model: Model<Entity>);
|
|
12
13
|
duplicateMany(ids: string[], partial: Partial<Entity> | undefined): Promise<Entity[]>;
|
|
13
14
|
}
|