@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.
- package/README.md +419 -79
- 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 +533 -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 +29 -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 +10 -0
- package/dist/decorators/column.decorator.d.ts.map +1 -0
- package/dist/decorators/column.decorator.js +181 -0
- package/dist/decorators/column.decorator.js.map +1 -0
- package/dist/decorators/columns/array.column.d.ts +3 -0
- package/dist/decorators/columns/array.column.d.ts.map +1 -0
- package/dist/decorators/columns/array.column.js +13 -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 +42 -0
- package/dist/decorators/columns/column.factory.js.map +1 -0
- package/dist/decorators/columns/column.type.d.ts +136 -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 +22 -0
- package/dist/decorators/columns/column.util.d.ts.map +1 -0
- package/dist/decorators/columns/column.util.js +163 -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 +17 -0
- package/dist/decorators/columns/index.d.ts.map +1 -0
- package/dist/decorators/columns/index.js +33 -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 +16 -0
- package/dist/decorators/columns/number.column.js.map +1 -0
- package/dist/decorators/columns/object.column.d.ts +4 -0
- package/dist/decorators/columns/object.column.d.ts.map +1 -0
- package/dist/decorators/columns/object.column.js +13 -0
- package/dist/decorators/columns/object.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 +28 -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 +49 -0
- package/dist/decorators/columns/swagger.column.js.map +1 -0
- package/dist/decorators/columns/timestamp.column.d.ts +6 -0
- package/dist/decorators/columns/timestamp.column.d.ts.map +1 -0
- package/dist/decorators/columns/timestamp.column.js +55 -0
- package/dist/decorators/columns/timestamp.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 +18 -0
- package/dist/decorators/columns/transform.column.js.map +1 -0
- package/dist/decorators/columns/virtual.column.d.ts +4 -0
- package/dist/decorators/columns/virtual.column.d.ts.map +1 -0
- package/dist/decorators/columns/virtual.column.js +23 -0
- package/dist/decorators/columns/virtual.column.js.map +1 -0
- package/dist/decorators/index.d.ts +3 -0
- package/dist/decorators/index.d.ts.map +1 -1
- package/dist/decorators/index.js +2 -0
- package/dist/decorators/index.js.map +1 -1
- package/dist/decorators/table.decorator.d.ts +31 -2
- package/dist/decorators/table.decorator.d.ts.map +1 -1
- package/dist/decorators/table.decorator.js +55 -18
- package/dist/decorators/table.decorator.js.map +1 -1
- package/dist/decorators/timestamp.decorator.d.ts +4 -0
- package/dist/decorators/timestamp.decorator.d.ts.map +1 -0
- package/dist/decorators/timestamp.decorator.js +19 -0
- package/dist/decorators/timestamp.decorator.js.map +1 -0
- package/dist/helpers/index.d.ts +0 -1
- package/dist/helpers/index.d.ts.map +1 -1
- package/dist/helpers/index.js +0 -1
- package/dist/helpers/index.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 +6 -0
- package/dist/index.js.map +1 -1
- package/dist/models/mysql.model.d.ts.map +1 -1
- package/dist/models/mysql.model.js +4 -11
- 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 +9 -2
- package/dist/mysql.repo.d.ts.map +1 -1
- package/dist/mysql.repo.js +164 -48
- 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
- package/dist/helpers/mysql.finder.d.ts +0 -15
- package/dist/helpers/mysql.finder.d.ts.map +0 -1
- package/dist/helpers/mysql.finder.js +0 -128
- package/dist/helpers/mysql.finder.js.map +0 -1
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransformColumn = TransformColumn;
|
|
4
|
+
const core_1 = require("@joktec/core");
|
|
5
|
+
const utils_1 = require("@joktec/utils");
|
|
6
|
+
const column_util_1 = require("./column.util");
|
|
7
|
+
const swagger_column_1 = require("./swagger.column");
|
|
8
|
+
function TransformColumn(options, designType, required) {
|
|
9
|
+
const type = (0, column_util_1.shouldValidateNested)(options, designType) ? undefined : (0, column_util_1.resolveTransformType)(options, designType);
|
|
10
|
+
const typeDecorators = type ? [(0, utils_1.Type)(() => type)] : [];
|
|
11
|
+
if (options.hidden)
|
|
12
|
+
return [...typeDecorators, (0, utils_1.Exclude)({ toPlainOnly: true }), (0, core_1.ApiHideProperty)()];
|
|
13
|
+
const decorators = [...typeDecorators];
|
|
14
|
+
decorators.push(options.groups?.length ? (0, utils_1.Expose)({ groups: options.groups }) : (0, utils_1.Expose)());
|
|
15
|
+
decorators.push((0, core_1.ApiProperty)((0, swagger_column_1.buildSwaggerOptions)(options, designType, required)));
|
|
16
|
+
return decorators;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=transform.column.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transform.column.js","sourceRoot":"","sources":["../../../src/decorators/columns/transform.column.ts"],"names":[],"mappings":";;AAMA,0CAcC;AApBD,uCAAyE;AACzE,yCAAsD;AAEtD,+CAA2E;AAC3E,qDAAuD;AAEvD,SAAgB,eAAe,CAC7B,OAAiC,EACjC,UAA4B,EAC5B,QAAiB;IAEjB,MAAM,IAAI,GAAG,IAAA,kCAAoB,EAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAA,kCAAoB,EAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAC/G,MAAM,cAAc,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAA,YAAI,EAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAEtD,IAAI,OAAO,CAAC,MAAM;QAAE,OAAO,CAAC,GAAG,cAAc,EAAE,IAAA,eAAO,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,IAAA,sBAAe,GAAE,CAAC,CAAC;IAElG,MAAM,UAAU,GAAwB,CAAC,GAAG,cAAc,CAAC,CAAC;IAC5D,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,IAAA,cAAM,EAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,IAAA,cAAM,GAAE,CAAC,CAAC;IACxF,UAAU,CAAC,IAAI,CAAC,IAAA,kBAAW,EAAC,IAAA,oCAAmB,EAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IACjF,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Constructor } from '@joktec/core';
|
|
2
|
+
import { IMysqlColumnBuildOptions } from './column.type';
|
|
3
|
+
export declare function buildVirtualColumnDecorators(options: IMysqlColumnBuildOptions, designType: Constructor<any>): PropertyDecorator[];
|
|
4
|
+
//# sourceMappingURL=virtual.column.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"virtual.column.d.ts","sourceRoot":"","sources":["../../../src/decorators/columns/virtual.column.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqD,WAAW,EAAE,MAAM,cAAc,CAAC;AAE9F,OAAO,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AAOzD,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,wBAAwB,EACjC,UAAU,EAAE,WAAW,CAAC,GAAG,CAAC,GAC3B,iBAAiB,EAAE,CAsBrB"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildVirtualColumnDecorators = buildVirtualColumnDecorators;
|
|
4
|
+
const core_1 = require("@joktec/core");
|
|
5
|
+
const utils_1 = require("@joktec/utils");
|
|
6
|
+
const column_util_1 = require("./column.util");
|
|
7
|
+
const swagger_column_1 = require("./swagger.column");
|
|
8
|
+
function buildVirtualColumnDecorators(options, designType) {
|
|
9
|
+
const virtualOptions = { ...options, immutable: options.immutable ?? true };
|
|
10
|
+
const decorators = [...(0, utils_1.toArray)(virtualOptions.decorators)];
|
|
11
|
+
if (virtualOptions.hidden) {
|
|
12
|
+
decorators.push((0, utils_1.Exclude)({ toPlainOnly: true }), (0, core_1.ApiHideProperty)());
|
|
13
|
+
return decorators;
|
|
14
|
+
}
|
|
15
|
+
decorators.push((0, utils_1.Expose)(virtualOptions.expose ??
|
|
16
|
+
(virtualOptions.groups?.length ? { groups: virtualOptions.groups, toPlainOnly: true } : { toPlainOnly: true })));
|
|
17
|
+
const required = virtualOptions.optional === true ? false : (0, column_util_1.resolveRequired)(virtualOptions).required;
|
|
18
|
+
const swaggerOptions = (0, swagger_column_1.buildSwaggerOptions)(virtualOptions, designType, required);
|
|
19
|
+
const swaggerDecorator = required ? core_1.ApiProperty : core_1.ApiPropertyOptional;
|
|
20
|
+
decorators.push(swaggerDecorator(swaggerOptions));
|
|
21
|
+
return decorators;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=virtual.column.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"virtual.column.js","sourceRoot":"","sources":["../../../src/decorators/columns/virtual.column.ts"],"names":[],"mappings":";;AASA,oEAyBC;AAlCD,uCAA8F;AAC9F,yCAAyD;AAEzD,+CAAgD;AAChD,qDAAuD;AAKvD,SAAgB,4BAA4B,CAC1C,OAAiC,EACjC,UAA4B;IAE5B,MAAM,cAAc,GAA6B,EAAE,GAAG,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;IACtG,MAAM,UAAU,GAAwB,CAAC,GAAG,IAAA,eAAO,EAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;IAEhF,IAAI,cAAc,CAAC,MAAM,EAAE,CAAC;QAC1B,UAAU,CAAC,IAAI,CAAC,IAAA,eAAO,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,IAAA,sBAAe,GAAE,CAAC,CAAC;QACnE,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,IAAI,CACb,IAAA,cAAM,EACJ,cAAc,CAAC,MAAM;QACnB,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CACjH,CACF,CAAC;IAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAA,6BAAe,EAAC,cAAc,CAAC,CAAC,QAAQ,CAAC;IACrG,MAAM,cAAc,GAAG,IAAA,oCAAmB,EAAC,cAAc,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IACjF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,kBAAW,CAAC,CAAC,CAAC,0BAAmB,CAAC;IACtE,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,CAAC;IAElD,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -1,2 +1,5 @@
|
|
|
1
|
+
export * from './column.decorator';
|
|
1
2
|
export * from './table.decorator';
|
|
3
|
+
export * from './timestamp.decorator';
|
|
4
|
+
export { ColumnDecoratorArgs, IMysqlColumnDatabaseOptions, IMysqlColumnOptions, IMysqlPrimaryColumnOptions, IMysqlRelationIdColumnOptions, IMysqlTimestampColumnOptions, IMysqlVersionColumnOptions, IMysqlViewColumnOptions, MysqlColumnCheckOptions, MysqlColumnIndexOptions, MysqlFieldDecorator, PrimaryColumnStrategy, RequiredOption, } from './columns';
|
|
2
5
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AACtC,OAAO,EACL,mBAAmB,EACnB,2BAA2B,EAC3B,mBAAmB,EACnB,0BAA0B,EAC1B,6BAA6B,EAC7B,4BAA4B,EAC5B,0BAA0B,EAC1B,uBAAuB,EACvB,uBAAuB,EACvB,uBAAuB,EACvB,mBAAmB,EACnB,qBAAqB,EACrB,cAAc,GACf,MAAM,WAAW,CAAC"}
|
package/dist/decorators/index.js
CHANGED
|
@@ -14,5 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./column.decorator"), exports);
|
|
17
18
|
__exportStar(require("./table.decorator"), exports);
|
|
19
|
+
__exportStar(require("./timestamp.decorator"), exports);
|
|
18
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,oDAAkC;AAClC,wDAAsC"}
|
|
@@ -1,20 +1,49 @@
|
|
|
1
1
|
import { KeyOf } from '@joktec/core';
|
|
2
|
-
import { EntityOptions, IndexOptions } from 'typeorm';
|
|
2
|
+
import { EntityOptions, IndexOptions, TableInheritance, Tree } from 'typeorm';
|
|
3
|
+
import { ViewEntityOptions } from 'typeorm/decorator/options/ViewEntityOptions';
|
|
3
4
|
import { MysqlModel } from '../models';
|
|
4
5
|
type KeyTypeOf<T, TYPE> = {
|
|
5
6
|
[K in keyof T]: T[K] extends TYPE | undefined ? K : never;
|
|
6
7
|
}[keyof T];
|
|
8
|
+
type MysqlTreeType = Parameters<typeof Tree>[0];
|
|
9
|
+
type MysqlTreeOptions = Parameters<typeof Tree>[1];
|
|
10
|
+
type MysqlInheritanceOptions = Parameters<typeof TableInheritance>[0];
|
|
11
|
+
type AllKeys<T> = T extends unknown ? keyof T : never;
|
|
12
|
+
type StrictUnionHelper<T, TAll> = T extends unknown ? T & Partial<Record<Exclude<AllKeys<TAll>, keyof T>, never>> : never;
|
|
13
|
+
type StrictUnion<T> = StrictUnionHelper<T, T>;
|
|
7
14
|
export interface IIndexOptions<T extends MysqlModel = any> extends IndexOptions {
|
|
8
15
|
name?: string;
|
|
9
16
|
fields: KeyOf<T>[];
|
|
10
17
|
}
|
|
11
|
-
export
|
|
18
|
+
export type ITableTreeOptions = MysqlTreeType | {
|
|
19
|
+
type: MysqlTreeType;
|
|
20
|
+
options?: MysqlTreeOptions;
|
|
21
|
+
};
|
|
22
|
+
export type ITableCheckOptions = string | {
|
|
23
|
+
name?: string;
|
|
24
|
+
expression: string;
|
|
25
|
+
};
|
|
26
|
+
export interface ITableCommonOptions<T extends MysqlModel = any> {
|
|
12
27
|
keywords?: KeyTypeOf<T, string>[];
|
|
28
|
+
}
|
|
29
|
+
export interface ITableEntityOptions<T extends MysqlModel = any> extends EntityOptions, ITableCommonOptions<T> {
|
|
30
|
+
kind?: 'entity';
|
|
31
|
+
inheritance?: true | MysqlInheritanceOptions;
|
|
32
|
+
tree?: ITableTreeOptions;
|
|
13
33
|
index?: KeyOf<T>[];
|
|
14
34
|
unique?: KeyOf<T>[];
|
|
15
35
|
textSearch?: KeyTypeOf<T, string>[];
|
|
16
36
|
customIndexes?: IIndexOptions<T>[];
|
|
37
|
+
checks?: ITableCheckOptions[];
|
|
38
|
+
}
|
|
39
|
+
export interface ITableViewOptions<T extends MysqlModel = any> extends ViewEntityOptions, ITableCommonOptions<T> {
|
|
40
|
+
kind: 'view';
|
|
41
|
+
}
|
|
42
|
+
export interface ITableChildOptions<T extends MysqlModel = any> extends ITableCommonOptions<T> {
|
|
43
|
+
kind: 'child';
|
|
44
|
+
discriminatorValue?: any;
|
|
17
45
|
}
|
|
46
|
+
export type ITableOptions<T extends MysqlModel = any> = StrictUnion<ITableEntityOptions<T> | ITableViewOptions<T> | ITableChildOptions<T>>;
|
|
18
47
|
export declare const Tables: <T extends MysqlModel = any>(options?: ITableOptions<T>) => ClassDecorator;
|
|
19
48
|
export {};
|
|
20
49
|
//# sourceMappingURL=table.decorator.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,EAAe,MAAM,cAAc,CAAC;AACnE,OAAO,
|
|
1
|
+
{"version":3,"file":"table.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,26 +6,63 @@ const typeorm_1 = require("typeorm");
|
|
|
6
6
|
const Tables = (options = {}) => {
|
|
7
7
|
return (target) => {
|
|
8
8
|
const className = target.name;
|
|
9
|
-
const decorators =
|
|
10
|
-
|
|
11
|
-
decorators.push((0, typeorm_1.Index)(options.index, { background: true }));
|
|
12
|
-
}
|
|
13
|
-
if (options.unique?.length) {
|
|
14
|
-
decorators.push((0, typeorm_1.Index)(options.unique, { unique: true, background: true }));
|
|
15
|
-
}
|
|
16
|
-
if (options.textSearch?.length) {
|
|
17
|
-
decorators.push((0, typeorm_1.Index)(options.textSearch.map(String), { fulltext: true, background: true }));
|
|
18
|
-
}
|
|
19
|
-
if (options.customIndexes?.length) {
|
|
20
|
-
options.customIndexes.map((idxOpts) => {
|
|
21
|
-
if (idxOpts.name)
|
|
22
|
-
decorators.push((0, typeorm_1.Index)(idxOpts.name, idxOpts.fields, idxOpts));
|
|
23
|
-
else
|
|
24
|
-
decorators.push((0, typeorm_1.Index)(idxOpts.fields, idxOpts));
|
|
25
|
-
});
|
|
26
|
-
}
|
|
9
|
+
const decorators = buildTableKindDecorators(options);
|
|
10
|
+
decorators.unshift((0, core_1.SetMetadata)(className, { ...options }));
|
|
27
11
|
(0, core_1.applyDecorators)(...decorators)(target);
|
|
28
12
|
};
|
|
29
13
|
};
|
|
30
14
|
exports.Tables = Tables;
|
|
15
|
+
function buildTableKindDecorators(options) {
|
|
16
|
+
if (options.kind === 'view')
|
|
17
|
+
return buildViewTableDecorators(options);
|
|
18
|
+
if (options.kind === 'child')
|
|
19
|
+
return [(0, typeorm_1.ChildEntity)(options.discriminatorValue)];
|
|
20
|
+
return buildEntityTableDecorators(options);
|
|
21
|
+
}
|
|
22
|
+
function buildEntityTableDecorators(options) {
|
|
23
|
+
const { kind: _kind, inheritance, tree, index, unique, textSearch, customIndexes, checks, keywords: _keywords, ...entityOptions } = options;
|
|
24
|
+
const decorators = [(0, typeorm_1.Entity)(entityOptions)];
|
|
25
|
+
if (inheritance) {
|
|
26
|
+
decorators.push((0, typeorm_1.TableInheritance)(inheritance === true ? undefined : inheritance));
|
|
27
|
+
}
|
|
28
|
+
if (tree) {
|
|
29
|
+
const treeOptions = typeof tree === 'string' ? { type: tree } : tree;
|
|
30
|
+
decorators.push((0, typeorm_1.Tree)(treeOptions.type, treeOptions.options));
|
|
31
|
+
}
|
|
32
|
+
decorators.push(...buildTableIndexDecorators({ index, unique, textSearch, customIndexes }));
|
|
33
|
+
decorators.push(...buildTableCheckDecorators(checks));
|
|
34
|
+
return decorators;
|
|
35
|
+
}
|
|
36
|
+
function buildViewTableDecorators(options) {
|
|
37
|
+
const { kind: _kind, keywords: _keywords, ...viewOptions } = options;
|
|
38
|
+
return [(0, typeorm_1.ViewEntity)(viewOptions)];
|
|
39
|
+
}
|
|
40
|
+
function buildTableIndexDecorators(options) {
|
|
41
|
+
const decorators = [];
|
|
42
|
+
const { index, unique, textSearch, customIndexes } = options;
|
|
43
|
+
if (index?.length)
|
|
44
|
+
decorators.push((0, typeorm_1.Index)(index.map(String)));
|
|
45
|
+
if (unique?.length)
|
|
46
|
+
decorators.push((0, typeorm_1.Index)(unique.map(String), { unique: true }));
|
|
47
|
+
if (textSearch?.length)
|
|
48
|
+
decorators.push((0, typeorm_1.Index)(textSearch.map(String), { fulltext: true }));
|
|
49
|
+
if (customIndexes?.length) {
|
|
50
|
+
customIndexes.forEach((idxOpts) => {
|
|
51
|
+
const { fields, ...indexOptions } = idxOpts;
|
|
52
|
+
const safeFields = fields.map(String);
|
|
53
|
+
if (indexOptions.name)
|
|
54
|
+
decorators.push((0, typeorm_1.Index)(indexOptions.name, safeFields, indexOptions));
|
|
55
|
+
else
|
|
56
|
+
decorators.push((0, typeorm_1.Index)(safeFields, indexOptions));
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
return decorators;
|
|
60
|
+
}
|
|
61
|
+
function buildTableCheckDecorators(checks = []) {
|
|
62
|
+
return checks.map(check => {
|
|
63
|
+
if (typeof check === 'string')
|
|
64
|
+
return (0, typeorm_1.Check)(check);
|
|
65
|
+
return check.name ? (0, typeorm_1.Check)(check.name, check.expression) : (0, typeorm_1.Check)(check.expression);
|
|
66
|
+
});
|
|
67
|
+
}
|
|
31
68
|
//# sourceMappingURL=table.decorator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.decorator.js","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":";;;AAAA,uCAAmE;AACnE,
|
|
1
|
+
{"version":3,"file":"table.decorator.js","sourceRoot":"","sources":["../../src/decorators/table.decorator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { IMysqlTimestampColumnOptions } from './columns';
|
|
2
|
+
export type TimestampColumnMode = 'create' | 'update' | 'delete';
|
|
3
|
+
export declare function TimestampColumn(mode: TimestampColumnMode, options?: IMysqlTimestampColumnOptions): PropertyDecorator;
|
|
4
|
+
//# sourceMappingURL=timestamp.decorator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timestamp.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/timestamp.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAM7B,MAAM,WAAW,CAAC;AAEnB,MAAM,MAAM,mBAAmB,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAajE,wBAAgB,eAAe,CAC7B,IAAI,EAAE,mBAAmB,EACzB,OAAO,GAAE,4BAAiC,GACzC,iBAAiB,CAenB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TimestampColumn = TimestampColumn;
|
|
4
|
+
const columns_1 = require("./columns");
|
|
5
|
+
function TimestampColumn(mode, options = {}) {
|
|
6
|
+
return (target, propertyKey) => {
|
|
7
|
+
const timestampOptions = (0, columns_1.cloneColumnOptions)(options);
|
|
8
|
+
if (mode === 'create') {
|
|
9
|
+
(0, columns_1.applyPropertyDecorators)(target, propertyKey, (0, columns_1.buildCreateDateColumnDecorators)(timestampOptions));
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (mode === 'update') {
|
|
13
|
+
(0, columns_1.applyPropertyDecorators)(target, propertyKey, (0, columns_1.buildUpdateDateColumnDecorators)(timestampOptions));
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
(0, columns_1.applyPropertyDecorators)(target, propertyKey, (0, columns_1.buildDeleteDateColumnDecorators)(timestampOptions));
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=timestamp.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timestamp.decorator.js","sourceRoot":"","sources":["../../src/decorators/timestamp.decorator.ts"],"names":[],"mappings":";;AAsBA,0CAkBC;AAxCD,uCAOmB;AAenB,SAAgB,eAAe,CAC7B,IAAyB,EACzB,UAAwC,EAAE;IAE1C,OAAO,CAAC,MAAc,EAAE,WAA4B,EAAE,EAAE;QACtD,MAAM,gBAAgB,GAAG,IAAA,4BAAkB,EAAC,OAAO,CAAC,CAAC;QACrD,IAAI,IAAI,KAAK,QAAQ,EAAE,CAAC;YACtB,IAAA,iCAAuB,EAAC,MAAM,EAAE,WAAW,EAAE,IAAA,yCAA+B,EAAC,gBAAgB,CAAC,CAAC,CAAC;YAChG,OAAO;QACT,CAAC;QAED,IAAI,IAAI,KAAK,QAAQ,EAAE,CAAC;YACtB,IAAA,iCAAuB,EAAC,MAAM,EAAE,WAAW,EAAE,IAAA,yCAA+B,EAAC,gBAAgB,CAAC,CAAC,CAAC;YAChG,OAAO;QACT,CAAC;QAED,IAAA,iCAAuB,EAAC,MAAM,EAAE,WAAW,EAAE,IAAA,yCAA+B,EAAC,gBAAgB,CAAC,CAAC,CAAC;IAClG,CAAC,CAAC;AACJ,CAAC"}
|
package/dist/helpers/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC"}
|
package/dist/helpers/index.js
CHANGED
|
@@ -14,7 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./mysql.finder"), exports);
|
|
18
17
|
__exportStar(require("./mysql.helper"), exports);
|
|
19
18
|
__exportStar(require("./mysql.utils"), exports);
|
|
20
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,gDAA8B"}
|
|
@@ -1,12 +1,27 @@
|
|
|
1
1
|
import { ICondition, IPopulate, ISort } from '@joktec/core';
|
|
2
|
-
import { SelectQueryBuilder } from 'typeorm';
|
|
2
|
+
import { EntityMetadata, SelectQueryBuilder } from 'typeorm';
|
|
3
3
|
import { IMysqlRequest } from '../models';
|
|
4
|
+
import { Dialect } from '../mysql.config';
|
|
5
|
+
export interface MysqlQueryContext {
|
|
6
|
+
metadata?: EntityMetadata;
|
|
7
|
+
dialect?: Dialect;
|
|
8
|
+
}
|
|
4
9
|
export declare class MysqlHelper {
|
|
10
|
+
private static readonly FIELD_PATTERN;
|
|
11
|
+
private static readonly LIKE_ESCAPE_SQL;
|
|
5
12
|
static applyPagination<T>(qb: SelectQueryBuilder<T>, query?: IMysqlRequest<T>): void;
|
|
6
|
-
static applyCondition<T>(qb: SelectQueryBuilder<T>, condition?: ICondition<T
|
|
7
|
-
static
|
|
8
|
-
static
|
|
9
|
-
static
|
|
10
|
-
static
|
|
13
|
+
static applyCondition<T>(qb: SelectQueryBuilder<T>, condition?: ICondition<T>, context?: MysqlQueryContext): void;
|
|
14
|
+
private static applyConditionEntry;
|
|
15
|
+
private static applyOperator;
|
|
16
|
+
static applyProjection<T>(qb: SelectQueryBuilder<T>, select?: string | string[], context?: MysqlQueryContext): void;
|
|
17
|
+
static applyOrder<T>(qb: SelectQueryBuilder<T>, sort?: ISort<T>, context?: MysqlQueryContext): void;
|
|
18
|
+
static applyRelations<T>(qb: SelectQueryBuilder<T>, populate?: IPopulate<T>, context?: MysqlQueryContext): void;
|
|
19
|
+
static assertColumn(path: string, context?: MysqlQueryContext): void;
|
|
20
|
+
static assertRelation(path: string, context?: MysqlQueryContext): void;
|
|
21
|
+
static column<T>(qb: SelectQueryBuilder<T>, path: string, context: MysqlQueryContext): string;
|
|
22
|
+
static escapeLikePattern(value: unknown): string;
|
|
23
|
+
private static assertSafePath;
|
|
24
|
+
private static nextParam;
|
|
25
|
+
private static assertNonEmptyArray;
|
|
11
26
|
}
|
|
12
27
|
//# sourceMappingURL=mysql.helper.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"mysql.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAY,cAAc,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAI1C,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAUD,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAsB;IAC3D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAmB;IAE1D,MAAM,CAAC,eAAe,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,KAAK,GAAE,aAAa,CAAC,CAAC,CAAM;IASjF,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,GAAE,iBAAsB;IAY9G,OAAO,CAAC,MAAM,CAAC,mBAAmB;IAsClC,OAAO,CAAC,MAAM,CAAC,aAAa;IA6E5B,MAAM,CAAC,eAAe,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,OAAO,GAAE,iBAAsB;IAMhH,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,OAAO,GAAE,iBAAsB;IAOhG,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,GAAE,iBAAsB;IAe5G,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,iBAAsB,GAAG,IAAI;IAUxE,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,iBAAsB,GAAG,IAAI;IAU1E,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,GAAG,MAAM;IAM7F,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM;IAIhD,OAAO,CAAC,MAAM,CAAC,cAAc;IAI7B,OAAO,CAAC,MAAM,CAAC,SAAS;IAOxB,OAAO,CAAC,MAAM,CAAC,mBAAmB;CAKnC"}
|