@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.
- package/README.md +211 -81
- package/dist/__tests__/mysql.column.decorator.spec.d.ts +2 -0
- package/dist/__tests__/mysql.column.decorator.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.column.decorator.spec.js +60 -0
- package/dist/__tests__/mysql.column.decorator.spec.js.map +1 -0
- package/dist/__tests__/mysql.dialect.spec.d.ts +2 -0
- package/dist/__tests__/mysql.dialect.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.dialect.spec.js +28 -0
- package/dist/__tests__/mysql.dialect.spec.js.map +1 -0
- package/dist/__tests__/mysql.exception.spec.d.ts +2 -0
- package/dist/__tests__/mysql.exception.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.exception.spec.js +42 -0
- package/dist/__tests__/mysql.exception.spec.js.map +1 -0
- package/dist/__tests__/mysql.helper.spec.d.ts +2 -0
- package/dist/__tests__/mysql.helper.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.helper.spec.js +80 -0
- package/dist/__tests__/mysql.helper.spec.js.map +1 -0
- package/dist/__tests__/mysql.module.integration.spec.d.ts +2 -0
- package/dist/__tests__/mysql.module.integration.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.module.integration.spec.js +67 -0
- package/dist/__tests__/mysql.module.integration.spec.js.map +1 -0
- package/dist/__tests__/mysql.repo.cursor.spec.d.ts +2 -0
- package/dist/__tests__/mysql.repo.cursor.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.repo.cursor.spec.js +146 -0
- package/dist/__tests__/mysql.repo.cursor.spec.js.map +1 -0
- package/dist/__tests__/mysql.service.spec.d.ts +2 -0
- package/dist/__tests__/mysql.service.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.service.spec.js +70 -0
- package/dist/__tests__/mysql.service.spec.js.map +1 -0
- package/dist/__tests__/mysql.utils.spec.d.ts +2 -0
- package/dist/__tests__/mysql.utils.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.utils.spec.js +21 -0
- package/dist/__tests__/mysql.utils.spec.js.map +1 -0
- package/dist/decorators/column.decorator.d.ts +11 -0
- package/dist/decorators/column.decorator.d.ts.map +1 -0
- package/dist/decorators/column.decorator.js +35 -0
- package/dist/decorators/column.decorator.js.map +1 -0
- package/dist/decorators/columns/array.column.d.ts +2 -0
- package/dist/decorators/columns/array.column.d.ts.map +1 -0
- package/dist/decorators/columns/array.column.js +8 -0
- package/dist/decorators/columns/array.column.js.map +1 -0
- package/dist/decorators/columns/bool.column.d.ts +2 -0
- package/dist/decorators/columns/bool.column.d.ts.map +1 -0
- package/dist/decorators/columns/bool.column.js +8 -0
- package/dist/decorators/columns/bool.column.js.map +1 -0
- package/dist/decorators/columns/column.factory.d.ts +5 -0
- package/dist/decorators/columns/column.factory.d.ts.map +1 -0
- package/dist/decorators/columns/column.factory.js +40 -0
- package/dist/decorators/columns/column.factory.js.map +1 -0
- package/dist/decorators/columns/column.type.d.ts +33 -0
- package/dist/decorators/columns/column.type.d.ts.map +1 -0
- package/dist/decorators/columns/column.type.js +3 -0
- package/dist/decorators/columns/column.type.js.map +1 -0
- package/dist/decorators/columns/column.util.d.ts +15 -0
- package/dist/decorators/columns/column.util.d.ts.map +1 -0
- package/dist/decorators/columns/column.util.js +82 -0
- package/dist/decorators/columns/column.util.js.map +1 -0
- package/dist/decorators/columns/date.column.d.ts +2 -0
- package/dist/decorators/columns/date.column.d.ts.map +1 -0
- package/dist/decorators/columns/date.column.js +8 -0
- package/dist/decorators/columns/date.column.js.map +1 -0
- package/dist/decorators/columns/enum.column.d.ts +3 -0
- package/dist/decorators/columns/enum.column.d.ts.map +1 -0
- package/dist/decorators/columns/enum.column.js +8 -0
- package/dist/decorators/columns/enum.column.js.map +1 -0
- package/dist/decorators/columns/index.d.ts +14 -0
- package/dist/decorators/columns/index.d.ts.map +1 -0
- package/dist/decorators/columns/index.js +30 -0
- package/dist/decorators/columns/index.js.map +1 -0
- package/dist/decorators/columns/nested.column.d.ts +4 -0
- package/dist/decorators/columns/nested.column.d.ts.map +1 -0
- package/dist/decorators/columns/nested.column.js +12 -0
- package/dist/decorators/columns/nested.column.js.map +1 -0
- package/dist/decorators/columns/number.column.d.ts +3 -0
- package/dist/decorators/columns/number.column.d.ts.map +1 -0
- package/dist/decorators/columns/number.column.js +15 -0
- package/dist/decorators/columns/number.column.js.map +1 -0
- package/dist/decorators/columns/primary.column.d.ts +3 -0
- package/dist/decorators/columns/primary.column.d.ts.map +1 -0
- package/dist/decorators/columns/primary.column.js +48 -0
- package/dist/decorators/columns/primary.column.js.map +1 -0
- package/dist/decorators/columns/string.column.d.ts +3 -0
- package/dist/decorators/columns/string.column.d.ts.map +1 -0
- package/dist/decorators/columns/string.column.js +25 -0
- package/dist/decorators/columns/string.column.js.map +1 -0
- package/dist/decorators/columns/swagger.column.d.ts +4 -0
- package/dist/decorators/columns/swagger.column.d.ts.map +1 -0
- package/dist/decorators/columns/swagger.column.js +40 -0
- package/dist/decorators/columns/swagger.column.js.map +1 -0
- package/dist/decorators/columns/transform.column.d.ts +4 -0
- package/dist/decorators/columns/transform.column.d.ts.map +1 -0
- package/dist/decorators/columns/transform.column.js +15 -0
- package/dist/decorators/columns/transform.column.js.map +1 -0
- package/dist/decorators/index.d.ts +1 -0
- package/dist/decorators/index.d.ts.map +1 -1
- package/dist/decorators/index.js +1 -0
- package/dist/decorators/index.js.map +1 -1
- package/dist/decorators/table.decorator.d.ts.map +1 -1
- package/dist/decorators/table.decorator.js +18 -12
- package/dist/decorators/table.decorator.js.map +1 -1
- package/dist/helpers/mysql.finder.d.ts.map +1 -1
- package/dist/helpers/mysql.finder.js.map +1 -1
- package/dist/helpers/mysql.helper.d.ts +21 -6
- package/dist/helpers/mysql.helper.d.ts.map +1 -1
- package/dist/helpers/mysql.helper.js +152 -82
- package/dist/helpers/mysql.helper.js.map +1 -1
- package/dist/helpers/mysql.utils.d.ts.map +1 -1
- package/dist/helpers/mysql.utils.js +28 -11
- package/dist/helpers/mysql.utils.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/models/mysql.model.d.ts.map +1 -1
- package/dist/models/mysql.model.js.map +1 -1
- package/dist/models/mysql.option.d.ts +11 -2
- package/dist/models/mysql.option.d.ts.map +1 -1
- package/dist/mysql.config.d.ts +1 -17
- package/dist/mysql.config.d.ts.map +1 -1
- package/dist/mysql.config.js +1 -17
- package/dist/mysql.config.js.map +1 -1
- package/dist/mysql.exception.d.ts.map +1 -1
- package/dist/mysql.exception.js +48 -4
- package/dist/mysql.exception.js.map +1 -1
- package/dist/mysql.module.d.ts.map +1 -1
- package/dist/mysql.module.js.map +1 -1
- package/dist/mysql.repo.d.ts +8 -0
- package/dist/mysql.repo.d.ts.map +1 -1
- package/dist/mysql.repo.js +164 -33
- package/dist/mysql.repo.js.map +1 -1
- package/dist/mysql.service.d.ts.map +1 -1
- package/dist/mysql.service.js +8 -2
- package/dist/mysql.service.js.map +1 -1
- package/dist/services/index.d.ts +1 -0
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +1 -0
- package/dist/services/index.js.map +1 -1
- package/dist/services/mysql.dialect.d.ts +14 -0
- package/dist/services/mysql.dialect.d.ts.map +1 -0
- package/dist/services/mysql.dialect.js +50 -0
- package/dist/services/mysql.dialect.js.map +1 -0
- package/dist/services/mysql.strategy.d.ts +1 -1
- package/dist/services/mysql.strategy.d.ts.map +1 -1
- package/dist/services/mysql.strategy.js +1 -1
- package/dist/services/mysql.strategy.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|