@joktec/mysql 0.0.95 → 0.0.97

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 (37) hide show
  1. package/dist/helpers/index.d.ts +2 -0
  2. package/dist/helpers/index.d.ts.map +1 -0
  3. package/dist/helpers/index.js +18 -0
  4. package/dist/helpers/index.js.map +1 -0
  5. package/dist/helpers/mysql.helper.d.ts +7 -0
  6. package/dist/helpers/mysql.helper.d.ts.map +1 -0
  7. package/dist/helpers/mysql.helper.js +60 -0
  8. package/dist/helpers/mysql.helper.js.map +1 -0
  9. package/dist/index.d.ts +0 -1
  10. package/dist/index.d.ts.map +1 -1
  11. package/dist/index.js +0 -1
  12. package/dist/index.js.map +1 -1
  13. package/dist/models/mysql.model.d.ts +2 -1
  14. package/dist/models/mysql.model.d.ts.map +1 -1
  15. package/dist/models/mysql.model.js.map +1 -1
  16. package/dist/models/mysql.request.d.ts +2 -2
  17. package/dist/models/mysql.request.d.ts.map +1 -1
  18. package/dist/mysql.client.d.ts +2 -2
  19. package/dist/mysql.client.d.ts.map +1 -1
  20. package/dist/mysql.config.d.ts +4 -5
  21. package/dist/mysql.config.d.ts.map +1 -1
  22. package/dist/mysql.config.js +7 -9
  23. package/dist/mysql.config.js.map +1 -1
  24. package/dist/mysql.repo.d.ts +1 -1
  25. package/dist/mysql.repo.d.ts.map +1 -1
  26. package/dist/mysql.repo.js +22 -15
  27. package/dist/mysql.repo.js.map +1 -1
  28. package/dist/tsconfig.tsbuildinfo +1 -1
  29. package/package.json +5 -7
  30. package/dist/__tests__/mysql.utils.spec.d.ts +0 -2
  31. package/dist/__tests__/mysql.utils.spec.d.ts.map +0 -1
  32. package/dist/__tests__/mysql.utils.spec.js +0 -26
  33. package/dist/__tests__/mysql.utils.spec.js.map +0 -1
  34. package/dist/mysql.utils.d.ts +0 -7
  35. package/dist/mysql.utils.d.ts.map +0 -1
  36. package/dist/mysql.utils.js +0 -53
  37. package/dist/mysql.utils.js.map +0 -1
@@ -0,0 +1,2 @@
1
+ export * from './mysql.helper';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./mysql.helper"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B"}
@@ -0,0 +1,7 @@
1
+ import { FindOptions } from 'sequelize';
2
+ import { IMysqlRequest } from '../models';
3
+ export declare class MysqlHelper {
4
+ static opMapping: Record<string, symbol>;
5
+ static parseFilter(query: IMysqlRequest<any>): FindOptions;
6
+ }
7
+ //# sourceMappingURL=mysql.helper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAe,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,qBAAa,WAAW;IACtB,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAgBtC;IAEF,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,aAAa,CAAC,GAAG,CAAC,GAAG,WAAW;CAqC3D"}
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MysqlHelper = void 0;
4
+ const core_1 = require("@joktec/core");
5
+ const lodash_1 = require("lodash");
6
+ const sequelize_1 = require("sequelize");
7
+ const mysql_exception_1 = require("../mysql.exception");
8
+ class MysqlHelper {
9
+ static parseFilter(query) {
10
+ const { condition = {}, keyword } = query;
11
+ const where = {};
12
+ for (const [key, value] of Object.entries(condition)) {
13
+ if (key === '$and') {
14
+ where[sequelize_1.Op.and] = (0, core_1.toArray)(value).map(c => this.parseFilter(c));
15
+ continue;
16
+ }
17
+ if (key === '$or') {
18
+ where[sequelize_1.Op.or] = (0, core_1.toArray)(value).map(c => this.parseFilter(c));
19
+ continue;
20
+ }
21
+ if ((0, lodash_1.isNil)(value)) {
22
+ where[key][sequelize_1.Op.is] = null;
23
+ continue;
24
+ }
25
+ if ((0, lodash_1.isDate)(value) || (0, lodash_1.isRegExp)(value)) {
26
+ where[key] = value;
27
+ continue;
28
+ }
29
+ const keyOrSymbol = key.startsWith('$') ? this.opMapping[key] : key;
30
+ if (!keyOrSymbol)
31
+ throw new mysql_exception_1.MysqlException(`Operator not support`, { key, condition });
32
+ where[keyOrSymbol] = (0, lodash_1.isObject)(value) ? this.parseFilter(value) : value;
33
+ }
34
+ if (keyword) {
35
+ if (!where[sequelize_1.Op.and])
36
+ where[sequelize_1.Op.and] = [];
37
+ where[sequelize_1.Op.and].push((0, sequelize_1.literal)(`MATCH(name) AGAINST('${keyword}' IN BOOLEAN MODE)`));
38
+ }
39
+ return { where };
40
+ }
41
+ }
42
+ exports.MysqlHelper = MysqlHelper;
43
+ MysqlHelper.opMapping = {
44
+ $and: sequelize_1.Op.and,
45
+ $or: sequelize_1.Op.or,
46
+ $eq: sequelize_1.Op.eq,
47
+ $gt: sequelize_1.Op.gt,
48
+ $gte: sequelize_1.Op.gte,
49
+ $lt: sequelize_1.Op.lt,
50
+ $lte: sequelize_1.Op.lte,
51
+ $ne: sequelize_1.Op.ne,
52
+ $in: sequelize_1.Op.in,
53
+ $nin: sequelize_1.Op.notIn,
54
+ $all: sequelize_1.Op.all,
55
+ $not: sequelize_1.Op.not,
56
+ $like: sequelize_1.Op.substring,
57
+ $begin: sequelize_1.Op.startsWith,
58
+ $end: sequelize_1.Op.endsWith,
59
+ };
60
+ //# sourceMappingURL=mysql.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.helper.js","sourceRoot":"","sources":["../../src/helpers/mysql.helper.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -2,7 +2,6 @@ export * from './mysql.module';
2
2
  export * from './mysql.client';
3
3
  export * from './mysql.service';
4
4
  export * from './mysql.config';
5
- export * from './mysql.utils';
6
5
  export * from './mysql.repo';
7
6
  export * from './mysql.exception';
8
7
  export * from './models';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,OAAO,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC"}
package/dist/index.js CHANGED
@@ -19,7 +19,6 @@ __exportStar(require("./mysql.module"), exports);
19
19
  __exportStar(require("./mysql.client"), exports);
20
20
  __exportStar(require("./mysql.service"), exports);
21
21
  __exportStar(require("./mysql.config"), exports);
22
- __exportStar(require("./mysql.utils"), exports);
23
22
  __exportStar(require("./mysql.repo"), exports);
24
23
  __exportStar(require("./mysql.exception"), exports);
25
24
  __exportStar(require("./models"), exports);
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,iDAA+B;AAC/B,kDAAgC;AAChC,iDAA+B;AAC/B,gDAA8B;AAC9B,+CAA6B;AAC7B,oDAAkC;AAClC,2CAAyB;AACzB,uDAAqC;AACrC,uCAA+B;AAAtB,+FAAA,EAAE,OAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,iDAA+B;AAC/B,kDAAgC;AAChC,iDAA+B;AAC/B,+CAA6B;AAC7B,oDAAkC;AAClC,2CAAyB;AACzB,uDAAqC;AACrC,uCAA+B;AAAtB,+FAAA,EAAE,OAAA"}
@@ -1,5 +1,6 @@
1
1
  import { Model } from 'sequelize-typescript';
2
- export declare abstract class MysqlModel<T> extends Model<T> {
2
+ export declare class MysqlModel<T> extends Model<T> {
3
+ id?: number | any;
3
4
  createdAt?: Date;
4
5
  updatedAt?: Date;
5
6
  deletedAt?: Date;
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.model.d.ts","sourceRoot":"","sources":["../../src/models/mysql.model.ts"],"names":[],"mappings":"AACA,OAAO,EAAwB,KAAK,EAAa,MAAM,sBAAsB,CAAC;AAE9E,8BAAsB,UAAU,CAAC,CAAC,CAAE,SAAQ,KAAK,CAAC,CAAC,CAAC;IAIlD,SAAS,CAAC,EAAE,IAAI,CAAC;IAKjB,SAAS,CAAC,EAAE,IAAI,CAAC;IAKjB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB"}
1
+ {"version":3,"file":"mysql.model.d.ts","sourceRoot":"","sources":["../../src/models/mysql.model.ts"],"names":[],"mappings":"AACA,OAAO,EAAwB,KAAK,EAAa,MAAM,sBAAsB,CAAC;AAE9E,qBAAa,UAAU,CAAC,CAAC,CAAE,SAAQ,KAAK,CAAC,CAAC,CAAC;IACzC,EAAE,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC;IAKlB,SAAS,CAAC,EAAE,IAAI,CAAC;IAKjB,SAAS,CAAC,EAAE,IAAI,CAAC;IAKjB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB"}
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.model.js","sourceRoot":"","sources":["../../src/models/mysql.model.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAAkD;AAClD,+DAA8E;AAE9E,MAAsB,UAAc,SAAQ,4BAAQ;CAenD;AAfD,gCAeC;AAXC;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC;AAKjB;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC;AAKjB;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC"}
1
+ {"version":3,"file":"mysql.model.js","sourceRoot":"","sources":["../../src/models/mysql.model.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAAkD;AAClD,+DAA8E;AAE9E,MAAa,UAAc,SAAQ,4BAAQ;CAiB1C;AAjBD,gCAiBC;AAXC;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC;AAKjB;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC;AAKjB;IAHC,gCAAS;IACT,IAAA,kBAAW,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3B,IAAA,YAAK,EAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC1B,IAAI;6CAAC"}
@@ -1,11 +1,11 @@
1
1
  import { IBaseRequest, IDataType } from '@joktec/core';
2
- import { Model } from 'sequelize-typescript';
2
+ import { MysqlModel } from './mysql.model';
3
3
  export type MysqlId = string | number | bigint;
4
4
  export type ArrayBinding = Array<IDataType>;
5
5
  export type DictBinding = {
6
6
  [key: string]: IDataType;
7
7
  };
8
8
  export type RawBinding = ArrayBinding | DictBinding;
9
- export interface IMysqlRequest<T extends Model<T>> extends IBaseRequest<T> {
9
+ export interface IMysqlRequest<T extends MysqlModel<T>> extends IBaseRequest<T> {
10
10
  }
11
11
  //# sourceMappingURL=mysql.request.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.request.d.ts","sourceRoot":"","sources":["../../src/models/mysql.request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAE7C,MAAM,MAAM,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAC/C,MAAM,MAAM,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;AAC5C,MAAM,MAAM,WAAW,GAAG;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAA;CAAE,CAAC;AACvD,MAAM,MAAM,UAAU,GAAG,YAAY,GAAG,WAAW,CAAC;AAEpD,MAAM,WAAW,aAAa,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAE,SAAQ,YAAY,CAAC,CAAC,CAAC;CAAG"}
1
+ {"version":3,"file":"mysql.request.d.ts","sourceRoot":"","sources":["../../src/models/mysql.request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,MAAM,MAAM,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAC/C,MAAM,MAAM,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;AAC5C,MAAM,MAAM,WAAW,GAAG;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAA;CAAE,CAAC;AACvD,MAAM,MAAM,UAAU,GAAG,YAAY,GAAG,WAAW,CAAC;AAEpD,MAAM,WAAW,aAAa,CAAC,CAAC,SAAS,UAAU,CAAC,CAAC,CAAC,CAAE,SAAQ,YAAY,CAAC,CAAC,CAAC;CAAG"}
@@ -1,9 +1,9 @@
1
- import { BaseRepository, Client, DeepPartial, ICondition } from '@joktec/core';
1
+ import { IBaseRepository, Client, DeepPartial, ICondition } from '@joktec/core';
2
2
  import { Model, Sequelize } from 'sequelize-typescript';
3
3
  import { MysqlConfig } from './mysql.config';
4
4
  export interface MysqlClient extends Client<MysqlConfig, Sequelize> {
5
5
  }
6
- export interface IMysqlRepository<T extends Model<T>, ID> extends BaseRepository<T, ID> {
6
+ export interface IMysqlRepository<T extends Model<T>, ID> extends IBaseRepository<T, ID> {
7
7
  upsert(condition: ICondition, body: DeepPartial<T>): Promise<T>;
8
8
  }
9
9
  //# sourceMappingURL=mysql.client.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.client.d.ts","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,MAAM,WAAW,WAAY,SAAQ,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC;CAAG;AAEtE,MAAM,WAAW,gBAAgB,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAE,SAAQ,cAAc,CAAC,CAAC,EAAE,EAAE,CAAC;IACrF,MAAM,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CACjE"}
1
+ {"version":3,"file":"mysql.client.d.ts","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChF,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,MAAM,WAAW,WAAY,SAAQ,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC;CAAG;AAEtE,MAAM,WAAW,gBAAgB,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAE,SAAQ,eAAe,CAAC,CAAC,EAAE,EAAE,CAAC;IACtF,MAAM,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CACjE"}
@@ -1,5 +1,4 @@
1
1
  import { ClientConfig } from '@joktec/core';
2
- import { SequelizeOptions } from 'sequelize-typescript/dist/sequelize/sequelize/sequelize-options';
3
2
  import { ConnectionOptions } from 'sequelize/types/sequelize';
4
3
  export declare class MysqlSlaveConfig implements ConnectionOptions {
5
4
  host: string;
@@ -19,10 +18,10 @@ export declare enum Dialect {
19
18
  SNOWFLAKE = "snowflake",
20
19
  ORACLE = "oracle"
21
20
  }
22
- export declare class MysqlConfig extends ClientConfig implements SequelizeOptions {
23
- dialect: Dialect;
24
- host: string;
25
- port: number;
21
+ export declare class MysqlConfig extends ClientConfig {
22
+ dialect?: Dialect;
23
+ host?: string;
24
+ port?: number;
26
25
  username: string;
27
26
  password: string;
28
27
  database: string;
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.config.d.ts","sourceRoot":"","sources":["../src/mysql.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAoE,MAAM,cAAc,CAAC;AAE9G,OAAO,EAAE,gBAAgB,EAAE,MAAM,iEAAiE,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,qBAAa,gBAAiB,YAAW,iBAAiB;IAGxD,IAAI,EAAE,MAAM,CAAC;IAIb,IAAI,EAAE,MAAM,CAAC;IAIb,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;gBAEL,KAAK,EAAE,gBAAgB;CAGpC;AAED,oBAAY,OAAO;IACjB,KAAK,UAAU;IACf,QAAQ,aAAa;IACrB,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,GAAG,QAAQ;IACX,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB;AAED,qBAAa,WAAY,SAAQ,YAAa,YAAW,gBAAgB;IAGvE,OAAO,EAAE,OAAO,CAAC;IAIjB,IAAI,EAAE,MAAM,CAAC;IAIb,IAAI,EAAE,MAAM,CAAC;IAIb,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;IAIjB,OAAO,CAAC,EAAE,MAAM,CAAC;IAIjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAIlB,cAAc,CAAC,EAAE,MAAM,CAAC;IAKxB,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAC;gBAEhB,KAAK,EAAE,WAAW;CAgB/B"}
1
+ {"version":3,"file":"mysql.config.d.ts","sourceRoot":"","sources":["../src/mysql.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAqE,MAAM,cAAc,CAAC;AAE/G,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,qBAAa,gBAAiB,YAAW,iBAAiB;IAGxD,IAAI,EAAE,MAAM,CAAC;IAIb,IAAI,EAAE,MAAM,CAAC;IAIb,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;IAIjB,QAAQ,EAAE,MAAM,CAAC;gBAEL,KAAK,EAAE,gBAAgB;CAGpC;AAED,oBAAY,OAAO;IACjB,KAAK,UAAU;IACf,QAAQ,aAAa;IACrB,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,GAAG,QAAQ;IACX,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB;AAED,qBAAa,WAAY,SAAQ,YAAY;IAG3C,OAAO,CAAC,EAAE,OAAO,CAAiB;IAIlC,IAAI,CAAC,EAAE,MAAM,CAAe;IAI5B,IAAI,CAAC,EAAE,MAAM,CAAQ;IAIrB,QAAQ,EAAG,MAAM,CAAC;IAIlB,QAAQ,EAAG,MAAM,CAAC;IAIlB,QAAQ,EAAG,MAAM,CAAC;IAIlB,OAAO,CAAC,EAAE,MAAM,CAAC;IAIjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAIlB,cAAc,CAAC,EAAE,MAAM,CAAS;IAKhC,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAM;gBAErB,KAAK,EAAE,WAAW;CAQ/B"}
@@ -57,14 +57,12 @@ var Dialect;
57
57
  class MysqlConfig extends core_1.ClientConfig {
58
58
  constructor(props) {
59
59
  super(props);
60
- Object.assign(this, {
61
- ...props,
62
- dialect: props?.dialect || Dialect.MYSQL,
63
- host: props?.host || 'localhost',
64
- port: (0, core_1.toInt)(props?.port, 3306),
65
- connectTimeout: (0, core_1.toInt)(props?.connectTimeout, 20000),
66
- slaves: [],
67
- });
60
+ this.dialect = Dialect.MYSQL;
61
+ this.host = 'localhost';
62
+ this.port = 3306;
63
+ this.connectTimeout = 20000;
64
+ this.slaves = [];
65
+ Object.assign(this, props);
68
66
  if (props?.slaves?.length) {
69
67
  const masterConfig = (0, lodash_1.pick)(props, ['host', 'port', 'username', 'password', 'database']);
70
68
  this.slaves = props.slaves.map(slave => new MysqlSlaveConfig({ ...masterConfig, ...slave }));
@@ -73,7 +71,7 @@ class MysqlConfig extends core_1.ClientConfig {
73
71
  }
74
72
  exports.MysqlConfig = MysqlConfig;
75
73
  __decorate([
76
- (0, core_1.IsString)(),
74
+ (0, core_1.IsEnum)(Dialect),
77
75
  (0, core_1.IsNotEmpty)(),
78
76
  __metadata("design:type", String)
79
77
  ], MysqlConfig.prototype, "dialect", void 0);
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.config.js","sourceRoot":"","sources":["../src/mysql.config.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAA8G;AAC9G,mCAA8B;AAI9B,MAAa,gBAAgB;IAqB3B,YAAY,KAAuB;QACjC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAxBD,4CAwBC;AArBC;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;8CACA;AAIb;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;8CACA;AAIb;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAOnB,IAAY,OASX;AATD,WAAY,OAAO;IACjB,0BAAe,CAAA;IACf,gCAAqB,CAAA;IACrB,4BAAiB,CAAA;IACjB,8BAAmB,CAAA;IACnB,0BAAe,CAAA;IACf,sBAAW,CAAA;IACX,kCAAuB,CAAA;IACvB,4BAAiB,CAAA;AACnB,CAAC,EATW,OAAO,uBAAP,OAAO,QASlB;AAED,MAAa,WAAY,SAAQ,mBAAY;IA0C3C,YAAY,KAAkB;QAC5B,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE;YAClB,GAAG,KAAK;YACR,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,OAAO,CAAC,KAAK;YACxC,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,WAAW;YAChC,IAAI,EAAE,IAAA,YAAK,EAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC;YAC9B,cAAc,EAAE,IAAA,YAAK,EAAC,KAAK,EAAE,cAAc,EAAE,KAAK,CAAC;YACnD,MAAM,EAAE,EAAE;SACX,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE;YACzB,MAAM,YAAY,GAAG,IAAA,aAAI,EAAC,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC;YACvF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,GAAG,YAAY,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC;SAC9F;IACH,CAAC;CACF;AA1DD,kCA0DC;AAvDC;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;4CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;yCACA;AAIb;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;yCACA;AAIb;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;4CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACK;AAIlB;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;mDACW;AAKxB;IAHC,IAAA,cAAO,GAAE;IACT,IAAA,cAAO,EAAC,CAAC,gBAAgB,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3C,IAAA,iBAAU,GAAE;;2CACe"}
1
+ {"version":3,"file":"mysql.config.js","sourceRoot":"","sources":["../src/mysql.config.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAA+G;AAC/G,mCAA8B;AAG9B,MAAa,gBAAgB;IAqB3B,YAAY,KAAuB;QACjC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAxBD,4CAwBC;AArBC;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;8CACA;AAIb;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;8CACA;AAIb;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;kDACI;AAOnB,IAAY,OASX;AATD,WAAY,OAAO;IACjB,0BAAe,CAAA;IACf,gCAAqB,CAAA;IACrB,4BAAiB,CAAA;IACjB,8BAAmB,CAAA;IACnB,0BAAe,CAAA;IACf,sBAAW,CAAA;IACX,kCAAuB,CAAA;IACvB,4BAAiB,CAAA;AACnB,CAAC,EATW,OAAO,uBAAP,OAAO,QASlB;AAED,MAAa,WAAY,SAAQ,mBAAY;IA0C3C,YAAY,KAAkB;QAC5B,KAAK,CAAC,KAAK,CAAC,CAAC;QAxCf,YAAO,GAAa,OAAO,CAAC,KAAK,CAAC;QAIlC,SAAI,GAAY,WAAW,CAAC;QAI5B,SAAI,GAAY,IAAI,CAAC;QAwBrB,mBAAc,GAAY,KAAK,CAAC;QAKhC,WAAM,GAAwB,EAAE,CAAC;QAI/B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC3B,IAAI,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE;YACzB,MAAM,YAAY,GAAG,IAAA,aAAI,EAAC,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC;YACvF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,GAAG,YAAY,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC;SAC9F;IACH,CAAC;CACF;AAlDD,kCAkDC;AA/CC;IAFC,IAAA,aAAM,EAAC,OAAO,CAAC;IACf,IAAA,iBAAU,GAAE;;4CACqB;AAIlC;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;yCACe;AAI5B;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;yCACQ;AAIrB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACK;AAIlB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACK;AAIlB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACK;AAIlB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;4CACI;AAIjB;IAFC,IAAA,eAAQ,GAAE;IACV,IAAA,iBAAU,GAAE;;6CACK;AAIlB;IAFC,IAAA,YAAK,GAAE;IACP,IAAA,iBAAU,GAAE;;mDACmB;AAKhC;IAHC,IAAA,cAAO,GAAE;IACT,IAAA,cAAO,EAAC,CAAC,gBAAgB,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC3C,IAAA,iBAAU,GAAE;;2CACoB"}
@@ -14,7 +14,7 @@ export declare abstract class MysqlRepo<T extends Model<T>, ID = MysqlId> implem
14
14
  find(query: IMysqlRequest<T>): Promise<T[]>;
15
15
  count(query: IMysqlRequest<T>): Promise<number>;
16
16
  findOne(query: IMysqlRequest<T>): Promise<T>;
17
- create(body: T): Promise<T>;
17
+ create(body: Model<T>): Promise<T>;
18
18
  update(condition: ICondition<T>, body: DeepPartial<T>): Promise<T>;
19
19
  delete(condition: ICondition<T>, opts?: {
20
20
  force?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.repo.d.ts","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAkB,UAAU,EAAE,UAAU,EAAE,YAAY,EAAU,MAAM,cAAc,CAAC;AAIxH,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAG/C,8BAAsB,SAAS,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,OAAO,CAAE,YAAW,gBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,YAAY;IAK9G,SAAS,CAAC,YAAY,EAAE,YAAY;IACpC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;IAC7B,SAAS,CAAC,KAAK,EAAE,MAAM;IANf,SAAS,CAAC,aAAa,EAAE,aAAa,CAAC;IACvC,SAAS,CAAC,UAAU,EAAE,UAAU,CAAC;IAE3C,SAAS,aACG,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EACnB,KAAK,GAAE,MAAuB;IAGpC,YAAY;IAMZ,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAY3C,KAAK,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAM/C,OAAO,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAO5C,MAAM,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAK3B,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IASlE,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,EAAE,CAAA;KAAE,GAAG,OAAO,CAAC,CAAC,CAAC;IAWrF,OAAO,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,EAAE,CAAA;KAAE,GAAG,OAAO,CAAC,CAAC,CAAC;IAUrE,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;CAOzE"}
1
+ {"version":3,"file":"mysql.repo.d.ts","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,WAAW,EAEX,UAAU,EAEV,UAAU,EACV,YAAY,EAIb,MAAM,cAAc,CAAC;AAGtB,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,8BACsB,SAAS,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,OAAO,CAAE,YAAW,gBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,YAAY;IAK9G,SAAS,CAAC,YAAY,EAAE,YAAY;IACpC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;IAC7B,SAAS,CAAC,KAAK,EAAE,MAAM;IANf,SAAS,CAAC,aAAa,EAAE,aAAa,CAAC;IACvC,SAAS,CAAC,UAAU,EAAE,UAAU,CAAC;IAE3C,SAAS,aACG,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EACnB,KAAK,GAAE,MAAuB;IAGpC,YAAY;IAMZ,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAa3C,KAAK,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAM/C,OAAO,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAO5C,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAKlC,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IASlE,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,EAAE,CAAA;KAAE,GAAG,OAAO,CAAC,CAAC,CAAC;IAWrF,OAAO,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,EAAE,CAAA;KAAE,GAAG,OAAO,CAAC,CAAC,CAAC;IAUrE,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;CAOzE"}
@@ -11,10 +11,11 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.MysqlRepo = void 0;
13
13
  const core_1 = require("@joktec/core");
14
- const common_1 = require("@nestjs/common");
14
+ const sequelize_typescript_1 = require("sequelize-typescript");
15
+ const helpers_1 = require("./helpers");
15
16
  const mysql_exception_1 = require("./mysql.exception");
16
- const mysql_utils_1 = require("./mysql.utils");
17
- class MysqlRepo {
17
+ const mysql_service_1 = require("./mysql.service");
18
+ let MysqlRepo = class MysqlRepo {
18
19
  constructor(mysqlService, model, conId = core_1.DEFAULT_CON_ID) {
19
20
  this.mysqlService = mysqlService;
20
21
  this.model = model;
@@ -25,11 +26,13 @@ class MysqlRepo {
25
26
  await this.mysqlService.getModelSync(this.model, this.conId);
26
27
  }
27
28
  async find(query) {
28
- const options = (0, mysql_utils_1.preHandleQuery)(query);
29
+ const options = helpers_1.MysqlHelper.parseFilter(query);
29
30
  if (query.select)
30
- options.attributes = query.select.split(',');
31
+ options.attributes = (0, core_1.toArray)(query.select, { split: ',' });
31
32
  if (query.sort)
32
33
  options.order = Object.entries(query.sort);
34
+ if (query.limit)
35
+ options.limit = query.limit;
33
36
  if (query.limit && query.page) {
34
37
  options.limit = query.limit;
35
38
  options.offset = (query.page - 1) * query.limit;
@@ -37,20 +40,20 @@ class MysqlRepo {
37
40
  return this.model.findAll(options);
38
41
  }
39
42
  async count(query) {
40
- const options = (0, mysql_utils_1.preHandleQuery)(query);
43
+ const options = helpers_1.MysqlHelper.parseFilter(query);
41
44
  return this.model.count(options);
42
45
  }
43
46
  async findOne(query) {
44
- const options = (0, mysql_utils_1.preHandleQuery)(query);
47
+ const options = helpers_1.MysqlHelper.parseFilter(query);
45
48
  if (query.select)
46
- options.attributes = query.select.split(',');
49
+ options.attributes = (0, core_1.toArray)(query.select, { split: ',' });
47
50
  return this.model.findOne(options);
48
51
  }
49
52
  async create(body) {
50
53
  return this.model.create(body);
51
54
  }
52
55
  async update(condition, body) {
53
- const options = (0, mysql_utils_1.preHandleQuery)({ condition });
56
+ const options = helpers_1.MysqlHelper.parseFilter({ condition });
54
57
  const model = await this.model.findOne(options);
55
58
  if (!model)
56
59
  return null;
@@ -61,13 +64,13 @@ class MysqlRepo {
61
64
  const existModel = await this.findOne({ condition });
62
65
  if (!existModel)
63
66
  return null;
64
- const options = (0, mysql_utils_1.preHandleQuery)({ condition });
67
+ const options = helpers_1.MysqlHelper.parseFilter({ condition });
65
68
  options.force = (0, core_1.toBool)(opts?.force, false);
66
69
  await this.model.destroy(options);
67
70
  return existModel;
68
71
  }
69
72
  async restore(condition, opts) {
70
- const options = (0, mysql_utils_1.preHandleQuery)({ condition });
73
+ const options = helpers_1.MysqlHelper.parseFilter({ condition });
71
74
  await this.model.restore(options);
72
75
  if (!opts?.userId) {
73
76
  return this.findOne({ condition });
@@ -82,14 +85,14 @@ class MysqlRepo {
82
85
  return null;
83
86
  return row;
84
87
  }
85
- }
88
+ };
86
89
  exports.MysqlRepo = MysqlRepo;
87
90
  __decorate([
88
- (0, common_1.Inject)(),
91
+ (0, core_1.Inject)(),
89
92
  __metadata("design:type", core_1.ConfigService)
90
93
  ], MysqlRepo.prototype, "configService", void 0);
91
94
  __decorate([
92
- (0, common_1.Inject)(),
95
+ (0, core_1.Inject)(),
93
96
  __metadata("design:type", core_1.LogService)
94
97
  ], MysqlRepo.prototype, "logService", void 0);
95
98
  __decorate([
@@ -113,7 +116,7 @@ __decorate([
113
116
  __decorate([
114
117
  mysql_exception_1.MysqlCatch,
115
118
  __metadata("design:type", Function),
116
- __metadata("design:paramtypes", [Object]),
119
+ __metadata("design:paramtypes", [sequelize_typescript_1.Model]),
117
120
  __metadata("design:returntype", Promise)
118
121
  ], MysqlRepo.prototype, "create", null);
119
122
  __decorate([
@@ -140,4 +143,8 @@ __decorate([
140
143
  __metadata("design:paramtypes", [Object, Object]),
141
144
  __metadata("design:returntype", Promise)
142
145
  ], MysqlRepo.prototype, "upsert", null);
146
+ exports.MysqlRepo = MysqlRepo = __decorate([
147
+ (0, core_1.Injectable)(),
148
+ __metadata("design:paramtypes", [mysql_service_1.MysqlService, Object, String])
149
+ ], MysqlRepo);
143
150
  //# sourceMappingURL=mysql.repo.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mysql.repo.js","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mysql.repo.js","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"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"}