mongodb-dynamic-api 1.2.1 → 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.
Files changed (78) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/README.md +4 -3
  3. package/package.json +1 -1
  4. package/src/builders/route-decorators.builder.d.ts +1 -0
  5. package/src/builders/route-decorators.builder.js +13 -2
  6. package/src/dtos/delete-many-entity.query.d.ts +3 -0
  7. package/src/dtos/delete-many-entity.query.js +24 -0
  8. package/src/dtos/index.d.ts +1 -0
  9. package/src/dtos/index.js +1 -0
  10. package/src/dynamic-api.module.js +19 -3
  11. package/src/helpers/format.helper.d.ts +1 -0
  12. package/src/helpers/format.helper.js +5 -1
  13. package/src/helpers/route-description.helper.js +6 -0
  14. package/src/helpers/versioning-config.helper.d.ts +2 -1
  15. package/src/helpers/versioning-config.helper.js +5 -1
  16. package/src/interfaces/route-config.interface.d.ts +1 -1
  17. package/src/modules/create-many/create-many-controller.mixin.js +4 -4
  18. package/src/modules/create-many/create-many.helper.js +3 -2
  19. package/src/modules/create-one/create-one-controller.mixin.js +3 -3
  20. package/src/modules/create-one/create-one.helper.js +3 -2
  21. package/src/modules/delete-many/base-delete-many.service.d.ts +34 -0
  22. package/src/modules/delete-many/base-delete-many.service.js +29 -0
  23. package/src/modules/delete-many/delete-many-controller.interface.d.ts +8 -0
  24. package/src/modules/delete-many/delete-many-controller.interface.js +2 -0
  25. package/src/modules/delete-many/delete-many-controller.mixin.d.ts +6 -0
  26. package/src/modules/delete-many/delete-many-controller.mixin.js +54 -0
  27. package/src/modules/delete-many/delete-many-service.interface.d.ts +6 -0
  28. package/src/modules/delete-many/delete-many-service.interface.js +2 -0
  29. package/src/modules/delete-many/delete-many.helper.d.ts +7 -0
  30. package/src/modules/delete-many/delete-many.helper.js +69 -0
  31. package/src/modules/delete-many/delete-many.module.d.ts +6 -0
  32. package/src/modules/delete-many/delete-many.module.js +28 -0
  33. package/src/modules/delete-many/delete-many.presenter.d.ts +3 -0
  34. package/src/modules/delete-many/delete-many.presenter.js +20 -0
  35. package/src/modules/delete-many/index.d.ts +7 -0
  36. package/src/modules/delete-many/index.js +23 -0
  37. package/src/modules/delete-one/delete-one-controller.mixin.js +3 -3
  38. package/src/modules/delete-one/delete-one.helper.js +3 -2
  39. package/src/modules/duplicate-many/base-duplicate-many.service.d.ts +33 -0
  40. package/src/modules/duplicate-many/base-duplicate-many.service.js +43 -0
  41. package/src/modules/duplicate-many/duplicate-many-controller.interface.d.ts +7 -0
  42. package/src/modules/duplicate-many/duplicate-many-controller.interface.js +2 -0
  43. package/src/modules/duplicate-many/duplicate-many-controller.mixin.d.ts +6 -0
  44. package/src/modules/duplicate-many/duplicate-many-controller.mixin.js +63 -0
  45. package/src/modules/duplicate-many/duplicate-many-service.interface.d.ts +5 -0
  46. package/src/modules/duplicate-many/duplicate-many-service.interface.js +2 -0
  47. package/src/modules/duplicate-many/duplicate-many.helper.d.ts +7 -0
  48. package/src/modules/duplicate-many/duplicate-many.helper.js +69 -0
  49. package/src/modules/duplicate-many/duplicate-many.module.d.ts +6 -0
  50. package/src/modules/duplicate-many/duplicate-many.module.js +28 -0
  51. package/src/modules/duplicate-many/index.d.ts +6 -0
  52. package/src/modules/duplicate-many/index.js +22 -0
  53. package/src/modules/duplicate-one/duplicate-one-controller.mixin.js +4 -4
  54. package/src/modules/duplicate-one/duplicate-one.helper.js +3 -2
  55. package/src/modules/get-many/get-many-controller.mixin.js +3 -3
  56. package/src/modules/get-many/get-many.helper.js +3 -2
  57. package/src/modules/get-one/get-one-controller.mixin.js +4 -4
  58. package/src/modules/get-one/get-one.helper.js +3 -2
  59. package/src/modules/replace-one/replace-one-controller.mixin.js +4 -4
  60. package/src/modules/replace-one/replace-one.helper.js +3 -2
  61. package/src/modules/update-many/base-update-many.service.d.ts +33 -0
  62. package/src/modules/update-many/base-update-many.service.js +32 -0
  63. package/src/modules/update-many/index.d.ts +6 -0
  64. package/src/modules/update-many/index.js +22 -0
  65. package/src/modules/update-many/update-many-controller.interface.d.ts +7 -0
  66. package/src/modules/update-many/update-many-controller.interface.js +2 -0
  67. package/src/modules/update-many/update-many-controller.mixin.d.ts +6 -0
  68. package/src/modules/update-many/update-many-controller.mixin.js +63 -0
  69. package/src/modules/update-many/update-many-service.interface.d.ts +5 -0
  70. package/src/modules/update-many/update-many-service.interface.js +2 -0
  71. package/src/modules/update-many/update-many.helper.d.ts +7 -0
  72. package/src/modules/update-many/update-many.helper.js +69 -0
  73. package/src/modules/update-many/update-many.module.d.ts +6 -0
  74. package/src/modules/update-many/update-many.module.js +28 -0
  75. package/src/modules/update-one/update-one-controller.mixin.js +4 -4
  76. package/src/modules/update-one/update-one.helper.js +3 -2
  77. package/src/version.json +1 -1
  78. package/tsconfig.tsbuildinfo +1 -1
@@ -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,3 @@
1
+ export declare class DeleteManyPresenter {
2
+ deletedCount: number;
3
+ }
@@ -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);
@@ -25,7 +25,7 @@ function DeleteOneControllerMixin(entity, path, apiTag, version, description, DT
25
25
  }
26
26
  if (!CustomParam) {
27
27
  Object.defineProperty(RouteParam, 'name', {
28
- value: `DeleteOne${displayedName}${version ? 'V' + version : ''}Param`,
28
+ value: `DeleteOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Param`,
29
29
  writable: false,
30
30
  });
31
31
  }
@@ -33,7 +33,7 @@ function DeleteOneControllerMixin(entity, path, apiTag, version, description, DT
33
33
  }
34
34
  if (!CustomPresenter) {
35
35
  Object.defineProperty(RoutePresenter, 'name', {
36
- value: `DeleteOne${displayedName}${version ? 'V' + version : ''}Presenter`,
36
+ value: `DeleteOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
37
37
  writable: false,
38
38
  });
39
39
  }
@@ -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: `BaseDeleteOne${entity.name}${version ? 'V' + version : ''}Controller`,
58
+ value: `BaseDeleteOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
59
59
  writable: false,
60
60
  });
61
61
  return BaseDeleteOneController;
@@ -18,10 +18,11 @@ 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
24
  function provideServiceName(entityName, version) {
24
- return `DeleteOne${entityName}${version ? 'V' + version : ''}Service`;
25
+ return `DeleteOne${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
25
26
  }
26
27
  function createDeleteOneServiceProvider(entity, version) {
27
28
  let DeleteOneService = class DeleteOneService extends base_delete_one_service_1.BaseDeleteOneService {
@@ -60,7 +61,7 @@ function createDeleteOneController(entity, path, apiTag, version, description, D
60
61
  __metadata("design:paramtypes", [Object])
61
62
  ], DeleteOneController);
62
63
  Object.defineProperty(DeleteOneController, 'name', {
63
- value: `DeleteOne${entity.name}${version ? 'V' + version : ''}Controller`,
64
+ value: `DeleteOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
64
65
  writable: false,
65
66
  });
66
67
  return DeleteOneController;
@@ -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,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,5 @@
1
+ import { BaseEntity } from '../../models';
2
+ interface DuplicateManyService<Entity extends BaseEntity> {
3
+ duplicateMany(ids: string[], partial: Partial<Entity> | undefined): Promise<Entity[]>;
4
+ }
5
+ export type { DuplicateManyService };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -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
+ }
@@ -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 DuplicateManyModule_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.DuplicateManyModule = void 0;
11
+ const common_1 = require("@nestjs/common");
12
+ const duplicate_many_helper_1 = require("./duplicate-many.helper");
13
+ let DuplicateManyModule = DuplicateManyModule_1 = class DuplicateManyModule {
14
+ static forFeature(databaseModule, entity, { path, apiTag }, { description, dTOs: DTOs }, version, validationPipeOptions) {
15
+ const controller = (0, duplicate_many_helper_1.createDuplicateManyController)(entity, path, apiTag, version, description, DTOs, validationPipeOptions);
16
+ const ServiceProvider = (0, duplicate_many_helper_1.createDuplicateManyServiceProvider)(entity, version);
17
+ return {
18
+ module: DuplicateManyModule_1,
19
+ imports: [databaseModule],
20
+ controllers: [controller],
21
+ providers: [ServiceProvider],
22
+ };
23
+ }
24
+ };
25
+ exports.DuplicateManyModule = DuplicateManyModule;
26
+ exports.DuplicateManyModule = DuplicateManyModule = DuplicateManyModule_1 = __decorate([
27
+ (0, common_1.Module)({})
28
+ ], DuplicateManyModule);
@@ -0,0 +1,6 @@
1
+ export * from './base-duplicate-many.service';
2
+ export * from './duplicate-many.helper';
3
+ export * from './duplicate-many.module';
4
+ export * from './duplicate-many-controller.interface';
5
+ export * from './duplicate-many-controller.mixin';
6
+ export * from './duplicate-many-service.interface';
@@ -0,0 +1,22 @@
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-duplicate-many.service"), exports);
18
+ __exportStar(require("./duplicate-many.helper"), exports);
19
+ __exportStar(require("./duplicate-many.module"), exports);
20
+ __exportStar(require("./duplicate-many-controller.interface"), exports);
21
+ __exportStar(require("./duplicate-many-controller.mixin"), exports);
22
+ __exportStar(require("./duplicate-many-service.interface"), exports);
@@ -25,7 +25,7 @@ function DuplicateOneControllerMixin(entity, path, apiTag, version, description,
25
25
  }
26
26
  if (!CustomBody) {
27
27
  Object.defineProperty(RouteBody, 'name', {
28
- value: `DuplicateOne${displayedName}${version ? 'V' + version : ''}Dto`,
28
+ value: `DuplicateOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Dto`,
29
29
  writable: false,
30
30
  });
31
31
  }
@@ -33,7 +33,7 @@ function DuplicateOneControllerMixin(entity, path, apiTag, version, description,
33
33
  }
34
34
  if (!CustomParam) {
35
35
  Object.defineProperty(RouteParam, 'name', {
36
- value: `DuplicateOne${displayedName}${version ? 'V' + version : ''}Param`,
36
+ value: `DuplicateOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Param`,
37
37
  writable: false,
38
38
  });
39
39
  }
@@ -41,7 +41,7 @@ function DuplicateOneControllerMixin(entity, path, apiTag, version, description,
41
41
  }
42
42
  if (!CustomPresenter) {
43
43
  Object.defineProperty(RoutePresenter, 'name', {
44
- value: `${displayedName}${version ? 'V' + version : ''}Presenter`,
44
+ value: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
45
45
  writable: false,
46
46
  });
47
47
  }
@@ -64,7 +64,7 @@ function DuplicateOneControllerMixin(entity, path, apiTag, version, description,
64
64
  __metadata("design:returntype", Promise)
65
65
  ], BaseDuplicateOneController.prototype, "duplicateOne", null);
66
66
  Object.defineProperty(BaseDuplicateOneController, 'name', {
67
- value: `BaseDuplicateOne${entity.name}${version ? 'V' + version : ''}Controller`,
67
+ value: `BaseDuplicateOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
68
68
  writable: false,
69
69
  });
70
70
  return BaseDuplicateOneController;
@@ -18,10 +18,11 @@ 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_duplicate_one_service_1 = require("./base-duplicate-one.service");
22
23
  const duplicate_one_controller_mixin_1 = require("./duplicate-one-controller.mixin");
23
24
  function provideServiceName(entityName, version) {
24
- return `DuplicateOne${entityName}${version ? 'V' + version : ''}Service`;
25
+ return `DuplicateOne${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
25
26
  }
26
27
  function createDuplicateOneServiceProvider(entity, version) {
27
28
  let DuplicateOneService = class DuplicateOneService extends base_duplicate_one_service_1.BaseDuplicateOneService {
@@ -60,7 +61,7 @@ function createDuplicateOneController(entity, path, apiTag, version, description
60
61
  __metadata("design:paramtypes", [Object])
61
62
  ], DuplicateOneController);
62
63
  Object.defineProperty(DuplicateOneController, 'name', {
63
- value: `DuplicateOne${entity.name}${version ? 'V' + version : ''}Controller`,
64
+ value: `DuplicateOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
64
65
  writable: false,
65
66
  });
66
67
  return DuplicateOneController;
@@ -25,7 +25,7 @@ function GetManyControllerMixin(entity, path, apiTag, version, description, DTOs
25
25
  }
26
26
  if (!CustomQuery) {
27
27
  Object.defineProperty(RouteQuery, 'name', {
28
- value: `GetMany${displayedName}${version ? 'V' + version : ''}Query`,
28
+ value: `GetMany${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Query`,
29
29
  writable: false,
30
30
  });
31
31
  }
@@ -33,7 +33,7 @@ function GetManyControllerMixin(entity, path, apiTag, version, description, DTOs
33
33
  }
34
34
  if (!CustomPresenter) {
35
35
  Object.defineProperty(RoutePresenter, 'name', {
36
- value: `${displayedName}${version ? 'V' + version : ''}Presenter`,
36
+ value: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
37
37
  writable: false,
38
38
  });
39
39
  }
@@ -55,7 +55,7 @@ function GetManyControllerMixin(entity, path, apiTag, version, description, DTOs
55
55
  __metadata("design:returntype", Promise)
56
56
  ], BaseGetManyController.prototype, "getMany", null);
57
57
  Object.defineProperty(BaseGetManyController, 'name', {
58
- value: `BaseGetMany${entity.name}${version ? 'V' + version : ''}Controller`,
58
+ value: `BaseGetMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
59
59
  writable: false,
60
60
  });
61
61
  return BaseGetManyController;
@@ -18,10 +18,11 @@ 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_get_many_service_1 = require("./base-get-many.service");
22
23
  const get_many_controller_mixin_1 = require("./get-many-controller.mixin");
23
24
  function provideServiceName(entityName, version) {
24
- return `GetMany${entityName}${version ? 'V' + version : ''}Service`;
25
+ return `GetMany${entityName}${(0, helpers_1.addVersionSuffix)(version)}Service`;
25
26
  }
26
27
  function createGetManyServiceProvider(entity, version) {
27
28
  let GetManyService = class GetManyService extends base_get_many_service_1.BaseGetManyService {
@@ -60,7 +61,7 @@ function createGetManyController(entity, path, apiTag, version, description, DTO
60
61
  __metadata("design:paramtypes", [Object])
61
62
  ], GetManyController);
62
63
  Object.defineProperty(GetManyController, 'name', {
63
- value: `GetMany${entity.name}${version ? 'V' + version : ''}Controller`,
64
+ value: `GetMany${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
64
65
  writable: false,
65
66
  });
66
67
  return GetManyController;
@@ -25,7 +25,7 @@ function GetOneControllerMixin(entity, path, apiTag, version, description, DTOs)
25
25
  }
26
26
  if (!CustomParam) {
27
27
  Object.defineProperty(RouteParam, 'name', {
28
- value: `GetOne${displayedName}${version ? 'V' + version : ''}Param`,
28
+ value: `GetOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Param`,
29
29
  writable: false,
30
30
  });
31
31
  }
@@ -33,7 +33,7 @@ function GetOneControllerMixin(entity, path, apiTag, version, description, DTOs)
33
33
  }
34
34
  if (!CustomQuery) {
35
35
  Object.defineProperty(RouteQuery, 'name', {
36
- value: `GetOne${displayedName}${version ? 'V' + version : ''}Query`,
36
+ value: `GetOne${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Query`,
37
37
  writable: false,
38
38
  });
39
39
  }
@@ -41,7 +41,7 @@ function GetOneControllerMixin(entity, path, apiTag, version, description, DTOs)
41
41
  }
42
42
  if (!CustomPresenter) {
43
43
  Object.defineProperty(RoutePresenter, 'name', {
44
- value: `${displayedName}${version ? 'V' + version : ''}Presenter`,
44
+ value: `${displayedName}${(0, helpers_1.addVersionSuffix)(version)}Presenter`,
45
45
  writable: false,
46
46
  });
47
47
  }
@@ -63,7 +63,7 @@ function GetOneControllerMixin(entity, path, apiTag, version, description, DTOs)
63
63
  __metadata("design:returntype", Promise)
64
64
  ], BaseGetOneController.prototype, "getOne", null);
65
65
  Object.defineProperty(BaseGetOneController, 'name', {
66
- value: `BaseGetOne${entity.name}${version ? 'V' + version : ''}Controller`,
66
+ value: `BaseGetOne${entity.name}${(0, helpers_1.addVersionSuffix)(version)}Controller`,
67
67
  writable: false,
68
68
  });
69
69
  return BaseGetOneController;