@joktec/mysql 0.0.158 → 0.0.160
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/mysql.client.d.ts +8 -0
- package/dist/mysql.client.d.ts.map +1 -1
- package/dist/mysql.client.js +2 -0
- package/dist/mysql.client.js.map +1 -1
- package/dist/mysql.module.d.ts +2 -2
- package/dist/mysql.module.d.ts.map +1 -1
- package/dist/mysql.module.js +8 -3
- package/dist/mysql.module.js.map +1 -1
- package/dist/mysql.service.d.ts +3 -3
- package/dist/mysql.service.d.ts.map +1 -1
- package/dist/mysql.service.js +7 -6
- package/dist/mysql.service.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -3
package/dist/mysql.client.d.ts
CHANGED
|
@@ -1,6 +1,14 @@
|
|
|
1
1
|
import { Client, DeepPartial, IBaseRepository } from '@joktec/core';
|
|
2
2
|
import { Model, ModelCtor, Repository, Sequelize } from 'sequelize-typescript';
|
|
3
3
|
import { MysqlConfig } from './mysql.config';
|
|
4
|
+
export declare const MODEL_REGISTRY_KEY = "MODEL_REGISTRY_KEY";
|
|
5
|
+
export interface MysqlModuleOptions {
|
|
6
|
+
models?: ModelCtor[];
|
|
7
|
+
conId?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface MysqlModelRegistry {
|
|
10
|
+
[conId: string]: ModelCtor[];
|
|
11
|
+
}
|
|
4
12
|
export interface MysqlClient extends Client<MysqlConfig, Sequelize> {
|
|
5
13
|
getModel<T extends Model<T>>(model: ModelCtor<T>, conId?: string): ModelCtor<T>;
|
|
6
14
|
getRepository<T extends Model<T>>(model: ModelCtor<T>, conId?: string): Repository<T>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.client.d.ts","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC/E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,MAAM,WAAW,WAAY,SAAQ,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC;IACjE,QAAQ,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;IAEhF,aAAa,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;CACvF;AAED,MAAM,WAAW,gBAAgB,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAE,SAAQ,eAAe,CAAC,CAAC,EAAE,EAAE,CAAC;IACtF,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CACpE"}
|
|
1
|
+
{"version":3,"file":"mysql.client.d.ts","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC/E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,eAAO,MAAM,kBAAkB,uBAAuB,CAAC;AAEvD,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,EAAE,SAAS,EAAE,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAAE,CAAC;CAC9B;AAED,MAAM,WAAW,WAAY,SAAQ,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC;IACjE,QAAQ,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;IAEhF,aAAa,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;CACvF;AAED,MAAM,WAAW,gBAAgB,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAE,SAAQ,eAAe,CAAC,CAAC,EAAE,EAAE,CAAC;IACtF,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CACpE"}
|
package/dist/mysql.client.js
CHANGED
package/dist/mysql.client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.client.js","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"mysql.client.js","sourceRoot":"","sources":["../src/mysql.client.ts"],"names":[],"mappings":";;;AAIa,QAAA,kBAAkB,GAAG,oBAAoB,CAAC"}
|
package/dist/mysql.module.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DynamicModule } from '@joktec/core';
|
|
2
|
-
import {
|
|
2
|
+
import { MysqlModuleOptions } from './mysql.client';
|
|
3
3
|
export declare class MysqlModule {
|
|
4
|
-
static forRoot(
|
|
4
|
+
static forRoot(opts?: MysqlModuleOptions | MysqlModuleOptions[]): DynamicModule;
|
|
5
5
|
}
|
|
6
6
|
//# sourceMappingURL=mysql.module.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.module.d.ts","sourceRoot":"","sources":["../src/mysql.module.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"mysql.module.d.ts","sourceRoot":"","sources":["../src/mysql.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,aAAa,EAA2B,MAAM,cAAc,CAAC;AACtF,OAAO,EAA0C,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAG5F,qBAKa,WAAW;IACtB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,kBAAkB,GAAG,kBAAkB,EAAE,GAAG,aAAa;CAYhF"}
|
package/dist/mysql.module.js
CHANGED
|
@@ -9,12 +9,17 @@ var MysqlModule_1;
|
|
|
9
9
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
10
|
exports.MysqlModule = void 0;
|
|
11
11
|
const core_1 = require("@joktec/core");
|
|
12
|
+
const mysql_client_1 = require("./mysql.client");
|
|
12
13
|
const mysql_service_1 = require("./mysql.service");
|
|
13
14
|
let MysqlModule = MysqlModule_1 = class MysqlModule {
|
|
14
|
-
static forRoot(
|
|
15
|
+
static forRoot(opts) {
|
|
16
|
+
const providers = (0, core_1.toArray)(opts).reduce((curr, acc) => {
|
|
17
|
+
curr[acc.conId || core_1.DEFAULT_CON_ID] = acc.models;
|
|
18
|
+
return curr;
|
|
19
|
+
}, {});
|
|
15
20
|
return {
|
|
16
21
|
module: MysqlModule_1,
|
|
17
|
-
providers: [mysql_service_1.MysqlService, { provide:
|
|
22
|
+
providers: [mysql_service_1.MysqlService, { provide: mysql_client_1.MODEL_REGISTRY_KEY, useValue: providers }],
|
|
18
23
|
exports: [mysql_service_1.MysqlService],
|
|
19
24
|
};
|
|
20
25
|
}
|
|
@@ -23,7 +28,7 @@ exports.MysqlModule = MysqlModule;
|
|
|
23
28
|
exports.MysqlModule = MysqlModule = MysqlModule_1 = __decorate([
|
|
24
29
|
(0, core_1.Global)(),
|
|
25
30
|
(0, core_1.Module)({
|
|
26
|
-
providers: [mysql_service_1.MysqlService, { provide:
|
|
31
|
+
providers: [mysql_service_1.MysqlService, { provide: mysql_client_1.MODEL_REGISTRY_KEY, useValue: { [core_1.DEFAULT_CON_ID]: [] } }],
|
|
27
32
|
exports: [mysql_service_1.MysqlService],
|
|
28
33
|
})
|
|
29
34
|
], MysqlModule);
|
package/dist/mysql.module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.module.js","sourceRoot":"","sources":["../src/mysql.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"mysql.module.js","sourceRoot":"","sources":["../src/mysql.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,uCAAsF;AACtF,iDAA4F;AAC5F,mDAA+C;AAOxC,IAAM,WAAW,mBAAjB,MAAM,WAAW;IACtB,MAAM,CAAC,OAAO,CAAC,IAAgD;QAC7D,MAAM,SAAS,GAAuB,IAAA,cAAO,EAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,IAAY,EAAE,GAAuB,EAAE,EAAE;YACnG,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,qBAAc,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC;YAC/C,OAAO,IAAI,CAAC;QACd,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,OAAO;YACL,MAAM,EAAE,aAAW;YACnB,SAAS,EAAE,CAAC,4BAAY,EAAE,EAAE,OAAO,EAAE,iCAAkB,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;YAC/E,OAAO,EAAE,CAAC,4BAAY,CAAC;SACxB,CAAC;IACJ,CAAC;CACF,CAAA;AAbY,kCAAW;sBAAX,WAAW;IALvB,IAAA,aAAM,GAAE;IACR,IAAA,aAAM,EAAC;QACN,SAAS,EAAE,CAAC,4BAAY,EAAE,EAAE,OAAO,EAAE,iCAAkB,EAAE,QAAQ,EAAE,EAAE,CAAC,qBAAc,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC;QAC9F,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAavB"}
|
package/dist/mysql.service.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { AbstractClientService } from '@joktec/core';
|
|
2
2
|
import { Model, ModelCtor, Repository, Sequelize } from 'sequelize-typescript';
|
|
3
|
-
import { MysqlClient } from './mysql.client';
|
|
3
|
+
import { MysqlClient, MysqlModelRegistry } from './mysql.client';
|
|
4
4
|
import { MysqlConfig } from './mysql.config';
|
|
5
5
|
export declare class MysqlService extends AbstractClientService<MysqlConfig, Sequelize> implements MysqlClient {
|
|
6
|
-
private
|
|
7
|
-
constructor(
|
|
6
|
+
private modelRegistry;
|
|
7
|
+
constructor(modelRegistry: MysqlModelRegistry);
|
|
8
8
|
protected init(config: MysqlConfig): Promise<Sequelize>;
|
|
9
9
|
start(client: Sequelize, conId?: string): Promise<void>;
|
|
10
10
|
stop(client: Sequelize, conId?: string): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.service.d.ts","sourceRoot":"","sources":["../src/mysql.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAA4D,MAAM,cAAc,CAAC;AAE/G,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAoB,MAAM,sBAAsB,CAAC;AACjG,OAAO,
|
|
1
|
+
{"version":3,"file":"mysql.service.d.ts","sourceRoot":"","sources":["../src/mysql.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAA4D,MAAM,cAAc,CAAC;AAE/G,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAoB,MAAM,sBAAsB,CAAC;AACjG,OAAO,EAAsB,WAAW,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACrF,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAI7C,qBACa,YAAa,SAAQ,qBAAqB,CAAC,WAAW,EAAE,SAAS,CAAE,YAAW,WAAW;IAC5D,OAAO,CAAC,aAAa;gBAAb,aAAa,EAAE,kBAAkB;cAKjE,IAAI,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;IAsBvD,KAAK,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,GAAE,MAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBvE,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,GAAE,MAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;IASrE,QAAQ,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,GAAE,MAAuB,GAAG,SAAS,CAAC,CAAC,CAAC;IAIxG,aAAa,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,GAAE,MAAuB,GAAG,UAAU,CAAC,CAAC,CAAC;CAG7G"}
|
package/dist/mysql.service.js
CHANGED
|
@@ -16,12 +16,13 @@ exports.MysqlService = void 0;
|
|
|
16
16
|
const core_1 = require("@joktec/core");
|
|
17
17
|
const lodash_1 = require("lodash");
|
|
18
18
|
const sequelize_typescript_1 = require("sequelize-typescript");
|
|
19
|
+
const mysql_client_1 = require("./mysql.client");
|
|
19
20
|
const mysql_config_1 = require("./mysql.config");
|
|
20
21
|
const RETRY_OPTS = 'mysql.retry';
|
|
21
22
|
let MysqlService = class MysqlService extends core_1.AbstractClientService {
|
|
22
|
-
constructor(
|
|
23
|
+
constructor(modelRegistry) {
|
|
23
24
|
super('mysql', mysql_config_1.MysqlConfig);
|
|
24
|
-
this.
|
|
25
|
+
this.modelRegistry = modelRegistry;
|
|
25
26
|
}
|
|
26
27
|
async init(config) {
|
|
27
28
|
const connection = (0, lodash_1.pick)(config, ['host', 'port', 'username', 'password', 'database']);
|
|
@@ -49,8 +50,8 @@ let MysqlService = class MysqlService extends core_1.AbstractClientService {
|
|
|
49
50
|
try {
|
|
50
51
|
await client.authenticate();
|
|
51
52
|
this.logService.info('`%s` Connected to MySQL successfully', conId);
|
|
52
|
-
if (this.
|
|
53
|
-
client.addModels(this.
|
|
53
|
+
if (this.modelRegistry[conId]) {
|
|
54
|
+
client.addModels(this.modelRegistry[conId]);
|
|
54
55
|
if (config.sync) {
|
|
55
56
|
await client.sync({ alter: { drop: false } });
|
|
56
57
|
this.logService.info('`%s` Sync MySQL schema successfully', conId);
|
|
@@ -86,7 +87,7 @@ __decorate([
|
|
|
86
87
|
], MysqlService.prototype, "init", null);
|
|
87
88
|
exports.MysqlService = MysqlService = __decorate([
|
|
88
89
|
(0, core_1.Injectable)(),
|
|
89
|
-
__param(0, (0, core_1.Inject)(
|
|
90
|
-
__metadata("design:paramtypes", [
|
|
90
|
+
__param(0, (0, core_1.Inject)(mysql_client_1.MODEL_REGISTRY_KEY)),
|
|
91
|
+
__metadata("design:paramtypes", [Object])
|
|
91
92
|
], MysqlService);
|
|
92
93
|
//# sourceMappingURL=mysql.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.service.js","sourceRoot":"","sources":["../src/mysql.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,uCAA+G;AAC/G,mCAA8B;AAC9B,+DAAiG;
|
|
1
|
+
{"version":3,"file":"mysql.service.js","sourceRoot":"","sources":["../src/mysql.service.ts"],"names":[],"mappings":"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"}
|