@diyaner/egg-typeorm 1.0.1 → 2.0.1
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 +75 -75
- package/README.zh_CN.md +4 -4
- package/agent.js +20 -6
- package/app.js +15 -5
- package/config/config.default.js +1 -1
- package/index.d.ts +79 -37
- package/lib/Logger.d.ts +2 -2
- package/lib/Logger.js +1 -1
- package/lib/MyDataSource.d.ts +8 -0
- package/lib/MyDataSource.js +51 -0
- package/lib/connection.d.ts +7 -2
- package/lib/connection.js +47 -29
- package/lib/loader.d.ts +2 -2
- package/lib/loader.js +8 -5
- package/package.json +64 -64
- package/tshelper.js +50 -24
package/README.md
CHANGED
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
# egg-ts-template
|
|
2
|
-
|
|
3
|
-
[![NPM version][npm-image]][npm-url]
|
|
4
|
-
[![build status][travis-image]][travis-url]
|
|
5
|
-
[![Test coverage][codecov-image]][codecov-url]
|
|
6
|
-
[![David deps][david-image]][david-url]
|
|
7
|
-
[![Known Vulnerabilities][snyk-image]][snyk-url]
|
|
8
|
-
[![npm download][download-image]][download-url]
|
|
9
|
-
|
|
10
|
-
[npm-image]: https://img.shields.io/npm/v/egg-ts-template.svg?style=flat-square
|
|
11
|
-
[npm-url]: https://npmjs.org/package/egg-ts-template
|
|
12
|
-
[travis-image]: https://img.shields.io/travis/eggjs/egg-ts-template.svg?style=flat-square
|
|
13
|
-
[travis-url]: https://travis-ci.org/eggjs/egg-ts-template
|
|
14
|
-
[codecov-image]: https://img.shields.io/codecov/c/github/eggjs/egg-ts-template.svg?style=flat-square
|
|
15
|
-
[codecov-url]: https://codecov.io/github/eggjs/egg-ts-template?branch=master
|
|
16
|
-
[david-image]: https://img.shields.io/david/eggjs/egg-ts-template.svg?style=flat-square
|
|
17
|
-
[david-url]: https://david-dm.org/eggjs/egg-ts-template
|
|
18
|
-
[snyk-image]: https://snyk.io/test/npm/egg-ts-template/badge.svg?style=flat-square
|
|
19
|
-
[snyk-url]: https://snyk.io/test/npm/egg-ts-template
|
|
20
|
-
[download-image]: https://img.shields.io/npm/dm/egg-ts-template.svg?style=flat-square
|
|
21
|
-
[download-url]: https://npmjs.org/package/egg-ts-template
|
|
22
|
-
|
|
23
|
-
<!--
|
|
24
|
-
Description here.
|
|
25
|
-
-->
|
|
26
|
-
|
|
27
|
-
## Install
|
|
28
|
-
|
|
29
|
-
```bash
|
|
30
|
-
$ npm i @diyaner/egg-typeorm --save
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Usage
|
|
34
|
-
|
|
35
|
-
```js
|
|
36
|
-
// {app_root}/config/plugin.js
|
|
37
|
-
exports.typeorm = {
|
|
38
|
-
enable: true,
|
|
39
|
-
package: '@diyaner/egg-typeorm',
|
|
40
|
-
};
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
## Configuration
|
|
44
|
-
|
|
45
|
-
```js
|
|
46
|
-
// {app_root}/config/config.default.js
|
|
47
|
-
exports.typeorm = {
|
|
48
|
-
agent:true,
|
|
49
|
-
datasources:[
|
|
50
|
-
{...}
|
|
51
|
-
]
|
|
52
|
-
};
|
|
53
|
-
```
|
|
54
|
-
|
|
55
|
-
see [config/config.default.js](config/config.default.js) for more detail.
|
|
56
|
-
|
|
57
|
-
## Example
|
|
58
|
-
|
|
59
|
-
<!-- example here -->
|
|
60
|
-
- 实体entity放在app/entity目录下
|
|
61
|
-
- 实体必须使用默认default导出,这样才能正确使用ets自动类型声明并绑定给app.entity
|
|
62
|
-
- 实体default导出,同时还是必须要设置class的类名,否则typeorm无法正确解析设置数据库表名
|
|
63
|
-
- 如果有多个连接,则每个连接必须提供name属性,且唯一。name也是entity下的子目录区分。这是entity目录下直接实体将挂在第一个数据库配置连接上。比如连接2使用db2,则entity目录下db2目录下的entity才会绑定给这个连接。
|
|
64
|
-
- 如果单个连接,则所有实体entity都会挂在这个连接上,不会按二级目录区分。
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
## Questions & Suggestions
|
|
70
|
-
|
|
71
|
-
Please open an issue [here](https://github.com/eggjs/egg/issues).
|
|
72
|
-
|
|
73
|
-
## License
|
|
74
|
-
|
|
75
|
-
[MIT](LICENSE)
|
|
1
|
+
# egg-ts-template
|
|
2
|
+
|
|
3
|
+
[![NPM version][npm-image]][npm-url]
|
|
4
|
+
[![build status][travis-image]][travis-url]
|
|
5
|
+
[![Test coverage][codecov-image]][codecov-url]
|
|
6
|
+
[![David deps][david-image]][david-url]
|
|
7
|
+
[![Known Vulnerabilities][snyk-image]][snyk-url]
|
|
8
|
+
[![npm download][download-image]][download-url]
|
|
9
|
+
|
|
10
|
+
[npm-image]: https://img.shields.io/npm/v/egg-ts-template.svg?style=flat-square
|
|
11
|
+
[npm-url]: https://npmjs.org/package/egg-ts-template
|
|
12
|
+
[travis-image]: https://img.shields.io/travis/eggjs/egg-ts-template.svg?style=flat-square
|
|
13
|
+
[travis-url]: https://travis-ci.org/eggjs/egg-ts-template
|
|
14
|
+
[codecov-image]: https://img.shields.io/codecov/c/github/eggjs/egg-ts-template.svg?style=flat-square
|
|
15
|
+
[codecov-url]: https://codecov.io/github/eggjs/egg-ts-template?branch=master
|
|
16
|
+
[david-image]: https://img.shields.io/david/eggjs/egg-ts-template.svg?style=flat-square
|
|
17
|
+
[david-url]: https://david-dm.org/eggjs/egg-ts-template
|
|
18
|
+
[snyk-image]: https://snyk.io/test/npm/egg-ts-template/badge.svg?style=flat-square
|
|
19
|
+
[snyk-url]: https://snyk.io/test/npm/egg-ts-template
|
|
20
|
+
[download-image]: https://img.shields.io/npm/dm/egg-ts-template.svg?style=flat-square
|
|
21
|
+
[download-url]: https://npmjs.org/package/egg-ts-template
|
|
22
|
+
|
|
23
|
+
<!--
|
|
24
|
+
Description here.
|
|
25
|
+
-->
|
|
26
|
+
|
|
27
|
+
## Install
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
$ npm i @diyaner/egg-typeorm --save
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Usage
|
|
34
|
+
|
|
35
|
+
```js
|
|
36
|
+
// {app_root}/config/plugin.js
|
|
37
|
+
exports.typeorm = {
|
|
38
|
+
enable: true,
|
|
39
|
+
package: '@diyaner/egg-typeorm',
|
|
40
|
+
};
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## Configuration
|
|
44
|
+
|
|
45
|
+
```js
|
|
46
|
+
// {app_root}/config/config.default.js
|
|
47
|
+
exports.typeorm = {
|
|
48
|
+
agent:true,
|
|
49
|
+
datasources:[
|
|
50
|
+
{...}
|
|
51
|
+
]
|
|
52
|
+
};
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
see [config/config.default.js](config/config.default.js) for more detail.
|
|
56
|
+
|
|
57
|
+
## Example
|
|
58
|
+
|
|
59
|
+
<!-- example here -->
|
|
60
|
+
- 实体entity放在app/entity目录下
|
|
61
|
+
- 实体必须使用默认default导出,这样才能正确使用ets自动类型声明并绑定给app.entity
|
|
62
|
+
- 实体default导出,同时还是必须要设置class的类名,否则typeorm无法正确解析设置数据库表名
|
|
63
|
+
- 如果有多个连接,则每个连接必须提供name属性,且唯一。name也是entity下的子目录区分。这是entity目录下直接实体将挂在第一个数据库配置连接上。比如连接2使用db2,则entity目录下db2目录下的entity才会绑定给这个连接。
|
|
64
|
+
- 如果单个连接,则所有实体entity都会挂在这个连接上,不会按二级目录区分。
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
## Questions & Suggestions
|
|
70
|
+
|
|
71
|
+
Please open an issue [here](https://github.com/eggjs/egg/issues).
|
|
72
|
+
|
|
73
|
+
## License
|
|
74
|
+
|
|
75
|
+
[MIT](LICENSE)
|
package/README.zh_CN.md
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
# egg-
|
|
1
|
+
# egg-typeorm
|
|
2
2
|
|
|
3
3
|
[![NPM version][npm-image]][npm-url]
|
|
4
4
|
[![build status][travis-image]][travis-url]
|
|
@@ -28,7 +28,7 @@ Description here.
|
|
|
28
28
|
|
|
29
29
|
### 依赖的 egg 版本
|
|
30
30
|
|
|
31
|
-
egg-
|
|
31
|
+
@diyaner/egg-typeorm 版本 | egg 3.x
|
|
32
32
|
--- | ---
|
|
33
33
|
1.x | 😁
|
|
34
34
|
0.x | ❌
|
|
@@ -47,9 +47,9 @@ egg-ts-template 版本 | egg 1.x
|
|
|
47
47
|
|
|
48
48
|
```js
|
|
49
49
|
// config/plugin.js
|
|
50
|
-
exports.
|
|
50
|
+
exports.typeorm = {
|
|
51
51
|
enable: true,
|
|
52
|
-
package: 'egg-
|
|
52
|
+
package: '@diyaner/egg-typeorm',
|
|
53
53
|
};
|
|
54
54
|
```
|
|
55
55
|
|
package/agent.js
CHANGED
|
@@ -1,21 +1,35 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
require("reflect-metadata");
|
|
4
|
+
const typeorm = require("typeorm");
|
|
4
5
|
const loader_1 = require("./lib/loader");
|
|
5
6
|
const connection_1 = require("./lib/connection");
|
|
6
7
|
class EggTypeOrmAppBoot {
|
|
7
8
|
constructor(app) {
|
|
8
9
|
this.app = app;
|
|
10
|
+
if (this.app.config.typeorm.agent) {
|
|
11
|
+
this.app.typeorm = {};
|
|
12
|
+
this.app.typeorm.typeORM = typeorm;
|
|
13
|
+
this.app.typeorm.datasources = {};
|
|
14
|
+
this.app.typeorm.entites = { all: [], level1: [], dirs: {} };
|
|
15
|
+
this.app.typeorm.createTypeORMDataSources = connection_1.createTypeORMDataSources;
|
|
16
|
+
}
|
|
9
17
|
}
|
|
10
|
-
configDidLoad() {
|
|
18
|
+
configDidLoad() { }
|
|
19
|
+
async didLoad() { }
|
|
20
|
+
async willReady() {
|
|
11
21
|
if (this.app.config.typeorm.agent) {
|
|
12
|
-
this.app.typeorm = this.app.typeorm || {
|
|
13
|
-
dataSource: {},
|
|
14
|
-
};
|
|
15
22
|
(0, loader_1.default)(this.app);
|
|
16
|
-
(0, connection_1.default)(this.app);
|
|
23
|
+
await (0, connection_1.default)(this.app);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async beforeClose() {
|
|
27
|
+
if (this.app.config.typeorm.agent) {
|
|
28
|
+
for (const ds of Object.keys(this.app.typeorm.datasources)) {
|
|
29
|
+
await this.app.typeorm.datasources[ds].destroy();
|
|
30
|
+
}
|
|
17
31
|
}
|
|
18
32
|
}
|
|
19
33
|
}
|
|
20
34
|
exports.default = EggTypeOrmAppBoot;
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLDRCQUEwQjtBQUMxQixtQ0FBbUM7QUFFbkMseUNBQXNDO0FBQ3RDLGlEQUF5RTtBQUV6RSxNQUFxQixpQkFBaUI7SUFFckMsWUFBWSxHQUFVO1FBQ3JCLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBRWYsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQ2xDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxHQUFHLEVBQVMsQ0FBQztZQUM3QixJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1lBQ25DLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsR0FBRyxFQUFFLENBQUM7WUFDbEMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsT0FBTyxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQztZQUM3RCxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyx3QkFBd0IsR0FBRyxxQ0FBd0IsQ0FBQztTQUNyRTtJQUNGLENBQUM7SUFDRCxhQUFhLEtBQVUsQ0FBQztJQUV4QixLQUFLLENBQUMsT0FBTyxLQUFJLENBQUM7SUFFbEIsS0FBSyxDQUFDLFNBQVM7UUFDZCxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUU7WUFDbEMsSUFBQSxnQkFBVSxFQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNyQixNQUFNLElBQUEsb0JBQVcsRUFBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDNUI7SUFDRixDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQVc7UUFDaEIsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQ2xDLEtBQUssTUFBTSxFQUFFLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRTtnQkFDM0QsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUM7YUFDakQ7U0FDRDtJQUNGLENBQUM7Q0FDRDtBQS9CRCxvQ0ErQkMifQ==
|
package/app.js
CHANGED
|
@@ -7,13 +7,23 @@ const connection_1 = require("./lib/connection");
|
|
|
7
7
|
class EggTypeOrmAppBoot {
|
|
8
8
|
constructor(app) {
|
|
9
9
|
this.app = app;
|
|
10
|
+
this.app.typeorm = {};
|
|
11
|
+
this.app.typeorm.typeORM = typeorm;
|
|
12
|
+
this.app.typeorm.datasources = {};
|
|
13
|
+
this.app.typeorm.entites = { all: [], level1: [], dirs: {} };
|
|
14
|
+
this.app.typeorm.createTypeORMDataSources = connection_1.createTypeORMDataSources;
|
|
10
15
|
}
|
|
11
|
-
configDidLoad() {
|
|
12
|
-
|
|
13
|
-
|
|
16
|
+
configDidLoad() { }
|
|
17
|
+
async didLoad() { }
|
|
18
|
+
async willReady() {
|
|
14
19
|
(0, loader_1.default)(this.app);
|
|
15
|
-
(0, connection_1.default)(this.app);
|
|
20
|
+
await (0, connection_1.default)(this.app);
|
|
21
|
+
}
|
|
22
|
+
async beforeClose() {
|
|
23
|
+
for (const ds of Object.keys(this.app.typeorm.datasources)) {
|
|
24
|
+
await this.app.typeorm.datasources[ds].destroy();
|
|
25
|
+
}
|
|
16
26
|
}
|
|
17
27
|
}
|
|
18
28
|
exports.default = EggTypeOrmAppBoot;
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXBwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsNEJBQTBCO0FBRTFCLG1DQUFtQztBQUduQyx5Q0FBc0M7QUFDdEMsaURBQXlFO0FBRXpFLE1BQXFCLGlCQUFpQjtJQUVyQyxZQUFZLEdBQWdCO1FBQzNCLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBRWYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEdBQUcsRUFBUyxDQUFDO1FBQzdCLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDbkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsV0FBVyxHQUFHLEVBQUUsQ0FBQztRQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDO1FBQzdELElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLHdCQUF3QixHQUFHLHFDQUF3QixDQUFDO0lBQ3RFLENBQUM7SUFDRCxhQUFhLEtBQVUsQ0FBQztJQUV4QixLQUFLLENBQUMsT0FBTyxLQUFJLENBQUM7SUFHbEIsS0FBSyxDQUFDLFNBQVM7UUFDZCxJQUFBLGdCQUFVLEVBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3JCLE1BQU0sSUFBQSxvQkFBVyxFQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQVc7UUFDaEIsS0FBSyxNQUFNLEVBQUUsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQzNELE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQ2pEO0lBQ0YsQ0FBQztDQUNEO0FBMUJELG9DQTBCQyJ9
|
package/config/config.default.js
CHANGED
|
@@ -7,4 +7,4 @@ exports.default = () => {
|
|
|
7
7
|
};
|
|
8
8
|
return config;
|
|
9
9
|
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmRlZmF1bHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjb25maWcuZGVmYXVsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxZQUFZLENBQUM7O0FBVWIsa0JBQWUsR0FBRyxFQUFFO0lBQ25CLE1BQU0sTUFBTSxHQUFHLEVBQWdDLENBQUM7SUFDaEQsTUFBTSxDQUFDLE9BQU8sR0FBRztRQUNoQixLQUFLLEVBQUUsS0FBSztLQUNaLENBQUM7SUFDRixPQUFPLE1BQU0sQ0FBQztBQUNmLENBQUMsQ0FBQyJ9
|
package/index.d.ts
CHANGED
|
@@ -1,37 +1,79 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* @copyright: Huang Ding
|
|
3
|
-
* @Author: ding-cx
|
|
4
|
-
* @Date: 2021-02-21 17:47:08
|
|
5
|
-
* @LastEditors: ding-cx
|
|
6
|
-
* @LastEditTime: 2021-02-21 17:47:51
|
|
7
|
-
* @Description: file content
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import Egg from "egg";
|
|
11
|
-
import * as typeorm from "typeorm";
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
1
|
+
/*
|
|
2
|
+
* @copyright: Huang Ding
|
|
3
|
+
* @Author: ding-cx
|
|
4
|
+
* @Date: 2021-02-21 17:47:08
|
|
5
|
+
* @LastEditors: ding-cx
|
|
6
|
+
* @LastEditTime: 2021-02-21 17:47:51
|
|
7
|
+
* @Description: file content
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import Egg from "egg";
|
|
11
|
+
import * as typeorm from "typeorm";
|
|
12
|
+
import { createTypeORMDataSources } from "./lib/connection";
|
|
13
|
+
import { MyDataSource } from "./lib/MyDataSource";
|
|
14
|
+
|
|
15
|
+
declare module "egg" {
|
|
16
|
+
/** egg插件的typeorm的连接选项 */
|
|
17
|
+
|
|
18
|
+
/** typeorm 已弃用name属性,暂时加上 */
|
|
19
|
+
type EggConfigTypeormDataSourceOptions = {
|
|
20
|
+
name?: string;
|
|
21
|
+
/** 实体类所在目录名 */
|
|
22
|
+
entityDir?: string;
|
|
23
|
+
} & typeorm.DataSourceOptions;
|
|
24
|
+
interface EggAppConfig {
|
|
25
|
+
/** typeorm 数据库连接配置 */
|
|
26
|
+
typeorm: {
|
|
27
|
+
/** 是否在agent上启用typeorm */
|
|
28
|
+
agent: boolean;
|
|
29
|
+
datasources: EggConfigTypeormDataSourceOptions[];
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
interface Application {
|
|
34
|
+
/** 绑定所有typeorm的导出,并添加连接实例map */
|
|
35
|
+
typeorm: {
|
|
36
|
+
typeORM: typeof typeorm;
|
|
37
|
+
/** 数据库连接实例 其key为配置时的name属性 */
|
|
38
|
+
datasources: {
|
|
39
|
+
[key: string]: MyDataSource;
|
|
40
|
+
};
|
|
41
|
+
/** 绑定实体类列表 */
|
|
42
|
+
entites: {
|
|
43
|
+
all: any[];
|
|
44
|
+
// 第一层中直接定义的实体,直接附加给第一个连接。(因为把第一个连接作为默认主连接数据库)
|
|
45
|
+
level1: any[];
|
|
46
|
+
// 按第一层文件夹区分的实体,是要对应到数据库连接name属性的。也就是不同name对应不同实体目录
|
|
47
|
+
dirs: {
|
|
48
|
+
[key: string]: any[];
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
/** 挂载app上,可动态创建typeORM实例 */
|
|
52
|
+
createTypeORMDataSources: createTypeORMDataSources;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
interface Agent {
|
|
57
|
+
/** 绑定所有typeorm的导出,并添加连接实例map */
|
|
58
|
+
typeorm: {
|
|
59
|
+
typeORM: typeof typeorm;
|
|
60
|
+
/** 数据库连接实例 其key为配置时的name属性 */
|
|
61
|
+
datasources: {
|
|
62
|
+
[key: string]: MyDataSource;
|
|
63
|
+
};
|
|
64
|
+
/** 绑定实体类列表 */
|
|
65
|
+
entites: {
|
|
66
|
+
all: any[];
|
|
67
|
+
// 第一层中直接定义的实体,直接附加给第一个连接。(因为把第一个连接作为默认主连接数据库)
|
|
68
|
+
level1: any[];
|
|
69
|
+
// 按第一层文件夹区分的实体,是要对应到数据库连接name属性的。也就是不同name对应不同实体目录
|
|
70
|
+
dirs: {
|
|
71
|
+
[key: string]: any[];
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
/** 挂载app上,可动态创建typeORM实例 */
|
|
75
|
+
createTypeORMDataSources: createTypeORMDataSources;
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
export = Egg;
|
package/lib/Logger.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Application } from "egg";
|
|
1
|
+
import { Agent, Application } from "egg";
|
|
2
2
|
import { Logger, QueryRunner } from "typeorm";
|
|
3
3
|
export default class EggTypeORMLogger implements Logger {
|
|
4
4
|
private app;
|
|
5
|
-
constructor(app: Application);
|
|
5
|
+
constructor(app: Application | Agent);
|
|
6
6
|
logQuery(query: string, parameters?: any[] | undefined, _queryRunner?: QueryRunner | undefined): void;
|
|
7
7
|
logQueryError(error: string | Error, query: string, parameters?: any[] | undefined, _queryRunner?: QueryRunner | undefined): void;
|
|
8
8
|
logQuerySlow(time: number, query: string, parameters?: any[] | undefined, _queryRunner?: QueryRunner | undefined): void;
|
package/lib/Logger.js
CHANGED
|
@@ -27,4 +27,4 @@ class EggTypeORMLogger {
|
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
exports.default = EggTypeORMLogger;
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiTG9nZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBR0EsTUFBcUIsZ0JBQWdCO0lBQ3BDLFlBQW9CLEdBQXdCO1FBQXhCLFFBQUcsR0FBSCxHQUFHLENBQXFCO1FBb0I1QyxjQUFTLEdBQUc7WUFDWCxHQUFHLEVBQUUsTUFBTTtZQUNYLElBQUksRUFBRSxNQUFNO1lBQ1osSUFBSSxFQUFFLE1BQU07U0FDWixDQUFDO0lBeEI2QyxDQUFDO0lBQ2hELFFBQVEsQ0FBQyxLQUFhLEVBQUUsVUFBOEIsRUFBRSxZQUFzQztRQUM3RixJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsZ0NBQWdDLEVBQUUsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ2hGLENBQUM7SUFDRCxhQUFhLENBQUMsS0FBcUIsRUFBRSxLQUFhLEVBQUUsVUFBOEIsRUFBRSxZQUFzQztRQUN6SCxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsWUFBWSxDQUFDLElBQVksRUFBRSxLQUFhLEVBQUUsVUFBOEIsRUFBRSxZQUFzQztRQUMvRyxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsZ0RBQWdELEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNyRyxDQUFDO0lBR0QsY0FBYyxDQUFDLE9BQWUsRUFBRSxXQUFxQztJQUVyRSxDQUFDO0lBRUQsWUFBWSxDQUFDLE9BQWUsRUFBRSxXQUFxQztJQUVuRSxDQUFDO0lBU0QsR0FBRyxDQUFDLEtBQThCLEVBQUUsT0FBWSxFQUFFLFdBQXFDO1FBRXRGLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqRCxDQUFDO0NBQ0Q7QUFoQ0QsbUNBZ0NDIn0=
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DataSource, QueryRunner } from "typeorm";
|
|
2
|
+
export declare class MyDataSource extends DataSource {
|
|
3
|
+
private customAddEntityCacheMap;
|
|
4
|
+
addEntity<T extends Function>(clz: T): Promise<this>;
|
|
5
|
+
private buildMetaData2;
|
|
6
|
+
removeEntity<T extends Function>(clz: T): void;
|
|
7
|
+
query2<T = any>(query: string, parameters: Record<string, any>, queryRunner?: QueryRunner): Promise<T>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MyDataSource = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const ConnectionMetadataBuilder_1 = require("typeorm/connection/ConnectionMetadataBuilder");
|
|
6
|
+
const EntityMetadataValidator_1 = require("typeorm/metadata-builder/EntityMetadataValidator");
|
|
7
|
+
class MyDataSource extends typeorm_1.DataSource {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.customAddEntityCacheMap = new Map();
|
|
11
|
+
}
|
|
12
|
+
async addEntity(clz) {
|
|
13
|
+
const entityCacheClz = this.customAddEntityCacheMap.get(clz);
|
|
14
|
+
if (entityCacheClz) {
|
|
15
|
+
return this;
|
|
16
|
+
}
|
|
17
|
+
await this.buildMetaData2(clz);
|
|
18
|
+
this.customAddEntityCacheMap.set(clz, true);
|
|
19
|
+
return this;
|
|
20
|
+
}
|
|
21
|
+
async buildMetaData2(entity) {
|
|
22
|
+
const connectionMetadataBuilder = new ConnectionMetadataBuilder_1.ConnectionMetadataBuilder(this);
|
|
23
|
+
const entityMetadataValidator = new EntityMetadataValidator_1.EntityMetadataValidator();
|
|
24
|
+
const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([entity]);
|
|
25
|
+
for (const metadata of entityMetadatas) {
|
|
26
|
+
this.entityMetadatas.push(metadata);
|
|
27
|
+
this.entityMetadatasMap.set(metadata.target, metadata);
|
|
28
|
+
}
|
|
29
|
+
entityMetadataValidator.validateMany(entityMetadatas, this.driver);
|
|
30
|
+
for (let entityMetadata of entityMetadatas) {
|
|
31
|
+
if (typeorm_1.InstanceChecker.isBaseEntityConstructor(entityMetadata.target)) {
|
|
32
|
+
entityMetadata.target.useDataSource(this);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
removeEntity(clz) {
|
|
37
|
+
this.customAddEntityCacheMap.delete(clz);
|
|
38
|
+
const metadata = this.entityMetadatasMap.get(clz);
|
|
39
|
+
if (metadata && typeorm_1.InstanceChecker.isBaseEntityConstructor(metadata.target)) {
|
|
40
|
+
metadata.target.dataSource = null;
|
|
41
|
+
}
|
|
42
|
+
this.entityMetadatas = this.entityMetadatas.filter((item) => item.target !== clz);
|
|
43
|
+
this.entityMetadatasMap.delete(clz);
|
|
44
|
+
}
|
|
45
|
+
async query2(query, parameters, queryRunner) {
|
|
46
|
+
const result = this.driver.escapeQueryWithParameters(query, parameters, {});
|
|
47
|
+
return await super.query(result[0], result[1], queryRunner);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.MyDataSource = MyDataSource;
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTXlEYXRhU291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiTXlEYXRhU291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFDQUFtRTtBQUNuRSw0RkFBeUY7QUFDekYsOEZBQTJGO0FBTTNGLE1BQWEsWUFBYSxTQUFRLG9CQUFVO0lBQTVDOztRQUNTLDRCQUF1QixHQUFHLElBQUksR0FBRyxFQUFrQixDQUFDO0lBNkQ3RCxDQUFDO0lBcERBLEtBQUssQ0FBQyxTQUFTLENBQXFCLEdBQU07UUFDekMsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLHVCQUF1QixDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM3RCxJQUFJLGNBQWMsRUFBRTtZQUNuQixPQUFPLElBQUksQ0FBQztTQUNaO1FBRUQsTUFBTSxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQzVDLE9BQU8sSUFBSSxDQUFDO0lBQ2IsQ0FBQztJQUdPLEtBQUssQ0FBQyxjQUFjLENBQUMsTUFBZ0I7UUFDNUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLHFEQUF5QixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3RFLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxpREFBdUIsRUFBRSxDQUFDO1FBRzlELE1BQU0sZUFBZSxHQUFHLE1BQU0seUJBQXlCLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQ3ZGLEtBQUssTUFBTSxRQUFRLElBQUksZUFBZSxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3BDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQztTQUN2RDtRQUdELHVCQUF1QixDQUFDLFlBQVksQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBR25FLEtBQUssSUFBSSxjQUFjLElBQUksZUFBZSxFQUFFO1lBQzNDLElBQUkseUJBQWUsQ0FBQyx1QkFBdUIsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEVBQUU7Z0JBQ25FLGNBQWMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQzFDO1NBQ0Q7SUFDRixDQUFDO0lBR0QsWUFBWSxDQUFxQixHQUFNO1FBQ3RDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDekMsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNsRCxJQUFJLFFBQVEsSUFBSSx5QkFBZSxDQUFDLHVCQUF1QixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUV6RSxRQUFRLENBQUMsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7U0FDbEM7UUFFRCxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2xGLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUdELEtBQUssQ0FBQyxNQUFNLENBQVUsS0FBYSxFQUFFLFVBQStCLEVBQUUsV0FBeUI7UUFDOUYsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzVFLE9BQU8sTUFBTSxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDN0QsQ0FBQztDQUNEO0FBOURELG9DQThEQyJ9
|
package/lib/connection.d.ts
CHANGED
|
@@ -1,2 +1,7 @@
|
|
|
1
|
-
import { Application } from "egg";
|
|
2
|
-
|
|
1
|
+
import { Application, Agent, EggConfigTypeormDataSourceOptions } from "egg";
|
|
2
|
+
import { MyDataSource } from "./MyDataSource";
|
|
3
|
+
export default function (app: Application | Agent): Promise<void>;
|
|
4
|
+
export declare function createTypeORMDataSources(app: Application | Agent, datasourcesConfig: EggConfigTypeormDataSourceOptions, entities?: any[]): Promise<{
|
|
5
|
+
config: EggConfigTypeormDataSourceOptions;
|
|
6
|
+
dataSource: MyDataSource;
|
|
7
|
+
}>;
|
package/lib/connection.js
CHANGED
|
@@ -1,22 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
|
|
3
|
+
exports.createTypeORMDataSources = void 0;
|
|
4
4
|
const Logger_1 = require("./Logger");
|
|
5
|
+
const assert = require("assert");
|
|
6
|
+
const MyDataSource_1 = require("./MyDataSource");
|
|
5
7
|
async function default_1(app) {
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
exports.default = default_1;
|
|
9
|
-
async function connect(app) {
|
|
10
|
-
const entities = app.config["__typeormAllEntityList"];
|
|
11
|
-
app.config["__typeormAllEntityList"] = undefined;
|
|
8
|
+
const entities = app.typeorm.entites;
|
|
12
9
|
const config = app.config.typeorm.datasources;
|
|
13
|
-
|
|
14
|
-
throw new Error(`typeorm plugin need your provide database connection params.`);
|
|
10
|
+
assert.ok(config.length > 0, `typeorm plugin need you provide database connection params.`);
|
|
15
11
|
if (config.length > 1) {
|
|
16
12
|
config.forEach((item, index) => {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
13
|
+
let entityDirName = item.entityDir || item.name;
|
|
14
|
+
assert.ok(entityDirName, `Error, connection need a unique entityDir or name for relate entity dir. ${item.host}`);
|
|
15
|
+
entityDirName = entityDirName.replace(/[._-]/gi, "").toUpperCase();
|
|
16
|
+
item.entities = [...(entities.dirs[entityDirName] || [])];
|
|
20
17
|
if (index === 0) {
|
|
21
18
|
item.entities = [...(entities.level1 || []), ...item.entities];
|
|
22
19
|
}
|
|
@@ -26,25 +23,46 @@ async function connect(app) {
|
|
|
26
23
|
config[0].entities = [...(entities.all || [])];
|
|
27
24
|
}
|
|
28
25
|
const names = [];
|
|
29
|
-
|
|
30
|
-
if (item.logger === undefined) {
|
|
31
|
-
item.logger = new Logger_1.default(app);
|
|
32
|
-
}
|
|
26
|
+
for (const item of config) {
|
|
33
27
|
item.name = item.name || "default";
|
|
34
28
|
if (names.includes(item.name)) {
|
|
35
|
-
throw new Error(`Egg-TypeORM: Error
|
|
29
|
+
throw new Error(`Egg-TypeORM: Error, your datasources name [${item.name}] has duplicated.`);
|
|
36
30
|
}
|
|
37
31
|
names.push(item.name);
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
.
|
|
41
|
-
app.coreLogger.info(`TypeORM DataSource %s %s %s init
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
app.coreLogger.
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
32
|
+
try {
|
|
33
|
+
const res = await createTypeORMDataSources(app, item);
|
|
34
|
+
app.typeorm.datasources[item.name] = res.dataSource;
|
|
35
|
+
app.coreLogger.info(`[Egg-TypeORM] DataSource %s %s, [%s] init success.`, item.host, item.port, item.name);
|
|
36
|
+
}
|
|
37
|
+
catch (err) {
|
|
38
|
+
app.coreLogger.error(`[Egg-TypeORM] DataSource %s %s, [%s] init failed. reason: \r\n %s`, item.host, item.port, item.name, err);
|
|
39
|
+
setTimeout(() => {
|
|
40
|
+
process.exit(1);
|
|
41
|
+
}, 600);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.default = default_1;
|
|
46
|
+
async function createTypeORMDataSources(app, datasourcesConfig, entities) {
|
|
47
|
+
if (datasourcesConfig.logger === undefined) {
|
|
48
|
+
datasourcesConfig.logger = new Logger_1.default(app);
|
|
49
|
+
}
|
|
50
|
+
if (entities) {
|
|
51
|
+
datasourcesConfig.entities = entities;
|
|
52
|
+
}
|
|
53
|
+
const ds = new MyDataSource_1.MyDataSource(datasourcesConfig);
|
|
54
|
+
for (let i = 0; i < 3; i++) {
|
|
55
|
+
try {
|
|
56
|
+
await ds.initialize();
|
|
57
|
+
return { config: datasourcesConfig, dataSource: ds };
|
|
58
|
+
}
|
|
59
|
+
catch (error) {
|
|
60
|
+
app.coreLogger.error(`[Egg-TypeORM] DataSource %s %s, [%s] init failed. reason: \r\n %s`, datasourcesConfig.host, datasourcesConfig.port, datasourcesConfig.name, error.message);
|
|
61
|
+
app.coreLogger.info(`[Egg-TypeORM] DataSource %s %s, [%s] retry init connection...`, datasourcesConfig.host, datasourcesConfig.port, datasourcesConfig.name);
|
|
62
|
+
await new Promise((resolve) => setTimeout(resolve, 1200));
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
throw new Error(`the DB init connection was failed after retry 3 times.`);
|
|
49
66
|
}
|
|
50
|
-
|
|
67
|
+
exports.createTypeORMDataSources = createTypeORMDataSources;
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNvbm5lY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBR0EscUNBQXdDO0FBQ3hDLGlDQUFpQztBQUNqQyxpREFBOEM7QUFLL0IsS0FBSyxvQkFBVyxHQUF3QjtJQUN0RCxNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztJQUNyQyxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUM7SUFFOUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSw2REFBNkQsQ0FBQyxDQUFDO0lBRTVGLElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFFdEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUM5QixJQUFJLGFBQWEsR0FBRyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDaEQsTUFBTSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEVBQUUsNEVBQTZFLElBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBRTNILGFBQWEsR0FBRyxhQUFhLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUVuRSxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUUxRCxJQUFJLEtBQUssS0FBSyxDQUFDLEVBQUU7Z0JBRWhCLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUMvRDtR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
|
package/lib/loader.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { Application } from "egg";
|
|
2
|
-
declare const _default: (app: Application) => Promise<void>;
|
|
1
|
+
import { Application, Agent } from "egg";
|
|
2
|
+
declare const _default: (app: Application | Agent) => Promise<void>;
|
|
3
3
|
export default _default;
|
package/lib/loader.js
CHANGED
|
@@ -3,20 +3,23 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const path = require("path");
|
|
4
4
|
exports.default = async (app) => {
|
|
5
5
|
const dir = path.join(app.config.baseDir, "app/entity");
|
|
6
|
-
|
|
6
|
+
app.typeorm.entites = app.typeorm.entites || {
|
|
7
7
|
dirs: {},
|
|
8
|
-
level1: [],
|
|
9
8
|
all: [],
|
|
10
|
-
|
|
9
|
+
level1: [],
|
|
10
|
+
};
|
|
11
|
+
const entitys = app.typeorm.entites;
|
|
11
12
|
app.loader.loadToApp(dir, "entity", {
|
|
13
|
+
caseStyle: "upper",
|
|
12
14
|
initializer(Clz, opt) {
|
|
15
|
+
Clz.app = app;
|
|
13
16
|
const properties = opt.pathName.split(".");
|
|
14
17
|
entitys.all.push(Clz);
|
|
15
18
|
if (properties.length === 2) {
|
|
16
19
|
entitys.level1.push(Clz);
|
|
17
20
|
}
|
|
18
21
|
else if (properties.length > 2) {
|
|
19
|
-
const dirName = properties[1];
|
|
22
|
+
const dirName = properties[1].toUpperCase();
|
|
20
23
|
entitys.dirs[dirName] = entitys.dirs[dirName] || [];
|
|
21
24
|
entitys.dirs[dirName].push(Clz);
|
|
22
25
|
}
|
|
@@ -24,4 +27,4 @@ exports.default = async (app) => {
|
|
|
24
27
|
},
|
|
25
28
|
});
|
|
26
29
|
};
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibG9hZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsNkJBQTZCO0FBRTdCLGtCQUFlLEtBQUssRUFBRSxHQUF3QixFQUFFLEVBQUU7SUFDakQsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN4RCxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSTtRQUM1QyxJQUFJLEVBQUUsRUFBRTtRQUNSLEdBQUcsRUFBRSxFQUFFO1FBQ1AsTUFBTSxFQUFFLEVBQUU7S0FDVixDQUFDO0lBQ0YsTUFBTSxPQUFPLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUM7SUFFcEMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLFFBQVEsRUFBRTtRQUNuQyxTQUFTLEVBQUUsT0FBTztRQUVsQixXQUFXLENBQUMsR0FBRyxFQUFFLEdBQUc7WUFFbkIsR0FBRyxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7WUFJZCxNQUFNLFVBQVUsR0FBRyxHQUFHLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUczQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUV0QixJQUFJLFVBQVUsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO2dCQUM1QixPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN6QjtpQkFBTSxJQUFJLFVBQVUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO2dCQUdqQyxNQUFNLE9BQU8sR0FBRyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQzVDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQ3BELE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2FBQ2hDO1lBRUQsT0FBTyxHQUFHLENBQUM7UUFDWixDQUFDO0tBQ0QsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDIn0=
|
package/package.json
CHANGED
|
@@ -1,64 +1,64 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@diyaner/egg-typeorm",
|
|
3
|
-
"version": "
|
|
4
|
-
"description": "egg plugin for nodejs orm freamwork typeorm.",
|
|
5
|
-
"eggPlugin": {
|
|
6
|
-
"name": "typeorm"
|
|
7
|
-
},
|
|
8
|
-
"keywords": [
|
|
9
|
-
"egg",
|
|
10
|
-
"eggPlugin",
|
|
11
|
-
"egg-plugin",
|
|
12
|
-
"egg-typeorm",
|
|
13
|
-
"typeorm"
|
|
14
|
-
],
|
|
15
|
-
"dependencies": {
|
|
16
|
-
"reflect-metadata": "^0.1.13",
|
|
17
|
-
"typeorm": "^0.3.
|
|
18
|
-
},
|
|
19
|
-
"devDependencies": {
|
|
20
|
-
"@types/mocha": "^8.2.1",
|
|
21
|
-
"autod": "^3.0.1",
|
|
22
|
-
"autod-egg": "^1.1.0",
|
|
23
|
-
"egg": "^3.17.4",
|
|
24
|
-
"egg-bin": "^6.4.2",
|
|
25
|
-
"egg-ci": "^1.11.0",
|
|
26
|
-
"egg-mock": "^3.21.0",
|
|
27
|
-
"eslint": "^5.13.0",
|
|
28
|
-
"eslint-config-egg": "^7.1.0",
|
|
29
|
-
"mysql2": "^3.6.0",
|
|
30
|
-
"typescript": "^5.1.3"
|
|
31
|
-
},
|
|
32
|
-
"engines": {
|
|
33
|
-
"node": ">=16.0.0"
|
|
34
|
-
},
|
|
35
|
-
"scripts": {
|
|
36
|
-
"test": "npm run lint -- --fix &&
|
|
37
|
-
"test-local": "egg-bin test && npm run clean:js",
|
|
38
|
-
"tsc": "tsc",
|
|
39
|
-
"clean:js": "tsc -b --clean",
|
|
40
|
-
"release": "tsc && npm publish --access public && npm run clean:js",
|
|
41
|
-
"cov": "egg-bin cov",
|
|
42
|
-
"lint": "eslint .",
|
|
43
|
-
"ci": "egg-bin pkgfiles --check && npm run lint && npm run cov",
|
|
44
|
-
"pkgfiles": "egg-bin pkgfiles",
|
|
45
|
-
"autod": "autod"
|
|
46
|
-
},
|
|
47
|
-
"files": [
|
|
48
|
-
"app.js",
|
|
49
|
-
"agent.js",
|
|
50
|
-
"tshelper.js",
|
|
51
|
-
"config/**/*.js",
|
|
52
|
-
"app/**/*.js",
|
|
53
|
-
"lib/**/*.js",
|
|
54
|
-
"lib/**/*.d.ts",
|
|
55
|
-
"typeorm.js",
|
|
56
|
-
"typeorm.d.ts",
|
|
57
|
-
"index.d.ts"
|
|
58
|
-
],
|
|
59
|
-
"ci": {
|
|
60
|
-
"version": "8, 10"
|
|
61
|
-
},
|
|
62
|
-
"author": "ding",
|
|
63
|
-
"license": "MIT"
|
|
64
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@diyaner/egg-typeorm",
|
|
3
|
+
"version": "2.0.1",
|
|
4
|
+
"description": "egg plugin for nodejs orm freamwork typeorm.",
|
|
5
|
+
"eggPlugin": {
|
|
6
|
+
"name": "typeorm"
|
|
7
|
+
},
|
|
8
|
+
"keywords": [
|
|
9
|
+
"egg",
|
|
10
|
+
"eggPlugin",
|
|
11
|
+
"egg-plugin",
|
|
12
|
+
"egg-typeorm",
|
|
13
|
+
"typeorm"
|
|
14
|
+
],
|
|
15
|
+
"dependencies": {
|
|
16
|
+
"reflect-metadata": "^0.1.13",
|
|
17
|
+
"typeorm": "^0.3.20"
|
|
18
|
+
},
|
|
19
|
+
"devDependencies": {
|
|
20
|
+
"@types/mocha": "^8.2.1",
|
|
21
|
+
"autod": "^3.0.1",
|
|
22
|
+
"autod-egg": "^1.1.0",
|
|
23
|
+
"egg": "^3.17.4",
|
|
24
|
+
"egg-bin": "^6.4.2",
|
|
25
|
+
"egg-ci": "^1.11.0",
|
|
26
|
+
"egg-mock": "^3.21.0",
|
|
27
|
+
"eslint": "^5.13.0",
|
|
28
|
+
"eslint-config-egg": "^7.1.0",
|
|
29
|
+
"mysql2": "^3.6.0",
|
|
30
|
+
"typescript": "^5.1.3"
|
|
31
|
+
},
|
|
32
|
+
"engines": {
|
|
33
|
+
"node": ">=16.0.0"
|
|
34
|
+
},
|
|
35
|
+
"scripts": {
|
|
36
|
+
"test": "npm run lint -- --fix && npm run test-local",
|
|
37
|
+
"test-local": "egg-bin test && npm run clean:js",
|
|
38
|
+
"tsc": "tsc",
|
|
39
|
+
"clean:js": "tsc -b --clean",
|
|
40
|
+
"release": "tsc && npm publish --access public && npm run clean:js",
|
|
41
|
+
"cov": "egg-bin cov",
|
|
42
|
+
"lint": "eslint .",
|
|
43
|
+
"ci": "egg-bin pkgfiles --check && npm run lint && npm run cov",
|
|
44
|
+
"pkgfiles": "egg-bin pkgfiles",
|
|
45
|
+
"autod": "autod"
|
|
46
|
+
},
|
|
47
|
+
"files": [
|
|
48
|
+
"app.js",
|
|
49
|
+
"agent.js",
|
|
50
|
+
"tshelper.js",
|
|
51
|
+
"config/**/*.js",
|
|
52
|
+
"app/**/*.js",
|
|
53
|
+
"lib/**/*.js",
|
|
54
|
+
"lib/**/*.d.ts",
|
|
55
|
+
"typeorm.js",
|
|
56
|
+
"typeorm.d.ts",
|
|
57
|
+
"index.d.ts"
|
|
58
|
+
],
|
|
59
|
+
"ci": {
|
|
60
|
+
"version": "8, 10"
|
|
61
|
+
},
|
|
62
|
+
"author": "ding",
|
|
63
|
+
"license": "MIT"
|
|
64
|
+
}
|
package/tshelper.js
CHANGED
|
@@ -1,24 +1,50 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
}
|
|
1
|
+
'use strict';
|
|
2
|
+
// const ClassGenerator = require("egg-ts-helper/dist/generators/class").default;
|
|
3
|
+
module.exports = {
|
|
4
|
+
watchDirs: {
|
|
5
|
+
entity: {
|
|
6
|
+
directory: 'app/entity',
|
|
7
|
+
generator: 'object',
|
|
8
|
+
interface: 'IEntity',
|
|
9
|
+
declareTo: 'Application.entity',
|
|
10
|
+
caseStyle: "upper",
|
|
11
|
+
watch: true,
|
|
12
|
+
distName: 'entity.d.ts',
|
|
13
|
+
},
|
|
14
|
+
},
|
|
15
|
+
generatorConfig: {
|
|
16
|
+
entity: {
|
|
17
|
+
directory: 'app/entity',
|
|
18
|
+
generator: 'object',
|
|
19
|
+
interface: 'IEntity',
|
|
20
|
+
declareTo: 'Application.entity',
|
|
21
|
+
caseStyle: "upper",
|
|
22
|
+
watch: true,
|
|
23
|
+
distName: 'entity.d.ts',
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* 插件提供的接口方式为、1直接提供类,2提供一个函数,函数返回类
|
|
32
|
+
* - 使用这种自定义方式进行类型提取
|
|
33
|
+
*/
|
|
34
|
+
function TypeOrmEntityGenerator(config, baseConfig) {
|
|
35
|
+
config.interfaceHandle = config.interfaceHandle || 'AutoTypeOfObject<typeof {{ 0 }}>';
|
|
36
|
+
|
|
37
|
+
const result = ClassGenerator(config, baseConfig);
|
|
38
|
+
/* istanbul ignore else */
|
|
39
|
+
if (result.content) {
|
|
40
|
+
result.content = [
|
|
41
|
+
'type AnyClass = new (...args: any[]) => any;',
|
|
42
|
+
'type AnyFunc<T = any> = (...args: any[]) => T;',
|
|
43
|
+
'type CanExportFunc = AnyFunc<Promise<any>> | AnyFunc<IterableIterator<any>>;',
|
|
44
|
+
'type AutoTypeOfObject<T> = T extends AnyClass ? T : T extends AnyFunc ? ReturnType<T> : T;',
|
|
45
|
+
result.content,
|
|
46
|
+
].join('\n');
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return result;
|
|
50
|
+
}
|