@eggjs/tegg-dal-plugin 3.33.0
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/LICENSE +21 -0
- package/README.md +623 -0
- package/app.d.ts +9 -0
- package/app.js +31 -0
- package/lib/DalModuleLoadUnitHook.d.ts +8 -0
- package/lib/DalModuleLoadUnitHook.js +31 -0
- package/lib/DalTableEggPrototypeHook.d.ts +8 -0
- package/lib/DalTableEggPrototypeHook.js +23 -0
- package/lib/DataSource.d.ts +12 -0
- package/lib/DataSource.js +113 -0
- package/lib/MysqlDataSourceManager.d.ts +11 -0
- package/lib/MysqlDataSourceManager.js +59 -0
- package/lib/SqlMapManager.d.ts +9 -0
- package/lib/SqlMapManager.js +26 -0
- package/lib/TableModelManager.d.ts +9 -0
- package/lib/TableModelManager.js +26 -0
- package/package.json +73 -0
- package/typings/index.d.ts +3 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2017-present Alibaba Group Holding Limited and other contributors.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,623 @@
|
|
|
1
|
+
# @eggjs/tegg-dal-plugin
|
|
2
|
+
|
|
3
|
+
@eggjs/tegg-dal-plugin 支持使用注解的方式来开发 egg 中的 dal。
|
|
4
|
+
|
|
5
|
+
## Install
|
|
6
|
+
|
|
7
|
+
```shell
|
|
8
|
+
# tegg 注解
|
|
9
|
+
npm i --save @eggjs/tegg
|
|
10
|
+
# tegg 插件
|
|
11
|
+
npm i --save @eggjs/tegg-plugin
|
|
12
|
+
# tegg dal 插件
|
|
13
|
+
npm i --save @eggjs/tegg-dal-plugin
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
## Prepare
|
|
17
|
+
```json
|
|
18
|
+
// tsconfig.json
|
|
19
|
+
{
|
|
20
|
+
"compilerOptions": {
|
|
21
|
+
// 注解特性需要显示打开
|
|
22
|
+
"experimentalDecorators": true
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Config
|
|
28
|
+
|
|
29
|
+
```js
|
|
30
|
+
// config/plugin.js
|
|
31
|
+
exports.tegg = {
|
|
32
|
+
package: '@eggjs/tegg-plugin',
|
|
33
|
+
enable: true,
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
exports.teggDal = {
|
|
37
|
+
package: '@eggjs/tegg-dal-plugin',
|
|
38
|
+
enable: true,
|
|
39
|
+
};
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
## Usage
|
|
43
|
+
|
|
44
|
+
### module.yml
|
|
45
|
+
通过 module.yml 来配置 module 中的 mysql 数据源。
|
|
46
|
+
|
|
47
|
+
```yaml
|
|
48
|
+
dataSource:
|
|
49
|
+
# 数据源名称,可以在 @Table 注解中指定
|
|
50
|
+
# 如果 module 中只有一个 dataSource,@Table 会默认使用这个数据源
|
|
51
|
+
foo:
|
|
52
|
+
connectionLimit: 100
|
|
53
|
+
database: 'test'
|
|
54
|
+
host: '127.0.0.1'
|
|
55
|
+
user: root
|
|
56
|
+
port: 3306
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
### Table
|
|
60
|
+
`TableModel` 定义一个表结构,包括表配置、列、索引。
|
|
61
|
+
|
|
62
|
+
```ts
|
|
63
|
+
import { Table, Index, Column, ColumnType, IndexType } from '@eggjs/tegg/dal';
|
|
64
|
+
|
|
65
|
+
// 定义了一个表
|
|
66
|
+
@Table({
|
|
67
|
+
comment: 'foo table',
|
|
68
|
+
})
|
|
69
|
+
// 定义了一个唯一索引,列是 name
|
|
70
|
+
@Index({
|
|
71
|
+
keys: [ 'name' ],
|
|
72
|
+
type: IndexType.UNIQUE,
|
|
73
|
+
})
|
|
74
|
+
export class Foo {
|
|
75
|
+
// 定义了主键,类型是 int
|
|
76
|
+
@Column({
|
|
77
|
+
type: ColumnType.INT,
|
|
78
|
+
}, {
|
|
79
|
+
primaryKey: true,
|
|
80
|
+
})
|
|
81
|
+
id: number;
|
|
82
|
+
|
|
83
|
+
// 定义了 name 列,类型是 varchar
|
|
84
|
+
@Column({
|
|
85
|
+
type: ColumnType.VARCHAR,
|
|
86
|
+
length: 100,
|
|
87
|
+
})
|
|
88
|
+
name: string;
|
|
89
|
+
}
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
详细参数定义如下,具体参数值可以参考 https://dev.mysql.com/doc/refman/8.0/en/create-table.html
|
|
93
|
+
|
|
94
|
+
建表参数,使用方式为 `@Table(parmas?: TableParams)`
|
|
95
|
+
```ts
|
|
96
|
+
export interface TableParams {
|
|
97
|
+
// 数据库表名
|
|
98
|
+
name?: string;
|
|
99
|
+
// 数据源名称,如果 module 只有一个 dataSource 则默认使用这个
|
|
100
|
+
dataSourceName?: string;
|
|
101
|
+
comment?: string;
|
|
102
|
+
autoExtendSize?: number;
|
|
103
|
+
autoIncrement?: number;
|
|
104
|
+
avgRowLength?: number;
|
|
105
|
+
characterSet?: string;
|
|
106
|
+
collate?: string;
|
|
107
|
+
compression?: CompressionType;
|
|
108
|
+
encryption?: boolean;
|
|
109
|
+
engine?: string;
|
|
110
|
+
engineAttribute?: string;
|
|
111
|
+
insertMethod?: InsertMethod;
|
|
112
|
+
keyBlockSize?: number;
|
|
113
|
+
maxRows?: number;
|
|
114
|
+
minRows?: number;
|
|
115
|
+
rowFormat?: RowFormat;
|
|
116
|
+
secondaryEngineAttribute?: string;
|
|
117
|
+
}
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
建索引参数,使用方式为 `@Index(parmas?: IndexParams)`
|
|
121
|
+
```ts
|
|
122
|
+
export interface IndexParams {
|
|
123
|
+
// 索引的列
|
|
124
|
+
keys: string[];
|
|
125
|
+
// 索引名称,如果未指定会用 列名拼接
|
|
126
|
+
// 如 [column1, column2 ]
|
|
127
|
+
// 普通索引为 idx_column1_column2
|
|
128
|
+
// 唯一索引为 uk_column1_column2
|
|
129
|
+
name?: string;
|
|
130
|
+
type?: IndexType,
|
|
131
|
+
storeType?: IndexStoreType;
|
|
132
|
+
comment?: string;
|
|
133
|
+
engineAttribute?: string;
|
|
134
|
+
secondaryEngineAttribute?: string;
|
|
135
|
+
parser?: string;
|
|
136
|
+
}
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
建列参数,使用方式为 `@Column(type: ColumnTypeParams, parmas?: ColumnParams)`
|
|
140
|
+
```ts
|
|
141
|
+
export interface ColumnParams {
|
|
142
|
+
// 列名,默认转换规则 userName 至 user_name
|
|
143
|
+
name?: string;
|
|
144
|
+
// 默认值
|
|
145
|
+
default?: string;
|
|
146
|
+
// 是否可控,默认为 false
|
|
147
|
+
canNull?: boolean;
|
|
148
|
+
comment?: string;
|
|
149
|
+
visible?: boolean;
|
|
150
|
+
autoIncrement?: boolean;
|
|
151
|
+
uniqueKey?: boolean;
|
|
152
|
+
primaryKey?: boolean;
|
|
153
|
+
collate?: string;
|
|
154
|
+
columnFormat?: ColumnFormat;
|
|
155
|
+
engineAttribute?: string;
|
|
156
|
+
secondaryEngineAttribute?: string;
|
|
157
|
+
}
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
支持的类型
|
|
161
|
+
```ts
|
|
162
|
+
export enum ColumnType {
|
|
163
|
+
// Numeric
|
|
164
|
+
BIT = 'BIT',
|
|
165
|
+
TINYINT = 'TINYINT',
|
|
166
|
+
BOOL = 'BOOL',
|
|
167
|
+
SMALLINT = 'SMALLINT',
|
|
168
|
+
MEDIUMINT = 'MEDIUMINT',
|
|
169
|
+
INT = 'INT',
|
|
170
|
+
BIGINT = 'BIGINT',
|
|
171
|
+
DECIMAL = 'DECIMAL',
|
|
172
|
+
FLOAT = 'FLOAT',
|
|
173
|
+
DOUBLE = 'DOUBLE',
|
|
174
|
+
// Date
|
|
175
|
+
DATE = 'DATE',
|
|
176
|
+
DATETIME = 'DATETIME',
|
|
177
|
+
TIMESTAMP = 'TIMESTAMP',
|
|
178
|
+
TIME = 'TIME',
|
|
179
|
+
YEAR = 'YEAR',
|
|
180
|
+
// String
|
|
181
|
+
CHAR = 'CHAR',
|
|
182
|
+
VARCHAR = 'VARCHAR',
|
|
183
|
+
BINARY = 'BINARY',
|
|
184
|
+
VARBINARY = 'VARBINARY',
|
|
185
|
+
TINYBLOB = 'TINYBLOB',
|
|
186
|
+
TINYTEXT = 'TINYTEXT',
|
|
187
|
+
BLOB = 'BLOB',
|
|
188
|
+
TEXT = 'TEXT',
|
|
189
|
+
MEDIUMBLOB = 'MEDIUMBLOB',
|
|
190
|
+
MEDIUMTEXT = 'MEDIUMTEXT',
|
|
191
|
+
LONGBLOB = 'LONGBLOB',
|
|
192
|
+
LONGTEXT = 'LONGTEXT',
|
|
193
|
+
ENUM = 'ENUM',
|
|
194
|
+
SET = 'SET',
|
|
195
|
+
// JSON
|
|
196
|
+
JSON = 'JSON',
|
|
197
|
+
// Spatial
|
|
198
|
+
GEOMETRY = 'GEOMETRY',
|
|
199
|
+
POINT = 'POINT',
|
|
200
|
+
LINESTRING = 'LINESTRING',
|
|
201
|
+
POLYGON = 'POLYGON',
|
|
202
|
+
MULTIPOINT = 'MULTIPOINT',
|
|
203
|
+
MULTILINESTRING = 'MULTILINESTRING',
|
|
204
|
+
MULTIPOLYGON = 'MULTIPOLYGON',
|
|
205
|
+
GEOMETRYCOLLECTION = 'GEOMETRYCOLLECTION',
|
|
206
|
+
}
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
支持的类型参数,详细可参考 https://dev.mysql.com/doc/refman/8.0/en/data-types.html
|
|
210
|
+
|
|
211
|
+
如果 mysql 类型和 ts 类型对应关系不确定可直接使用 `ColumnTsType` 类型,如
|
|
212
|
+
```ts
|
|
213
|
+
import { Table, Index, Column, ColumnType, IndexType, ColumnTsType } from '@eggjs/tegg/dal';
|
|
214
|
+
|
|
215
|
+
// 定义了一个表
|
|
216
|
+
@Table({
|
|
217
|
+
comment: 'foo table',
|
|
218
|
+
})
|
|
219
|
+
// 定义了一个唯一索引,列是 name
|
|
220
|
+
@Index({
|
|
221
|
+
keys: [ 'name' ],
|
|
222
|
+
type: IndexType.UNIQUE,
|
|
223
|
+
})
|
|
224
|
+
export class Foo {
|
|
225
|
+
// 定义了主键,类型是 int
|
|
226
|
+
@Column({
|
|
227
|
+
type: ColumnType.INT,
|
|
228
|
+
}, {
|
|
229
|
+
primaryKey: true,
|
|
230
|
+
})
|
|
231
|
+
id: ColumnTsType['INT'];
|
|
232
|
+
|
|
233
|
+
// 定义了 name 列,类型是 varchar
|
|
234
|
+
@Column({
|
|
235
|
+
type: ColumnType.VARCHAR,
|
|
236
|
+
length: 100,
|
|
237
|
+
})
|
|
238
|
+
name: ColumnTsType['VARCHAR'];
|
|
239
|
+
}
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
```ts
|
|
243
|
+
// Bit 类型,对应 js 中的 Buffer
|
|
244
|
+
export interface BitParams {
|
|
245
|
+
type: ColumnType.BIT,
|
|
246
|
+
// Bit 长度
|
|
247
|
+
length?: number;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
// Bool 类型,注意在 js 中需要使用 0 或者 1
|
|
251
|
+
export interface BoolParams {
|
|
252
|
+
type: ColumnType.BOOL,
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
// TinyInt 类型,对应 js 中的 number
|
|
256
|
+
export interface TinyIntParams {
|
|
257
|
+
type: ColumnType.TINYINT;
|
|
258
|
+
length?: number;
|
|
259
|
+
unsigned?: boolean;
|
|
260
|
+
zeroFill?: boolean;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
// SmallInt 类型,对应 js 中的 number
|
|
264
|
+
export interface SmallIntParams {
|
|
265
|
+
type: ColumnType.SMALLINT;
|
|
266
|
+
length?: number;
|
|
267
|
+
unsigned?: boolean;
|
|
268
|
+
zeroFill?: boolean;
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
// MediumInt 类型,对应 js 中的 number
|
|
272
|
+
export interface MediumIntParams {
|
|
273
|
+
type: ColumnType.MEDIUMINT;
|
|
274
|
+
length?: number;
|
|
275
|
+
unsigned?: boolean;
|
|
276
|
+
zeroFill?: boolean;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// MediumInt 类型,对应 js 中的 number
|
|
280
|
+
export interface IntParams {
|
|
281
|
+
type: ColumnType.INT;
|
|
282
|
+
length?: number;
|
|
283
|
+
unsigned?: boolean;
|
|
284
|
+
zeroFill?: boolean;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
// BigInt 类型,对应 js 中的 string
|
|
288
|
+
export interface BigIntParams {
|
|
289
|
+
type: ColumnType.BIGINT;
|
|
290
|
+
length?: number;
|
|
291
|
+
unsigned?: boolean;
|
|
292
|
+
zeroFill?: boolean;
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
// Decimal 类型,对应 js 中的 string
|
|
296
|
+
export interface DecimalParams {
|
|
297
|
+
type: ColumnType.DECIMAL;
|
|
298
|
+
length?: number;
|
|
299
|
+
fractionalLength?: number;
|
|
300
|
+
unsigned?: boolean;
|
|
301
|
+
zeroFill?: boolean;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
// Float 类型,对应 js 中的 number
|
|
305
|
+
export interface FloatParams {
|
|
306
|
+
type: ColumnType.FLOAT;
|
|
307
|
+
length?: number;
|
|
308
|
+
fractionalLength?: number;
|
|
309
|
+
unsigned?: boolean;
|
|
310
|
+
zeroFill?: boolean;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
// Double 类型,对应 js 中的 number
|
|
314
|
+
export interface DoubleParams {
|
|
315
|
+
type: ColumnType.DOUBLE;
|
|
316
|
+
length?: number;
|
|
317
|
+
fractionalLength?: number;
|
|
318
|
+
unsigned?: boolean;
|
|
319
|
+
zeroFill?: boolean;
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
// Date 类型,对应 js 中的 Date
|
|
323
|
+
export interface DateParams {
|
|
324
|
+
type: ColumnType.DATE;
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
// DateTime 类型,对应 js 中的 Date
|
|
328
|
+
export interface DateTimeParams {
|
|
329
|
+
type: ColumnType.DATETIME;
|
|
330
|
+
precision?: number;
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
// Timestamp 类型,对应 js 中的 Date
|
|
334
|
+
export interface TimestampParams {
|
|
335
|
+
type: ColumnType.TIMESTAMP;
|
|
336
|
+
precision?: number;
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
// Times 类型,对应 js 中的 string
|
|
340
|
+
export interface TimeParams {
|
|
341
|
+
type: ColumnType.TIME;
|
|
342
|
+
precision?: number;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
// Year 类型,对应 js 中的 number
|
|
346
|
+
export interface YearParams {
|
|
347
|
+
type: ColumnType.YEAR;
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
// Char 类型,对应 js 中的 string
|
|
351
|
+
export interface CharParams {
|
|
352
|
+
type: ColumnType.CHAR;
|
|
353
|
+
length?: number;
|
|
354
|
+
characterSet?: string;
|
|
355
|
+
collate?: string;
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
// VarChar 类型,对应 js 中的 string
|
|
359
|
+
export interface VarCharParams {
|
|
360
|
+
type: ColumnType.VARCHAR;
|
|
361
|
+
length: number;
|
|
362
|
+
characterSet?: string;
|
|
363
|
+
collate?: string;
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
// Binary 类型,对应 js 中的 Buffer
|
|
367
|
+
export interface BinaryParams {
|
|
368
|
+
type: ColumnType.BINARY;
|
|
369
|
+
length?: number;
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
// VarBinary 类型,对应 js 中的 Buffer
|
|
373
|
+
export interface VarBinaryParams {
|
|
374
|
+
type: ColumnType.VARBINARY;
|
|
375
|
+
length: number;
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
// TinyBlob 类型,对应 js 中的 Buffer
|
|
379
|
+
export interface TinyBlobParams {
|
|
380
|
+
type: ColumnType.TINYBLOB;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
// TinyText 类型,对应 js 中的 string
|
|
384
|
+
export interface TinyTextParams {
|
|
385
|
+
type: ColumnType.TINYTEXT;
|
|
386
|
+
characterSet?: string;
|
|
387
|
+
collate?: string;
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
// Blob 类型,对应 js 中的 Buffer
|
|
391
|
+
export interface BlobParams {
|
|
392
|
+
type: ColumnType.BLOB;
|
|
393
|
+
length?: number;
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
// Text 类型,对应 js 中的 string
|
|
397
|
+
export interface TextParams {
|
|
398
|
+
type: ColumnType.TEXT;
|
|
399
|
+
length?: number;
|
|
400
|
+
characterSet?: string;
|
|
401
|
+
collate?: string;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
// MediumBlob 类型,对应 js 中的 Buffer
|
|
405
|
+
export interface MediumBlobParams {
|
|
406
|
+
type: ColumnType.MEDIUMBLOB;
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
// LongBlob 类型,对应 js 中的 Buffer
|
|
410
|
+
export interface LongBlobParams {
|
|
411
|
+
type: ColumnType.LONGBLOB;
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
// MediumText 类型,对应 js 中的 string
|
|
415
|
+
export interface MediumTextParams {
|
|
416
|
+
type: ColumnType.MEDIUMTEXT;
|
|
417
|
+
characterSet?: string;
|
|
418
|
+
collate?: string;
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
// LongText 类型,对应 js 中的 string
|
|
422
|
+
export interface LongTextParams {
|
|
423
|
+
type: ColumnType.LONGTEXT;
|
|
424
|
+
characterSet?: string;
|
|
425
|
+
collate?: string;
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
// Enum 类型,对应 js 中的 string
|
|
429
|
+
export interface EnumParams {
|
|
430
|
+
type: ColumnType.ENUM;
|
|
431
|
+
enums: string[];
|
|
432
|
+
characterSet?: string;
|
|
433
|
+
collate?: string;
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
// Set 类型,对应 js 中的 string
|
|
437
|
+
export interface SetParams {
|
|
438
|
+
type: ColumnType.SET;
|
|
439
|
+
enums: string[];
|
|
440
|
+
characterSet?: string;
|
|
441
|
+
collate?: string;
|
|
442
|
+
}
|
|
443
|
+
|
|
444
|
+
// Json 类型,对应 js 中的 Object
|
|
445
|
+
export interface JsonParams {
|
|
446
|
+
type: ColumnType.JSON;
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
// Gemotry 类型,对应 Point, Line, Polygon
|
|
450
|
+
export interface GeometryParams {
|
|
451
|
+
type: ColumnType.GEOMETRY;
|
|
452
|
+
SRID?: number;
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
export interface PointParams {
|
|
456
|
+
type: ColumnType.POINT;
|
|
457
|
+
SRID?: number;
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
export interface LinestringParams {
|
|
461
|
+
type: ColumnType.LINESTRING;
|
|
462
|
+
SRID?: number;
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
export interface PolygonParams {
|
|
466
|
+
type: ColumnType.POLYGON;
|
|
467
|
+
SRID?: number;
|
|
468
|
+
}
|
|
469
|
+
|
|
470
|
+
export interface MultiPointParams {
|
|
471
|
+
type: ColumnType.MULTIPOINT;
|
|
472
|
+
SRID?: number;
|
|
473
|
+
}
|
|
474
|
+
|
|
475
|
+
export interface MultiLinestringParams {
|
|
476
|
+
type: ColumnType.MULTILINESTRING;
|
|
477
|
+
SRID?: number;
|
|
478
|
+
}
|
|
479
|
+
|
|
480
|
+
export interface MultiPolygonParams {
|
|
481
|
+
type: ColumnType.MULTIPOLYGON;
|
|
482
|
+
SRID?: number;
|
|
483
|
+
}
|
|
484
|
+
|
|
485
|
+
// GeometryCollection 对应 Array<Point | Line | Ploygon>
|
|
486
|
+
export interface GeometryCollectionParams {
|
|
487
|
+
type: ColumnType.GEOMETRYCOLLECTION;
|
|
488
|
+
SRID?: number;
|
|
489
|
+
}
|
|
490
|
+
```
|
|
491
|
+
|
|
492
|
+
### 目录结构
|
|
493
|
+
运行 `egg-bin dal gen` 即可生成 `dal` 相关目录,包括 dao、extension、structure
|
|
494
|
+
|
|
495
|
+
```plain
|
|
496
|
+
dal
|
|
497
|
+
├── dao
|
|
498
|
+
│ ├── FooDAO.ts
|
|
499
|
+
│ └── base
|
|
500
|
+
│ └── BaseFooDAO.ts
|
|
501
|
+
├── extension
|
|
502
|
+
│ └── FooExtension.ts
|
|
503
|
+
└── structure
|
|
504
|
+
├── Foo.json
|
|
505
|
+
└── Foo.sql
|
|
506
|
+
```
|
|
507
|
+
|
|
508
|
+
- dao: 表访问类,生成的 BaseDAO 请勿修改,其中包含了根据表结构生成的基础访问方法,如 insert/update/delete 以及根据索引信息生成的 find 方法
|
|
509
|
+
- extension: 扩展文件,如果需要自定义 sql,需要在 extension 文件中定义
|
|
510
|
+
- structure: 建表语句以及表结构
|
|
511
|
+
|
|
512
|
+
### DAO
|
|
513
|
+
|
|
514
|
+
注入 DAO 即可实现对表的访问
|
|
515
|
+
|
|
516
|
+
```ts
|
|
517
|
+
import { SingletonProto, Inject } from '@eggjs/tegg';
|
|
518
|
+
|
|
519
|
+
@SingletonProto()
|
|
520
|
+
export class FooRepository {
|
|
521
|
+
@Inject()
|
|
522
|
+
private readonly fooDAO: FooDAO;
|
|
523
|
+
|
|
524
|
+
async create(foo: Foo) {
|
|
525
|
+
await this.fooDAO.insert(foo);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
```
|
|
529
|
+
|
|
530
|
+
#### 自定义 Sql
|
|
531
|
+
1. 在 extension 中定义自定义 Sql
|
|
532
|
+
|
|
533
|
+
```ts
|
|
534
|
+
// dal/extension/FooExtension.ts
|
|
535
|
+
import { SqlMap, SqlType } from '@eggjs/tegg/dal';
|
|
536
|
+
|
|
537
|
+
export default {
|
|
538
|
+
findByName: {
|
|
539
|
+
type: SqlType.SELECT,
|
|
540
|
+
sql: 'SELECT {{ allColumns }} FROM egg_foo WHERE name = {{ name }}',
|
|
541
|
+
},
|
|
542
|
+
} as Record<string, SqlMap>;
|
|
543
|
+
```
|
|
544
|
+
|
|
545
|
+
2. 在 dao 中定义自定义方法
|
|
546
|
+
```ts
|
|
547
|
+
import { SingletonProto, AccessLevel } from '@eggjs/tegg';
|
|
548
|
+
import { BaseFooDAO } from './base/BaseFooDAO';
|
|
549
|
+
import { Foo } from '../../Foo';
|
|
550
|
+
|
|
551
|
+
@SingletonProto({
|
|
552
|
+
accessLevel: AccessLevel.PUBLIC,
|
|
553
|
+
})
|
|
554
|
+
export default class FooDAO extends BaseFooDAO {
|
|
555
|
+
async findByName(name: string): Promise<Foo[]> {
|
|
556
|
+
return this.dataSource.execute('findByName', {
|
|
557
|
+
name,
|
|
558
|
+
});
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
```
|
|
562
|
+
|
|
563
|
+
支持的自定义 filter
|
|
564
|
+
```
|
|
565
|
+
- toPoint
|
|
566
|
+
- toLine
|
|
567
|
+
- toPolygon
|
|
568
|
+
- toGeometry
|
|
569
|
+
- toMultiPoint
|
|
570
|
+
- toMultiLine
|
|
571
|
+
- toMultiPolygon
|
|
572
|
+
- toGeometryCollection
|
|
573
|
+
```
|
|
574
|
+
|
|
575
|
+
支持自定义 block 来简化 sql, 如内置的 allColumns
|
|
576
|
+
```ts
|
|
577
|
+
export default {
|
|
578
|
+
findByName: {
|
|
579
|
+
type: SqlType.BLOCK,
|
|
580
|
+
sql: 'id, name',
|
|
581
|
+
},
|
|
582
|
+
} as Record<string, SqlMap>;
|
|
583
|
+
```
|
|
584
|
+
|
|
585
|
+
### DataSource
|
|
586
|
+
DataSource 仅能在 DAO 中使用,可以将 mysql 返回的数据反序列化为类。支持的方法有
|
|
587
|
+
|
|
588
|
+
```ts
|
|
589
|
+
export interface DataSource<T> {
|
|
590
|
+
// 将返回的行都转换为 T
|
|
591
|
+
execute(sqlName: string, data?: any): Promise<Array<T>>;
|
|
592
|
+
// 将返回的行都转换为 T, 仅返回第一条
|
|
593
|
+
executeScalar(sqlName: string, data?: any): Promise<T | null>;
|
|
594
|
+
// 直接返回 mysql 数据
|
|
595
|
+
executeRaw(sqlName: string, data?: any): Promise<Array<any>>;
|
|
596
|
+
// 直接返回 mysql 数据, 仅返回第一条
|
|
597
|
+
executeRawScalar(sqlName: string, data?: any): Promise<any | null>;
|
|
598
|
+
// 返回分页数据
|
|
599
|
+
paginate(sqlName: string, data: any, currentPage: number, perPageCount: number): Promise<any>;
|
|
600
|
+
// 返回行数
|
|
601
|
+
count(sqlName: string, data?: any): Promise<number>;
|
|
602
|
+
}
|
|
603
|
+
```
|
|
604
|
+
|
|
605
|
+
### 时区问题
|
|
606
|
+
|
|
607
|
+
注意连接配置中的时区必须和数据库的时区完全一致,否则可能出现时间错误的问题。
|
|
608
|
+
|
|
609
|
+
```yaml
|
|
610
|
+
dataSource:
|
|
611
|
+
foo:
|
|
612
|
+
connectionLimit: 100
|
|
613
|
+
database: 'test'
|
|
614
|
+
host: '127.0.0.1'
|
|
615
|
+
user: root
|
|
616
|
+
port: 3306
|
|
617
|
+
timezone: '+08:00'
|
|
618
|
+
```
|
|
619
|
+
|
|
620
|
+
可以通过以下 SQL 来查看数据库时区
|
|
621
|
+
```sql
|
|
622
|
+
SELECT @@GLOBAL.time_zone;
|
|
623
|
+
```
|
package/app.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Application } from 'egg';
|
|
2
|
+
export default class ControllerAppBootHook {
|
|
3
|
+
private readonly app;
|
|
4
|
+
private dalTableEggPrototypeHook;
|
|
5
|
+
private dalModuleLoadUnitHook;
|
|
6
|
+
constructor(app: Application);
|
|
7
|
+
configWillLoad(): void;
|
|
8
|
+
beforeClose(): Promise<void>;
|
|
9
|
+
}
|
package/app.js
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const DalTableEggPrototypeHook_1 = require("./lib/DalTableEggPrototypeHook");
|
|
4
|
+
const MysqlDataSourceManager_1 = require("./lib/MysqlDataSourceManager");
|
|
5
|
+
const SqlMapManager_1 = require("./lib/SqlMapManager");
|
|
6
|
+
const TableModelManager_1 = require("./lib/TableModelManager");
|
|
7
|
+
const DalModuleLoadUnitHook_1 = require("./lib/DalModuleLoadUnitHook");
|
|
8
|
+
class ControllerAppBootHook {
|
|
9
|
+
constructor(app) {
|
|
10
|
+
this.app = app;
|
|
11
|
+
}
|
|
12
|
+
configWillLoad() {
|
|
13
|
+
this.dalModuleLoadUnitHook = new DalModuleLoadUnitHook_1.DalModuleLoadUnitHook(this.app.moduleConfigs);
|
|
14
|
+
this.dalTableEggPrototypeHook = new DalTableEggPrototypeHook_1.DalTableEggPrototypeHook(this.app.logger);
|
|
15
|
+
this.app.eggPrototypeLifecycleUtil.registerLifecycle(this.dalTableEggPrototypeHook);
|
|
16
|
+
this.app.loadUnitLifecycleUtil.registerLifecycle(this.dalModuleLoadUnitHook);
|
|
17
|
+
}
|
|
18
|
+
async beforeClose() {
|
|
19
|
+
if (this.dalTableEggPrototypeHook) {
|
|
20
|
+
await this.app.eggPrototypeLifecycleUtil.deleteLifecycle(this.dalTableEggPrototypeHook);
|
|
21
|
+
}
|
|
22
|
+
if (this.dalModuleLoadUnitHook) {
|
|
23
|
+
await this.app.loadUnitLifecycleUtil.deleteLifecycle(this.dalModuleLoadUnitHook);
|
|
24
|
+
}
|
|
25
|
+
MysqlDataSourceManager_1.MysqlDataSourceManager.instance.clear();
|
|
26
|
+
SqlMapManager_1.SqlMapManager.instance.clear();
|
|
27
|
+
TableModelManager_1.TableModelManager.instance.clear();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.default = ControllerAppBootHook;
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXBwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsNkVBQTBFO0FBQzFFLHlFQUFzRTtBQUN0RSx1REFBb0Q7QUFDcEQsK0RBQTREO0FBQzVELHVFQUFvRTtBQUVwRSxNQUFxQixxQkFBcUI7SUFLeEMsWUFBWSxHQUFnQjtRQUMxQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztJQUNqQixDQUFDO0lBRUQsY0FBYztRQUNaLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxJQUFJLDZDQUFxQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDL0UsSUFBSSxDQUFDLHdCQUF3QixHQUFHLElBQUksbURBQXdCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM5RSxJQUFJLENBQUMsR0FBRyxDQUFDLHlCQUF5QixDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBQ3BGLElBQUksQ0FBQyxHQUFHLENBQUMscUJBQXFCLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDL0UsQ0FBQztJQUVELEtBQUssQ0FBQyxXQUFXO1FBQ2YsSUFBSSxJQUFJLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztZQUNsQyxNQUFNLElBQUksQ0FBQyxHQUFHLENBQUMseUJBQXlCLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBQzFGLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1lBQy9CLE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFDbkYsQ0FBQztRQUNELCtDQUFzQixDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN4Qyw2QkFBYSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMvQixxQ0FBaUIsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckMsQ0FBQztDQUNGO0FBM0JELHdDQTJCQyJ9
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { LifecycleHook } from '@eggjs/tegg-lifecycle';
|
|
2
|
+
import { ModuleConfigHolder } from '@eggjs/tegg-common-util';
|
|
3
|
+
import { LoadUnit, LoadUnitLifecycleContext } from '@eggjs/tegg/helper';
|
|
4
|
+
export declare class DalModuleLoadUnitHook implements LifecycleHook<LoadUnitLifecycleContext, LoadUnit> {
|
|
5
|
+
private readonly moduleConfigs;
|
|
6
|
+
constructor(moduleConfigs: Record<string, ModuleConfigHolder>);
|
|
7
|
+
preCreate(_: LoadUnitLifecycleContext, loadUnit: LoadUnit): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DalModuleLoadUnitHook = void 0;
|
|
4
|
+
const MysqlDataSourceManager_1 = require("./MysqlDataSourceManager");
|
|
5
|
+
class DalModuleLoadUnitHook {
|
|
6
|
+
constructor(moduleConfigs) {
|
|
7
|
+
this.moduleConfigs = moduleConfigs;
|
|
8
|
+
}
|
|
9
|
+
async preCreate(_, loadUnit) {
|
|
10
|
+
const moduleConfigHolder = this.moduleConfigs[loadUnit.name];
|
|
11
|
+
if (!moduleConfigHolder)
|
|
12
|
+
return;
|
|
13
|
+
const dataSourceConfig = moduleConfigHolder.config.dataSource;
|
|
14
|
+
if (!dataSourceConfig)
|
|
15
|
+
return;
|
|
16
|
+
await Promise.all(Object.entries(dataSourceConfig).map(async ([name, config]) => {
|
|
17
|
+
try {
|
|
18
|
+
await MysqlDataSourceManager_1.MysqlDataSourceManager.instance.createDataSource(loadUnit.name, name, {
|
|
19
|
+
...config,
|
|
20
|
+
name,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
catch (e) {
|
|
24
|
+
e.message = `create module ${loadUnit.name} datasource ${name} failed: ` + e.message;
|
|
25
|
+
throw e;
|
|
26
|
+
}
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.DalModuleLoadUnitHook = DalModuleLoadUnitHook;
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFsTW9kdWxlTG9hZFVuaXRIb29rLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiRGFsTW9kdWxlTG9hZFVuaXRIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFFQUFrRTtBQU1sRSxNQUFhLHFCQUFxQjtJQUdoQyxZQUFZLGFBQWlEO1FBQzNELElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLENBQTJCLEVBQUUsUUFBa0I7UUFDN0QsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsa0JBQWtCO1lBQUUsT0FBTztRQUNoQyxNQUFNLGdCQUFnQixHQUFtRCxrQkFBa0IsQ0FBQyxNQUFjLENBQUMsVUFBVSxDQUFDO1FBQ3RILElBQUksQ0FBQyxnQkFBZ0I7WUFBRSxPQUFPO1FBQzlCLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFFLElBQUksRUFBRSxNQUFNLENBQUUsRUFBRSxFQUFFO1lBQ2hGLElBQUksQ0FBQztnQkFDSCxNQUFNLCtDQUFzQixDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRTtvQkFDMUUsR0FBRyxNQUFNO29CQUNULElBQUk7aUJBQ0wsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztZQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7Z0JBQ1gsQ0FBQyxDQUFDLE9BQU8sR0FBRyxpQkFBaUIsUUFBUSxDQUFDLElBQUksZUFBZSxJQUFJLFdBQVcsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDO2dCQUNyRixNQUFNLENBQUMsQ0FBQztZQUNWLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQztDQUNGO0FBeEJELHNEQXdCQyJ9
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { LifecycleHook } from '@eggjs/tegg-lifecycle';
|
|
2
|
+
import { EggPrototype, EggPrototypeLifecycleContext } from '@eggjs/tegg-metadata';
|
|
3
|
+
import { EggLogger } from 'egg';
|
|
4
|
+
export declare class DalTableEggPrototypeHook implements LifecycleHook<EggPrototypeLifecycleContext, EggPrototype> {
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(logger: EggLogger);
|
|
7
|
+
preCreate(ctx: EggPrototypeLifecycleContext): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DalTableEggPrototypeHook = void 0;
|
|
4
|
+
const dal_decorator_1 = require("@eggjs/dal-decorator");
|
|
5
|
+
const dal_runtime_1 = require("@eggjs/dal-runtime");
|
|
6
|
+
const TableModelManager_1 = require("./TableModelManager");
|
|
7
|
+
const SqlMapManager_1 = require("./SqlMapManager");
|
|
8
|
+
class DalTableEggPrototypeHook {
|
|
9
|
+
constructor(logger) {
|
|
10
|
+
this.logger = logger;
|
|
11
|
+
}
|
|
12
|
+
async preCreate(ctx) {
|
|
13
|
+
if (!dal_decorator_1.TableInfoUtil.getIsTable(ctx.clazz))
|
|
14
|
+
return;
|
|
15
|
+
const tableModel = dal_decorator_1.TableModel.build(ctx.clazz);
|
|
16
|
+
TableModelManager_1.TableModelManager.instance.set(ctx.loadUnit.name, tableModel);
|
|
17
|
+
const loader = new dal_runtime_1.SqlMapLoader(tableModel, ctx.loadUnit.unitPath, this.logger);
|
|
18
|
+
const sqlMap = loader.load();
|
|
19
|
+
SqlMapManager_1.SqlMapManager.instance.set(ctx.loadUnit.name, sqlMap);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.DalTableEggPrototypeHook = DalTableEggPrototypeHook;
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFsVGFibGVFZ2dQcm90b3R5cGVIb29rLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiRGFsVGFibGVFZ2dQcm90b3R5cGVIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLHdEQUFpRTtBQUVqRSxvREFBa0Q7QUFDbEQsMkRBQXdEO0FBQ3hELG1EQUFnRDtBQUVoRCxNQUFhLHdCQUF3QjtJQUduQyxZQUFZLE1BQWlCO1FBQzNCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQWlDO1FBQy9DLElBQUksQ0FBQyw2QkFBYSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDO1lBQUUsT0FBTztRQUNqRCxNQUFNLFVBQVUsR0FBRywwQkFBVSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MscUNBQWlCLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsQ0FBQztRQUM5RCxNQUFNLE1BQU0sR0FBRyxJQUFJLDBCQUFZLENBQUMsVUFBVSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNoRixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDN0IsNkJBQWEsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3hELENBQUM7Q0FDRjtBQWZELDREQWVDIn0=
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { DataSource as IDataSource, PaginateData } from '@eggjs/tegg/dal';
|
|
2
|
+
import { EggObject, EggObjectLifeCycleContext } from '@eggjs/tegg-runtime';
|
|
3
|
+
export declare class DataSourceDelegate<T> implements IDataSource<T> {
|
|
4
|
+
private dataSource;
|
|
5
|
+
init(_: EggObjectLifeCycleContext, obj: EggObject): Promise<void>;
|
|
6
|
+
execute(sqlName: string, data?: any): Promise<T[]>;
|
|
7
|
+
executeScalar(sqlName: string, data?: any): Promise<T | null>;
|
|
8
|
+
executeRaw(sqlName: string, data?: any): Promise<any[]>;
|
|
9
|
+
executeRawScalar(sqlName: string, data?: any): Promise<any>;
|
|
10
|
+
paginate(sqlName: string, data: any, currentPage: number, perPageCount: number): Promise<PaginateData<T>>;
|
|
11
|
+
count(sqlName: string, data?: any): Promise<number>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.DataSourceDelegate = void 0;
|
|
16
|
+
const node_assert_1 = __importDefault(require("node:assert"));
|
|
17
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
18
|
+
const node_fs_1 = __importDefault(require("node:fs"));
|
|
19
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
20
|
+
const tegg_common_util_1 = require("@eggjs/tegg-common-util");
|
|
21
|
+
const dal_1 = require("@eggjs/tegg/dal");
|
|
22
|
+
const dal_runtime_1 = require("@eggjs/dal-runtime");
|
|
23
|
+
const TableModelManager_1 = require("./TableModelManager");
|
|
24
|
+
const MysqlDataSourceManager_1 = require("./MysqlDataSourceManager");
|
|
25
|
+
const SqlMapManager_1 = require("./SqlMapManager");
|
|
26
|
+
let DataSourceDelegate = class DataSourceDelegate {
|
|
27
|
+
async init(_, obj) {
|
|
28
|
+
const dataSourceQualifierValue = obj.proto.getQualifier(dal_1.DataSourceQualifierAttribute);
|
|
29
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
30
|
+
const [moduleName, dataSource, clazzName] = dataSourceQualifierValue.split('.');
|
|
31
|
+
const tableModel = TableModelManager_1.TableModelManager.instance.get(moduleName, clazzName);
|
|
32
|
+
(0, node_assert_1.default)(tableModel, `not found table ${dataSourceQualifierValue}`);
|
|
33
|
+
const mysqlDataSource = MysqlDataSourceManager_1.MysqlDataSourceManager.instance.get(moduleName, dataSource);
|
|
34
|
+
(0, node_assert_1.default)(mysqlDataSource, `not found dataSource ${dataSource} in module ${moduleName}`);
|
|
35
|
+
const sqlMap = SqlMapManager_1.SqlMapManager.instance.get(moduleName, clazzName);
|
|
36
|
+
(0, node_assert_1.default)(sqlMap, `not found SqlMap ${clazzName} in module ${moduleName}`);
|
|
37
|
+
this.dataSource = new dal_runtime_1.DataSource(tableModel, mysqlDataSource, sqlMap);
|
|
38
|
+
}
|
|
39
|
+
async execute(sqlName, data) {
|
|
40
|
+
return this.dataSource.execute(sqlName, data);
|
|
41
|
+
}
|
|
42
|
+
async executeScalar(sqlName, data) {
|
|
43
|
+
return this.dataSource.executeScalar(sqlName, data);
|
|
44
|
+
}
|
|
45
|
+
async executeRaw(sqlName, data) {
|
|
46
|
+
return this.dataSource.executeRaw(sqlName, data);
|
|
47
|
+
}
|
|
48
|
+
async executeRawScalar(sqlName, data) {
|
|
49
|
+
return this.dataSource.executeRawScalar(sqlName, data);
|
|
50
|
+
}
|
|
51
|
+
async paginate(sqlName, data, currentPage, perPageCount) {
|
|
52
|
+
return this.dataSource.paginate(sqlName, data, currentPage, perPageCount);
|
|
53
|
+
}
|
|
54
|
+
async count(sqlName, data) {
|
|
55
|
+
return this.dataSource.count(sqlName, data);
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
exports.DataSourceDelegate = DataSourceDelegate;
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, tegg_1.LifecycleInit)(),
|
|
61
|
+
__metadata("design:type", Function),
|
|
62
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
63
|
+
__metadata("design:returntype", Promise)
|
|
64
|
+
], DataSourceDelegate.prototype, "init", null);
|
|
65
|
+
exports.DataSourceDelegate = DataSourceDelegate = __decorate([
|
|
66
|
+
(0, tegg_1.MultiInstanceProto)({
|
|
67
|
+
accessLevel: tegg_1.AccessLevel.PUBLIC,
|
|
68
|
+
initType: tegg_1.ObjectInitType.SINGLETON,
|
|
69
|
+
getObjects(ctx) {
|
|
70
|
+
const config = tegg_common_util_1.ModuleConfigUtil.loadModuleConfigSync(ctx.unitPath);
|
|
71
|
+
const dataSources = Object.keys((config === null || config === void 0 ? void 0 : config.dataSource) || {});
|
|
72
|
+
const result = [];
|
|
73
|
+
const daoDir = node_path_1.default.join(ctx.unitPath, 'dal/dao');
|
|
74
|
+
let dirents;
|
|
75
|
+
try {
|
|
76
|
+
dirents = node_fs_1.default.readdirSync(daoDir);
|
|
77
|
+
}
|
|
78
|
+
catch {
|
|
79
|
+
return [];
|
|
80
|
+
}
|
|
81
|
+
const daos = dirents.filter(t => t.endsWith('DAO.ts'));
|
|
82
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
83
|
+
const daoClazzList = daos.map(t => {
|
|
84
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
85
|
+
return require(node_path_1.default.join(daoDir, t)).default;
|
|
86
|
+
});
|
|
87
|
+
const tableClazzList = daoClazzList.map(t => {
|
|
88
|
+
// eslint-disable-next-line no-proto
|
|
89
|
+
return Object.getPrototypeOf(t).clazzModel;
|
|
90
|
+
});
|
|
91
|
+
const dataSourceLength = dataSources.length;
|
|
92
|
+
for (const dataSource of dataSources) {
|
|
93
|
+
const moduleClazzList = tableClazzList.filter(clazz => {
|
|
94
|
+
var _a;
|
|
95
|
+
const tableParams = dal_1.TableInfoUtil.getTableParams(clazz);
|
|
96
|
+
const dataSourceName = (_a = tableParams === null || tableParams === void 0 ? void 0 : tableParams.dataSourceName) !== null && _a !== void 0 ? _a : 'default';
|
|
97
|
+
return dataSourceLength === 1 || dataSourceName === dataSource;
|
|
98
|
+
});
|
|
99
|
+
for (const clazz of moduleClazzList) {
|
|
100
|
+
result.push({
|
|
101
|
+
name: dal_1.DataSourceInjectName,
|
|
102
|
+
qualifiers: [{
|
|
103
|
+
attribute: dal_1.DataSourceQualifierAttribute,
|
|
104
|
+
value: `${ctx.moduleName}.${dataSource}.${clazz.name}`,
|
|
105
|
+
}],
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return result;
|
|
110
|
+
},
|
|
111
|
+
})
|
|
112
|
+
], DataSourceDelegate);
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGF0YVNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIkRhdGFTb3VyY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsOERBQWlDO0FBQ2pDLDBEQUE2QjtBQUM3QixzREFBeUI7QUFDekIsc0NBT3FCO0FBQ3JCLDhEQUEyRDtBQUMzRCx5Q0FLeUI7QUFDekIsb0RBQWdEO0FBRWhELDJEQUF3RDtBQUN4RCxxRUFBa0U7QUFDbEUsbURBQWdEO0FBZ0R6QyxJQUFNLGtCQUFrQixHQUF4QixNQUFNLGtCQUFrQjtJQUl2QixBQUFOLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBNEIsRUFBRSxHQUFjO1FBQ3JELE1BQU0sd0JBQXdCLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsa0NBQTRCLENBQUMsQ0FBQztRQUN0Riw2REFBNkQ7UUFDN0QsTUFBTSxDQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsU0FBUyxDQUFFLEdBQUksd0JBQW1DLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzlGLE1BQU0sVUFBVSxHQUFHLHFDQUFpQixDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3pFLElBQUEscUJBQU0sRUFBQyxVQUFVLEVBQUUsbUJBQW1CLHdCQUF3QixFQUFFLENBQUMsQ0FBQztRQUNsRSxNQUFNLGVBQWUsR0FBRywrQ0FBc0IsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUNwRixJQUFBLHFCQUFNLEVBQUMsZUFBZSxFQUFFLHdCQUF3QixVQUFVLGNBQWMsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUN0RixNQUFNLE1BQU0sR0FBRyw2QkFBYSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ2pFLElBQUEscUJBQU0sRUFBQyxNQUFNLEVBQUUsb0JB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
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DataSourceOptions, MysqlDataSource } from '@eggjs/dal-runtime';
|
|
2
|
+
export declare class MysqlDataSourceManager {
|
|
3
|
+
static instance: MysqlDataSourceManager;
|
|
4
|
+
private readonly dataSourceIndices;
|
|
5
|
+
private readonly dataSources;
|
|
6
|
+
constructor();
|
|
7
|
+
get(moduleName: string, dataSourceName: string): MysqlDataSource | undefined;
|
|
8
|
+
createDataSource(moduleName: string, dataSourceName: string, config: DataSourceOptions): Promise<void>;
|
|
9
|
+
clear(): void;
|
|
10
|
+
static createDataSourceKey(dataSourceOptions: DataSourceOptions): string;
|
|
11
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.MysqlDataSourceManager = void 0;
|
|
7
|
+
const dal_runtime_1 = require("@eggjs/dal-runtime");
|
|
8
|
+
const node_crypto_1 = __importDefault(require("node:crypto"));
|
|
9
|
+
class MysqlDataSourceManager {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.dataSourceIndices = new Map();
|
|
12
|
+
this.dataSources = new Map();
|
|
13
|
+
}
|
|
14
|
+
get(moduleName, dataSourceName) {
|
|
15
|
+
var _a;
|
|
16
|
+
const dataSourceIndex = (_a = this.dataSourceIndices.get(moduleName)) === null || _a === void 0 ? void 0 : _a.get(dataSourceName);
|
|
17
|
+
if (dataSourceIndex) {
|
|
18
|
+
return this.dataSources.get(dataSourceIndex);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
async createDataSource(moduleName, dataSourceName, config) {
|
|
22
|
+
const dataSourceConfig = {
|
|
23
|
+
...config,
|
|
24
|
+
name: dataSourceName,
|
|
25
|
+
};
|
|
26
|
+
const index = MysqlDataSourceManager.createDataSourceKey(dataSourceConfig);
|
|
27
|
+
let dataSource = this.dataSources.get(index);
|
|
28
|
+
if (!dataSource) {
|
|
29
|
+
dataSource = new dal_runtime_1.MysqlDataSource(dataSourceConfig);
|
|
30
|
+
this.dataSources.set(index, dataSource);
|
|
31
|
+
}
|
|
32
|
+
let moduledataSourceIndices = this.dataSourceIndices.get(moduleName);
|
|
33
|
+
if (!moduledataSourceIndices) {
|
|
34
|
+
moduledataSourceIndices = new Map();
|
|
35
|
+
this.dataSourceIndices.set(moduleName, moduledataSourceIndices);
|
|
36
|
+
}
|
|
37
|
+
moduledataSourceIndices.set(dataSourceName, index);
|
|
38
|
+
await dataSource.ready();
|
|
39
|
+
}
|
|
40
|
+
clear() {
|
|
41
|
+
this.dataSourceIndices.clear();
|
|
42
|
+
}
|
|
43
|
+
static createDataSourceKey(dataSourceOptions) {
|
|
44
|
+
const hash = node_crypto_1.default.createHash('md5');
|
|
45
|
+
const keys = Object.keys(dataSourceOptions)
|
|
46
|
+
.sort();
|
|
47
|
+
for (const key of keys) {
|
|
48
|
+
const value = dataSourceOptions[key];
|
|
49
|
+
if (value) {
|
|
50
|
+
hash.update(key);
|
|
51
|
+
hash.update(String(value));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return hash.digest('hex');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.MysqlDataSourceManager = MysqlDataSourceManager;
|
|
58
|
+
MysqlDataSourceManager.instance = new MysqlDataSourceManager();
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTXlzcWxEYXRhU291cmNlTWFuYWdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIk15c3FsRGF0YVNvdXJjZU1hbmFnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsb0RBQXdFO0FBQ3hFLDhEQUFpQztBQUVqQyxNQUFhLHNCQUFzQjtJQU1qQztRQUNFLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ25DLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsR0FBRyxDQUFDLFVBQWtCLEVBQUUsY0FBc0I7O1FBQzVDLE1BQU0sZUFBZSxHQUFHLE1BQUEsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsMENBQzFELEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUN4QixJQUFJLGVBQWUsRUFBRSxDQUFDO1lBQ3BCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDL0MsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsZ0JBQWdCLENBQUMsVUFBa0IsRUFBRSxjQUFzQixFQUFFLE1BQXlCO1FBQzFGLE1BQU0sZ0JBQWdCLEdBQUc7WUFDdkIsR0FBRyxNQUFNO1lBQ1QsSUFBSSxFQUFFLGNBQWM7U0FDckIsQ0FBQztRQUNGLE1BQU0sS0FBSyxHQUFHLHNCQUFzQixDQUFDLG1CQUFtQixDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDM0UsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2hCLFVBQVUsR0FBRyxJQUFJLDZCQUFlLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDMUMsQ0FBQztRQUNELElBQUksdUJBQXVCLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNyRSxJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztZQUM3Qix1QkFBdUIsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBQ3BDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLHVCQUF1QixDQUFDLENBQUM7UUFDbEUsQ0FBQztRQUNELHVCQUF1QixDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFbkQsTUFBTSxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVELE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxpQkFBb0M7UUFDN0QsTUFBTSxJQUFJLEdBQUcscUJBQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEMsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQzthQUN4QyxJQUFJLEVBQUUsQ0FBQztRQUNWLEtBQUssTUFBTSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7WUFDdkIsTUFBTSxLQUFLLEdBQUcsaUJBQWlCLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDckMsSUFBSSxLQUFLLEVBQUUsQ0FBQztnQkFDVixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNqQixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzdCLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7O0FBeERILHdEQXlEQztBQXhEUSwrQkFBUSxHQUFHLElBQUksc0JBQXNCLEVBQUUsQ0FBQyJ9
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TableSqlMap } from '@eggjs/dal-runtime';
|
|
2
|
+
export declare class SqlMapManager {
|
|
3
|
+
static instance: SqlMapManager;
|
|
4
|
+
private sqlMaps;
|
|
5
|
+
constructor();
|
|
6
|
+
get(moduleName: string, clazzName: string): TableSqlMap | undefined;
|
|
7
|
+
set(moduleName: string, sqlMap: TableSqlMap): void;
|
|
8
|
+
clear(): void;
|
|
9
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SqlMapManager = void 0;
|
|
4
|
+
class SqlMapManager {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.sqlMaps = new Map();
|
|
7
|
+
}
|
|
8
|
+
get(moduleName, clazzName) {
|
|
9
|
+
var _a;
|
|
10
|
+
return (_a = this.sqlMaps.get(moduleName)) === null || _a === void 0 ? void 0 : _a.get(clazzName);
|
|
11
|
+
}
|
|
12
|
+
set(moduleName, sqlMap) {
|
|
13
|
+
let tables = this.sqlMaps.get(moduleName);
|
|
14
|
+
if (!tables) {
|
|
15
|
+
tables = new Map();
|
|
16
|
+
this.sqlMaps.set(moduleName, tables);
|
|
17
|
+
}
|
|
18
|
+
tables.set(sqlMap.name, sqlMap);
|
|
19
|
+
}
|
|
20
|
+
clear() {
|
|
21
|
+
this.sqlMaps.clear();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.SqlMapManager = SqlMapManager;
|
|
25
|
+
SqlMapManager.instance = new SqlMapManager();
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsTWFwTWFuYWdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIlNxbE1hcE1hbmFnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsTUFBYSxhQUFhO0lBS3hCO1FBQ0UsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxHQUFHLENBQUMsVUFBa0IsRUFBRSxTQUFpQjs7UUFDdkMsT0FBTyxNQUFBLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQywwQ0FBRSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELEdBQUcsQ0FBQyxVQUFrQixFQUFFLE1BQW1CO1FBQ3pDLElBQUksTUFBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNaLE1BQU0sR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUN2QyxDQUFDO1FBQ0QsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN2QixDQUFDOztBQXhCSCxzQ0F5QkM7QUF4QlEsc0JBQVEsR0FBRyxJQUFJLGFBQWEsRUFBRSxDQUFDIn0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TableModel } from '@eggjs/dal-decorator';
|
|
2
|
+
export declare class TableModelManager {
|
|
3
|
+
static instance: TableModelManager;
|
|
4
|
+
private tableModels;
|
|
5
|
+
constructor();
|
|
6
|
+
get(moduleName: string, clazzName: string): TableModel | undefined;
|
|
7
|
+
set(moduleName: string, tableModel: TableModel): void;
|
|
8
|
+
clear(): void;
|
|
9
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TableModelManager = void 0;
|
|
4
|
+
class TableModelManager {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.tableModels = new Map();
|
|
7
|
+
}
|
|
8
|
+
get(moduleName, clazzName) {
|
|
9
|
+
var _a;
|
|
10
|
+
return (_a = this.tableModels.get(moduleName)) === null || _a === void 0 ? void 0 : _a.get(clazzName);
|
|
11
|
+
}
|
|
12
|
+
set(moduleName, tableModel) {
|
|
13
|
+
let tables = this.tableModels.get(moduleName);
|
|
14
|
+
if (!tables) {
|
|
15
|
+
tables = new Map();
|
|
16
|
+
this.tableModels.set(moduleName, tables);
|
|
17
|
+
}
|
|
18
|
+
tables.set(tableModel.clazz.name, tableModel);
|
|
19
|
+
}
|
|
20
|
+
clear() {
|
|
21
|
+
this.tableModels.clear();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.TableModelManager = TableModelManager;
|
|
25
|
+
TableModelManager.instance = new TableModelManager();
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVNb2RlbE1hbmFnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJUYWJsZU1vZGVsTWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxNQUFhLGlCQUFpQjtJQUs1QjtRQUNFLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsR0FBRyxDQUFDLFVBQWtCLEVBQUUsU0FBaUI7O1FBQ3ZDLE9BQU8sTUFBQSxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsMENBQUUsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRCxHQUFHLENBQUMsVUFBa0IsRUFBRSxVQUFzQjtRQUM1QyxJQUFJLE1BQU0sR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWixNQUFNLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDM0MsQ0FBQztRQUNELE1BQU0sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzNCLENBQUM7O0FBeEJILDhDQXlCQztBQXhCUSwwQkFBUSxHQUFHLElBQUksaUJBQWlCLEVBQUUsQ0FBQyJ9
|
package/package.json
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@eggjs/tegg-dal-plugin",
|
|
3
|
+
"eggPlugin": {
|
|
4
|
+
"name": "teggDal",
|
|
5
|
+
"strict": false,
|
|
6
|
+
"dependencies": [
|
|
7
|
+
"tegg"
|
|
8
|
+
]
|
|
9
|
+
},
|
|
10
|
+
"eggModule": {
|
|
11
|
+
"name": "teggDal"
|
|
12
|
+
},
|
|
13
|
+
"version": "3.33.0",
|
|
14
|
+
"description": "dal plugin for egg",
|
|
15
|
+
"keywords": [
|
|
16
|
+
"egg",
|
|
17
|
+
"plugin",
|
|
18
|
+
"typescript",
|
|
19
|
+
"module",
|
|
20
|
+
"tegg",
|
|
21
|
+
"dal"
|
|
22
|
+
],
|
|
23
|
+
"files": [
|
|
24
|
+
"app.js",
|
|
25
|
+
"app.d.ts",
|
|
26
|
+
"lib/**/*.js",
|
|
27
|
+
"lib/**/*.d.ts",
|
|
28
|
+
"app/**/*.js",
|
|
29
|
+
"app/**/*.d.ts",
|
|
30
|
+
"typings/*.d.ts"
|
|
31
|
+
],
|
|
32
|
+
"types": "typings/index.d.ts",
|
|
33
|
+
"scripts": {
|
|
34
|
+
"test": "cross-env NODE_ENV=test NODE_OPTIONS='--no-deprecation' mocha",
|
|
35
|
+
"clean": "tsc -b --clean",
|
|
36
|
+
"tsc": "npm run clean && tsc -p ./tsconfig.json",
|
|
37
|
+
"tsc:pub": "npm run clean && tsc -p ./tsconfig.pub.json",
|
|
38
|
+
"prepublishOnly": "npm run tsc:pub"
|
|
39
|
+
},
|
|
40
|
+
"homepage": "https://github.com/eggjs/tegg",
|
|
41
|
+
"bugs": {
|
|
42
|
+
"url": "https://github.com/eggjs/tegg/issues"
|
|
43
|
+
},
|
|
44
|
+
"repository": {
|
|
45
|
+
"type": "git",
|
|
46
|
+
"url": "git@github.com:eggjs/tegg.git",
|
|
47
|
+
"directory": "plugin/controller"
|
|
48
|
+
},
|
|
49
|
+
"engines": {
|
|
50
|
+
"node": ">=14.0.0"
|
|
51
|
+
},
|
|
52
|
+
"dependencies": {
|
|
53
|
+
"@eggjs/dal-runtime": "^3.33.0",
|
|
54
|
+
"@eggjs/tegg": "^3.33.0"
|
|
55
|
+
},
|
|
56
|
+
"devDependencies": {
|
|
57
|
+
"@eggjs/tegg-plugin": "^3.33.0",
|
|
58
|
+
"@types/mocha": "^10.0.1",
|
|
59
|
+
"@types/node": "^20.2.4",
|
|
60
|
+
"cross-env": "^7.0.3",
|
|
61
|
+
"egg": "^3.9.1",
|
|
62
|
+
"egg-mock": "^5.5.0",
|
|
63
|
+
"egg-tracer": "^2.0.0",
|
|
64
|
+
"globby": "^11.1.0",
|
|
65
|
+
"mocha": "^10.2.0",
|
|
66
|
+
"ts-node": "^10.9.1",
|
|
67
|
+
"typescript": "^5.0.4"
|
|
68
|
+
},
|
|
69
|
+
"publishConfig": {
|
|
70
|
+
"access": "public"
|
|
71
|
+
},
|
|
72
|
+
"gitHead": "8415595364405be14730f6151ded8763bfb12454"
|
|
73
|
+
}
|