@joktec/mysql 0.0.176 → 0.0.177

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 (52) hide show
  1. package/dist/decorators/index.d.ts +2 -0
  2. package/dist/decorators/index.d.ts.map +1 -0
  3. package/dist/decorators/index.js +18 -0
  4. package/dist/decorators/index.js.map +1 -0
  5. package/dist/decorators/table.decorator.d.ts +20 -0
  6. package/dist/decorators/table.decorator.d.ts.map +1 -0
  7. package/dist/decorators/table.decorator.js +31 -0
  8. package/dist/decorators/table.decorator.js.map +1 -0
  9. package/dist/helpers/index.d.ts +2 -0
  10. package/dist/helpers/index.d.ts.map +1 -1
  11. package/dist/helpers/index.js +2 -0
  12. package/dist/helpers/index.js.map +1 -1
  13. package/dist/helpers/mysql.finder.d.ts +11 -0
  14. package/dist/helpers/mysql.finder.d.ts.map +1 -0
  15. package/dist/helpers/mysql.finder.js +105 -0
  16. package/dist/helpers/mysql.finder.js.map +1 -0
  17. package/dist/helpers/mysql.helper.d.ts +7 -8
  18. package/dist/helpers/mysql.helper.d.ts.map +1 -1
  19. package/dist/helpers/mysql.helper.js +68 -56
  20. package/dist/helpers/mysql.helper.js.map +1 -1
  21. package/dist/helpers/mysql.utils.d.ts +4 -0
  22. package/dist/helpers/mysql.utils.d.ts.map +1 -0
  23. package/dist/helpers/mysql.utils.js +25 -0
  24. package/dist/helpers/mysql.utils.js.map +1 -0
  25. package/dist/index.d.ts +3 -0
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +3 -0
  28. package/dist/index.js.map +1 -1
  29. package/dist/mysql.benchmark.d.ts +15 -0
  30. package/dist/mysql.benchmark.d.ts.map +1 -0
  31. package/dist/mysql.benchmark.js +72 -0
  32. package/dist/mysql.benchmark.js.map +1 -0
  33. package/dist/mysql.config.d.ts +16 -1
  34. package/dist/mysql.config.d.ts.map +1 -1
  35. package/dist/mysql.config.js +44 -7
  36. package/dist/mysql.config.js.map +1 -1
  37. package/dist/mysql.exception.d.ts +1 -1
  38. package/dist/mysql.exception.d.ts.map +1 -1
  39. package/dist/mysql.exception.js.map +1 -1
  40. package/dist/mysql.repo.d.ts +3 -1
  41. package/dist/mysql.repo.d.ts.map +1 -1
  42. package/dist/mysql.repo.js +38 -7
  43. package/dist/mysql.repo.js.map +1 -1
  44. package/dist/mysql.service.d.ts.map +1 -1
  45. package/dist/mysql.service.js +4 -2
  46. package/dist/mysql.service.js.map +1 -1
  47. package/dist/mysql.strategy.d.ts +15 -0
  48. package/dist/mysql.strategy.d.ts.map +1 -0
  49. package/dist/mysql.strategy.js +49 -0
  50. package/dist/mysql.strategy.js.map +1 -0
  51. package/dist/tsconfig.tsbuildinfo +1 -1
  52. package/package.json +3 -4
@@ -0,0 +1,2 @@
1
+ export * from './table.decorator';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./table.decorator"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC"}
@@ -0,0 +1,20 @@
1
+ import { KeyOf } from '@joktec/core';
2
+ import { EntityOptions, IndexOptions } from 'typeorm';
3
+ import { MysqlModel } from '../models';
4
+ type KeyTypeOf<T, TYPE> = {
5
+ [K in keyof T]: T[K] extends TYPE | undefined ? K : never;
6
+ }[keyof T];
7
+ export interface IIndexOptions<T extends MysqlModel = any> extends IndexOptions {
8
+ name?: string;
9
+ fields: KeyOf<T>[];
10
+ }
11
+ export interface ITableOptions<T extends MysqlModel = any> extends EntityOptions {
12
+ keywords?: KeyTypeOf<T, string>[];
13
+ index?: KeyOf<T>[];
14
+ unique?: KeyOf<T>[];
15
+ textSearch?: KeyTypeOf<T, string>[];
16
+ customIndexes?: IIndexOptions<T>[];
17
+ }
18
+ export declare const Tables: <T extends MysqlModel = any>(options?: ITableOptions<T>) => ClassDecorator;
19
+ export {};
20
+ //# sourceMappingURL=table.decorator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,EAAe,MAAM,cAAc,CAAC;AACnE,OAAO,EAAU,aAAa,EAAS,YAAY,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,KAAK,SAAS,CAAC,CAAC,EAAE,IAAI,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,GAAG,SAAS,GAAG,CAAC,GAAG,KAAK;CAAE,CAAC,MAAM,CAAC,CAAC,CAAC;AAEjG,MAAM,WAAW,aAAa,CAAC,CAAC,SAAS,UAAU,GAAG,GAAG,CAAE,SAAQ,YAAY;IAC7E,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;CACpB;AAED,MAAM,WAAW,aAAa,CAAC,CAAC,SAAS,UAAU,GAAG,GAAG,CAAE,SAAQ,aAAa;IAC9E,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;IAElC,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IACnB,MAAM,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IACpB,UAAU,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;IACpC,aAAa,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;CACpC;AAED,eAAO,MAAM,MAAM,GAAI,CAAC,SAAS,UAAU,kBAAiB,aAAa,CAAC,CAAC,CAAC,KAAQ,cA2BnF,CAAC"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Tables = void 0;
4
+ const core_1 = require("@joktec/core");
5
+ const typeorm_1 = require("typeorm");
6
+ const Tables = (options = {}) => {
7
+ return (target) => {
8
+ const className = target.name;
9
+ const decorators = [(0, core_1.SetMetadata)(className, options), (0, typeorm_1.Entity)(options)];
10
+ if (options.index?.length) {
11
+ options.index.map(indexOpts => decorators.push((0, typeorm_1.Index)(indexOpts)));
12
+ }
13
+ if (options.unique?.length) {
14
+ options.unique.map(uniqueOpts => decorators.push((0, typeorm_1.Index)(uniqueOpts, { unique: true })));
15
+ }
16
+ if (options.textSearch?.length) {
17
+ decorators.push((0, typeorm_1.Index)(options.textSearch.map(String), { fulltext: true }));
18
+ }
19
+ if (options.customIndexes?.length) {
20
+ options.customIndexes.map((idxOpts) => {
21
+ if (idxOpts.name)
22
+ decorators.push((0, typeorm_1.Index)(idxOpts.name, idxOpts.fields, idxOpts));
23
+ else
24
+ decorators.push((0, typeorm_1.Index)(idxOpts.fields, idxOpts));
25
+ });
26
+ }
27
+ (0, core_1.applyDecorators)(...decorators)(target);
28
+ };
29
+ };
30
+ exports.Tables = Tables;
31
+ //# sourceMappingURL=table.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table.decorator.js","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":";;;AAAA,uCAAmE;AACnE,qCAAqE;AAmB9D,MAAM,MAAM,GAAG,CAA6B,UAA4B,EAAE,EAAkB,EAAE;IACnG,OAAO,CAAC,MAAW,EAAE,EAAE;QACrB,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;QAE9B,MAAM,UAAU,GAAqB,CAAC,IAAA,kBAAW,EAAwB,SAAS,EAAE,OAAO,CAAC,EAAE,IAAA,gBAAM,EAAC,OAAO,CAAC,CAAC,CAAC;QAE/G,IAAI,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC;YAC1B,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAA,eAAK,EAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;YAC3B,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAA,eAAK,EAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzF,CAAC;QAED,IAAI,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC;YAC/B,UAAU,CAAC,IAAI,CAAC,IAAA,eAAK,EAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7E,CAAC;QAED,IAAI,OAAO,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;YAClC,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,OAAsB,EAAE,EAAE;gBACnD,IAAI,OAAO,CAAC,IAAI;oBAAE,UAAU,CAAC,IAAI,CAAC,IAAA,eAAK,EAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;;oBAC3E,UAAU,CAAC,IAAI,CAAC,IAAA,eAAK,EAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;YACvD,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAA,sBAAe,EAAC,GAAG,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC,CAAC;AACJ,CAAC,CAAC;AA3BW,QAAA,MAAM,UA2BjB"}
@@ -1,2 +1,4 @@
1
+ export * from './mysql.finder';
1
2
  export * from './mysql.helper';
3
+ export * from './mysql.utils';
2
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC"}
@@ -14,5 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./mysql.finder"), exports);
17
18
  __exportStar(require("./mysql.helper"), exports);
19
+ __exportStar(require("./mysql.utils"), exports);
18
20
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,iDAA+B;AAC/B,gDAA8B"}
@@ -0,0 +1,11 @@
1
+ import { IBaseRequest, ICondition, IPopulate } from '@joktec/core';
2
+ import { FindManyOptions } from 'typeorm';
3
+ import { MysqlModel } from '../models';
4
+ export declare class MysqlFinder {
5
+ static parseFilter<T>(query: IBaseRequest<T>): FindManyOptions<T>;
6
+ static parseProjection<T extends MysqlModel>(select: string | string[] | Record<string, number | boolean>): FindManyOptions<T>['select'];
7
+ static parseCondition<T>(condition: ICondition<T>): FindManyOptions<T>['where'];
8
+ static parseOrder<T>(sort: any): FindManyOptions<T>['order'];
9
+ static parseRelations<T>(populate: IPopulate<T>): FindManyOptions<T>['relations'];
10
+ }
11
+ //# sourceMappingURL=mysql.finder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.finder.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.finder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAmB,MAAM,cAAc,CAAC;AACpF,OAAO,EAAE,eAAe,EAAwE,MAAM,SAAS,CAAC;AAChH,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAGvC,qBAAa,WAAW;IACtB,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC;IASjE,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,UAAU,EACzC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,GAC3D,eAAe,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IAc/B,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IA2D/E,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAQ5D,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;CAalF"}
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MysqlFinder = void 0;
4
+ const core_1 = require("@joktec/core");
5
+ const typeorm_1 = require("typeorm");
6
+ const mysql_exception_1 = require("../mysql.exception");
7
+ class MysqlFinder {
8
+ static parseFilter(query) {
9
+ const { condition = {}, keyword } = query;
10
+ const where = MysqlFinder.parseCondition(condition);
11
+ if (keyword && typeof where === 'object') {
12
+ where['name'] = (0, typeorm_1.ILike)(`%${keyword}%`);
13
+ }
14
+ return { where };
15
+ }
16
+ static parseProjection(select) {
17
+ if (typeof select === 'object') {
18
+ return Object.entries(select).reduce((acc, [field, direction]) => {
19
+ acc[field] = (0, core_1.toBool)(direction);
20
+ return acc;
21
+ }, {});
22
+ }
23
+ return (0, core_1.toArray)(select, { split: ',' }).reduce((acc, field) => {
24
+ acc[field] = true;
25
+ return acc;
26
+ }, {});
27
+ }
28
+ static parseCondition(condition) {
29
+ const where = {};
30
+ for (const [key, value] of Object.entries(condition)) {
31
+ if (key === '$and' || key === '$or') {
32
+ where[key === '$and' ? 'AND' : 'OR'] = value.map((c) => MysqlFinder.parseCondition(c));
33
+ continue;
34
+ }
35
+ if (value === null || value === undefined) {
36
+ where[key] = (0, typeorm_1.Not)(null);
37
+ continue;
38
+ }
39
+ if (typeof value === 'object') {
40
+ for (const [op, val] of Object.entries(value)) {
41
+ switch (op) {
42
+ case '$eq':
43
+ where[key] = val;
44
+ break;
45
+ case '$gt':
46
+ where[key] = (0, typeorm_1.MoreThan)(val);
47
+ break;
48
+ case '$gte':
49
+ where[key] = (0, typeorm_1.MoreThanOrEqual)(val);
50
+ break;
51
+ case '$lt':
52
+ where[key] = (0, typeorm_1.LessThan)(val);
53
+ break;
54
+ case '$lte':
55
+ where[key] = (0, typeorm_1.LessThanOrEqual)(val);
56
+ break;
57
+ case '$ne':
58
+ where[key] = (0, typeorm_1.Not)(val);
59
+ break;
60
+ case '$in':
61
+ where[key] = (0, typeorm_1.In)((0, core_1.toArray)(val));
62
+ break;
63
+ case '$like':
64
+ where[key] = (0, typeorm_1.ILike)(`%${val}%`);
65
+ break;
66
+ case '$begin':
67
+ where[key] = (0, typeorm_1.ILike)(`${val}%`);
68
+ break;
69
+ case '$end':
70
+ where[key] = (0, typeorm_1.ILike)(`%${val}`);
71
+ break;
72
+ default:
73
+ throw new mysql_exception_1.MysqlException(`Operator ${op} not supported`, { op, val });
74
+ }
75
+ }
76
+ }
77
+ else {
78
+ where[key] = value;
79
+ }
80
+ }
81
+ return where;
82
+ }
83
+ static parseOrder(sort) {
84
+ const order = {};
85
+ for (const [key, value] of Object.entries(sort)) {
86
+ order[key] = value === 'asc' ? 'ASC' : 'DESC';
87
+ }
88
+ return order;
89
+ }
90
+ static parseRelations(populate) {
91
+ const relations = {};
92
+ for (const [path, value] of Object.entries(populate)) {
93
+ if (value === '*') {
94
+ relations[path] = true;
95
+ continue;
96
+ }
97
+ if (typeof value === 'object') {
98
+ relations[path] = MysqlFinder.parseRelations(value['populate'] || {});
99
+ }
100
+ }
101
+ return relations;
102
+ }
103
+ }
104
+ exports.MysqlFinder = MysqlFinder;
105
+ //# sourceMappingURL=mysql.finder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.finder.js","sourceRoot":"","sources":["../../src/helpers/mysql.finder.ts"],"names":[],"mappings":";;;AAAA,uCAAoF;AACpF,qCAAgH;AAEhH,wDAAoD;AAEpD,MAAa,WAAW;IACtB,MAAM,CAAC,WAAW,CAAI,KAAsB;QAC1C,MAAM,EAAE,SAAS,GAAG,EAAE,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;QAC1C,MAAM,KAAK,GAAgC,WAAW,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACjF,IAAI,OAAO,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACzC,KAAK,CAAC,MAAM,CAAC,GAAG,IAAA,eAAK,EAAC,IAAI,OAAO,GAAG,CAAC,CAAC;QACxC,CAAC;QACD,OAAO,EAAE,KAAK,EAAE,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,eAAe,CACpB,MAA4D;QAE5D,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;YAC/B,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,EAAE;gBAC/D,GAAG,CAAC,KAAK,CAAC,GAAG,IAAA,aAAM,EAAC,SAAS,CAAC,CAAC;gBAC/B,OAAO,GAAG,CAAC;YACb,CAAC,EAAE,EAAE,CAAC,CAAC;QACT,CAAC;QAED,OAAO,IAAA,cAAO,EAAC,MAAM,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YAC3D,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;YAClB,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;IAED,MAAM,CAAC,cAAc,CAAI,SAAwB;QAC/C,MAAM,KAAK,GAAgC,EAAE,CAAC;QAE9C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YACrD,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;gBACpC,KAAK,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAgB,EAAE,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;gBACtG,SAAS;YACX,CAAC;YAED,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC1C,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,aAAG,EAAC,IAAI,CAAC,CAAC;gBACvB,SAAS;YACX,CAAC;YAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9B,KAAK,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC9C,QAAQ,EAAE,EAAE,CAAC;wBACX,KAAK,KAAK;4BACR,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;4BACjB,MAAM;wBACR,KAAK,KAAK;4BACR,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,kBAAQ,EAAC,GAAG,CAAC,CAAC;4BAC3B,MAAM;wBACR,KAAK,MAAM;4BACT,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,yBAAe,EAAC,GAAG,CAAC,CAAC;4BAClC,MAAM;wBACR,KAAK,KAAK;4BACR,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,kBAAQ,EAAC,GAAG,CAAC,CAAC;4BAC3B,MAAM;wBACR,KAAK,MAAM;4BACT,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,yBAAe,EAAC,GAAG,CAAC,CAAC;4BAClC,MAAM;wBACR,KAAK,KAAK;4BACR,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,aAAG,EAAC,GAAG,CAAC,CAAC;4BACtB,MAAM;wBACR,KAAK,KAAK;4BACR,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,YAAE,EAAC,IAAA,cAAO,EAAC,GAAG,CAAC,CAAC,CAAC;4BAC9B,MAAM;wBACR,KAAK,OAAO;4BACV,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,eAAK,EAAC,IAAI,GAAG,GAAG,CAAC,CAAC;4BAC/B,MAAM;wBACR,KAAK,QAAQ;4BACX,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,eAAK,EAAC,GAAG,GAAG,GAAG,CAAC,CAAC;4BAC9B,MAAM;wBACR,KAAK,MAAM;4BACT,KAAK,CAAC,GAAG,CAAC,GAAG,IAAA,eAAK,EAAC,IAAI,GAAG,EAAE,CAAC,CAAC;4BAC9B,MAAM;wBACR;4BACE,MAAM,IAAI,gCAAc,CAAC,YAAY,EAAE,gBAAgB,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;oBAC1E,CAAC;gBACH,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YACrB,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,UAAU,CAAI,IAAS;QAC5B,MAAM,KAAK,GAAgC,EAAE,CAAC;QAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;QAChD,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,cAAc,CAAI,QAAsB;QAC7C,MAAM,SAAS,GAAoC,EAAE,CAAC;QACtD,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrD,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC;gBAClB,SAAS,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;gBACvB,SAAS;YACX,CAAC;YACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9B,SAAS,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC;YACxE,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AA1GD,kCA0GC"}
@@ -1,11 +1,10 @@
1
- import { IBaseRequest, ICondition, IPopulate } from '@joktec/core';
2
- import { FindManyOptions, FindOptionsWhere } from 'typeorm';
3
- import { MysqlModel } from '../models';
1
+ import { ICondition, IPopulate, ISort } from '@joktec/core';
2
+ import { SelectQueryBuilder } from 'typeorm';
4
3
  export declare class MysqlHelper {
5
- static parseProjection<T extends MysqlModel>(select: string | string[] | Record<string, number | boolean>): FindManyOptions<T>['select'];
6
- static parseFilter<T>(query: IBaseRequest<T>): FindManyOptions<T>;
7
- static parseCondition<T>(condition: ICondition<T>): FindOptionsWhere<T>;
8
- static parseOrder<T>(sort: any): FindManyOptions<T>['order'];
9
- static parseRelations<T>(populate: IPopulate<T>): FindManyOptions<T>['relations'];
4
+ static applyCondition<T>(qb: SelectQueryBuilder<T>, condition?: ICondition<T>): void;
5
+ static buildCondition<T>(qb: SelectQueryBuilder<T>, condition: ICondition<T>): SelectQueryBuilder<T>;
6
+ static applyProjection<T>(qb: SelectQueryBuilder<T>, select?: string | string[]): void;
7
+ static applyOrder<T>(qb: SelectQueryBuilder<T>, sort?: ISort<T>): void;
8
+ static applyRelations<T>(qb: SelectQueryBuilder<T>, populate?: IPopulate<T>): void;
10
9
  }
11
10
  //# sourceMappingURL=mysql.helper.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAmB,MAAM,cAAc,CAAC;AACpF,OAAO,EACL,eAAe,EACf,gBAAgB,EAQjB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAGvC,qBAAa,WAAW;IACtB,MAAM,CAAC,eAAe,CAAC,CAAC,SAAS,UAAU,EACzC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,GAC3D,eAAe,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IAc/B,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC;IASjE,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC;IA2DvE,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAQ5D,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;CAclF"}
1
+ {"version":3,"file":"mysql.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAE7C,qBAAa,WAAW;IACtB,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC;IAiB7E,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC;IAmF5E,MAAM,CAAC,eAAe,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAM/E,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;IAO/D,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;CAU5E"}
@@ -1,104 +1,116 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.MysqlHelper = void 0;
4
- const core_1 = require("@joktec/core");
5
- const typeorm_1 = require("typeorm");
6
- const mysql_exception_1 = require("../mysql.exception");
7
4
  class MysqlHelper {
8
- static parseProjection(select) {
9
- if (typeof select === 'object') {
10
- return Object.entries(select).reduce((acc, [field, direction]) => {
11
- acc[field] = (0, core_1.toBool)(direction);
12
- return acc;
13
- }, {});
14
- }
15
- return (0, core_1.toArray)(select, { split: ',' }).reduce((acc, field) => {
16
- acc[field] = true;
17
- return acc;
18
- }, {});
19
- }
20
- static parseFilter(query) {
21
- const { condition = {}, keyword } = query;
22
- const where = MysqlHelper.parseCondition(condition);
23
- if (keyword && typeof where === 'object') {
24
- where['name'] = (0, typeorm_1.ILike)(`%${keyword}%`);
25
- }
26
- return { where };
27
- }
28
- static parseCondition(condition) {
29
- const where = {};
5
+ static applyCondition(qb, condition) {
6
+ if (!condition)
7
+ return;
30
8
  for (const [key, value] of Object.entries(condition)) {
31
- if (key === '$and' || key === '$or') {
32
- where[key === '$and' ? 'AND' : 'OR'] = value.map((c) => MysqlHelper.parseCondition(c));
33
- continue;
9
+ if (key === '$or') {
10
+ const orConditions = value.map((c) => MysqlHelper.buildCondition(qb, c));
11
+ qb.orWhere(orConditions.join(' OR '));
34
12
  }
35
- if (value === null || value === undefined) {
36
- where[key] = (0, typeorm_1.Not)(null);
37
- continue;
13
+ else if (key === '$and') {
14
+ const andConditions = value.map((c) => MysqlHelper.buildCondition(qb, c));
15
+ qb.andWhere(andConditions.join(' AND '));
38
16
  }
17
+ else {
18
+ const whereClause = MysqlHelper.buildCondition(qb, { [key]: value });
19
+ qb.andWhere(whereClause);
20
+ }
21
+ }
22
+ }
23
+ static buildCondition(qb, condition) {
24
+ for (const [key, value] of Object.entries(condition)) {
39
25
  if (typeof value === 'object') {
40
26
  for (const [op, val] of Object.entries(value)) {
41
27
  switch (op) {
42
28
  case '$eq':
43
- where[key] = val;
29
+ qb.andWhere(`${qb.alias}.${key} = :${key}`, { [key]: val });
44
30
  break;
45
31
  case '$gt':
46
- where[key] = (0, typeorm_1.MoreThan)(val);
32
+ qb.andWhere(`${qb.alias}.${key} > :${key}`, { [key]: val });
47
33
  break;
48
34
  case '$gte':
49
- where[key] = (0, typeorm_1.MoreThanOrEqual)(val);
35
+ qb.andWhere(`${qb.alias}.${key} >= :${key}`, { [key]: val });
50
36
  break;
51
37
  case '$lt':
52
- where[key] = (0, typeorm_1.LessThan)(val);
38
+ qb.andWhere(`${qb.alias}.${key} < :${key}`, { [key]: val });
53
39
  break;
54
40
  case '$lte':
55
- where[key] = (0, typeorm_1.LessThanOrEqual)(val);
41
+ qb.andWhere(`${qb.alias}.${key} <= :${key}`, { [key]: val });
56
42
  break;
57
43
  case '$ne':
58
- where[key] = (0, typeorm_1.Not)(val);
44
+ qb.andWhere(`${qb.alias}.${key} != :${key}`, { [key]: val });
59
45
  break;
60
46
  case '$in':
61
- where[key] = (0, typeorm_1.In)((0, core_1.toArray)(val));
47
+ qb.andWhere(`${qb.alias}.${key} IN (:...${key})`, { [key]: val });
48
+ break;
49
+ case '$nin':
50
+ qb.andWhere(`${qb.alias}.${key} NOT IN (:...${key})`, { [key]: val });
51
+ break;
52
+ case '$all':
53
+ qb.andWhere(`${qb.alias}.${key} @> ARRAY[:...${key}]`, { [key]: val });
62
54
  break;
63
55
  case '$like':
64
- where[key] = (0, typeorm_1.ILike)(`%${val}%`);
56
+ qb.andWhere(`${qb.alias}.${key} LIKE :${key}`, { [key]: `%${val}%` });
65
57
  break;
66
58
  case '$begin':
67
- where[key] = (0, typeorm_1.ILike)(`${val}%`);
59
+ qb.andWhere(`${qb.alias}.${key} LIKE :${key}`, { [key]: `${val}%` });
68
60
  break;
69
61
  case '$end':
70
- where[key] = (0, typeorm_1.ILike)(`%${val}`);
62
+ qb.andWhere(`${qb.alias}.${key} LIKE :${key}`, { [key]: `%${val}` });
63
+ break;
64
+ case '$exists':
65
+ qb.andWhere(`${qb.alias}.${key} IS NOT NULL`);
66
+ break;
67
+ case '$nil':
68
+ qb.andWhere(`${qb.alias}.${key} IS NULL`);
69
+ break;
70
+ case '$empty':
71
+ qb.andWhere(`${qb.alias}.${key} = ''`);
72
+ break;
73
+ case '$not':
74
+ qb.andWhere(`${qb.alias}.${key} != :${key}`, { [key]: val });
75
+ break;
76
+ case '$size':
77
+ qb.andWhere(`array_length(${key}, 1) = :${key}`, { [key]: val });
71
78
  break;
72
79
  default:
73
- throw new mysql_exception_1.MysqlException(`Operator ${op} not supported`, { op, val });
80
+ throw new Error(`Unsupported operator: ${op}`);
74
81
  }
75
82
  }
76
83
  }
77
84
  else {
78
- where[key] = value;
85
+ qb.andWhere(`${qb.alias}.${key} = :${key}`, { [key]: value });
79
86
  }
80
87
  }
81
- return where;
88
+ return qb;
82
89
  }
83
- static parseOrder(sort) {
84
- const order = {};
90
+ static applyProjection(qb, select) {
91
+ if (!select)
92
+ return;
93
+ const fields = Array.isArray(select) ? select : select.split(',');
94
+ qb.select(fields.map(field => `${qb.alias}.${field.trim()}`));
95
+ }
96
+ static applyOrder(qb, sort) {
97
+ if (!sort)
98
+ return;
85
99
  for (const [key, value] of Object.entries(sort)) {
86
- order[key] = value === 'asc' ? 'ASC' : 'DESC';
100
+ qb.addOrderBy(`${qb.alias}.${key}`, value === 'asc' ? 'ASC' : 'DESC');
87
101
  }
88
- return order;
89
102
  }
90
- static parseRelations(populate) {
91
- const relations = {};
92
- for (const [key, value] of Object.entries(populate)) {
103
+ static applyRelations(qb, populate) {
104
+ if (!populate)
105
+ return;
106
+ for (const [relation, value] of Object.entries(populate)) {
93
107
  if (value === '*') {
94
- relations[key] = true;
95
- continue;
108
+ qb.leftJoinAndSelect(`${qb.alias}.${relation}`, relation);
96
109
  }
97
- if (typeof value === 'object') {
98
- relations[key] = MysqlHelper.parseRelations(value['populate'] || {});
110
+ else if (typeof value === 'object') {
111
+ qb.leftJoinAndSelect(`${qb.alias}.${relation}`, relation);
99
112
  }
100
113
  }
101
- return relations;
102
114
  }
103
115
  }
104
116
  exports.MysqlHelper = MysqlHelper;
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.helper.js","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mysql.helper.js","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":";;;AAGA,MAAa,WAAW;IACtB,MAAM,CAAC,cAAc,CAAI,EAAyB,EAAE,SAAyB;QAC3E,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YACrD,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;gBAClB,MAAM,YAAY,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAgB,EAAE,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;gBACxF,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YACxC,CAAC;iBAAM,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;gBAC1B,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAgB,EAAE,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;gBACzF,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAC3C,CAAC;iBAAM,CAAC;gBACN,MAAM,WAAW,GAAG,WAAW,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAmB,CAAC,CAAC;gBACtF,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,CAAC,cAAc,CAAI,EAAyB,EAAE,SAAwB;QAC1E,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YACrD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9B,KAAK,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC9C,QAAQ,EAAE,EAAE,CAAC;wBAEX,KAAK,KAAK;4BACR,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC5D,MAAM;wBACR,KAAK,KAAK;4BACR,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC5D,MAAM;wBACR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,QAAQ,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC7D,MAAM;wBACR,KAAK,KAAK;4BACR,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC5D,MAAM;wBACR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,QAAQ,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC7D,MAAM;wBACR,KAAK,KAAK;4BACR,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,QAAQ,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC7D,MAAM;wBAGR,KAAK,KAAK;4BACR,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,YAAY,GAAG,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAClE,MAAM;wBACR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,gBAAgB,GAAG,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BACtE,MAAM;wBACR,KAAK,MAAM;4BAET,EAAE,CAAC,QAAQ,CACT,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,iBAAiB,GAAG,GAAG,EACzC,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CACf,CAAC;4BACF,MAAM;wBAGR,KAAK,OAAO;4BACV,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,UAAU,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC;4BACtE,MAAM;wBACR,KAAK,QAAQ;4BACX,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,UAAU,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC;4BACrE,MAAM;wBACR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,UAAU,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,GAAG,EAAE,EAAE,CAAC,CAAC;4BACrE,MAAM;wBAGR,KAAK,SAAS;4BACZ,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,cAAc,CAAC,CAAC;4BAC9C,MAAM;wBACR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,UAAU,CAAC,CAAC;4BAC1C,MAAM;wBACR,KAAK,QAAQ;4BACX,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;4BACvC,MAAM;wBAGR,KAAK,MAAM;4BACT,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,QAAQ,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC7D,MAAM;wBAGR,KAAK,OAAO;4BACV,EAAE,CAAC,QAAQ,CAAC,gBAAgB,GAAG,WAAW,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;4BACjE,MAAM;wBAER;4BACE,MAAM,IAAI,KAAK,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC;oBACnD,CAAC;gBACH,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;YAChE,CAAC;QACH,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,CAAC,eAAe,CAAI,EAAyB,EAAE,MAA0B;QAC7E,IAAI,CAAC,MAAM;YAAE,OAAO;QACpB,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,MAAM,CAAC,UAAU,CAAI,EAAyB,EAAE,IAAe;QAC7D,IAAI,CAAC,IAAI;YAAE,OAAO;QAClB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,EAAE,EAAE,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED,MAAM,CAAC,cAAc,CAAI,EAAyB,EAAE,QAAuB;QACzE,IAAI,CAAC,QAAQ;YAAE,OAAO;QACtB,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzD,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC;gBAClB,EAAE,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAC;YAC5D,CAAC;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBACrC,EAAE,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAC;YAC5D,CAAC;QACH,CAAC;IACH,CAAC;CACF;AA5HD,kCA4HC"}
@@ -0,0 +1,4 @@
1
+ import { SelectQueryBuilder } from 'typeorm';
2
+ export declare function printSql(query: string, parameters?: any[]): string;
3
+ export declare function exportSql(builder: SelectQueryBuilder<any>): string;
4
+ //# sourceMappingURL=mysql.utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.utils.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAE7C,wBAAgB,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,MAAM,CAWlE;AAED,wBAAgB,SAAS,CAAC,OAAO,EAAE,kBAAkB,CAAC,GAAG,CAAC,UAGzD"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.printSql = printSql;
4
+ exports.exportSql = exportSql;
5
+ function printSql(query, parameters) {
6
+ let sql = query;
7
+ parameters.forEach((param) => {
8
+ sql = sql.replace('?', () => {
9
+ if (typeof param === 'string')
10
+ return `'${param}'`;
11
+ else if (param instanceof Date)
12
+ return `'${param.toISOString()}'`;
13
+ else if (param === null || param === undefined)
14
+ return 'NULL';
15
+ else
16
+ return param.toString();
17
+ });
18
+ });
19
+ return sql;
20
+ }
21
+ function exportSql(builder) {
22
+ const [query, params] = builder.getQueryAndParameters();
23
+ return printSql(query, params);
24
+ }
25
+ //# sourceMappingURL=mysql.utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.utils.js","sourceRoot":"","sources":["../../src/helpers/mysql.utils.ts"],"names":[],"mappings":";;AAEA,4BAWC;AAED,8BAGC;AAhBD,SAAgB,QAAQ,CAAC,KAAa,EAAE,UAAkB;IACxD,IAAI,GAAG,GAAW,KAAK,CAAC;IACxB,UAAU,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;QAChC,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE;YAC1B,IAAI,OAAO,KAAK,KAAK,QAAQ;gBAAE,OAAO,IAAI,KAAK,GAAG,CAAC;iBAC9C,IAAI,KAAK,YAAY,IAAI;gBAAE,OAAO,IAAI,KAAK,CAAC,WAAW,EAAE,GAAG,CAAC;iBAC7D,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;gBAAE,OAAO,MAAM,CAAC;;gBACzD,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAgB,SAAS,CAAC,OAAgC;IACxD,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;IACxD,OAAO,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACjC,CAAC"}
package/dist/index.d.ts CHANGED
@@ -4,6 +4,9 @@ export * from './mysql.service';
4
4
  export * from './mysql.config';
5
5
  export * from './mysql.repo';
6
6
  export * from './mysql.exception';
7
+ export * from './mysql.benchmark';
8
+ export * from './decorators';
9
+ export * from './helpers';
7
10
  export * from './models';
8
11
  export * from 'typeorm';
9
12
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
package/dist/index.js CHANGED
@@ -20,6 +20,9 @@ __exportStar(require("./mysql.service"), exports);
20
20
  __exportStar(require("./mysql.config"), exports);
21
21
  __exportStar(require("./mysql.repo"), exports);
22
22
  __exportStar(require("./mysql.exception"), exports);
23
+ __exportStar(require("./mysql.benchmark"), exports);
24
+ __exportStar(require("./decorators"), exports);
25
+ __exportStar(require("./helpers"), exports);
23
26
  __exportStar(require("./models"), exports);
24
27
  __exportStar(require("typeorm"), exports);
25
28
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,iDAA+B;AAC/B,kDAAgC;AAChC,iDAA+B;AAC/B,+CAA6B;AAC7B,oDAAkC;AAClC,2CAAyB;AACzB,0CAAwB"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,iDAA+B;AAC/B,kDAAgC;AAChC,iDAA+B;AAC/B,+CAA6B;AAC7B,oDAAkC;AAClC,oDAAkC;AAClC,+CAA6B;AAC7B,4CAA0B;AAC1B,2CAAyB;AACzB,0CAAwB"}
@@ -0,0 +1,15 @@
1
+ import { LogService } from '@joktec/core';
2
+ import { Logger } from 'typeorm';
3
+ import { MysqlBenchmarkConfig } from './mysql.config';
4
+ export declare class MysqlBenchmark implements Logger {
5
+ private benchmark;
6
+ private logService;
7
+ constructor(benchmark: MysqlBenchmarkConfig, logService: LogService);
8
+ logQuery(query: string, parameters?: any[]): void;
9
+ logQueryError(error: string | Error, query: string, parameters?: any[]): void;
10
+ logQuerySlow(time: number, query: string, parameters?: any[]): void;
11
+ logSchemaBuild(message: string): void;
12
+ logMigration(message: string): void;
13
+ log(level: 'log' | 'info' | 'warn', message: any): void;
14
+ }
15
+ //# sourceMappingURL=mysql.benchmark.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.benchmark.d.ts","sourceRoot":"","sources":["../src/mysql.benchmark.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,oBAAoB,EAAiB,MAAM,gBAAgB,CAAC;AAGrE,qBACa,cAAe,YAAW,MAAM;IAEzC,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,UAAU;gBADV,SAAS,EAAE,oBAAoB,EAC/B,UAAU,EAAE,UAAU;IAKhC,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE;IAO1C,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE;IAQtE,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE;IAK5D,cAAc,CAAC,OAAO,EAAE,MAAM;IAM9B,YAAY,CAAC,OAAO,EAAE,MAAM;IAI5B,GAAG,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,MAAM,EAAE,OAAO,EAAE,GAAG;CAgBjD"}