@joktec/mysql 0.2.13 → 0.2.15

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 (171) hide show
  1. package/README.md +419 -79
  2. package/dist/__tests__/mysql.column.decorator.spec.d.ts +2 -0
  3. package/dist/__tests__/mysql.column.decorator.spec.d.ts.map +1 -0
  4. package/dist/__tests__/mysql.column.decorator.spec.js +533 -0
  5. package/dist/__tests__/mysql.column.decorator.spec.js.map +1 -0
  6. package/dist/__tests__/mysql.dialect.spec.d.ts +2 -0
  7. package/dist/__tests__/mysql.dialect.spec.d.ts.map +1 -0
  8. package/dist/__tests__/mysql.dialect.spec.js +29 -0
  9. package/dist/__tests__/mysql.dialect.spec.js.map +1 -0
  10. package/dist/__tests__/mysql.exception.spec.d.ts +2 -0
  11. package/dist/__tests__/mysql.exception.spec.d.ts.map +1 -0
  12. package/dist/__tests__/mysql.exception.spec.js +42 -0
  13. package/dist/__tests__/mysql.exception.spec.js.map +1 -0
  14. package/dist/__tests__/mysql.helper.spec.d.ts +2 -0
  15. package/dist/__tests__/mysql.helper.spec.d.ts.map +1 -0
  16. package/dist/__tests__/mysql.helper.spec.js +80 -0
  17. package/dist/__tests__/mysql.helper.spec.js.map +1 -0
  18. package/dist/__tests__/mysql.module.integration.spec.d.ts +2 -0
  19. package/dist/__tests__/mysql.module.integration.spec.d.ts.map +1 -0
  20. package/dist/__tests__/mysql.module.integration.spec.js +67 -0
  21. package/dist/__tests__/mysql.module.integration.spec.js.map +1 -0
  22. package/dist/__tests__/mysql.repo.cursor.spec.d.ts +2 -0
  23. package/dist/__tests__/mysql.repo.cursor.spec.d.ts.map +1 -0
  24. package/dist/__tests__/mysql.repo.cursor.spec.js +146 -0
  25. package/dist/__tests__/mysql.repo.cursor.spec.js.map +1 -0
  26. package/dist/__tests__/mysql.service.spec.d.ts +2 -0
  27. package/dist/__tests__/mysql.service.spec.d.ts.map +1 -0
  28. package/dist/__tests__/mysql.service.spec.js +70 -0
  29. package/dist/__tests__/mysql.service.spec.js.map +1 -0
  30. package/dist/__tests__/mysql.utils.spec.d.ts +2 -0
  31. package/dist/__tests__/mysql.utils.spec.d.ts.map +1 -0
  32. package/dist/__tests__/mysql.utils.spec.js +21 -0
  33. package/dist/__tests__/mysql.utils.spec.js.map +1 -0
  34. package/dist/decorators/column.decorator.d.ts +10 -0
  35. package/dist/decorators/column.decorator.d.ts.map +1 -0
  36. package/dist/decorators/column.decorator.js +181 -0
  37. package/dist/decorators/column.decorator.js.map +1 -0
  38. package/dist/decorators/columns/array.column.d.ts +3 -0
  39. package/dist/decorators/columns/array.column.d.ts.map +1 -0
  40. package/dist/decorators/columns/array.column.js +13 -0
  41. package/dist/decorators/columns/array.column.js.map +1 -0
  42. package/dist/decorators/columns/bool.column.d.ts +2 -0
  43. package/dist/decorators/columns/bool.column.d.ts.map +1 -0
  44. package/dist/decorators/columns/bool.column.js +8 -0
  45. package/dist/decorators/columns/bool.column.js.map +1 -0
  46. package/dist/decorators/columns/column.factory.d.ts +5 -0
  47. package/dist/decorators/columns/column.factory.d.ts.map +1 -0
  48. package/dist/decorators/columns/column.factory.js +42 -0
  49. package/dist/decorators/columns/column.factory.js.map +1 -0
  50. package/dist/decorators/columns/column.type.d.ts +136 -0
  51. package/dist/decorators/columns/column.type.d.ts.map +1 -0
  52. package/dist/decorators/columns/column.type.js +3 -0
  53. package/dist/decorators/columns/column.type.js.map +1 -0
  54. package/dist/decorators/columns/column.util.d.ts +22 -0
  55. package/dist/decorators/columns/column.util.d.ts.map +1 -0
  56. package/dist/decorators/columns/column.util.js +163 -0
  57. package/dist/decorators/columns/column.util.js.map +1 -0
  58. package/dist/decorators/columns/date.column.d.ts +2 -0
  59. package/dist/decorators/columns/date.column.d.ts.map +1 -0
  60. package/dist/decorators/columns/date.column.js +8 -0
  61. package/dist/decorators/columns/date.column.js.map +1 -0
  62. package/dist/decorators/columns/enum.column.d.ts +3 -0
  63. package/dist/decorators/columns/enum.column.d.ts.map +1 -0
  64. package/dist/decorators/columns/enum.column.js +8 -0
  65. package/dist/decorators/columns/enum.column.js.map +1 -0
  66. package/dist/decorators/columns/index.d.ts +17 -0
  67. package/dist/decorators/columns/index.d.ts.map +1 -0
  68. package/dist/decorators/columns/index.js +33 -0
  69. package/dist/decorators/columns/index.js.map +1 -0
  70. package/dist/decorators/columns/nested.column.d.ts +4 -0
  71. package/dist/decorators/columns/nested.column.d.ts.map +1 -0
  72. package/dist/decorators/columns/nested.column.js +12 -0
  73. package/dist/decorators/columns/nested.column.js.map +1 -0
  74. package/dist/decorators/columns/number.column.d.ts +3 -0
  75. package/dist/decorators/columns/number.column.d.ts.map +1 -0
  76. package/dist/decorators/columns/number.column.js +16 -0
  77. package/dist/decorators/columns/number.column.js.map +1 -0
  78. package/dist/decorators/columns/object.column.d.ts +4 -0
  79. package/dist/decorators/columns/object.column.d.ts.map +1 -0
  80. package/dist/decorators/columns/object.column.js +13 -0
  81. package/dist/decorators/columns/object.column.js.map +1 -0
  82. package/dist/decorators/columns/primary.column.d.ts +3 -0
  83. package/dist/decorators/columns/primary.column.d.ts.map +1 -0
  84. package/dist/decorators/columns/primary.column.js +48 -0
  85. package/dist/decorators/columns/primary.column.js.map +1 -0
  86. package/dist/decorators/columns/string.column.d.ts +3 -0
  87. package/dist/decorators/columns/string.column.d.ts.map +1 -0
  88. package/dist/decorators/columns/string.column.js +28 -0
  89. package/dist/decorators/columns/string.column.js.map +1 -0
  90. package/dist/decorators/columns/swagger.column.d.ts +4 -0
  91. package/dist/decorators/columns/swagger.column.d.ts.map +1 -0
  92. package/dist/decorators/columns/swagger.column.js +49 -0
  93. package/dist/decorators/columns/swagger.column.js.map +1 -0
  94. package/dist/decorators/columns/timestamp.column.d.ts +6 -0
  95. package/dist/decorators/columns/timestamp.column.d.ts.map +1 -0
  96. package/dist/decorators/columns/timestamp.column.js +55 -0
  97. package/dist/decorators/columns/timestamp.column.js.map +1 -0
  98. package/dist/decorators/columns/transform.column.d.ts +4 -0
  99. package/dist/decorators/columns/transform.column.d.ts.map +1 -0
  100. package/dist/decorators/columns/transform.column.js +18 -0
  101. package/dist/decorators/columns/transform.column.js.map +1 -0
  102. package/dist/decorators/columns/virtual.column.d.ts +4 -0
  103. package/dist/decorators/columns/virtual.column.d.ts.map +1 -0
  104. package/dist/decorators/columns/virtual.column.js +23 -0
  105. package/dist/decorators/columns/virtual.column.js.map +1 -0
  106. package/dist/decorators/index.d.ts +3 -0
  107. package/dist/decorators/index.d.ts.map +1 -1
  108. package/dist/decorators/index.js +2 -0
  109. package/dist/decorators/index.js.map +1 -1
  110. package/dist/decorators/table.decorator.d.ts +31 -2
  111. package/dist/decorators/table.decorator.d.ts.map +1 -1
  112. package/dist/decorators/table.decorator.js +55 -18
  113. package/dist/decorators/table.decorator.js.map +1 -1
  114. package/dist/decorators/timestamp.decorator.d.ts +4 -0
  115. package/dist/decorators/timestamp.decorator.d.ts.map +1 -0
  116. package/dist/decorators/timestamp.decorator.js +19 -0
  117. package/dist/decorators/timestamp.decorator.js.map +1 -0
  118. package/dist/helpers/index.d.ts +0 -1
  119. package/dist/helpers/index.d.ts.map +1 -1
  120. package/dist/helpers/index.js +0 -1
  121. package/dist/helpers/index.js.map +1 -1
  122. package/dist/helpers/mysql.helper.d.ts +21 -6
  123. package/dist/helpers/mysql.helper.d.ts.map +1 -1
  124. package/dist/helpers/mysql.helper.js +152 -82
  125. package/dist/helpers/mysql.helper.js.map +1 -1
  126. package/dist/helpers/mysql.utils.d.ts.map +1 -1
  127. package/dist/helpers/mysql.utils.js +28 -11
  128. package/dist/helpers/mysql.utils.js.map +1 -1
  129. package/dist/index.d.ts +1 -0
  130. package/dist/index.d.ts.map +1 -1
  131. package/dist/index.js +6 -0
  132. package/dist/index.js.map +1 -1
  133. package/dist/models/mysql.model.d.ts.map +1 -1
  134. package/dist/models/mysql.model.js +4 -11
  135. package/dist/models/mysql.model.js.map +1 -1
  136. package/dist/models/mysql.option.d.ts +11 -2
  137. package/dist/models/mysql.option.d.ts.map +1 -1
  138. package/dist/mysql.config.d.ts +1 -17
  139. package/dist/mysql.config.d.ts.map +1 -1
  140. package/dist/mysql.config.js +1 -17
  141. package/dist/mysql.config.js.map +1 -1
  142. package/dist/mysql.exception.d.ts.map +1 -1
  143. package/dist/mysql.exception.js +48 -4
  144. package/dist/mysql.exception.js.map +1 -1
  145. package/dist/mysql.module.d.ts.map +1 -1
  146. package/dist/mysql.module.js.map +1 -1
  147. package/dist/mysql.repo.d.ts +9 -2
  148. package/dist/mysql.repo.d.ts.map +1 -1
  149. package/dist/mysql.repo.js +164 -48
  150. package/dist/mysql.repo.js.map +1 -1
  151. package/dist/mysql.service.d.ts.map +1 -1
  152. package/dist/mysql.service.js +8 -2
  153. package/dist/mysql.service.js.map +1 -1
  154. package/dist/services/index.d.ts +1 -0
  155. package/dist/services/index.d.ts.map +1 -1
  156. package/dist/services/index.js +1 -0
  157. package/dist/services/index.js.map +1 -1
  158. package/dist/services/mysql.dialect.d.ts +14 -0
  159. package/dist/services/mysql.dialect.d.ts.map +1 -0
  160. package/dist/services/mysql.dialect.js +50 -0
  161. package/dist/services/mysql.dialect.js.map +1 -0
  162. package/dist/services/mysql.strategy.d.ts +1 -1
  163. package/dist/services/mysql.strategy.d.ts.map +1 -1
  164. package/dist/services/mysql.strategy.js +1 -1
  165. package/dist/services/mysql.strategy.js.map +1 -1
  166. package/dist/tsconfig.tsbuildinfo +1 -1
  167. package/package.json +14 -10
  168. package/dist/helpers/mysql.finder.d.ts +0 -15
  169. package/dist/helpers/mysql.finder.d.ts.map +0 -1
  170. package/dist/helpers/mysql.finder.js +0 -128
  171. package/dist/helpers/mysql.finder.js.map +0 -1
@@ -0,0 +1,42 @@
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
+ const typeorm_1 = require("typeorm");
13
+ const mysql_exception_1 = require("../mysql.exception");
14
+ class QueryFailureHarness {
15
+ constructor() {
16
+ this.PinoLogger = {
17
+ setContext: jest.fn(),
18
+ };
19
+ }
20
+ async run(error) {
21
+ throw error;
22
+ }
23
+ }
24
+ __decorate([
25
+ mysql_exception_1.MysqlCatch,
26
+ __metadata("design:type", Function),
27
+ __metadata("design:paramtypes", [Error]),
28
+ __metadata("design:returntype", Promise)
29
+ ], QueryFailureHarness.prototype, "run", null);
30
+ describe('Mysql exception mapping', () => {
31
+ it('should normalize duplicate key driver errors', async () => {
32
+ const harness = new QueryFailureHarness();
33
+ const error = new typeorm_1.QueryFailedError('insert', [], { code: 'ER_DUP_ENTRY' });
34
+ await expect(harness.run(error)).rejects.toThrow('MYSQL_DUPLICATE_KEY');
35
+ });
36
+ it('should normalize postgres deadlock driver errors', async () => {
37
+ const harness = new QueryFailureHarness();
38
+ const error = new typeorm_1.QueryFailedError('update', [], { code: '40P01' });
39
+ await expect(harness.run(error)).rejects.toThrow('MYSQL_DEADLOCK');
40
+ });
41
+ });
42
+ //# sourceMappingURL=mysql.exception.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.exception.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.exception.spec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,qCAA2C;AAC3C,wDAAgD;AAEhD,MAAM,mBAAmB;IAAzB;QACE,eAAU,GAAG;YACX,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE;SACtB,CAAC;IAMJ,CAAC;IAHO,AAAN,KAAK,CAAC,GAAG,CAAC,KAAY;QACpB,MAAM,KAAK,CAAC;IACd,CAAC;CACF;AAHO;IADL,4BAAU;;qCACM,KAAK;;8CAErB;AAGH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,OAAO,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,IAAI,0BAAgB,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,cAAc,EAA8B,CAAC,CAAC;QAEvG,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,OAAO,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,IAAI,0BAAgB,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAA8B,CAAC,CAAC;QAEhG,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mysql.helper.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.helper.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.helper.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const helpers_1 = require("../helpers");
4
+ const mysql_config_1 = require("../mysql.config");
5
+ const metadata = {
6
+ name: 'TestMysqlEntity',
7
+ columns: [
8
+ { propertyName: 'id', propertyPath: 'id' },
9
+ { propertyName: 'title', propertyPath: 'title' },
10
+ { propertyName: 'createdAt', propertyPath: 'createdAt' },
11
+ ],
12
+ relations: [{ propertyName: 'author', propertyPath: 'author' }],
13
+ };
14
+ const createQueryBuilder = () => ({
15
+ alias: 'TestMysqlEntity',
16
+ andWhere: jest.fn().mockReturnThis(),
17
+ addOrderBy: jest.fn().mockReturnThis(),
18
+ select: jest.fn().mockReturnThis(),
19
+ leftJoinAndSelect: jest.fn().mockReturnThis(),
20
+ });
21
+ describe('MysqlHelper query safety', () => {
22
+ it('should reject unsafe field paths before interpolating identifiers', () => {
23
+ const qb = createQueryBuilder();
24
+ expect(() => helpers_1.MysqlHelper.applyOrder(qb, { 'title;drop': 'asc' }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_UNSAFE_FIELD_PATH');
25
+ });
26
+ it('should reject unknown columns from request query', () => {
27
+ const qb = createQueryBuilder();
28
+ expect(() => helpers_1.MysqlHelper.applyProjection(qb, ['missingColumn'], { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_UNKNOWN_COLUMN');
29
+ });
30
+ it('should reject unsupported array operators for mysql dialect', () => {
31
+ const qb = createQueryBuilder();
32
+ expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $size: 2 } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_OPERATOR_UNSUPPORTED_BY_DIALECT');
33
+ });
34
+ it('should choose postgres case-insensitive like operator and escape wildcard input', () => {
35
+ const qb = createQueryBuilder();
36
+ helpers_1.MysqlHelper.applyCondition(qb, { title: { $like: 'hello_%\\' } }, {
37
+ metadata,
38
+ dialect: mysql_config_1.Dialect.POSTGRES,
39
+ });
40
+ expect(qb.andWhere).toHaveBeenCalledWith("TestMysqlEntity.title ILIKE :title_0 ESCAPE '\\\\'", {
41
+ title_0: '%hello\\_\\%\\\\%',
42
+ });
43
+ });
44
+ it('should reject empty or non-array values for list operators', () => {
45
+ const qb = createQueryBuilder();
46
+ expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $in: [] } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_INVALID_OPERATOR_VALUE');
47
+ expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $nin: 'draft' } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_INVALID_OPERATOR_VALUE');
48
+ });
49
+ it('should respect boolean semantics for nil and exists operators', () => {
50
+ const qb = createQueryBuilder();
51
+ helpers_1.MysqlHelper.applyCondition(qb, {
52
+ title: { $nil: false },
53
+ createdAt: { $exists: false },
54
+ }, { metadata, dialect: mysql_config_1.Dialect.MYSQL });
55
+ expect(qb.andWhere).toHaveBeenCalledWith('TestMysqlEntity.title IS NOT NULL');
56
+ expect(qb.andWhere).toHaveBeenCalledWith('TestMysqlEntity.createdAt IS NULL');
57
+ });
58
+ it('should keep the root alias when building nested logical clauses', () => {
59
+ const qb = createQueryBuilder();
60
+ helpers_1.MysqlHelper.applyCondition(qb, { $or: [{ title: 'first' }, { title: 'second' }] }, {
61
+ metadata,
62
+ dialect: mysql_config_1.Dialect.MYSQL,
63
+ });
64
+ const rootBracket = qb.andWhere.mock.calls[0][0];
65
+ const childBuilder = {
66
+ andWhere: jest.fn().mockReturnThis(),
67
+ orWhere: jest.fn().mockReturnThis(),
68
+ };
69
+ rootBracket.whereFactory(childBuilder);
70
+ const firstNestedBracket = childBuilder.andWhere.mock.calls[0][0];
71
+ const grandChildBuilder = {
72
+ andWhere: jest.fn().mockReturnThis(),
73
+ };
74
+ firstNestedBracket.whereFactory(grandChildBuilder);
75
+ expect(grandChildBuilder.andWhere).toHaveBeenCalledWith('TestMysqlEntity.title = :title_0', {
76
+ title_0: 'first',
77
+ });
78
+ });
79
+ });
80
+ //# sourceMappingURL=mysql.helper.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.helper.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.helper.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mysql.module.integration.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.module.integration.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.module.integration.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,67 @@
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
+ const common_1 = require("@nestjs/common");
13
+ const testing_1 = require("@nestjs/testing");
14
+ const typeorm_1 = require("typeorm");
15
+ const core_1 = require("@joktec/core");
16
+ const models_1 = require("../models");
17
+ const mysql_client_1 = require("../mysql.client");
18
+ const mysql_module_1 = require("../mysql.module");
19
+ const mysql_service_1 = require("../mysql.service");
20
+ let TestMysqlEntity = class TestMysqlEntity extends models_1.MysqlModel {
21
+ };
22
+ __decorate([
23
+ (0, typeorm_1.PrimaryGeneratedColumn)(),
24
+ __metadata("design:type", Number)
25
+ ], TestMysqlEntity.prototype, "id", void 0);
26
+ __decorate([
27
+ (0, typeorm_1.Column)(),
28
+ __metadata("design:type", String)
29
+ ], TestMysqlEntity.prototype, "title", void 0);
30
+ TestMysqlEntity = __decorate([
31
+ (0, typeorm_1.Entity)()
32
+ ], TestMysqlEntity);
33
+ class TestMysqlSubscriber {
34
+ }
35
+ let TestSupportModule = class TestSupportModule {
36
+ };
37
+ TestSupportModule = __decorate([
38
+ (0, common_1.Global)(),
39
+ (0, common_1.Module)({
40
+ providers: [
41
+ { provide: core_1.ConfigService, useValue: { get: jest.fn() } },
42
+ { provide: core_1.LogService, useValue: { setContext: jest.fn(), info: jest.fn(), warn: jest.fn(), error: jest.fn() } },
43
+ ],
44
+ exports: [core_1.ConfigService, core_1.LogService],
45
+ })
46
+ ], TestSupportModule);
47
+ describe('MysqlModule integration', () => {
48
+ it('should compile MysqlModule.forRoot and expose model/subscriber registries', async () => {
49
+ const moduleRef = await testing_1.Test.createTestingModule({
50
+ imports: [
51
+ TestSupportModule,
52
+ mysql_module_1.MysqlModule.forRoot({
53
+ conId: 'reporting',
54
+ models: [TestMysqlEntity],
55
+ subscribers: [TestMysqlSubscriber],
56
+ }),
57
+ ],
58
+ }).compile();
59
+ expect(moduleRef.get(mysql_service_1.MysqlService)).toBeDefined();
60
+ expect(moduleRef.get(mysql_client_1.MODEL_REGISTRY_KEY, { strict: false })).toEqual({ reporting: [TestMysqlEntity] });
61
+ expect(moduleRef.get(mysql_client_1.SUBSCRIBER_REGISTRY_KEY, { strict: false })).toEqual({
62
+ reporting: [TestMysqlSubscriber],
63
+ });
64
+ await moduleRef.close();
65
+ });
66
+ });
67
+ //# sourceMappingURL=mysql.module.integration.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.module.integration.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.module.integration.spec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,2CAAgD;AAChD,6CAAuC;AACvC,qCAA2G;AAC3G,uCAAyD;AACzD,sCAAuC;AACvC,kDAA8E;AAC9E,kDAA8C;AAC9C,oDAAgD;AAGhD,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,mBAAU;CAMvC,CAAA;AAJC;IADC,IAAA,gCAAsB,GAAE;;2CACb;AAGZ;IADC,IAAA,gBAAM,GAAE;;8CACM;AALX,eAAe;IADpB,IAAA,gBAAW,GAAE;GACR,eAAe,CAMpB;AAED,MAAM,mBAAmB;CAAyD;AAUlF,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,iBAAiB;IARtB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,SAAS,EAAE;YACT,EAAE,OAAO,EAAE,oBAAa,EAAE,QAAQ,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE;YACxD,EAAE,OAAO,EAAE,iBAAU,EAAE,QAAQ,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE;SACjH;QACD,OAAO,EAAE,CAAC,oBAAa,EAAE,iBAAU,CAAC;KACrC,CAAC;GACI,iBAAiB,CAAG;AAE1B,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,2EAA2E,EAAE,KAAK,IAAI,EAAE;QACzF,MAAM,SAAS,GAAG,MAAM,cAAI,CAAC,mBAAmB,CAAC;YAC/C,OAAO,EAAE;gBACP,iBAAiB;gBACjB,0BAAW,CAAC,OAAO,CAAC;oBAClB,KAAK,EAAE,WAAW;oBAClB,MAAM,EAAE,CAAC,eAAe,CAAC;oBACzB,WAAW,EAAE,CAAC,mBAAmB,CAAC;iBACnC,CAAC;aACH;SACF,CAAC,CAAC,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,4BAAY,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,iCAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QACvG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,sCAAuB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACxE,SAAS,EAAE,CAAC,mBAAmB,CAAC;SACjC,CAAC,CAAC;QAEH,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mysql.repo.cursor.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.repo.cursor.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.repo.cursor.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,146 @@
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
+ const core_1 = require("@joktec/core");
13
+ const typeorm_1 = require("typeorm");
14
+ const mysql_config_1 = require("../mysql.config");
15
+ const models_1 = require("../models");
16
+ const mysql_repo_1 = require("../mysql.repo");
17
+ let TestMysqlEntity = class TestMysqlEntity extends models_1.MysqlModel {
18
+ };
19
+ __decorate([
20
+ (0, typeorm_1.PrimaryGeneratedColumn)(),
21
+ __metadata("design:type", Number)
22
+ ], TestMysqlEntity.prototype, "id", void 0);
23
+ __decorate([
24
+ (0, typeorm_1.Column)(),
25
+ __metadata("design:type", String)
26
+ ], TestMysqlEntity.prototype, "title", void 0);
27
+ TestMysqlEntity = __decorate([
28
+ (0, typeorm_1.Entity)()
29
+ ], TestMysqlEntity);
30
+ class TestMysqlRepo extends mysql_repo_1.MysqlRepo {
31
+ constructor(mysqlService) {
32
+ super(mysqlService, TestMysqlEntity);
33
+ }
34
+ }
35
+ const createQueryBuilder = (items) => {
36
+ const qb = {
37
+ alias: TestMysqlEntity.name,
38
+ addOrderBy: jest.fn().mockReturnThis(),
39
+ andWhere: jest.fn().mockReturnThis(),
40
+ setParameter: jest.fn().mockReturnThis(),
41
+ take: jest.fn().mockReturnThis(),
42
+ withDeleted: jest.fn().mockReturnThis(),
43
+ comment: jest.fn().mockReturnThis(),
44
+ cache: jest.fn().mockReturnThis(),
45
+ getMany: jest.fn().mockResolvedValue(items),
46
+ getCount: jest.fn().mockResolvedValue(3),
47
+ getOne: jest.fn().mockResolvedValue(items[0] || null),
48
+ };
49
+ return qb;
50
+ };
51
+ const createTypeormRepository = (qb) => ({
52
+ metadata: {
53
+ primaryColumns: [{ propertyName: 'id' }],
54
+ deleteDateColumn: { propertyName: 'deletedAt' },
55
+ columns: [
56
+ { propertyName: 'id', propertyPath: 'id' },
57
+ { propertyName: 'title', propertyPath: 'title' },
58
+ { propertyName: 'createdAt', propertyPath: 'createdAt' },
59
+ ],
60
+ relations: [],
61
+ },
62
+ createQueryBuilder: jest.fn().mockReturnValue(qb),
63
+ softRemove: jest.fn(async (entity) => entity),
64
+ remove: jest.fn(async (entity) => entity),
65
+ });
66
+ const createCompositeTypeormRepository = (qb) => ({
67
+ ...createTypeormRepository(qb),
68
+ metadata: {
69
+ ...createTypeormRepository(qb).metadata,
70
+ primaryColumns: [{ propertyName: 'tenantId' }, { propertyName: 'id' }],
71
+ columns: [
72
+ { propertyName: 'tenantId', propertyPath: 'tenantId' },
73
+ { propertyName: 'id', propertyPath: 'id' },
74
+ { propertyName: 'title', propertyPath: 'title' },
75
+ { propertyName: 'createdAt', propertyPath: 'createdAt' },
76
+ ],
77
+ },
78
+ });
79
+ const createMysqlService = (repository) => ({
80
+ getRepository: jest.fn().mockReturnValue(repository),
81
+ getConfig: jest.fn().mockReturnValue({ dialect: mysql_config_1.Dialect.MYSQL }),
82
+ });
83
+ const attachDecoratorServices = (repo) => {
84
+ Object.assign(repo, {
85
+ PinoLogger: { setContext: jest.fn() },
86
+ ConfigService: {},
87
+ });
88
+ return repo;
89
+ };
90
+ describe('MysqlRepo cursor pagination', () => {
91
+ it('should build a cursor query using requested cursor key and stable tie breaker', async () => {
92
+ const rawItems = [
93
+ { id: 1, title: 'first', createdAt: new Date('2026-01-01T00:00:00.000Z') },
94
+ { id: 2, title: 'second', createdAt: new Date('2026-01-02T00:00:00.000Z') },
95
+ { id: 3, title: 'third', createdAt: new Date('2026-01-03T00:00:00.000Z') },
96
+ ];
97
+ const qb = createQueryBuilder(rawItems);
98
+ const repository = createTypeormRepository(qb);
99
+ const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
100
+ const result = await repo.paginate({
101
+ cursorKey: 'createdAt',
102
+ limit: 2,
103
+ sort: { createdAt: 'desc' },
104
+ });
105
+ expect(repository.createQueryBuilder).toHaveBeenCalledWith(TestMysqlEntity.name);
106
+ expect(qb.addOrderBy).toHaveBeenCalledWith(`${TestMysqlEntity.name}.createdAt`, 'DESC');
107
+ expect(qb.addOrderBy).toHaveBeenCalledWith(`${TestMysqlEntity.name}.id`, 'DESC');
108
+ expect(qb.take).toHaveBeenCalledWith(3);
109
+ expect(result.items).toHaveLength(2);
110
+ expect(result.total).toBe(3);
111
+ expect(result.hasNextPage).toBe(true);
112
+ expect(result.nextCursor).toEqual(expect.any(String));
113
+ const cursor = core_1.CursorPagination.resolve({ cursor: result.nextCursor, defaultKeys: ['id'] });
114
+ expect(cursor.keys).toEqual(['createdAt', 'id']);
115
+ expect(cursor.values).toEqual([rawItems[1].createdAt, rawItems[1].id]);
116
+ });
117
+ it('should reject unsafe cursor field names before building SQL', async () => {
118
+ const qb = createQueryBuilder([]);
119
+ const repository = createTypeormRepository(qb);
120
+ const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
121
+ await expect(repo.paginate({ cursorKey: 'createdAt;drop' })).rejects.toThrow('MYSQL_INVALID_CURSOR');
122
+ });
123
+ it('should reject cursor keys that are not mapped columns', async () => {
124
+ const qb = createQueryBuilder([]);
125
+ const repository = createTypeormRepository(qb);
126
+ const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
127
+ await expect(repo.paginate({ cursorKey: 'missingColumn' })).rejects.toThrow('MYSQL_UNKNOWN_COLUMN');
128
+ });
129
+ it('should reject scalar id lookup for entities with composite primary keys', async () => {
130
+ const qb = createQueryBuilder([]);
131
+ const repository = createCompositeTypeormRepository(qb);
132
+ const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
133
+ await expect(repo.findOne(1)).rejects.toThrow('MYSQL_COMPOSITE_PRIMARY_KEY_REQUIRES_CONDITION');
134
+ });
135
+ it('should call repository softRemove without losing repository context', async () => {
136
+ const entity = { id: 1, title: 'delete me' };
137
+ const qb = createQueryBuilder([]);
138
+ const repository = createTypeormRepository(qb);
139
+ const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
140
+ jest.spyOn(repo, 'findOne').mockResolvedValue(entity);
141
+ const result = await repo.delete(entity.id);
142
+ expect(repository.softRemove).toHaveBeenCalledWith(entity, {});
143
+ expect(result).toEqual(entity);
144
+ });
145
+ });
146
+ //# sourceMappingURL=mysql.repo.cursor.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.repo.cursor.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.repo.cursor.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mysql.service.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.service.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.service.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const core_1 = require("@joktec/core");
4
+ const mysql_config_1 = require("../mysql.config");
5
+ const mysql_service_1 = require("../mysql.service");
6
+ class TestMysqlService extends mysql_service_1.MysqlService {
7
+ constructor() {
8
+ super({ [core_1.DEFAULT_CON_ID]: [] }, { [core_1.DEFAULT_CON_ID]: [] });
9
+ const logService = {
10
+ debug: jest.fn(),
11
+ error: jest.fn(),
12
+ info: jest.fn(),
13
+ warn: jest.fn(),
14
+ setContext: jest.fn(),
15
+ };
16
+ Object.assign(this, {
17
+ PinoLogger: logService,
18
+ logService,
19
+ });
20
+ }
21
+ setConfig(config) {
22
+ this.configs = {
23
+ [config.conId || core_1.DEFAULT_CON_ID]: new mysql_config_1.MysqlConfig({
24
+ conId: core_1.DEFAULT_CON_ID,
25
+ dialect: mysql_config_1.Dialect.MYSQL,
26
+ username: 'root',
27
+ password: 'root',
28
+ database: 'joktec',
29
+ ...config,
30
+ }),
31
+ };
32
+ }
33
+ startForTest(client, conId = core_1.DEFAULT_CON_ID) {
34
+ return this.start(client, conId);
35
+ }
36
+ stopForTest(client, conId = core_1.DEFAULT_CON_ID) {
37
+ return this.stop(client, conId);
38
+ }
39
+ }
40
+ const createDataSource = (props = {}) => ({
41
+ isInitialized: false,
42
+ initialize: jest.fn().mockResolvedValue(undefined),
43
+ synchronize: jest.fn().mockResolvedValue(undefined),
44
+ destroy: jest.fn().mockResolvedValue(undefined),
45
+ ...props,
46
+ });
47
+ describe('MysqlService lifecycle', () => {
48
+ it('should throw when datasource initialization fails', async () => {
49
+ const service = new TestMysqlService();
50
+ service.setConfig({});
51
+ const error = new Error('connect failed');
52
+ const client = createDataSource({ initialize: jest.fn().mockRejectedValue(error) });
53
+ await expect(service.startForTest(client)).rejects.toThrow('connect failed');
54
+ });
55
+ it('should synchronize only when sync is explicitly enabled', async () => {
56
+ const service = new TestMysqlService();
57
+ service.setConfig({ sync: true });
58
+ const client = createDataSource();
59
+ await service.startForTest(client);
60
+ expect(client.initialize).toHaveBeenCalled();
61
+ expect(client.synchronize).toHaveBeenCalledWith(false);
62
+ });
63
+ it('should not destroy an uninitialized datasource', async () => {
64
+ const service = new TestMysqlService();
65
+ const client = createDataSource({ isInitialized: false });
66
+ await service.stopForTest(client);
67
+ expect(client.destroy).not.toHaveBeenCalled();
68
+ });
69
+ });
70
+ //# sourceMappingURL=mysql.service.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.service.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.service.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=mysql.utils.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.utils.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.utils.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const helpers_1 = require("../helpers");
4
+ describe('Mysql SQL utils', () => {
5
+ it('should quote and escape positional SQL parameters', () => {
6
+ const sql = (0, helpers_1.printSql)('select * from users where name = ? and active = ? and meta = ?', [
7
+ "O'Reilly",
8
+ true,
9
+ { role: 'admin' },
10
+ ]);
11
+ expect(sql).toBe("select * from users where name = 'O''Reilly' and active = TRUE and meta = '{\"role\":\"admin\"}'");
12
+ });
13
+ it('should replace postgres-style numbered parameters', () => {
14
+ const sql = (0, helpers_1.printSql)('select * from users where id = $1 and created_at > $2', [
15
+ 10,
16
+ new Date('2026-01-01T00:00:00.000Z'),
17
+ ]);
18
+ expect(sql).toBe("select * from users where id = 10 and created_at > '2026-01-01T00:00:00.000Z'");
19
+ });
20
+ });
21
+ //# sourceMappingURL=mysql.utils.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.utils.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.utils.spec.ts"],"names":[],"mappings":";;AAAA,wCAAsC;AAEtC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,GAAG,GAAG,IAAA,kBAAQ,EAAC,gEAAgE,EAAE;YACrF,UAAU;YACV,IAAI;YACJ,EAAE,IAAI,EAAE,OAAO,EAAE;SAClB,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CACd,kGAAkG,CACnG,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,GAAG,GAAG,IAAA,kBAAQ,EAAC,uDAAuD,EAAE;YAC5E,EAAE;YACF,IAAI,IAAI,CAAC,0BAA0B,CAAC;SACrC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,+EAA+E,CAAC,CAAC;IACpG,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { ColumnType } from 'typeorm';
2
+ import { IMysqlColumnOptions, IMysqlPrimaryColumnOptions, MysqlFieldDecorator, PrimaryColumnStrategy } from './columns';
3
+ export declare function Column(): MysqlFieldDecorator;
4
+ export declare function Column(options: IMysqlColumnOptions): MysqlFieldDecorator;
5
+ export declare function Column(type: ColumnType, options?: IMysqlColumnOptions): MysqlFieldDecorator;
6
+ export declare function PrimaryColumn(): PropertyDecorator;
7
+ export declare function PrimaryColumn(strategy: PrimaryColumnStrategy, options?: IMysqlPrimaryColumnOptions): PropertyDecorator;
8
+ export declare function PrimaryColumn(options: IMysqlPrimaryColumnOptions): PropertyDecorator;
9
+ export declare const PrimaryGeneratedColumn: typeof PrimaryColumn;
10
+ //# sourceMappingURL=column.decorator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/column.decorator.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,UAAU,EAcX,MAAM,SAAS,CAAC;AAEjB,OAAO,EAIL,mBAAmB,EACnB,0BAA0B,EAQ1B,mBAAmB,EACnB,qBAAqB,EAWtB,MAAM,WAAW,CAAC;AAcnB,wBAAgB,MAAM,IAAI,mBAAmB,CAAC;AAC9C,wBAAgB,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,mBAAmB,CAAC;AAC1E,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,mBAAmB,CAAC;AAmM7F,wBAAgB,aAAa,IAAI,iBAAiB,CAAC;AACnD,wBAAgB,aAAa,CAAC,QAAQ,EAAE,qBAAqB,EAAE,OAAO,CAAC,EAAE,0BAA0B,GAAG,iBAAiB,CAAC;AACxH,wBAAgB,aAAa,CAAC,OAAO,EAAE,0BAA0B,GAAG,iBAAiB,CAAC;AAsCtF,eAAO,MAAM,sBAAsB,sBAAgB,CAAC"}