mongodb-dynamic-api 1.2.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +23 -14
- package/README.md +250 -22
- package/package.json +3 -3
- package/src/builders/route-decorators.builder.d.ts +3 -1
- package/src/builders/route-decorators.builder.js +16 -4
- package/src/dtos/delete-many-entity.query.d.ts +3 -0
- package/src/dtos/delete-many-entity.query.js +24 -0
- package/src/dtos/index.d.ts +1 -0
- package/src/dtos/index.js +1 -0
- package/src/dynamic-api.module.d.ts +1 -1
- package/src/dynamic-api.module.js +32 -13
- package/src/helpers/format.helper.d.ts +2 -0
- package/src/helpers/format.helper.js +12 -0
- package/src/helpers/index.d.ts +5 -1
- package/src/helpers/index.js +5 -1
- package/src/helpers/route-description.helper.d.ts +3 -0
- package/src/helpers/route-description.helper.js +34 -0
- package/src/helpers/swagger-config.helper.d.ts +4 -0
- package/src/helpers/{config.helper.js → swagger-config.helper.js} +36 -21
- package/src/helpers/validation-config.helper.d.ts +3 -0
- package/src/helpers/validation-config.helper.js +8 -0
- package/src/helpers/versioning-config.helper.d.ts +4 -0
- package/src/helpers/versioning-config.helper.js +15 -0
- package/src/{helpers/config.helper.d.ts → interfaces/dynamic-api-swagger-options.type.d.ts} +23 -15
- package/src/interfaces/dynamic-api-swagger-options.type.js +2 -0
- package/src/interfaces/index.d.ts +1 -1
- package/src/interfaces/index.js +1 -1
- package/src/interfaces/route-config.interface.d.ts +1 -1
- package/src/modules/create-many/create-many-controller.mixin.js +6 -6
- package/src/modules/create-many/create-many.helper.d.ts +1 -1
- package/src/modules/create-many/create-many.helper.js +8 -7
- package/src/modules/create-many/create-many.module.d.ts +2 -2
- package/src/modules/create-many/create-many.module.js +2 -2
- package/src/modules/create-one/create-one-controller.mixin.js +5 -5
- package/src/modules/create-one/create-one.helper.d.ts +1 -1
- package/src/modules/create-one/create-one.helper.js +8 -7
- package/src/modules/create-one/create-one.module.d.ts +2 -2
- package/src/modules/create-one/create-one.module.js +2 -2
- package/src/modules/delete-many/base-delete-many.service.d.ts +34 -0
- package/src/modules/delete-many/base-delete-many.service.js +29 -0
- package/src/modules/delete-many/delete-many-controller.interface.d.ts +8 -0
- package/src/modules/delete-many/delete-many-controller.interface.js +2 -0
- package/src/modules/delete-many/delete-many-controller.mixin.d.ts +6 -0
- package/src/modules/delete-many/delete-many-controller.mixin.js +54 -0
- package/src/modules/delete-many/delete-many-service.interface.d.ts +6 -0
- package/src/modules/delete-many/delete-many-service.interface.js +2 -0
- package/src/modules/delete-many/delete-many.helper.d.ts +7 -0
- package/src/modules/delete-many/delete-many.helper.js +69 -0
- package/src/modules/delete-many/delete-many.module.d.ts +6 -0
- package/src/modules/delete-many/delete-many.module.js +28 -0
- package/src/modules/delete-many/delete-many.presenter.d.ts +3 -0
- package/src/modules/delete-many/delete-many.presenter.js +20 -0
- package/src/modules/delete-many/index.d.ts +7 -0
- package/src/modules/delete-many/index.js +23 -0
- package/src/modules/delete-one/delete-one-controller.mixin.js +5 -5
- package/src/modules/delete-one/delete-one.helper.d.ts +1 -1
- package/src/modules/delete-one/delete-one.helper.js +8 -7
- package/src/modules/delete-one/delete-one.module.d.ts +2 -2
- package/src/modules/delete-one/delete-one.module.js +2 -2
- package/src/modules/duplicate-many/base-duplicate-many.service.d.ts +33 -0
- package/src/modules/duplicate-many/base-duplicate-many.service.js +43 -0
- package/src/modules/duplicate-many/duplicate-many-controller.interface.d.ts +7 -0
- package/src/modules/duplicate-many/duplicate-many-controller.interface.js +2 -0
- package/src/modules/duplicate-many/duplicate-many-controller.mixin.d.ts +6 -0
- package/src/modules/duplicate-many/duplicate-many-controller.mixin.js +63 -0
- package/src/modules/duplicate-many/duplicate-many-service.interface.d.ts +5 -0
- package/src/modules/duplicate-many/duplicate-many-service.interface.js +2 -0
- package/src/modules/duplicate-many/duplicate-many.helper.d.ts +7 -0
- package/src/modules/duplicate-many/duplicate-many.helper.js +69 -0
- package/src/modules/duplicate-many/duplicate-many.module.d.ts +6 -0
- package/src/modules/duplicate-many/duplicate-many.module.js +28 -0
- package/src/modules/duplicate-many/index.d.ts +6 -0
- package/src/modules/duplicate-many/index.js +22 -0
- package/src/modules/duplicate-one/duplicate-one-controller.mixin.js +6 -6
- package/src/modules/duplicate-one/duplicate-one.helper.d.ts +1 -1
- package/src/modules/duplicate-one/duplicate-one.helper.js +8 -7
- package/src/modules/duplicate-one/duplicate-one.module.d.ts +2 -2
- package/src/modules/duplicate-one/duplicate-one.module.js +2 -2
- package/src/modules/get-many/get-many-controller.mixin.js +5 -5
- package/src/modules/get-many/get-many.helper.d.ts +1 -1
- package/src/modules/get-many/get-many.helper.js +8 -7
- package/src/modules/get-many/get-many.module.d.ts +2 -2
- package/src/modules/get-many/get-many.module.js +2 -2
- package/src/modules/get-one/get-one-controller.mixin.js +6 -6
- package/src/modules/get-one/get-one.helper.d.ts +1 -1
- package/src/modules/get-one/get-one.helper.js +8 -7
- package/src/modules/get-one/get-one.module.d.ts +2 -2
- package/src/modules/get-one/get-one.module.js +2 -2
- package/src/modules/replace-one/replace-one-controller.mixin.js +6 -6
- package/src/modules/replace-one/replace-one.helper.d.ts +1 -1
- package/src/modules/replace-one/replace-one.helper.js +8 -7
- package/src/modules/replace-one/replace-one.module.d.ts +2 -2
- package/src/modules/replace-one/replace-one.module.js +2 -2
- package/src/modules/update-many/base-update-many.service.d.ts +33 -0
- package/src/modules/update-many/base-update-many.service.js +32 -0
- package/src/modules/update-many/index.d.ts +6 -0
- package/src/modules/update-many/index.js +22 -0
- package/src/modules/update-many/update-many-controller.interface.d.ts +7 -0
- package/src/modules/update-many/update-many-controller.interface.js +2 -0
- package/src/modules/update-many/update-many-controller.mixin.d.ts +6 -0
- package/src/modules/update-many/update-many-controller.mixin.js +63 -0
- package/src/modules/update-many/update-many-service.interface.d.ts +5 -0
- package/src/modules/update-many/update-many-service.interface.js +2 -0
- package/src/modules/update-many/update-many.helper.d.ts +7 -0
- package/src/modules/update-many/update-many.helper.js +69 -0
- package/src/modules/update-many/update-many.module.d.ts +6 -0
- package/src/modules/update-many/update-many.module.js +28 -0
- package/src/modules/update-one/update-one-controller.mixin.js +6 -6
- package/src/modules/update-one/update-one.helper.d.ts +1 -1
- package/src/modules/update-one/update-one.helper.js +8 -7
- package/src/modules/update-one/update-one.module.d.ts +2 -2
- package/src/modules/update-one/update-one.module.js +2 -2
- package/src/version.json +1 -1
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -0,0 +1,54 @@
|
|
|
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.DeleteManyControllerMixin = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const builders_1 = require("../../builders");
|
|
18
|
+
const helpers_1 = require("../../helpers");
|
|
19
|
+
const delete_many_presenter_1 = require("./delete-many.presenter");
|
|
20
|
+
function DeleteManyControllerMixin(entity, path, apiTag, version, description, DTOs) {
|
|
21
|
+
const displayedName = (0, helpers_1.pascalCase)(apiTag) ?? entity.name;
|
|
22
|
+
const { presenter: CustomPresenter } = DTOs ?? {};
|
|
23
|
+
class RoutePresenter extends (CustomPresenter ?? delete_many_presenter_1.DeleteManyPresenter) {
|
|
24
|
+
}
|
|
25
|
+
if (!CustomPresenter) {
|
|
26
|
+
Object.defineProperty(RoutePresenter, 'name', {
|
|
27
|
+
value: `DeleteMany${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
|
|
28
|
+
writable: false,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
const routeDecoratorsBuilder = new builders_1.RouteDecoratorsBuilder('DeleteMany', entity, version, description, undefined, undefined, undefined, RoutePresenter);
|
|
32
|
+
class BaseDeleteManyController {
|
|
33
|
+
constructor(service) {
|
|
34
|
+
this.service = service;
|
|
35
|
+
this.entity = entity;
|
|
36
|
+
}
|
|
37
|
+
async deleteMany(ids) {
|
|
38
|
+
return this.service.deleteMany(ids);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, helpers_1.RouteDecoratorsHelper)(routeDecoratorsBuilder),
|
|
43
|
+
__param(0, (0, common_1.Query)('ids')),
|
|
44
|
+
__metadata("design:type", Function),
|
|
45
|
+
__metadata("design:paramtypes", [Array]),
|
|
46
|
+
__metadata("design:returntype", Promise)
|
|
47
|
+
], BaseDeleteManyController.prototype, "deleteMany", null);
|
|
48
|
+
Object.defineProperty(BaseDeleteManyController, 'name', {
|
|
49
|
+
value: `BaseDeleteMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
50
|
+
writable: false,
|
|
51
|
+
});
|
|
52
|
+
return BaseDeleteManyController;
|
|
53
|
+
}
|
|
54
|
+
exports.DeleteManyControllerMixin = DeleteManyControllerMixin;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
+
import { DTOsBundle, ServiceProvider } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
import { DeleteManyControllerConstructor } from './delete-many-controller.interface';
|
|
5
|
+
declare function createDeleteManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, version: string | undefined): ServiceProvider;
|
|
6
|
+
declare function createDeleteManyController<Entity extends BaseEntity>(entity: Type<Entity>, path: string, apiTag?: string, version?: string, description?: string, DTOs?: DTOsBundle, validationPipeOptions?: ValidationPipeOptions): DeleteManyControllerConstructor<Entity>;
|
|
7
|
+
export { createDeleteManyController, createDeleteManyServiceProvider };
|
|
@@ -0,0 +1,69 @@
|
|
|
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.createDeleteManyServiceProvider = exports.createDeleteManyController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const mongoose_1 = require("@nestjs/mongoose");
|
|
18
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
19
|
+
const mongoose_2 = require("mongoose");
|
|
20
|
+
const dynamic_api_module_1 = require("../../dynamic-api.module");
|
|
21
|
+
const helpers_1 = require("../../helpers");
|
|
22
|
+
const base_delete_many_service_1 = require("./base-delete-many.service");
|
|
23
|
+
const delete_many_controller_mixin_1 = require("./delete-many-controller.mixin");
|
|
24
|
+
function provideServiceName(entityName, version) {
|
|
25
|
+
return `DeleteMany${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
|
|
26
|
+
}
|
|
27
|
+
function createDeleteManyServiceProvider(entity, version) {
|
|
28
|
+
let DeleteManyService = class DeleteManyService extends base_delete_many_service_1.BaseDeleteManyService {
|
|
29
|
+
constructor(model) {
|
|
30
|
+
super(model);
|
|
31
|
+
this.model = model;
|
|
32
|
+
this.entity = entity;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
DeleteManyService = __decorate([
|
|
36
|
+
__param(0, (0, mongoose_1.InjectModel)(entity.name, dynamic_api_module_1.DynamicApiModule.connectionName)),
|
|
37
|
+
__metadata("design:paramtypes", [mongoose_2.Model])
|
|
38
|
+
], DeleteManyService);
|
|
39
|
+
Object.defineProperty(DeleteManyService, 'name', {
|
|
40
|
+
value: provideServiceName(entity.name, version),
|
|
41
|
+
writable: false,
|
|
42
|
+
});
|
|
43
|
+
return {
|
|
44
|
+
provide: provideServiceName(entity.name, version),
|
|
45
|
+
useClass: DeleteManyService,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
exports.createDeleteManyServiceProvider = createDeleteManyServiceProvider;
|
|
49
|
+
function createDeleteManyController(entity, path, apiTag, version, description, DTOs, validationPipeOptions) {
|
|
50
|
+
let DeleteManyController = class DeleteManyController extends (0, delete_many_controller_mixin_1.DeleteManyControllerMixin)(entity, path, apiTag, version, description, DTOs) {
|
|
51
|
+
constructor(service) {
|
|
52
|
+
super(service);
|
|
53
|
+
this.service = service;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
DeleteManyController = __decorate([
|
|
57
|
+
(0, common_1.Controller)({ path, version }),
|
|
58
|
+
(0, swagger_1.ApiTags)(apiTag || entity.name),
|
|
59
|
+
(0, common_1.UsePipes)(new common_1.ValidationPipe(validationPipeOptions ?? { transform: true })),
|
|
60
|
+
__param(0, (0, common_1.Inject)(provideServiceName(entity.name, version))),
|
|
61
|
+
__metadata("design:paramtypes", [Object])
|
|
62
|
+
], DeleteManyController);
|
|
63
|
+
Object.defineProperty(DeleteManyController, 'name', {
|
|
64
|
+
value: `DeleteMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
65
|
+
writable: false,
|
|
66
|
+
});
|
|
67
|
+
return DeleteManyController;
|
|
68
|
+
}
|
|
69
|
+
exports.createDeleteManyController = createDeleteManyController;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { DynamicModule, Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
+
import { ControllerOptions, RouteConfig } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
export declare class DeleteManyModule {
|
|
5
|
+
static forFeature<Entity extends BaseEntity>(databaseModule: DynamicModule, entity: Type<Entity>, { path, apiTag }: ControllerOptions, { description, dTOs: DTOs }: RouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DynamicModule;
|
|
6
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
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 DeleteManyModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.DeleteManyModule = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const delete_many_helper_1 = require("./delete-many.helper");
|
|
13
|
+
let DeleteManyModule = DeleteManyModule_1 = class DeleteManyModule {
|
|
14
|
+
static forFeature(databaseModule, entity, { path, apiTag }, { description, dTOs: DTOs }, version, validationPipeOptions) {
|
|
15
|
+
const controller = (0, delete_many_helper_1.createDeleteManyController)(entity, path, apiTag, version, description, DTOs, validationPipeOptions);
|
|
16
|
+
const ServiceProvider = (0, delete_many_helper_1.createDeleteManyServiceProvider)(entity, version);
|
|
17
|
+
return {
|
|
18
|
+
module: DeleteManyModule_1,
|
|
19
|
+
imports: [databaseModule],
|
|
20
|
+
controllers: [controller],
|
|
21
|
+
providers: [ServiceProvider],
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
exports.DeleteManyModule = DeleteManyModule;
|
|
26
|
+
exports.DeleteManyModule = DeleteManyModule = DeleteManyModule_1 = __decorate([
|
|
27
|
+
(0, common_1.Module)({})
|
|
28
|
+
], DeleteManyModule);
|
|
@@ -0,0 +1,20 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.DeleteManyPresenter = void 0;
|
|
13
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
14
|
+
class DeleteManyPresenter {
|
|
15
|
+
}
|
|
16
|
+
exports.DeleteManyPresenter = DeleteManyPresenter;
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, swagger_1.ApiProperty)(),
|
|
19
|
+
__metadata("design:type", Number)
|
|
20
|
+
], DeleteManyPresenter.prototype, "deletedCount", void 0);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './base-delete-many.service';
|
|
2
|
+
export * from './delete-many.helper';
|
|
3
|
+
export * from './delete-many.module';
|
|
4
|
+
export * from './delete-many.presenter';
|
|
5
|
+
export * from './delete-many-controller.interface';
|
|
6
|
+
export * from './delete-many-controller.mixin';
|
|
7
|
+
export * from './delete-many-service.interface';
|
|
@@ -0,0 +1,23 @@
|
|
|
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("./base-delete-many.service"), exports);
|
|
18
|
+
__exportStar(require("./delete-many.helper"), exports);
|
|
19
|
+
__exportStar(require("./delete-many.module"), exports);
|
|
20
|
+
__exportStar(require("./delete-many.presenter"), exports);
|
|
21
|
+
__exportStar(require("./delete-many-controller.interface"), exports);
|
|
22
|
+
__exportStar(require("./delete-many-controller.mixin"), exports);
|
|
23
|
+
__exportStar(require("./delete-many-service.interface"), exports);
|
|
@@ -19,13 +19,13 @@ const dtos_1 = require("../../dtos");
|
|
|
19
19
|
const helpers_1 = require("../../helpers");
|
|
20
20
|
const delete_one_presenter_1 = require("./delete-one.presenter");
|
|
21
21
|
function DeleteOneControllerMixin(entity, path, apiTag, version, description, DTOs) {
|
|
22
|
-
const displayedName = apiTag ?? entity.name;
|
|
22
|
+
const displayedName = (0, helpers_1.pascalCase)(apiTag) ?? entity.name;
|
|
23
23
|
const { param: CustomParam, presenter: CustomPresenter } = DTOs ?? {};
|
|
24
24
|
class RouteParam extends (CustomParam ?? dtos_1.EntityParam) {
|
|
25
25
|
}
|
|
26
26
|
if (!CustomParam) {
|
|
27
27
|
Object.defineProperty(RouteParam, 'name', {
|
|
28
|
-
value: `DeleteOne${displayedName}Param`,
|
|
28
|
+
value: `DeleteOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Param`,
|
|
29
29
|
writable: false,
|
|
30
30
|
});
|
|
31
31
|
}
|
|
@@ -33,11 +33,11 @@ function DeleteOneControllerMixin(entity, path, apiTag, version, description, DT
|
|
|
33
33
|
}
|
|
34
34
|
if (!CustomPresenter) {
|
|
35
35
|
Object.defineProperty(RoutePresenter, 'name', {
|
|
36
|
-
value: `DeleteOne${displayedName}Presenter`,
|
|
36
|
+
value: `DeleteOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
|
|
37
37
|
writable: false,
|
|
38
38
|
});
|
|
39
39
|
}
|
|
40
|
-
const routeDecoratorsBuilder = new builders_1.RouteDecoratorsBuilder('DeleteOne', entity, description, RouteParam, undefined, undefined, RoutePresenter);
|
|
40
|
+
const routeDecoratorsBuilder = new builders_1.RouteDecoratorsBuilder('DeleteOne', entity, version, description, RouteParam, undefined, undefined, RoutePresenter);
|
|
41
41
|
class BaseDeleteOneController {
|
|
42
42
|
constructor(service) {
|
|
43
43
|
this.service = service;
|
|
@@ -55,7 +55,7 @@ function DeleteOneControllerMixin(entity, path, apiTag, version, description, DT
|
|
|
55
55
|
__metadata("design:returntype", Promise)
|
|
56
56
|
], BaseDeleteOneController.prototype, "deleteOne", null);
|
|
57
57
|
Object.defineProperty(BaseDeleteOneController, 'name', {
|
|
58
|
-
value: `
|
|
58
|
+
value: `BaseDeleteOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
59
59
|
writable: false,
|
|
60
60
|
});
|
|
61
61
|
return BaseDeleteOneController;
|
|
@@ -2,6 +2,6 @@ import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
|
2
2
|
import { DTOsBundle, ServiceProvider } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
import { DeleteOneControllerConstructor } from './delete-one-controller.interface';
|
|
5
|
-
declare function createDeleteOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity
|
|
5
|
+
declare function createDeleteOneServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, version: string | undefined): ServiceProvider;
|
|
6
6
|
declare function createDeleteOneController<Entity extends BaseEntity>(entity: Type<Entity>, path: string, apiTag?: string, version?: string, description?: string, DTOs?: DTOsBundle, validationPipeOptions?: ValidationPipeOptions): DeleteOneControllerConstructor<Entity>;
|
|
7
7
|
export { createDeleteOneController, createDeleteOneServiceProvider };
|
|
@@ -18,12 +18,13 @@ const mongoose_1 = require("@nestjs/mongoose");
|
|
|
18
18
|
const swagger_1 = require("@nestjs/swagger");
|
|
19
19
|
const mongoose_2 = require("mongoose");
|
|
20
20
|
const dynamic_api_module_1 = require("../../dynamic-api.module");
|
|
21
|
+
const helpers_1 = require("../../helpers");
|
|
21
22
|
const base_delete_one_service_1 = require("./base-delete-one.service");
|
|
22
23
|
const delete_one_controller_mixin_1 = require("./delete-one-controller.mixin");
|
|
23
|
-
function provideServiceName(entityName) {
|
|
24
|
-
return `DeleteOne${entityName}Service`;
|
|
24
|
+
function provideServiceName(entityName, version) {
|
|
25
|
+
return `DeleteOne${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
|
|
25
26
|
}
|
|
26
|
-
function createDeleteOneServiceProvider(entity) {
|
|
27
|
+
function createDeleteOneServiceProvider(entity, version) {
|
|
27
28
|
let DeleteOneService = class DeleteOneService extends base_delete_one_service_1.BaseDeleteOneService {
|
|
28
29
|
constructor(model) {
|
|
29
30
|
super(model);
|
|
@@ -36,11 +37,11 @@ function createDeleteOneServiceProvider(entity) {
|
|
|
36
37
|
__metadata("design:paramtypes", [mongoose_2.Model])
|
|
37
38
|
], DeleteOneService);
|
|
38
39
|
Object.defineProperty(DeleteOneService, 'name', {
|
|
39
|
-
value: provideServiceName(entity.name),
|
|
40
|
+
value: provideServiceName(entity.name, version),
|
|
40
41
|
writable: false,
|
|
41
42
|
});
|
|
42
43
|
return {
|
|
43
|
-
provide: provideServiceName(entity.name),
|
|
44
|
+
provide: provideServiceName(entity.name, version),
|
|
44
45
|
useClass: DeleteOneService,
|
|
45
46
|
};
|
|
46
47
|
}
|
|
@@ -56,11 +57,11 @@ function createDeleteOneController(entity, path, apiTag, version, description, D
|
|
|
56
57
|
(0, common_1.Controller)({ path, version }),
|
|
57
58
|
(0, swagger_1.ApiTags)(apiTag || entity.name),
|
|
58
59
|
(0, common_1.UsePipes)(new common_1.ValidationPipe(validationPipeOptions ?? { transform: true })),
|
|
59
|
-
__param(0, (0, common_1.Inject)(provideServiceName(entity.name))),
|
|
60
|
+
__param(0, (0, common_1.Inject)(provideServiceName(entity.name, version))),
|
|
60
61
|
__metadata("design:paramtypes", [Object])
|
|
61
62
|
], DeleteOneController);
|
|
62
63
|
Object.defineProperty(DeleteOneController, 'name', {
|
|
63
|
-
value: `DeleteOne${entity.name}Controller`,
|
|
64
|
+
value: `DeleteOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
64
65
|
writable: false,
|
|
65
66
|
});
|
|
66
67
|
return DeleteOneController;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DynamicModule, Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
-
import {
|
|
2
|
+
import { ControllerOptions, RouteConfig } from '../../interfaces';
|
|
3
3
|
import { BaseEntity } from '../../models';
|
|
4
4
|
export declare class DeleteOneModule {
|
|
5
|
-
static forFeature<Entity extends BaseEntity>(databaseModule: DynamicModule, entity: Type<Entity>, path
|
|
5
|
+
static forFeature<Entity extends BaseEntity>(databaseModule: DynamicModule, entity: Type<Entity>, { path, apiTag }: ControllerOptions, { description, dTOs: DTOs }: RouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DynamicModule;
|
|
6
6
|
}
|
|
@@ -11,9 +11,9 @@ exports.DeleteOneModule = void 0;
|
|
|
11
11
|
const common_1 = require("@nestjs/common");
|
|
12
12
|
const delete_one_helper_1 = require("./delete-one.helper");
|
|
13
13
|
let DeleteOneModule = DeleteOneModule_1 = class DeleteOneModule {
|
|
14
|
-
static forFeature(databaseModule, entity, path, apiTag
|
|
14
|
+
static forFeature(databaseModule, entity, { path, apiTag }, { description, dTOs: DTOs }, version, validationPipeOptions) {
|
|
15
15
|
const controller = (0, delete_one_helper_1.createDeleteOneController)(entity, path, apiTag, version, description, DTOs, validationPipeOptions);
|
|
16
|
-
const ServiceProvider = (0, delete_one_helper_1.createDeleteOneServiceProvider)(entity);
|
|
16
|
+
const ServiceProvider = (0, delete_one_helper_1.createDeleteOneServiceProvider)(entity, version);
|
|
17
17
|
return {
|
|
18
18
|
module: DeleteOneModule_1,
|
|
19
19
|
imports: [databaseModule],
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/// <reference types="mongoose/types/aggregate" />
|
|
2
|
+
/// <reference types="mongoose/types/callback" />
|
|
3
|
+
/// <reference types="mongoose/types/collection" />
|
|
4
|
+
/// <reference types="mongoose/types/connection" />
|
|
5
|
+
/// <reference types="mongoose/types/cursor" />
|
|
6
|
+
/// <reference types="mongoose/types/document" />
|
|
7
|
+
/// <reference types="mongoose/types/error" />
|
|
8
|
+
/// <reference types="mongoose/types/expressions" />
|
|
9
|
+
/// <reference types="mongoose/types/helpers" />
|
|
10
|
+
/// <reference types="mongoose/types/middlewares" />
|
|
11
|
+
/// <reference types="mongoose/types/indexes" />
|
|
12
|
+
/// <reference types="mongoose/types/models" />
|
|
13
|
+
/// <reference types="mongoose/types/mongooseoptions" />
|
|
14
|
+
/// <reference types="mongoose/types/pipelinestage" />
|
|
15
|
+
/// <reference types="mongoose/types/populate" />
|
|
16
|
+
/// <reference types="mongoose/types/query" />
|
|
17
|
+
/// <reference types="mongoose/types/schemaoptions" />
|
|
18
|
+
/// <reference types="mongoose/types/schematypes" />
|
|
19
|
+
/// <reference types="mongoose/types/session" />
|
|
20
|
+
/// <reference types="mongoose/types/types" />
|
|
21
|
+
/// <reference types="mongoose/types/utility" />
|
|
22
|
+
/// <reference types="mongoose/types/validation" />
|
|
23
|
+
/// <reference types="mongoose/types/virtuals" />
|
|
24
|
+
/// <reference types="mongoose/types/inferschematype" />
|
|
25
|
+
import { Model } from 'mongoose';
|
|
26
|
+
import { BaseEntity } from '../../models';
|
|
27
|
+
import { BaseService } from '../../services';
|
|
28
|
+
import { DuplicateManyService } from './duplicate-many-service.interface';
|
|
29
|
+
export declare abstract class BaseDuplicateManyService<Entity extends BaseEntity> extends BaseService<Entity> implements DuplicateManyService<Entity> {
|
|
30
|
+
protected readonly model: Model<Entity>;
|
|
31
|
+
protected constructor(model: Model<Entity>);
|
|
32
|
+
duplicateMany(ids: string[], partial: Partial<Entity> | undefined): Promise<Entity[]>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BaseDuplicateManyService = void 0;
|
|
4
|
+
const mixins_1 = require("../../mixins");
|
|
5
|
+
const services_1 = require("../../services");
|
|
6
|
+
class BaseDuplicateManyService extends services_1.BaseService {
|
|
7
|
+
constructor(model) {
|
|
8
|
+
super(model);
|
|
9
|
+
this.model = model;
|
|
10
|
+
}
|
|
11
|
+
async duplicateMany(ids, partial) {
|
|
12
|
+
try {
|
|
13
|
+
const toDuplicateList = await this.model
|
|
14
|
+
.find({
|
|
15
|
+
_id: { $in: ids },
|
|
16
|
+
...(this.isSoftDeletable ? { isDeleted: false } : undefined),
|
|
17
|
+
})
|
|
18
|
+
.lean()
|
|
19
|
+
.exec();
|
|
20
|
+
if (!toDuplicateList?.length) {
|
|
21
|
+
this.handleDocumentNotFound();
|
|
22
|
+
}
|
|
23
|
+
const duplicatedList = await this.model.create(toDuplicateList.map((d) => ({
|
|
24
|
+
...Object.entries(d).reduce((acc, [key, value]) => {
|
|
25
|
+
if ((0, mixins_1.baseEntityKeysToExclude)().includes(key)) {
|
|
26
|
+
return acc;
|
|
27
|
+
}
|
|
28
|
+
return { ...acc, [key]: value };
|
|
29
|
+
}, {}),
|
|
30
|
+
...partial,
|
|
31
|
+
})));
|
|
32
|
+
const documents = await this.model.find({ _id: { $in: duplicatedList.map(({ _id }) => _id.toString()) } })
|
|
33
|
+
.lean()
|
|
34
|
+
.exec();
|
|
35
|
+
return documents.map((d) => this.buildInstance(d));
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
this.handleDuplicateKeyError(error);
|
|
39
|
+
throw error;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.BaseDuplicateManyService = BaseDuplicateManyService;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BaseEntity } from '../../models';
|
|
2
|
+
import { DuplicateManyService } from './duplicate-many-service.interface';
|
|
3
|
+
interface DuplicateManyController<Entity extends BaseEntity> {
|
|
4
|
+
duplicateMany(ids: string[], body?: Partial<Entity>): Promise<Entity[]>;
|
|
5
|
+
}
|
|
6
|
+
type DuplicateManyControllerConstructor<Entity extends BaseEntity> = new (service: DuplicateManyService<Entity>) => DuplicateManyController<Entity>;
|
|
7
|
+
export type { DuplicateManyController, DuplicateManyControllerConstructor };
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Type } from '@nestjs/common';
|
|
2
|
+
import { DTOsBundle } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
import { DuplicateManyControllerConstructor } from './duplicate-many-controller.interface';
|
|
5
|
+
declare function DuplicateManyControllerMixin<Entity extends BaseEntity>(entity: Type<Entity>, path: string, apiTag?: string, version?: string, description?: string, DTOs?: DTOsBundle): DuplicateManyControllerConstructor<Entity>;
|
|
6
|
+
export { DuplicateManyControllerMixin };
|
|
@@ -0,0 +1,63 @@
|
|
|
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.DuplicateManyControllerMixin = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const builders_1 = require("../../builders");
|
|
18
|
+
const helpers_1 = require("../../helpers");
|
|
19
|
+
const mixins_1 = require("../../mixins");
|
|
20
|
+
function DuplicateManyControllerMixin(entity, path, apiTag, version, description, DTOs) {
|
|
21
|
+
const displayedName = (0, helpers_1.pascalCase)(apiTag) ?? entity.name;
|
|
22
|
+
const { body: CustomBody, presenter: CustomPresenter, } = DTOs ?? {};
|
|
23
|
+
class RouteBody extends (CustomBody ?? (0, mixins_1.EntityBodyMixin)(entity, true)) {
|
|
24
|
+
}
|
|
25
|
+
if (!CustomBody) {
|
|
26
|
+
Object.defineProperty(RouteBody, 'name', {
|
|
27
|
+
value: `DuplicateMany${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Dto`,
|
|
28
|
+
writable: false,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
class RoutePresenter extends (CustomPresenter ?? (0, mixins_1.EntityPresenterMixin)(entity)) {
|
|
32
|
+
}
|
|
33
|
+
if (!CustomPresenter) {
|
|
34
|
+
Object.defineProperty(RoutePresenter, 'name', {
|
|
35
|
+
value: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
|
|
36
|
+
writable: false,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
const routeDecoratorsBuilder = new builders_1.RouteDecoratorsBuilder('DuplicateMany', entity, version, description, undefined, undefined, RouteBody, RoutePresenter);
|
|
40
|
+
class BaseDuplicateManyController {
|
|
41
|
+
constructor(service) {
|
|
42
|
+
this.service = service;
|
|
43
|
+
this.entity = entity;
|
|
44
|
+
}
|
|
45
|
+
async duplicateMany(ids, body) {
|
|
46
|
+
return this.service.duplicateMany(ids, body);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, helpers_1.RouteDecoratorsHelper)(routeDecoratorsBuilder),
|
|
51
|
+
__param(0, (0, common_1.Query)('ids')),
|
|
52
|
+
__param(1, (0, common_1.Body)()),
|
|
53
|
+
__metadata("design:type", Function),
|
|
54
|
+
__metadata("design:paramtypes", [Array, RouteBody]),
|
|
55
|
+
__metadata("design:returntype", Promise)
|
|
56
|
+
], BaseDuplicateManyController.prototype, "duplicateMany", null);
|
|
57
|
+
Object.defineProperty(BaseDuplicateManyController, 'name', {
|
|
58
|
+
value: `BaseDuplicateMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
59
|
+
writable: false,
|
|
60
|
+
});
|
|
61
|
+
return BaseDuplicateManyController;
|
|
62
|
+
}
|
|
63
|
+
exports.DuplicateManyControllerMixin = DuplicateManyControllerMixin;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
+
import { DTOsBundle, ServiceProvider } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
import { DuplicateManyControllerConstructor } from './duplicate-many-controller.interface';
|
|
5
|
+
declare function createDuplicateManyServiceProvider<Entity extends BaseEntity>(entity: Type<Entity>, version: string | undefined): ServiceProvider;
|
|
6
|
+
declare function createDuplicateManyController<Entity extends BaseEntity>(entity: Type<Entity>, path: string, apiTag?: string, version?: string, description?: string, DTOs?: DTOsBundle, validationPipeOptions?: ValidationPipeOptions): DuplicateManyControllerConstructor<Entity>;
|
|
7
|
+
export { createDuplicateManyController, createDuplicateManyServiceProvider };
|
|
@@ -0,0 +1,69 @@
|
|
|
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.createDuplicateManyServiceProvider = exports.createDuplicateManyController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const mongoose_1 = require("@nestjs/mongoose");
|
|
18
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
19
|
+
const mongoose_2 = require("mongoose");
|
|
20
|
+
const dynamic_api_module_1 = require("../../dynamic-api.module");
|
|
21
|
+
const helpers_1 = require("../../helpers");
|
|
22
|
+
const base_duplicate_many_service_1 = require("./base-duplicate-many.service");
|
|
23
|
+
const duplicate_many_controller_mixin_1 = require("./duplicate-many-controller.mixin");
|
|
24
|
+
function provideServiceName(entityName, version) {
|
|
25
|
+
return `DuplicateMany${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
|
|
26
|
+
}
|
|
27
|
+
function createDuplicateManyServiceProvider(entity, version) {
|
|
28
|
+
let DuplicateManyService = class DuplicateManyService extends base_duplicate_many_service_1.BaseDuplicateManyService {
|
|
29
|
+
constructor(model) {
|
|
30
|
+
super(model);
|
|
31
|
+
this.model = model;
|
|
32
|
+
this.entity = entity;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
DuplicateManyService = __decorate([
|
|
36
|
+
__param(0, (0, mongoose_1.InjectModel)(entity.name, dynamic_api_module_1.DynamicApiModule.connectionName)),
|
|
37
|
+
__metadata("design:paramtypes", [mongoose_2.Model])
|
|
38
|
+
], DuplicateManyService);
|
|
39
|
+
Object.defineProperty(DuplicateManyService, 'name', {
|
|
40
|
+
value: provideServiceName(entity.name, version),
|
|
41
|
+
writable: false,
|
|
42
|
+
});
|
|
43
|
+
return {
|
|
44
|
+
provide: provideServiceName(entity.name, version),
|
|
45
|
+
useClass: DuplicateManyService,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
exports.createDuplicateManyServiceProvider = createDuplicateManyServiceProvider;
|
|
49
|
+
function createDuplicateManyController(entity, path, apiTag, version, description, DTOs, validationPipeOptions) {
|
|
50
|
+
let DuplicateManyController = class DuplicateManyController extends (0, duplicate_many_controller_mixin_1.DuplicateManyControllerMixin)(entity, path, apiTag, version, description, DTOs) {
|
|
51
|
+
constructor(service) {
|
|
52
|
+
super(service);
|
|
53
|
+
this.service = service;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
DuplicateManyController = __decorate([
|
|
57
|
+
(0, common_1.Controller)({ path, version }),
|
|
58
|
+
(0, swagger_1.ApiTags)(apiTag || entity.name),
|
|
59
|
+
(0, common_1.UsePipes)(new common_1.ValidationPipe(validationPipeOptions ?? { transform: true })),
|
|
60
|
+
__param(0, (0, common_1.Inject)(provideServiceName(entity.name, version))),
|
|
61
|
+
__metadata("design:paramtypes", [Object])
|
|
62
|
+
], DuplicateManyController);
|
|
63
|
+
Object.defineProperty(DuplicateManyController, 'name', {
|
|
64
|
+
value: `DuplicateMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
|
|
65
|
+
writable: false,
|
|
66
|
+
});
|
|
67
|
+
return DuplicateManyController;
|
|
68
|
+
}
|
|
69
|
+
exports.createDuplicateManyController = createDuplicateManyController;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { DynamicModule, Type, ValidationPipeOptions } from '@nestjs/common';
|
|
2
|
+
import { ControllerOptions, RouteConfig } from '../../interfaces';
|
|
3
|
+
import { BaseEntity } from '../../models';
|
|
4
|
+
export declare class DuplicateManyModule {
|
|
5
|
+
static forFeature<Entity extends BaseEntity>(databaseModule: DynamicModule, entity: Type<Entity>, { path, apiTag }: ControllerOptions, { description, dTOs: DTOs }: RouteConfig<Entity>, version?: string, validationPipeOptions?: ValidationPipeOptions): DynamicModule;
|
|
6
|
+
}
|