@steroidsjs/nest 1.1.1 → 1.1.2

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.
@@ -0,0 +1,17 @@
1
+ import { ICondition } from '../../infrastructure/helpers/ConditionHelper';
2
+ import { Repository } from 'typeorm';
3
+ import { SelectQueryBuilder } from 'typeorm/query-builder/SelectQueryBuilder';
4
+ export interface IQueryRelation {
5
+ name: string;
6
+ alias?: string;
7
+ isId?: boolean;
8
+ }
9
+ export default class SearchQuery {
10
+ select?: string[];
11
+ excludeSelect?: string[];
12
+ relations?: IQueryRelation[];
13
+ condition?: ICondition;
14
+ static createFromSchema(SchemaClass: any): SearchQuery;
15
+ static prepare(dbRepository: Repository<any>, dbQuery: SelectQueryBuilder<any>, searchQuery: SearchQuery): void;
16
+ constructor(data?: SearchQuery);
17
+ }
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const MetaHelper_1 = require("../../infrastructure/helpers/MetaHelper");
4
+ const ConditionHelper_1 = require("../../infrastructure/helpers/ConditionHelper");
5
+ class SearchQuery {
6
+ constructor(data = {}) {
7
+ this.select = data.select;
8
+ this.excludeSelect = data.excludeSelect;
9
+ this.relations = data.relations;
10
+ this.condition = data.condition;
11
+ }
12
+ static createFromSchema(SchemaClass) {
13
+ return new SearchQuery(MetaHelper_1.MetaHelper.getSchemaQueryData(SchemaClass));
14
+ }
15
+ static prepare(dbRepository, dbQuery, searchQuery) {
16
+ const prefix = dbQuery.expressionMap.mainAlias.name + '.';
17
+ let select = searchQuery.select;
18
+ if (searchQuery.excludeSelect) {
19
+ select = dbRepository.metadata.columns
20
+ .map(column => column.propertyName)
21
+ .filter(name => !searchQuery.excludeSelect.includes(name));
22
+ }
23
+ if (select) {
24
+ dbQuery.select(select.map(name => prefix + name));
25
+ }
26
+ (searchQuery.relations || []).forEach(relation => {
27
+ if (relation.isId) {
28
+ dbQuery.loadRelationIdAndMap(prefix + (relation.alias || relation.name), prefix + relation.name);
29
+ }
30
+ else {
31
+ dbQuery.relation(relation.name);
32
+ }
33
+ });
34
+ if (searchQuery.condition) {
35
+ dbQuery.andWhere(ConditionHelper_1.ConditionHelper.toTypeOrm(searchQuery.condition));
36
+ }
37
+ }
38
+ }
39
+ exports.default = SearchQuery;
40
+ //# sourceMappingURL=SearchQuery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchQuery.js","sourceRoot":"","sources":["../../../src/usecases/base/SearchQuery.ts"],"names":[],"mappings":";;AAAA,wEAAmE;AACnE,kFAAyF;AAUzF,MAAqB,WAAW;IAiD5B,YAAY,OAAoB,EAAE;QAC9B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IACpC,CAAC;IAhDD,MAAM,CAAC,gBAAgB,CAAC,WAAW;QAC/B,OAAO,IAAI,WAAW,CAAC,uBAAU,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,MAAM,CAAC,OAAO,CACV,YAA6B,EAC7B,OAAgC,EAChC,WAAwB;QAGxB,MAAM,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,GAAG,GAAG,CAAC;QAG1D,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;QAChC,IAAI,WAAW,CAAC,aAAa,EAAE;YAC3B,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO;iBACjC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC;iBAClC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;SAClE;QAED,IAAI,MAAM,EAAE;YAER,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC;SACrD;QAGD,CAAC,WAAW,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC7C,IAAI,QAAQ,CAAC,IAAI,EAAE;gBACf,OAAO,CAAC,oBAAoB,CACxB,MAAM,GAAG,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,IAAI,CAAC,EAC1C,MAAM,GAAG,QAAQ,CAAC,IAAI,CACzB,CAAC;aACL;iBAAM;gBACH,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;aACnC;QACL,CAAC,CAAC,CAAC;QAGH,IAAI,WAAW,CAAC,SAAS,EAAE;YACvB,OAAO,CAAC,QAAQ,CAAC,iCAAe,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC;SACtE;IACL,CAAC;CAQJ;AAvDD,8BAuDC"}
@@ -1,5 +1,7 @@
1
1
  export declare class DataMapperHelper {
2
2
  static getKeys(object: any): any;
3
3
  static anyToModel(source: any, ModelClass: any, fieldNames?: any): any;
4
+ static anyToSchema(source: any, SchemaClass: any): any;
5
+ static anyToPlain(source: any): any;
4
6
  static applyFields(target: Record<string, unknown> | any, source: any, fields?: string[]): void;
5
7
  }
@@ -37,6 +37,27 @@ class DataMapperHelper {
37
37
  });
38
38
  return model;
39
39
  }
40
+ static anyToSchema(source, SchemaClass) {
41
+ return source;
42
+ }
43
+ static anyToPlain(source) {
44
+ if (Array.isArray(source)) {
45
+ return source.map(item => this.anyToPlain(item));
46
+ }
47
+ if ((0, lodash_1.isDate)(source)) {
48
+ return source;
49
+ }
50
+ if ((0, lodash_1.isObject)(source)) {
51
+ const keys = MetaHelper_1.MetaHelper.getFieldNames(source.constructor);
52
+ return Object.keys(source).reduce((obj, key) => {
53
+ if (!keys || keys.includes(key)) {
54
+ obj[key] = DataMapperHelper.anyToPlain(source[key]);
55
+ }
56
+ return obj;
57
+ }, {});
58
+ }
59
+ return source;
60
+ }
40
61
  static applyFields(target, source, fields = null) {
41
62
  if ((0, lodash_1.isObject)(source)) {
42
63
  Object.assign(target, source);
@@ -1 +1 @@
1
- {"version":3,"file":"DataMapperHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/DataMapperHelper.ts"],"names":[],"mappings":";;;AAAA,mCAGgB;AAChB,gFAAuF;AACvF,wEAAmE;AAGnE,MAAa,gBAAgB;IACzB,MAAM,CAAC,OAAO,CAAC,MAAM;QACjB,OAAO,OAAO,CAAC,WAAW,CAAC,iCAAqB,EAAE,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IAC9E,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,IAAI;QACnD,IAAI,CAAC,UAAU,EAAE;YACb,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;SACzC;QAED,MAAM,KAAK,GAAG,IAAI,UAAU,EAAE,CAAC;QAE/B,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC3B,IAAI,IAAA,YAAI,EAAC,MAAM,EAAE,SAAS,CAAC,EAAE;gBACzB,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;gBAEhC,IAAI,IAAA,iBAAS,EAAC,KAAK,CAAC,EAAE;oBAClB,MAAM,SAAS,GAAG,uBAAU,CAAC,eAAe,CAAC,UAAU,EAAE,SAAS,CAA0B,CAAC;oBAC7F,IAAI,SAAS,CAAC,OAAO,KAAK,UAAU,EAAE;wBAClC,KAAK,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC;qBACrE;yBAAM;qBAEN;iBACJ;qBAAM;oBACH,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;iBAC5B;aACJ;iBAAM,IAAI,IAAA,YAAI,EAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAAC,EAAE;gBACvC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC;aACtD;iBAAM,IAAI,IAAA,YAAI,EAAC,MAAM,EAAE,SAAS,GAAG,KAAK,CAAC,EAAE;gBACxC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,GAAG,MAAM,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;aACxD;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,MAAqC,EAAE,MAAW,EAAE,SAAmB,IAAI;QAC1F,IAAI,IAAA,iBAAS,EAAC,MAAM,CAAC,EAAE;YACnB,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;SAkBjC;IACL,CAAC;CACJ;AA1DD,4CA0DC"}
1
+ {"version":3,"file":"DataMapperHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/DataMapperHelper.ts"],"names":[],"mappings":"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"}
@@ -2,8 +2,7 @@ import { Repository } from 'typeorm';
2
2
  import { SelectQueryBuilder } from 'typeorm/query-builder/SelectQueryBuilder';
3
3
  import { SearchInputDto } from '../dtos/SearchInputDto';
4
4
  import { SearchResultDto } from '../dtos/SearchResultDto';
5
- import SteroidsQuery from '../base/SteroidsQuery';
5
+ import SearchQuery from '../base/SearchQuery';
6
6
  export declare class SearchHelper {
7
- static prepareSelect(repository: Repository<any>, dbQuery: SelectQueryBuilder<any>, query: SteroidsQuery<SearchInputDto>): void;
8
- static search<TTable>(repository: Repository<any>, query: SteroidsQuery<SearchInputDto>, prepareHandler?: (query: SelectQueryBuilder<TTable>) => void | null): Promise<SearchResultDto<TTable>>;
7
+ static search<TTable>(repository: Repository<any>, dto: SearchInputDto, query: SearchQuery, prepareHandler?: (query: SelectQueryBuilder<TTable>) => void | null): Promise<SearchResultDto<TTable>>;
9
8
  }
@@ -2,32 +2,13 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SearchHelper = void 0;
4
4
  const SearchResultDto_1 = require("../dtos/SearchResultDto");
5
+ const SearchQuery_1 = require("../base/SearchQuery");
5
6
  class SearchHelper {
6
- static prepareSelect(repository, dbQuery, query) {
7
- const prefix = dbQuery.expressionMap.mainAlias.name + '.';
8
- let select = query.select;
9
- if (query.excludeSelect) {
10
- select = repository.metadata.columns
11
- .map(column => column.propertyName)
12
- .filter(name => !query.excludeSelect.includes(name));
13
- }
14
- if (select) {
15
- dbQuery.select(select.map(name => prefix + name));
16
- }
17
- (query.relations || []).forEach(relation => {
18
- if (relation.isId) {
19
- dbQuery.loadRelationIdAndMap(prefix + (relation.alias || relation.name), prefix + relation.name);
20
- }
21
- else {
22
- dbQuery.relation(relation.name);
23
- }
24
- });
25
- }
26
- static async search(repository, query, prepareHandler = null) {
7
+ static async search(repository, dto, query, prepareHandler = null) {
27
8
  const result = new SearchResultDto_1.SearchResultDto();
28
- const dto = Object.assign({ page: 1, pageSize: 50 }, query.dto);
9
+ dto = Object.assign({ page: 1, pageSize: 50 }, dto);
29
10
  const dbQuery = repository.createQueryBuilder();
30
- this.prepareSelect(repository, dbQuery, query);
11
+ SearchQuery_1.default.prepare(repository, dbQuery, query);
31
12
  const sort = typeof dto.sort === 'string' ? dto.sort.split(',') : (dto.sort || []);
32
13
  if (sort.length === 0) {
33
14
  dbQuery.orderBy(sort.reduce((obj, value) => {
@@ -1 +1 @@
1
- {"version":3,"file":"SearchHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/SearchHelper.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"SearchHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/SearchHelper.ts"],"names":[],"mappings":";;;AAGA,6DAAwD;AACxD,qDAA8C;AAE9C,MAAa,YAAY;IAErB,MAAM,CAAC,KAAK,CAAC,MAAM,CACf,UAA2B,EAC3B,GAAmB,EACnB,KAAkB,EAClB,iBAAqE,IAAI;QAEzE,MAAM,MAAM,GAAG,IAAI,iCAAe,EAAU,CAAC;QAG7C,GAAG,mBACC,IAAI,EAAE,CAAC,EACP,QAAQ,EAAE,EAAE,IACT,GAAG,CACT,CAAC;QAGF,MAAM,OAAO,GAAG,UAAU,CAAC,kBAAkB,EAAE,CAAC;QAEhD,qBAAW,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAGhD,MAAM,IAAI,GAAG,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACnF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;gBACvC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBACxE,OAAO,GAAG,CAAC;YACf,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;SACX;QAGD,IAAI,cAAc,EAAE;YAChB,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;SACtC;QAGD,OAAO;aACF,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC;aACrC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAGzB,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,eAAe,EAAE,CAAC;QACvD,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QAErB,OAAO,MAAM,CAAC;IAClB,CAAC;CACJ;AAhDD,oCAgDC"}
@@ -2,11 +2,13 @@ import { Repository } from 'typeorm';
2
2
  import { SearchResultDto } from '../dtos/SearchResultDto';
3
3
  import { SearchInputDto } from '../dtos/SearchInputDto';
4
4
  import { ICondition } from '../../infrastructure/helpers/ConditionHelper';
5
- import SteroidsQuery from '../base/SteroidsQuery';
5
+ import { Type } from '@nestjs/common';
6
+ import SearchQuery from '../base/SearchQuery';
6
7
  export interface ICrudRepository<TModel> {
7
8
  dbRepository: Repository<any>;
8
- search: (query: SteroidsQuery<SearchInputDto>) => Promise<SearchResultDto<TModel>>;
9
- findOne: (condition: ICondition) => Promise<TModel>;
9
+ search: <TItem>(dto: SearchInputDto, searchQuery: SearchQuery) => Promise<SearchResultDto<TModel | Type<TItem>>>;
10
+ findOne: (conditionOrQuery: ICondition | SearchQuery) => Promise<TModel | null>;
11
+ findMany: (conditionOrQuery: ICondition | SearchQuery) => Promise<TModel[]>;
10
12
  create: (model: TModel) => Promise<TModel>;
11
13
  update: (id: number, model: TModel) => Promise<TModel>;
12
14
  remove: (id: number) => Promise<void>;
@@ -1,16 +1,24 @@
1
+ import { Type } from '@nestjs/common';
1
2
  import { ICrudRepository } from '../interfaces/ICrudRepository';
2
3
  import { ISearchInputDto } from '../dtos/SearchInputDto';
3
4
  import { SearchResultDto } from '../dtos/SearchResultDto';
4
- import SteroidsQuery from '../base/SteroidsQuery';
5
+ import SearchQuery from '../base/SearchQuery';
5
6
  export declare class CrudService<TModel, TSearchDto = ISearchInputDto, TSaveDto = TModel> {
6
7
  protected primaryKey: string;
7
8
  protected repository: ICrudRepository<TModel>;
8
9
  protected modelClass: any;
9
10
  init(repository: ICrudRepository<TModel>, ModelClass: any): void;
10
- search(query: SteroidsQuery<TSearchDto>): Promise<SearchResultDto<TModel>>;
11
+ search(dto: TSearchDto): Promise<SearchResultDto<TModel>>;
12
+ search<TSchema>(dto: TSearchDto, schemaClass: Type<TSchema>): Promise<SearchResultDto<Type<TSchema>>>;
11
13
  findById(id: number | string): Promise<TModel>;
14
+ findById<TSchema>(id: number | string, schemaClass: Type<TSchema>): Promise<Type<TSchema>>;
15
+ findOne(searchQuery: SearchQuery): Promise<TModel>;
16
+ findMany(searchQuery: SearchQuery): Promise<TModel[]>;
12
17
  create(dto: TSaveDto): Promise<TModel>;
13
- update(id: number | string, dto: TSaveDto): Promise<TModel>;
18
+ create<TSchema>(dto: TSaveDto, schemaClass: Type<TSchema>): Promise<Type<TSchema>>;
19
+ update<TSchema>(id: number | string, dto: TSaveDto): Promise<TModel>;
20
+ update<TSchema>(id: number | string, dto: TSaveDto, schemaClass: Type<TSchema>): Promise<Type<TSchema>>;
14
21
  remove(id: number | string): Promise<void>;
22
+ protected modelToSchema<TSchema>(model: TModel, schemaClass: Type<TSchema>): Type<TSchema>;
15
23
  protected dtoToModel(dto: TSaveDto): Promise<TModel>;
16
24
  }
@@ -4,6 +4,7 @@ exports.CrudService = void 0;
4
4
  const lodash_1 = require("lodash");
5
5
  const DataMapperHelper_1 = require("../helpers/DataMapperHelper");
6
6
  const ValidationHelper_1 = require("../helpers/ValidationHelper");
7
+ const SearchQuery_1 = require("../base/SearchQuery");
7
8
  class CrudService {
8
9
  constructor() {
9
10
  this.primaryKey = 'id';
@@ -12,25 +13,43 @@ class CrudService {
12
13
  this.repository = repository;
13
14
  this.modelClass = ModelClass;
14
15
  }
15
- async search(query) {
16
- await (0, ValidationHelper_1.validateOrReject)(query.dto);
17
- return await this.repository.search(query);
16
+ async search(dto, schemaClass = null) {
17
+ await (0, ValidationHelper_1.validateOrReject)(dto);
18
+ const result = await this.repository.search(dto, SearchQuery_1.default.createFromSchema(schemaClass));
19
+ if (schemaClass) {
20
+ result.items = result.items.map((model) => this.modelToSchema(model, schemaClass));
21
+ }
22
+ return result;
23
+ }
24
+ async findById(id, schemaClass = null) {
25
+ const searchQuery = SearchQuery_1.default.createFromSchema(schemaClass);
26
+ searchQuery.condition = { [this.primaryKey]: (0, lodash_1.toInteger)(id) };
27
+ const model = await this.findOne(searchQuery);
28
+ return schemaClass ? this.modelToSchema(model, schemaClass) : model;
18
29
  }
19
- async findById(id) {
20
- return this.repository.findOne({ [this.primaryKey]: (0, lodash_1.toInteger)(id) });
30
+ async findOne(searchQuery) {
31
+ return await this.repository.findOne(searchQuery);
21
32
  }
22
- async create(dto) {
33
+ async findMany(searchQuery) {
34
+ return await this.repository.findMany(searchQuery);
35
+ }
36
+ async create(dto, schemaClass = null) {
23
37
  await (0, ValidationHelper_1.validateOrReject)(dto);
24
- return this.repository.create(await this.dtoToModel(dto));
38
+ const model = await this.repository.create(await this.dtoToModel(dto));
39
+ return schemaClass ? this.findById(model[this.primaryKey], schemaClass) : model;
25
40
  }
26
- async update(id, dto) {
41
+ async update(id, dto, schemaClass = null) {
27
42
  await (0, ValidationHelper_1.validateOrReject)(dto);
28
- return this.repository.update((0, lodash_1.toInteger)(id), await this.dtoToModel(dto));
43
+ const model = await this.repository.update((0, lodash_1.toInteger)(id), await this.dtoToModel(dto));
44
+ return schemaClass ? this.findById(id, schemaClass) : model;
29
45
  }
30
46
  async remove(id) {
31
47
  await this.repository.remove((0, lodash_1.toInteger)(id));
32
48
  }
33
- async dtoToModel(dto) {
49
+ modelToSchema(model, schemaClass) {
50
+ return DataMapperHelper_1.DataMapperHelper.anyToSchema(model, schemaClass);
51
+ }
52
+ dtoToModel(dto) {
34
53
  if (!this.modelClass) {
35
54
  throw new Error('Property modelClass is not set in service: ' + this.constructor.name);
36
55
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CrudService.js","sourceRoot":"","sources":["../../../src/usecases/services/CrudService.ts"],"names":[],"mappings":";;;AAAA,mCAA+C;AAE/C,kEAA6D;AAG7D,kEAA6D;AAM7D,MAAa,WAAW;IAAxB;QAMc,eAAU,GAAW,IAAI,CAAC;IA4ExC,CAAC;IA7DG,IAAI,CAAC,UAAmC,EAAE,UAAU;QAChD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAMD,KAAK,CAAC,MAAM,CAAC,KAAgC;QACzC,MAAM,IAAA,mCAAgB,EAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IAMD,KAAK,CAAC,QAAQ,CAAC,EAAmB;QAC9B,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAA,kBAAU,EAAC,EAAE,CAAC,EAAC,CAAC,CAAC;IACxE,CAAC;IAMD,KAAK,CAAC,MAAM,CAAC,GAAa;QACtB,MAAM,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;QAC5B,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9D,CAAC;IAOD,KAAK,CAAC,MAAM,CAAC,EAAmB,EAAE,GAAa;QAC3C,MAAM,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;QAC5B,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAA,kBAAU,EAAC,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9E,CAAC;IAMD,KAAK,CAAC,MAAM,CAAC,EAAmB;QAC5B,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAA,kBAAU,EAAC,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAOS,KAAK,CAAC,UAAU,CAAC,GAAa;QACpC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,6CAA6C,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SAC1F;QAED,OAAO,mCAAgB,CAAC,UAAU,CAAC,GAAG,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7D,CAAC;CACJ;AAlFD,kCAkFC"}
1
+ {"version":3,"file":"CrudService.js","sourceRoot":"","sources":["../../../src/usecases/services/CrudService.ts"],"names":[],"mappings":";;;AACA,mCAA+C;AAE/C,kEAA6D;AAG7D,kEAA6D;AAC7D,qDAA8C;AAK9C,MAAa,WAAW;IAAxB;QAMc,eAAU,GAAW,IAAI,CAAC;IA2JxC,CAAC;IA7IG,IAAI,CAAC,UAAmC,EAAE,UAAU;QAChD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAaD,KAAK,CAAC,MAAM,CACR,GAAe,EACf,cAA6B,IAAI;QAEjC,MAAM,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;QAE5B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAU,GAAG,EAAE,qBAAW,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC,CAAC;QACrG,IAAI,WAAW,EAAE;YACb,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAU,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC;SACvG;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAaD,KAAK,CAAC,QAAQ,CACV,EAAmB,EACnB,cAA6B,IAAI;QAEjC,MAAM,WAAW,GAAG,qBAAW,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;QAC9D,WAAW,CAAC,SAAS,GAAG,EAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAA,kBAAU,EAAC,EAAE,CAAC,EAAC,CAAC;QAC5D,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC9C,OAAO,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAU,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACjF,CAAC;IAMD,KAAK,CAAC,OAAO,CAAC,WAAwB;QAClC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACtD,CAAC;IAMD,KAAK,CAAC,QAAQ,CAAC,WAAwB;QACnC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACvD,CAAC;IAaD,KAAK,CAAC,MAAM,CACR,GAAa,EACb,cAA6B,IAAI;QAEjC,MAAM,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;QAE5B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;QACvE,OAAO,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACpF,CAAC;IAeD,KAAK,CAAC,MAAM,CACR,EAAmB,EACnB,GAAa,EACb,cAA6B,IAAI;QAEjC,MAAM,IAAA,mCAAgB,EAAC,GAAG,CAAC,CAAC;QAE5B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAA,kBAAU,EAAC,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;QACvF,OAAO,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAChE,CAAC;IAMD,KAAK,CAAC,MAAM,CAAC,EAAmB;QAC5B,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAA,kBAAU,EAAC,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAQS,aAAa,CAAU,KAAa,EAAE,WAA0B;QACtE,OAAO,mCAAgB,CAAC,WAAW,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IAC5D,CAAC;IAOS,UAAU,CAAC,GAAa;QAC9B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,6CAA6C,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SAC1F;QAED,OAAO,mCAAgB,CAAC,UAAU,CAAC,GAAG,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7D,CAAC;CACJ;AAjKD,kCAiKC"}
@@ -1,13 +0,0 @@
1
- export interface IQueryRelation {
2
- name: string;
3
- alias?: string;
4
- isId?: boolean;
5
- }
6
- export default class SteroidsQuery<TDto> {
7
- readonly dto?: TDto;
8
- readonly select?: string[];
9
- readonly excludeSelect?: string[];
10
- readonly relations?: IQueryRelation[];
11
- static create(dto?: any, SchemaClass?: any): SteroidsQuery<any>;
12
- constructor(data?: SteroidsQuery<TDto>);
13
- }
@@ -1,16 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const MetaHelper_1 = require("../../infrastructure/helpers/MetaHelper");
4
- class SteroidsQuery {
5
- constructor(data = {}) {
6
- this.dto = data.dto;
7
- this.select = data.select;
8
- this.excludeSelect = data.excludeSelect;
9
- this.relations = data.relations;
10
- }
11
- static create(dto = null, SchemaClass = null) {
12
- return new SteroidsQuery(Object.assign({ dto }, MetaHelper_1.MetaHelper.getSchemaQueryData(SchemaClass)));
13
- }
14
- }
15
- exports.default = SteroidsQuery;
16
- //# sourceMappingURL=SteroidsQuery.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SteroidsQuery.js","sourceRoot":"","sources":["../../../src/usecases/base/SteroidsQuery.ts"],"names":[],"mappings":";;AAAA,wEAAmE;AAQnE,MAAqB,aAAa;IAa9B,YAAY,OAA4B,EAAE;QACtC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IACpC,CAAC;IAZD,MAAM,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,EAAE,WAAW,GAAG,IAAI;QACxC,OAAO,IAAI,aAAa,iBACpB,GAAG,IACA,uBAAU,CAAC,kBAAkB,CAAC,WAAW,CAAC,EAC/C,CAAC;IACP,CAAC;CAQJ;AAnBD,gCAmBC"}