@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.
- package/dist/helpers/index.d.ts +2 -0
- package/dist/helpers/index.d.ts.map +1 -0
- package/dist/helpers/index.js +18 -0
- package/dist/helpers/index.js.map +1 -0
- package/dist/helpers/mysql.helper.d.ts +7 -0
- package/dist/helpers/mysql.helper.d.ts.map +1 -0
- package/dist/helpers/mysql.helper.js +60 -0
- package/dist/helpers/mysql.helper.js.map +1 -0
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/models/mysql.model.d.ts +2 -1
- package/dist/models/mysql.model.d.ts.map +1 -1
- package/dist/models/mysql.model.js.map +1 -1
- package/dist/models/mysql.request.d.ts +2 -2
- package/dist/models/mysql.request.d.ts.map +1 -1
- package/dist/mysql.client.d.ts +2 -2
- package/dist/mysql.client.d.ts.map +1 -1
- package/dist/mysql.config.d.ts +4 -5
- package/dist/mysql.config.d.ts.map +1 -1
- package/dist/mysql.config.js +7 -9
- package/dist/mysql.config.js.map +1 -1
- package/dist/mysql.repo.d.ts +1 -1
- package/dist/mysql.repo.d.ts.map +1 -1
- package/dist/mysql.repo.js +22 -15
- package/dist/mysql.repo.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -7
- package/dist/__tests__/mysql.utils.spec.d.ts +0 -2
- package/dist/__tests__/mysql.utils.spec.d.ts.map +0 -1
- package/dist/__tests__/mysql.utils.spec.js +0 -26
- package/dist/__tests__/mysql.utils.spec.js.map +0 -1
- package/dist/mysql.utils.d.ts +0 -7
- package/dist/mysql.utils.d.ts.map +0 -1
- package/dist/mysql.utils.js +0 -53
- package/dist/mysql.utils.js.map +0 -1
|
@@ -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
package/dist/index.d.ts.map
CHANGED
|
@@ -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,
|
|
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
|
|
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 +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,
|
|
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,
|
|
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 {
|
|
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
|
|
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,
|
|
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"}
|
package/dist/mysql.client.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import {
|
|
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
|
|
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,
|
|
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"}
|
package/dist/mysql.config.d.ts
CHANGED
|
@@ -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
|
|
23
|
-
dialect
|
|
24
|
-
host
|
|
25
|
-
port
|
|
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,
|
|
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"}
|
package/dist/mysql.config.js
CHANGED
|
@@ -57,14 +57,12 @@ var Dialect;
|
|
|
57
57
|
class MysqlConfig extends core_1.ClientConfig {
|
|
58
58
|
constructor(props) {
|
|
59
59
|
super(props);
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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.
|
|
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);
|
package/dist/mysql.config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.config.js","sourceRoot":"","sources":["../src/mysql.config.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
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"}
|
package/dist/mysql.repo.d.ts
CHANGED
|
@@ -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;
|
package/dist/mysql.repo.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.repo.d.ts","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
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"}
|
package/dist/mysql.repo.js
CHANGED
|
@@ -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
|
|
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
|
|
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 =
|
|
29
|
+
const options = helpers_1.MysqlHelper.parseFilter(query);
|
|
29
30
|
if (query.select)
|
|
30
|
-
options.attributes = query.select
|
|
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 =
|
|
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 =
|
|
47
|
+
const options = helpers_1.MysqlHelper.parseFilter(query);
|
|
45
48
|
if (query.select)
|
|
46
|
-
options.attributes = query.select
|
|
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 =
|
|
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 =
|
|
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 =
|
|
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,
|
|
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,
|
|
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", [
|
|
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
|
package/dist/mysql.repo.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.repo.js","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"mysql.repo.js","sourceRoot":"","sources":["../src/mysql.repo.ts"],"names":[],"mappings":"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"}
|