@joktec/mysql 0.2.12 → 0.2.14

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 (147) hide show
  1. package/README.md +211 -81
  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 +60 -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 +28 -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 +11 -0
  35. package/dist/decorators/column.decorator.d.ts.map +1 -0
  36. package/dist/decorators/column.decorator.js +35 -0
  37. package/dist/decorators/column.decorator.js.map +1 -0
  38. package/dist/decorators/columns/array.column.d.ts +2 -0
  39. package/dist/decorators/columns/array.column.d.ts.map +1 -0
  40. package/dist/decorators/columns/array.column.js +8 -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 +40 -0
  49. package/dist/decorators/columns/column.factory.js.map +1 -0
  50. package/dist/decorators/columns/column.type.d.ts +33 -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 +15 -0
  55. package/dist/decorators/columns/column.util.d.ts.map +1 -0
  56. package/dist/decorators/columns/column.util.js +82 -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 +14 -0
  67. package/dist/decorators/columns/index.d.ts.map +1 -0
  68. package/dist/decorators/columns/index.js +30 -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 +15 -0
  77. package/dist/decorators/columns/number.column.js.map +1 -0
  78. package/dist/decorators/columns/primary.column.d.ts +3 -0
  79. package/dist/decorators/columns/primary.column.d.ts.map +1 -0
  80. package/dist/decorators/columns/primary.column.js +48 -0
  81. package/dist/decorators/columns/primary.column.js.map +1 -0
  82. package/dist/decorators/columns/string.column.d.ts +3 -0
  83. package/dist/decorators/columns/string.column.d.ts.map +1 -0
  84. package/dist/decorators/columns/string.column.js +25 -0
  85. package/dist/decorators/columns/string.column.js.map +1 -0
  86. package/dist/decorators/columns/swagger.column.d.ts +4 -0
  87. package/dist/decorators/columns/swagger.column.d.ts.map +1 -0
  88. package/dist/decorators/columns/swagger.column.js +40 -0
  89. package/dist/decorators/columns/swagger.column.js.map +1 -0
  90. package/dist/decorators/columns/transform.column.d.ts +4 -0
  91. package/dist/decorators/columns/transform.column.d.ts.map +1 -0
  92. package/dist/decorators/columns/transform.column.js +15 -0
  93. package/dist/decorators/columns/transform.column.js.map +1 -0
  94. package/dist/decorators/index.d.ts +1 -0
  95. package/dist/decorators/index.d.ts.map +1 -1
  96. package/dist/decorators/index.js +1 -0
  97. package/dist/decorators/index.js.map +1 -1
  98. package/dist/decorators/table.decorator.d.ts.map +1 -1
  99. package/dist/decorators/table.decorator.js +18 -12
  100. package/dist/decorators/table.decorator.js.map +1 -1
  101. package/dist/helpers/mysql.finder.d.ts.map +1 -1
  102. package/dist/helpers/mysql.finder.js.map +1 -1
  103. package/dist/helpers/mysql.helper.d.ts +21 -6
  104. package/dist/helpers/mysql.helper.d.ts.map +1 -1
  105. package/dist/helpers/mysql.helper.js +152 -82
  106. package/dist/helpers/mysql.helper.js.map +1 -1
  107. package/dist/helpers/mysql.utils.d.ts.map +1 -1
  108. package/dist/helpers/mysql.utils.js +28 -11
  109. package/dist/helpers/mysql.utils.js.map +1 -1
  110. package/dist/index.d.ts +1 -0
  111. package/dist/index.d.ts.map +1 -1
  112. package/dist/index.js +5 -0
  113. package/dist/index.js.map +1 -1
  114. package/dist/models/mysql.model.d.ts.map +1 -1
  115. package/dist/models/mysql.model.js.map +1 -1
  116. package/dist/models/mysql.option.d.ts +11 -2
  117. package/dist/models/mysql.option.d.ts.map +1 -1
  118. package/dist/mysql.config.d.ts +1 -17
  119. package/dist/mysql.config.d.ts.map +1 -1
  120. package/dist/mysql.config.js +1 -17
  121. package/dist/mysql.config.js.map +1 -1
  122. package/dist/mysql.exception.d.ts.map +1 -1
  123. package/dist/mysql.exception.js +48 -4
  124. package/dist/mysql.exception.js.map +1 -1
  125. package/dist/mysql.module.d.ts.map +1 -1
  126. package/dist/mysql.module.js.map +1 -1
  127. package/dist/mysql.repo.d.ts +8 -0
  128. package/dist/mysql.repo.d.ts.map +1 -1
  129. package/dist/mysql.repo.js +164 -33
  130. package/dist/mysql.repo.js.map +1 -1
  131. package/dist/mysql.service.d.ts.map +1 -1
  132. package/dist/mysql.service.js +8 -2
  133. package/dist/mysql.service.js.map +1 -1
  134. package/dist/services/index.d.ts +1 -0
  135. package/dist/services/index.d.ts.map +1 -1
  136. package/dist/services/index.js +1 -0
  137. package/dist/services/index.js.map +1 -1
  138. package/dist/services/mysql.dialect.d.ts +14 -0
  139. package/dist/services/mysql.dialect.d.ts.map +1 -0
  140. package/dist/services/mysql.dialect.js +50 -0
  141. package/dist/services/mysql.dialect.js.map +1 -0
  142. package/dist/services/mysql.strategy.d.ts +1 -1
  143. package/dist/services/mysql.strategy.d.ts.map +1 -1
  144. package/dist/services/mysql.strategy.js +1 -1
  145. package/dist/services/mysql.strategy.js.map +1 -1
  146. package/dist/tsconfig.tsbuildinfo +1 -1
  147. package/package.json +14 -10
@@ -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,11 @@
1
+ import { ColumnType } from 'typeorm';
2
+ import { IMysqlColumnOptions, IMysqlPrimaryColumnOptions, PrimaryColumnStrategy } from './columns';
3
+ export { ColumnDecoratorArgs, IMysqlColumnOptions, IMysqlPrimaryColumnOptions, PrimaryColumnStrategy, RequiredOption, } from './columns';
4
+ export declare function Column(): PropertyDecorator;
5
+ export declare function Column(options: IMysqlColumnOptions): PropertyDecorator;
6
+ export declare function Column(type: ColumnType, options?: IMysqlColumnOptions): PropertyDecorator;
7
+ export declare function PrimaryColumn(): PropertyDecorator;
8
+ export declare function PrimaryColumn(strategy: PrimaryColumnStrategy, options?: IMysqlPrimaryColumnOptions): PropertyDecorator;
9
+ export declare function PrimaryColumn(options: IMysqlPrimaryColumnOptions): PropertyDecorator;
10
+ export declare const PrimaryGeneratedColumn: typeof PrimaryColumn;
11
+ //# 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":"AAAA,OAAO,EAA2B,UAAU,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,EAEL,mBAAmB,EACnB,0BAA0B,EAC1B,qBAAqB,EAOtB,MAAM,WAAW,CAAC;AAEnB,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,0BAA0B,EAC1B,qBAAqB,EACrB,cAAc,GACf,MAAM,WAAW,CAAC;AAKnB,wBAAgB,MAAM,IAAI,iBAAiB,CAAC;AAC5C,wBAAgB,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,iBAAiB,CAAC;AACxE,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,iBAAiB,CAAC;AAe3F,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;AA0BtF,eAAO,MAAM,sBAAsB,sBAAgB,CAAC"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PrimaryGeneratedColumn = void 0;
4
+ exports.Column = Column;
5
+ exports.PrimaryColumn = PrimaryColumn;
6
+ const typeorm_1 = require("typeorm");
7
+ const columns_1 = require("./columns");
8
+ function Column(...args) {
9
+ const { type, options } = (0, columns_1.parseColumnArgs)(args);
10
+ return (target, propertyKey) => {
11
+ const designType = Reflect.getMetadata('design:type', target, propertyKey);
12
+ const typeormOptions = (0, columns_1.toTypeormOptions)(options);
13
+ const typeormDecorator = type ? typeorm_1.Column(type, typeormOptions) : (0, typeorm_1.Column)(typeormOptions);
14
+ (0, columns_1.applyPropertyDecorators)(target, propertyKey, [typeormDecorator, ...(0, columns_1.buildColumnDecorators)(options, designType)]);
15
+ };
16
+ }
17
+ function PrimaryColumn(strategyOrOptions = 'increment', options = {}) {
18
+ return (target, propertyKey) => {
19
+ const designType = Reflect.getMetadata('design:type', target, propertyKey);
20
+ const strategy = typeof strategyOrOptions === 'string' ? strategyOrOptions : 'increment';
21
+ const primaryOptions = (0, columns_1.cloneColumnOptions)(typeof strategyOrOptions === 'string' ? options : strategyOrOptions);
22
+ const primaryDecorator = (0, columns_1.buildPrimaryDecorator)(strategy, primaryOptions, target, propertyKey);
23
+ (0, columns_1.applyPropertyDecorators)(target, propertyKey, [
24
+ primaryDecorator,
25
+ ...(0, columns_1.buildColumnDecorators)({
26
+ ...primaryOptions,
27
+ nullable: false,
28
+ required: primaryOptions.required ?? false,
29
+ swagger: { readOnly: true, ...primaryOptions.swagger },
30
+ }, designType),
31
+ ]);
32
+ };
33
+ }
34
+ exports.PrimaryGeneratedColumn = PrimaryColumn;
35
+ //# sourceMappingURL=column.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.decorator.js","sourceRoot":"","sources":["../../src/decorators/column.decorator.ts"],"names":[],"mappings":";;;AA4BA,wBASC;AAQD,sCAuBC;AApED,qCAA8D;AAC9D,uCAWmB;AAgBnB,SAAgB,MAAM,CAAC,GAAG,IAAyB;IACjD,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAA,yBAAe,EAAC,IAAI,CAAC,CAAC;IAChD,OAAO,CAAC,MAAc,EAAE,WAA4B,EAAE,EAAE;QACtD,MAAM,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,aAAa,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAC3E,MAAM,cAAc,GAAG,IAAA,0BAAgB,EAAC,OAAO,CAAC,CAAC;QACjD,MAAM,gBAAgB,GAAG,IAAI,CAAC,CAAC,CAAE,gBAAqB,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAA,gBAAa,EAAC,cAAc,CAAC,CAAC;QAE7G,IAAA,iCAAuB,EAAC,MAAM,EAAE,WAAW,EAAE,CAAC,gBAAgB,EAAE,GAAG,IAAA,+BAAqB,EAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;IAClH,CAAC,CAAC;AACJ,CAAC;AAQD,SAAgB,aAAa,CAC3B,oBAAwE,WAAW,EACnF,UAAsC,EAAE;IAExC,OAAO,CAAC,MAAc,EAAE,WAA4B,EAAE,EAAE;QACtD,MAAM,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,aAAa,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAC3E,MAAM,QAAQ,GAAG,OAAO,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,WAAW,CAAC;QACzF,MAAM,cAAc,GAAG,IAAA,4BAAkB,EAAC,OAAO,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC;QAC/G,MAAM,gBAAgB,GAAG,IAAA,+BAAqB,EAAC,QAAQ,EAAE,cAAc,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAE9F,IAAA,iCAAuB,EAAC,MAAM,EAAE,WAAW,EAAE;YAC3C,gBAAgB;YAChB,GAAG,IAAA,+BAAqB,EACtB;gBACE,GAAG,cAAc;gBACjB,QAAQ,EAAE,KAAK;gBACf,QAAQ,EAAE,cAAc,CAAC,QAAQ,IAAI,KAAK;gBAC1C,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,cAAc,CAAC,OAAO,EAAE;aACvD,EACD,UAAU,CACX;SACF,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAEY,QAAA,sBAAsB,GAAG,aAAa,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function ArrayColumn(): PropertyDecorator[];
2
+ //# sourceMappingURL=array.column.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"array.column.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/array.column.ts"],"names":[],"mappings":"AAEA,wBAAgB,WAAW,IAAI,iBAAiB,EAAE,CAEjD"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ArrayColumn = ArrayColumn;
4
+ const utils_1 = require("@joktec/utils");
5
+ function ArrayColumn() {
6
+ return [(0, utils_1.IsArray)()];
7
+ }
8
+ //# sourceMappingURL=array.column.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"array.column.js","sourceRoot":"","sources":["../../../src/decorators/columns/array.column.ts"],"names":[],"mappings":";;AAEA,kCAEC;AAJD,yCAAwC;AAExC,SAAgB,WAAW;IACzB,OAAO,CAAC,IAAA,eAAO,GAAE,CAAC,CAAC;AACrB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function BoolColumn(): PropertyDecorator[];
2
+ //# sourceMappingURL=bool.column.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bool.column.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/bool.column.ts"],"names":[],"mappings":"AAEA,wBAAgB,UAAU,IAAI,iBAAiB,EAAE,CAEhD"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BoolColumn = BoolColumn;
4
+ const utils_1 = require("@joktec/utils");
5
+ function BoolColumn() {
6
+ return [(0, utils_1.IsBoolean)()];
7
+ }
8
+ //# sourceMappingURL=bool.column.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bool.column.js","sourceRoot":"","sources":["../../../src/decorators/columns/bool.column.ts"],"names":[],"mappings":";;AAEA,gCAEC;AAJD,yCAA0C;AAE1C,SAAgB,UAAU;IACxB,OAAO,CAAC,IAAA,iBAAS,GAAE,CAAC,CAAC;AACvB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { Constructor } from '@joktec/core';
2
+ import { IMysqlColumnOptions } from './column.type';
3
+ export declare function buildValidationDecorators(options: IMysqlColumnOptions, designType: Constructor<any>): PropertyDecorator[];
4
+ export declare function buildColumnDecorators(options: IMysqlColumnOptions, designType: Constructor<any>): PropertyDecorator[];
5
+ //# sourceMappingURL=column.factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.factory.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/column.factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAI3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAYpD,wBAAgB,yBAAyB,CACvC,OAAO,EAAE,mBAAmB,EAC5B,UAAU,EAAE,WAAW,CAAC,GAAG,CAAC,GAC3B,iBAAiB,EAAE,CAiBrB;AAKD,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,mBAAmB,EAAE,UAAU,EAAE,WAAW,CAAC,GAAG,CAAC,GAAG,iBAAiB,EAAE,CAGrH"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.buildValidationDecorators = buildValidationDecorators;
4
+ exports.buildColumnDecorators = buildColumnDecorators;
5
+ const utils_1 = require("@joktec/utils");
6
+ const array_column_1 = require("./array.column");
7
+ const bool_column_1 = require("./bool.column");
8
+ const column_util_1 = require("./column.util");
9
+ const date_column_1 = require("./date.column");
10
+ const enum_column_1 = require("./enum.column");
11
+ const nested_column_1 = require("./nested.column");
12
+ const number_column_1 = require("./number.column");
13
+ const string_column_1 = require("./string.column");
14
+ const transform_column_1 = require("./transform.column");
15
+ function buildValidationDecorators(options, designType) {
16
+ const decorators = [...(options.decorators || [])];
17
+ const required = (0, column_util_1.resolveRequired)(options);
18
+ if (required.required)
19
+ decorators.push((0, utils_1.IsNotEmpty)(required.message ? { message: required.message } : undefined));
20
+ else
21
+ decorators.push((0, utils_1.IsOptional)());
22
+ if (designType === String)
23
+ decorators.push(...(0, string_column_1.StringColumn)(options));
24
+ if (designType === Number)
25
+ decorators.push(...(0, number_column_1.NumberColumn)(options));
26
+ if (designType === Boolean)
27
+ decorators.push(...(0, bool_column_1.BoolColumn)());
28
+ if (designType === Date)
29
+ decorators.push(...(0, date_column_1.DateColumn)());
30
+ if (designType === Array)
31
+ decorators.push(...(0, array_column_1.ArrayColumn)());
32
+ decorators.push(...(0, enum_column_1.EnumColumn)(options));
33
+ decorators.push(...(0, nested_column_1.NestedColumn)(options, designType));
34
+ return decorators;
35
+ }
36
+ function buildColumnDecorators(options, designType) {
37
+ const { required } = (0, column_util_1.resolveRequired)(options);
38
+ return [...buildValidationDecorators(options, designType), ...(0, transform_column_1.TransformColumn)(options, designType, required)];
39
+ }
40
+ //# sourceMappingURL=column.factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.factory.js","sourceRoot":"","sources":["../../../src/decorators/columns/column.factory.ts"],"names":[],"mappings":";;AAgBA,8DAoBC;AAKD,sDAGC;AA3CD,yCAAuD;AACvD,iDAA6C;AAC7C,+CAA2C;AAE3C,+CAAgD;AAChD,+CAA2C;AAC3C,+CAA2C;AAC3C,mDAA+C;AAC/C,mDAA+C;AAC/C,mDAA+C;AAC/C,yDAAqD;AAKrD,SAAgB,yBAAyB,CACvC,OAA4B,EAC5B,UAA4B;IAE5B,MAAM,UAAU,GAAwB,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,CAAC;IACxE,MAAM,QAAQ,GAAG,IAAA,6BAAe,EAAC,OAAO,CAAC,CAAC;IAE1C,IAAI,QAAQ,CAAC,QAAQ;QAAE,UAAU,CAAC,IAAI,CAAC,IAAA,kBAAU,EAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;;QAC5G,UAAU,CAAC,IAAI,CAAC,IAAA,kBAAU,GAAE,CAAC,CAAC;IAEnC,IAAI,UAAU,KAAK,MAAM;QAAE,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,4BAAY,EAAC,OAAO,CAAC,CAAC,CAAC;IACrE,IAAI,UAAU,KAAK,MAAM;QAAE,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,4BAAY,EAAC,OAAO,CAAC,CAAC,CAAC;IACrE,IAAI,UAAU,KAAK,OAAO;QAAE,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,wBAAU,GAAE,CAAC,CAAC;IAC7D,IAAI,UAAU,KAAK,IAAI;QAAE,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,wBAAU,GAAE,CAAC,CAAC;IAC1D,IAAI,UAAU,KAAK,KAAK;QAAE,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,0BAAW,GAAE,CAAC,CAAC;IAE5D,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,wBAAU,EAAC,OAAO,CAAC,CAAC,CAAC;IACxC,UAAU,CAAC,IAAI,CAAC,GAAG,IAAA,4BAAY,EAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;IAEtD,OAAO,UAAU,CAAC;AACpB,CAAC;AAKD,SAAgB,qBAAqB,CAAC,OAA4B,EAAE,UAA4B;IAC9F,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAA,6BAAe,EAAC,OAAO,CAAC,CAAC;IAC9C,OAAO,CAAC,GAAG,yBAAyB,CAAC,OAAO,EAAE,UAAU,CAAC,EAAE,GAAG,IAAA,kCAAe,EAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;AAChH,CAAC"}
@@ -0,0 +1,33 @@
1
+ import { ApiPropertyOptions, Constructor } from '@joktec/core';
2
+ import { ColumnOptions, ColumnType } from 'typeorm';
3
+ export type RequiredOption = boolean | [boolean, string];
4
+ export type PrimaryColumnStrategy = 'increment' | 'uuid' | 'uuidv7' | 'rowid' | 'identity';
5
+ export interface IMysqlColumnOptions extends ColumnOptions {
6
+ hidden?: boolean;
7
+ nested?: boolean | Constructor<any>;
8
+ example?: any;
9
+ deprecated?: boolean;
10
+ groups?: string[];
11
+ decorators?: PropertyDecorator[];
12
+ swagger?: ApiPropertyOptions;
13
+ required?: RequiredOption;
14
+ isEmail?: boolean;
15
+ isPhone?: boolean;
16
+ isHexColor?: boolean;
17
+ isUrl?: boolean;
18
+ minlength?: number;
19
+ maxlength?: number;
20
+ minLength?: number;
21
+ maxLength?: number;
22
+ min?: number;
23
+ max?: number;
24
+ }
25
+ export interface IMysqlPrimaryColumnOptions extends Omit<IMysqlColumnOptions, 'primary' | 'nullable'> {
26
+ nullable?: false;
27
+ }
28
+ export type ColumnDecoratorArgs = [IMysqlColumnOptions?] | [ColumnType, IMysqlColumnOptions?];
29
+ export interface RequiredResult {
30
+ required: boolean;
31
+ message?: string;
32
+ }
33
+ //# sourceMappingURL=column.type.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.type.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/column.type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAEpD,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;AACzD,MAAM,MAAM,qBAAqB,GAAG,WAAW,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,CAAC;AAE3F,MAAM,WAAW,mBAAoB,SAAQ,aAAa;IACxD,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC;IACpC,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,UAAU,CAAC,EAAE,iBAAiB,EAAE,CAAC;IACjC,OAAO,CAAC,EAAE,kBAAkB,CAAC;IAC7B,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,0BAA2B,SAAQ,IAAI,CAAC,mBAAmB,EAAE,SAAS,GAAG,UAAU,CAAC;IACnG,QAAQ,CAAC,EAAE,KAAK,CAAC;CAClB;AAED,MAAM,MAAM,mBAAmB,GAAG,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,mBAAmB,CAAC,CAAC,CAAC;AAE9F,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=column.type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.type.js","sourceRoot":"","sources":["../../../src/decorators/columns/column.type.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import { Constructor } from '@joktec/core';
2
+ import { ColumnOptions, ColumnType } from 'typeorm';
3
+ import { ColumnDecoratorArgs, IMysqlColumnOptions, RequiredResult } from './column.type';
4
+ export declare const applyPropertyDecorators: (target: object, propertyKey: string | symbol, decorators: PropertyDecorator[]) => void;
5
+ export declare const cloneColumnOptions: <T extends IMysqlColumnOptions>(options?: T) => T;
6
+ export declare const toTypeormOptions: <T extends IMysqlColumnOptions>(options: T) => ColumnOptions;
7
+ export declare const parseColumnArgs: (args: ColumnDecoratorArgs) => {
8
+ type?: ColumnType;
9
+ options: IMysqlColumnOptions;
10
+ };
11
+ export declare const resolveRequired: (options: IMysqlColumnOptions) => RequiredResult;
12
+ export declare const getLengthValue: (value: string | number | undefined) => number;
13
+ export declare const enumValues: (enumLike: IMysqlColumnOptions["enum"]) => any[] | undefined;
14
+ export declare const resolveNestedType: (nested: IMysqlColumnOptions["nested"], designType: Constructor<any>) => Constructor<any>;
15
+ //# sourceMappingURL=column.util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"column.util.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/column.util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAmB,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAuBzF,eAAO,MAAM,uBAAuB,WAC1B,MAAM,eACD,MAAM,GAAG,MAAM,cAChB,iBAAiB,EAAE,KAC9B,IAEF,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,CAAC,SAAS,mBAAmB,YAAW,CAAC,KAAa,CAExF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,mBAAmB,WAAW,CAAC,KAAG,aAM5E,CAAC;AAEF,eAAO,MAAM,eAAe,SAAU,mBAAmB,KAAG;IAAE,IAAI,CAAC,EAAE,UAAU,CAAC;IAAC,OAAO,EAAE,mBAAmB,CAAA;CAO5G,CAAC;AAEF,eAAO,MAAM,eAAe,YAAa,mBAAmB,KAAG,cAI9D,CAAC;AAEF,eAAO,MAAM,cAAc,UAAW,MAAM,GAAG,MAAM,GAAG,SAAS,KAAG,MAOnE,CAAC;AAEF,eAAO,MAAM,UAAU,aAAc,mBAAmB,CAAC,MAAM,CAAC,KAAG,GAAG,EAAE,GAAG,SAI1E,CAAC;AAEF,eAAO,MAAM,iBAAiB,WACpB,mBAAmB,CAAC,QAAQ,CAAC,cACzB,WAAW,CAAC,GAAG,CAAC,KAC3B,WAAW,CAAC,GAAG,CAEjB,CAAC"}