@eggjs/dal-runtime 3.62.0 → 4.0.0-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/README.md +13 -1
  2. package/dist/{src/BaseSqlMap.d.ts → BaseSqlMap.d.ts} +4 -4
  3. package/dist/BaseSqlMap.js +304 -0
  4. package/dist/{src/CodeGenerator.d.ts → CodeGenerator.d.ts} +1 -1
  5. package/dist/CodeGenerator.js +139 -0
  6. package/dist/DaoLoader.d.ts +4 -0
  7. package/dist/DaoLoader.js +14 -0
  8. package/dist/{src/DataSource.d.ts → DataSource.d.ts} +5 -5
  9. package/dist/DataSource.js +82 -0
  10. package/dist/{src/DatabaseForker.d.ts → DatabaseForker.d.ts} +2 -2
  11. package/dist/DatabaseForker.js +50 -0
  12. package/dist/{src/MySqlDataSource.d.ts → MySqlDataSource.d.ts} +2 -2
  13. package/dist/{src/MySqlDataSource.js → MySqlDataSource.js} +5 -12
  14. package/dist/{src/NunjucksConverter.js → NunjucksConverter.js} +3 -7
  15. package/dist/NunjucksUtil.js +74 -0
  16. package/dist/{src/SqlGenerator.d.ts → SqlGenerator.d.ts} +1 -1
  17. package/dist/SqlGenerator.js +392 -0
  18. package/dist/{src/SqlMapLoader.d.ts → SqlMapLoader.d.ts} +2 -2
  19. package/dist/SqlMapLoader.js +20 -0
  20. package/dist/{src/SqlUtil.js → SqlUtil.js} +3 -14
  21. package/dist/{src/TableModelInstanceBuilder.d.ts → TableModelInstanceBuilder.d.ts} +1 -1
  22. package/dist/TableModelInstanceBuilder.js +23 -0
  23. package/dist/TableSqlMap.js +92 -0
  24. package/dist/{src/TemplateUtil.d.ts → TemplateUtil.d.ts} +3 -12
  25. package/dist/TemplateUtil.js +86 -0
  26. package/dist/index.d.ts +15 -9
  27. package/dist/index.js +16 -28
  28. package/package.json +33 -32
  29. package/dist/src/BaseSqlMap.js +0 -310
  30. package/dist/src/CodeGenerator.js +0 -145
  31. package/dist/src/DaoLoader.d.ts +0 -4
  32. package/dist/src/DaoLoader.js +0 -17
  33. package/dist/src/DataSource.js +0 -83
  34. package/dist/src/DatabaseForker.js +0 -56
  35. package/dist/src/NunjucksUtil.js +0 -114
  36. package/dist/src/SqlGenerator.js +0 -395
  37. package/dist/src/SqlMapLoader.js +0 -23
  38. package/dist/src/TableModelInstanceBuilder.js +0 -26
  39. package/dist/src/TableSqlMap.js +0 -95
  40. package/dist/src/TemplateUtil.js +0 -93
  41. package/dist/src/templates/base_dao.njk +0 -166
  42. package/dist/src/templates/dao.njk +0 -17
  43. package/dist/src/templates/extension.njk +0 -17
  44. /package/dist/{src/NunjucksConverter.d.ts → NunjucksConverter.d.ts} +0 -0
  45. /package/dist/{src/NunjucksUtil.d.ts → NunjucksUtil.d.ts} +0 -0
  46. /package/dist/{src/SqlUtil.d.ts → SqlUtil.d.ts} +0 -0
  47. /package/dist/{src/TableSqlMap.d.ts → TableSqlMap.d.ts} +0 -0
package/README.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # `@eggjs/dal-runtime`
2
2
 
3
+ [![NPM version][npm-image]][npm-url]
4
+ [![Known Vulnerabilities][snyk-image]][snyk-url]
5
+ [![npm download][download-image]][download-url]
6
+ [![Node.js Version](https://img.shields.io/node/v/@eggjs/dal-runtime.svg?style=flat)](https://nodejs.org/en/download/)
7
+
8
+ [npm-image]: https://img.shields.io/npm/v/@eggjs/dal-runtime.svg?style=flat-square
9
+ [npm-url]: https://npmjs.org/package/@eggjs/dal-runtime
10
+ [snyk-image]: https://snyk.io/test/npm/@eggjs/dal-runtime/badge.svg?style=flat-square
11
+ [snyk-url]: https://snyk.io/test/npm/@eggjs/dal-runtime
12
+ [download-image]: https://img.shields.io/npm/dm/@eggjs/dal-runtime.svg?style=flat-square
13
+ [download-url]: https://npmjs.org/package/@eggjs/dal-runtime
14
+
3
15
  ## Usage
4
16
 
5
- Please read [@eggjs/tegg-dal-plugin](../../plugin/dal-plugin)
17
+ Please read [@eggjs/tegg-dal-plugin](../../plugin/dal/README.md)
@@ -1,5 +1,5 @@
1
- import { TableModel } from '@eggjs/tegg/dal';
2
- import { SqlMap } from '@eggjs/tegg-types';
1
+ import { TableModel } from '@eggjs/dal-decorator';
2
+ import { type SqlMap } from '@eggjs/tegg-types';
3
3
  import type { Logger, GenerateSqlMap } from '@eggjs/tegg-types';
4
4
  export declare class BaseSqlMapGenerator {
5
5
  private readonly tableModel;
@@ -9,7 +9,7 @@ export declare class BaseSqlMapGenerator {
9
9
  generateFindByPrimary(): Array<GenerateSqlMap>;
10
10
  generateFindByIndexes(): GenerateSqlMap[];
11
11
  generateInsert(): string;
12
- generateUpdate(): string | undefined;
13
- generateDelete(): string | undefined;
12
+ generateUpdate(): string;
13
+ generateDelete(): string;
14
14
  load(): Record<string, SqlMap>;
15
15
  }
@@ -0,0 +1,304 @@
1
+ import _ from 'lodash';
2
+ import { TableModel } from '@eggjs/dal-decorator';
3
+ import { ColumnType, IndexType, SqlType } from '@eggjs/tegg-types';
4
+ import { TemplateUtil } from "./TemplateUtil.js";
5
+ export class BaseSqlMapGenerator {
6
+ constructor(tableModel, logger) {
7
+ this.tableModel = tableModel;
8
+ this.logger = logger;
9
+ }
10
+ generateAllColumns(countIf) {
11
+ const str = this.tableModel.columns.map(t => `\`${t.columnName}\``)
12
+ .join(',');
13
+ return countIf ? `{% if $$count == true %}0{% else %}${str}{% endif %}` : str;
14
+ }
15
+ generateFindByPrimary() {
16
+ const result = [];
17
+ const primary = this.tableModel.getPrimary();
18
+ if (!primary) {
19
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键查询语句。`);
20
+ return result;
21
+ }
22
+ let sql = `SELECT ${this.generateAllColumns(true)}
23
+ FROM \`${this.tableModel.name}\`
24
+ WHERE `;
25
+ sql += primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{$${indexKey.propertyName}}}`)
26
+ .join(' AND ');
27
+ if (primary.keys.length === 1) {
28
+ result.push({
29
+ type: SqlType.SELECT,
30
+ name: `findBy${_.upperFirst(primary.keys[0].propertyName)}`,
31
+ sql,
32
+ });
33
+ }
34
+ result.push({
35
+ name: 'findByPrimary',
36
+ type: SqlType.SELECT,
37
+ sql,
38
+ });
39
+ return result;
40
+ }
41
+ // TODO index 的左匹配
42
+ generateFindByIndexes() {
43
+ const sqlMaps = [];
44
+ for (const index of this.tableModel.indices) {
45
+ if (index.type === IndexType.PRIMARY)
46
+ continue;
47
+ let sql = `SELECT ${this.generateAllColumns(true)}
48
+ FROM \`${this.tableModel.name}\`
49
+ WHERE `;
50
+ sql += index.keys.map(indexKey => {
51
+ const s = `\`${indexKey.columnName}\` {{ "IS" if $${indexKey.propertyName} == null else "=" }} {{$${indexKey.propertyName}}}`;
52
+ return s;
53
+ })
54
+ .join(' AND ');
55
+ const tempName = _.upperFirst(_.camelCase(index.keys.length === 1 ? index.keys[0].propertyName : index.name));
56
+ sqlMaps.push({
57
+ name: `findBy${tempName}`,
58
+ type: SqlType.SELECT,
59
+ sql,
60
+ });
61
+ sqlMaps.push({
62
+ name: `findOneBy${tempName}`,
63
+ type: SqlType.SELECT,
64
+ sql: `${sql} LIMIT 0, 1`,
65
+ });
66
+ }
67
+ return sqlMaps;
68
+ }
69
+ generateInsert() {
70
+ let sql = `INSERT INTO \`${this.tableModel.name}\` `;
71
+ sql += '{% set ___first = true %}';
72
+ const keys = [];
73
+ const values = [];
74
+ for (const column of this.tableModel.columns) {
75
+ const { propertyName, columnName, type } = column;
76
+ if (column.propertyName !== 'gmtCreate' && column.propertyName !== 'gmtModified') {
77
+ // Add filter for Spatial Type
78
+ // - toPoint
79
+ // - toLine
80
+ // - toPolygon
81
+ // - toGeometry
82
+ // - toMultiPoint
83
+ // - toMultiLine
84
+ // - toMultiPolygon
85
+ // - toGeometryCollection
86
+ keys.push((`
87
+ {% if $${propertyName} !== undefined %}
88
+ {% if ___first %}
89
+ {% set ___first = false %}
90
+ {% else %}
91
+ ,
92
+ {% endif %}
93
+
94
+ \`${columnName}\`
95
+ {% endif %}
96
+ `).trim());
97
+ if (TemplateUtil.isSpatialType(column)) {
98
+ const filter = TemplateUtil.getSpatialFilter(column.type.type);
99
+ values.push((`
100
+ {% if $${propertyName} !== undefined %}
101
+ {% if ___first %}
102
+ {% set ___first = false %}
103
+ {% else %}
104
+ ,
105
+ {% endif %}
106
+
107
+ {{$${propertyName} | ${filter}}}
108
+ {% endif %}
109
+ `).trim());
110
+ }
111
+ else if (column.type.type === ColumnType.JSON) {
112
+ values.push((`
113
+ {% if $${propertyName} !== undefined %}
114
+ {% if ___first %}
115
+ {% set ___first = false %}
116
+ {% else %}
117
+ ,
118
+ {% endif %}
119
+
120
+ {{$${propertyName} | toJson}}
121
+ {% endif %}
122
+ `).trim());
123
+ }
124
+ else {
125
+ values.push((`
126
+ {% if $${propertyName} !== undefined %}
127
+ {% if ___first %}
128
+ {% set ___first = false %}
129
+ {% else %}
130
+ ,
131
+ {% endif %}
132
+
133
+ {{$${propertyName}}}
134
+ {% endif %}
135
+ `).trim());
136
+ }
137
+ }
138
+ else {
139
+ let now;
140
+ // Default value for gmtCreate/gmtModified
141
+ // int:UNIX_TEIMESTAMP
142
+ // bigint: ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)
143
+ // datetime/timestamp Now()
144
+ if (type.type === ColumnType.INT) {
145
+ // 秒级时间戳
146
+ now = 'UNIX_TIMESTAMP()';
147
+ }
148
+ else if (type.type === ColumnType.BIGINT) {
149
+ // 毫秒级时间戳
150
+ now = 'ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)';
151
+ }
152
+ else if (type.type === ColumnType.DATETIME || type.type === ColumnType.TIMESTAMP) {
153
+ now = type.precision ? `NOW(${type.precision})` : 'NOW()';
154
+ }
155
+ else {
156
+ this.logger.warn(`unknown type ${type.type} for ${propertyName}`);
157
+ }
158
+ keys.push((`
159
+ {% if ___first %}
160
+ {% set ___first = false %}
161
+ {% else %}
162
+ ,
163
+ {% endif %}
164
+
165
+ \`${columnName}\`
166
+ `).trim());
167
+ values.push((`
168
+ {% if ___first %}
169
+ {% set ___first = false %}
170
+ {% else %}
171
+ ,
172
+ {% endif %}
173
+
174
+ {{ $${propertyName} if $${propertyName} !== undefined else '${now}' }}
175
+ `).trim());
176
+ }
177
+ }
178
+ sql += `(${keys.join('')})`;
179
+ sql += '{% set ___first = true %}';
180
+ sql += `VALUES(${values.join('')});`;
181
+ return sql;
182
+ }
183
+ generateUpdate() {
184
+ const primary = this.tableModel.getPrimary();
185
+ if (!primary) {
186
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键更新语句。`);
187
+ return;
188
+ }
189
+ let sql = `UPDATE \`${this.tableModel.name}\` SET`;
190
+ sql += '{% set ___first = true %}';
191
+ const kv = [];
192
+ for (const column of this.tableModel.columns) {
193
+ const { type, propertyName, columnName } = column;
194
+ let now;
195
+ if (type.type === ColumnType.INT) {
196
+ // 秒级时间戳
197
+ now = 'UNIX_TIMESTAMP()';
198
+ }
199
+ else if (type.type === ColumnType.BIGINT) {
200
+ // 毫秒级时间戳
201
+ now = 'ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)';
202
+ }
203
+ else if (type.type === ColumnType.TIMESTAMP || type.type === ColumnType.DATETIME) {
204
+ now = type.precision ? `NOW(${type.precision})` : 'NOW()';
205
+ }
206
+ // 若无更新时间字段,则自动更新该字段
207
+ const temp = propertyName !== 'gmtModified' ?
208
+ `
209
+ {% if $${propertyName} !== undefined %}
210
+ {% if ___first %}
211
+ {% set ___first = false %}
212
+ {% else %}
213
+ ,
214
+ {% endif %}
215
+
216
+ \`${columnName}\` = {{$${propertyName}}}
217
+ {% endif %}
218
+ ` :
219
+ `
220
+ {% if ___first %}
221
+ {% set ___first = false %}
222
+ {% else %}
223
+ ,
224
+ {% endif %}
225
+
226
+ \`${columnName}\` =
227
+ {{ $${propertyName} if $${propertyName} !== undefined else '${now}' }}
228
+ `;
229
+ kv.push(temp);
230
+ }
231
+ sql += kv.join('');
232
+ sql += `WHERE ${primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{primary.${indexKey.propertyName}}}`)
233
+ .join(' AND ')}`;
234
+ return sql;
235
+ }
236
+ generateDelete() {
237
+ const primary = this.tableModel.getPrimary();
238
+ if (!primary) {
239
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键删除语句。`);
240
+ return;
241
+ }
242
+ let sql = `DELETE
243
+ FROM \`${this.tableModel.name}\`
244
+ WHERE `;
245
+ sql += primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{${indexKey.propertyName}}}`)
246
+ .join(' AND ');
247
+ return sql;
248
+ }
249
+ load() {
250
+ const map = {};
251
+ map.allColumns = {
252
+ type: SqlType.BLOCK,
253
+ content: this.generateAllColumns(false),
254
+ };
255
+ const sqlMaps = [
256
+ /**
257
+ * 以主键进行索引
258
+ *
259
+ * + `findByPrimary`
260
+ * + 若为单主键,则再加 `findBy键名`
261
+ */
262
+ ...this.generateFindByPrimary(),
263
+ /**
264
+ * findBy 各索引
265
+ *
266
+ * + 若为多列索引,则为 `findBy索引名`
267
+ * + 若为单列索引,则为 `findBy列名`
268
+ */
269
+ ...this.generateFindByIndexes(),
270
+ /**
271
+ * 插入
272
+ */
273
+ {
274
+ name: 'insert',
275
+ type: SqlType.INSERT,
276
+ sql: this.generateInsert(),
277
+ },
278
+ /**
279
+ * 主键更新
280
+ */
281
+ {
282
+ name: 'update',
283
+ type: SqlType.UPDATE,
284
+ sql: this.generateUpdate(),
285
+ },
286
+ /**
287
+ * 主键删除
288
+ */
289
+ {
290
+ name: 'delete',
291
+ type: SqlType.DELETE,
292
+ sql: this.generateDelete(),
293
+ },
294
+ ];
295
+ for (const sqlMap of sqlMaps) {
296
+ map[sqlMap.name] = {
297
+ type: sqlMap.type,
298
+ sql: sqlMap.sql,
299
+ };
300
+ }
301
+ return map;
302
+ }
303
+ }
304
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFzZVNxbE1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9CYXNlU3FsTWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sQ0FBQyxNQUFNLFFBQVEsQ0FBQztBQUN2QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFlLE1BQU0sbUJBQW1CLENBQUM7QUFHaEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWpELE1BQU0sT0FBTyxtQkFBbUI7SUFJOUIsWUFBWSxVQUFzQixFQUFFLE1BQWM7UUFDaEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVELGtCQUFrQixDQUFDLE9BQWdCO1FBQ2pDLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsSUFBSSxDQUFDO2FBQ2hFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNiLE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxzQ0FBc0MsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUNoRixDQUFDO0lBRUQscUJBQXFCO1FBQ25CLE1BQU0sTUFBTSxHQUEwQixFQUFFLENBQUM7UUFDekMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUM3QyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDYixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxxQkFBcUIsQ0FBQyxDQUFDO1lBQ25FLE9BQU8sTUFBTSxD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
@@ -1,6 +1,6 @@
1
1
  import { Templates } from '@eggjs/tegg-types';
2
2
  import type { CodeGeneratorOptions } from '@eggjs/tegg-types';
3
- import { TableModel } from '@eggjs/tegg/dal';
3
+ import { TableModel } from '@eggjs/dal-decorator';
4
4
  export declare class CodeGenerator {
5
5
  private readonly moduleDir;
6
6
  private readonly moduleName;
@@ -0,0 +1,139 @@
1
+ import fs from 'node:fs/promises';
2
+ import path from 'node:path';
3
+ import js_beautify from 'js-beautify';
4
+ import _ from 'lodash';
5
+ import nunjucks, {} from 'nunjucks';
6
+ import { Templates } from '@eggjs/tegg-types';
7
+ import { ColumnModel, TableModel } from '@eggjs/dal-decorator';
8
+ import { PrototypeUtil } from '@eggjs/core-decorator';
9
+ import { SqlGenerator } from "./SqlGenerator.js";
10
+ import { TemplateUtil } from "./TemplateUtil.js";
11
+ export class CodeGenerator {
12
+ constructor(options) {
13
+ this.moduleDir = options.moduleDir;
14
+ this.moduleName = options.moduleName;
15
+ this.teggPkg = options.teggPkg ?? '@eggjs/tegg';
16
+ this.dalPkg = options.dalPkg ?? '@eggjs/tegg/dal';
17
+ this.createNunjucksEnv();
18
+ }
19
+ createNunjucksEnv() {
20
+ this.njkEnv = nunjucks.configure(path.join(__dirname, './templates'), {
21
+ autoescape: false,
22
+ });
23
+ this.njkEnv.addFilter('pascalCase', name => _.upperFirst(_.camelCase(name)));
24
+ this.njkEnv.addFilter('camelCase', name => _.camelCase(name));
25
+ this.njkEnv.addFilter('dbTypeToTSType', TemplateUtil.dbTypeToTsType);
26
+ }
27
+ genCode(tplName, filePath, tableModel) {
28
+ let tableModelAbsolutePath = PrototypeUtil.getFilePath(tableModel.clazz);
29
+ tableModelAbsolutePath = tableModelAbsolutePath.substring(0, tableModelAbsolutePath.length - 3);
30
+ const data = {
31
+ table: tableModel,
32
+ file: filePath,
33
+ fileName: path.basename(filePath),
34
+ clazzName: tableModel.clazz.name,
35
+ moduleName: this.moduleName,
36
+ teggPkg: this.teggPkg,
37
+ dalPkg: this.dalPkg,
38
+ id: tableModel.columns.find(t => t.propertyName === 'id'),
39
+ primaryIndex: tableModel.getPrimary(),
40
+ tableModelPath: TemplateUtil.importPath(tableModelAbsolutePath, path.dirname(filePath)),
41
+ extensionPath: `../../extension/${tableModel.clazz.name}Extension`,
42
+ structurePath: `../../structure/${tableModel.clazz.name}.json`,
43
+ sqlPath: `../../structure/${tableModel.clazz.name}.sql`,
44
+ columnMap: tableModel.columns.reduce((p, c) => {
45
+ p[c.propertyName] = c;
46
+ return p;
47
+ }, {}),
48
+ };
49
+ return this.njkEnv.render(`${tplName}.njk`, data);
50
+ }
51
+ async generate(tableModel) {
52
+ let dalDir;
53
+ try {
54
+ await fs.access(path.join(this.moduleDir, 'src'));
55
+ dalDir = path.join(this.moduleDir, 'src/dal');
56
+ }
57
+ catch {
58
+ dalDir = path.join(this.moduleDir, 'dal');
59
+ }
60
+ // const tableName = tableModel.name;
61
+ // const clazzName = tableModel.clazz.name;
62
+ const clazzFileName = path.basename(PrototypeUtil.getFilePath(tableModel.clazz));
63
+ const baseFileName = path.basename(clazzFileName, '.ts');
64
+ // 要动的一些文件
65
+ const paths = {
66
+ // e.g. app/dal/dao/base/example.ts
67
+ baseBizDAO: path.join(dalDir, `dao/base/Base${baseFileName}DAO.ts`),
68
+ // e.g. app/dal/dao/example.ts
69
+ bizDAO: path.join(dalDir, `dao/${baseFileName}DAO.ts`),
70
+ // e.g. app/dal/extension/example.ts
71
+ extension: path.join(dalDir, `extension/${baseFileName}Extension.ts`),
72
+ // e.g. app/dal/structure/example.json
73
+ structure: path.join(dalDir, `structure/${baseFileName}.json`),
74
+ // e.g. app/dal/structure/example.sql
75
+ structureSql: path.join(dalDir, `structure/${baseFileName}.sql`),
76
+ };
77
+ // 建立 structure 文件
78
+ await fs.mkdir(path.dirname(paths.structure), {
79
+ recursive: true,
80
+ });
81
+ await fs.writeFile(paths.structure, JSON.stringify(tableModel, null, 2), 'utf8');
82
+ const sqlGenerator = new SqlGenerator();
83
+ const structureSql = sqlGenerator.generate(tableModel);
84
+ await fs.writeFile(paths.structureSql, structureSql, 'utf8');
85
+ const codes = [{
86
+ templates: Templates.BASE_DAO,
87
+ filePath: paths.baseBizDAO,
88
+ beautify: true,
89
+ overwrite: true,
90
+ }, {
91
+ templates: Templates.DAO,
92
+ filePath: paths.bizDAO,
93
+ beautify: true,
94
+ overwrite: false,
95
+ }, {
96
+ templates: Templates.EXTENSION,
97
+ filePath: paths.extension,
98
+ beautify: false,
99
+ overwrite: false,
100
+ }];
101
+ for (const { templates, filePath, beautify, overwrite } of codes) {
102
+ await fs.mkdir(path.dirname(filePath), {
103
+ recursive: true,
104
+ });
105
+ const code = this.genCode(templates, filePath, tableModel);
106
+ let beautified;
107
+ if (beautify) {
108
+ beautified = js_beautify(code, {
109
+ brace_style: 'preserve-inline',
110
+ indent_size: 2,
111
+ jslint_happy: true,
112
+ preserve_newlines: false,
113
+ });
114
+ }
115
+ else {
116
+ beautified = code;
117
+ }
118
+ beautified = beautified
119
+ .replace(/( )*\/\/ empty-line( )*/g, '')
120
+ .replace(/Promise( )*<( )*(.+?)( )*>/g, 'Promise<$3>')
121
+ .replace(/Optional( )*<( )*(.+?)( )*>/g, 'Optional<$3>')
122
+ .replace(/Record( )*<( )*(.+?)( )*>/g, 'Record<$3>')
123
+ .replace(/Partial( )*<( )*(.+?)( )*>/g, 'Partial<$3>')
124
+ .replace(/DataSource( )*<( )*(.+?)( )*>/g, 'DataSource<$3>')
125
+ .replace(/ \? :/g, '?:');
126
+ if (overwrite !== true) {
127
+ try {
128
+ await fs.access(filePath);
129
+ continue;
130
+ }
131
+ catch {
132
+ // file not exists
133
+ }
134
+ }
135
+ await fs.writeFile(filePath, beautified, 'utf8');
136
+ }
137
+ }
138
+ }
139
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29kZUdlbmVyYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9Db2RlR2VuZXJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2xDLE9BQU8sSUFBSSxNQUFNLFdBQVcsQ0FBQztBQUU3QixPQUFPLFdBQVcsTUFBTSxhQUFhLENBQUM7QUFDdEMsT0FBTyxDQUFDLE1BQU0sUUFBUSxDQUFDO0FBQ3ZCLE9BQU8sUUFBUSxFQUFFLEVBQW9CLE1BQU0sVUFBVSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUU5QyxPQUFPLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWpELE1BQU0sT0FBTyxhQUFhO0lBTXhCLFlBQVksT0FBNkI7UUFDdkMsSUFBSSxDQUFDLFNBQVMsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDO1FBQ25DLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQztRQUNyQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLElBQUksYUFBYSxDQUFDO1FBQ2hELElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sSUFBSSxpQkFBaUIsQ0FBQztRQUNsRCxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBSUQsaUJBQWlCO1FBQ2YsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lB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
@@ -0,0 +1,4 @@
1
+ import { type BaseDaoType } from '@eggjs/tegg-types/dal';
2
+ export declare class DaoLoader {
3
+ static loadDaos(moduleDir: string): Promise<Array<BaseDaoType>>;
4
+ }
@@ -0,0 +1,14 @@
1
+ import { EggLoadUnitType } from '@eggjs/tegg-types';
2
+ import { DaoInfoUtil } from '@eggjs/dal-decorator';
3
+ import {} from '@eggjs/tegg-types/dal';
4
+ import { LoaderFactory } from '@eggjs/tegg-loader';
5
+ export class DaoLoader {
6
+ static async loadDaos(moduleDir) {
7
+ const loader = LoaderFactory.createLoader(moduleDir, EggLoadUnitType.MODULE);
8
+ const clazzList = await loader.load();
9
+ return clazzList.filter((t) => {
10
+ return DaoInfoUtil.getIsDao(t);
11
+ });
12
+ }
13
+ }
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFvTG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL0Rhb0xvYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBb0IsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFbkQsTUFBTSxPQUFPLFNBQVM7SUFDcEIsTUFBTSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsU0FBaUI7UUFDckMsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLFlBQVksQ0FBQyxTQUFTLEVBQUUsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzdFLE1BQU0sU0FBUyxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3RDLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBb0IsRUFBRTtZQUM5QyxPQUFPLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YifQ==
@@ -1,7 +1,7 @@
1
- import { TableModel } from '@eggjs/tegg/dal';
1
+ import { TableModel } from '@eggjs/dal-decorator';
2
2
  import type { DataSource as IDataSource, PaginateData, SqlType } from '@eggjs/tegg-types';
3
- import { MysqlDataSource } from './MySqlDataSource';
4
- import { TableSqlMap } from './TableSqlMap';
3
+ import { MysqlDataSource } from './MySqlDataSource.ts';
4
+ import { TableSqlMap } from './TableSqlMap.ts';
5
5
  export interface ExecuteSql {
6
6
  sql: string;
7
7
  template: string;
@@ -15,8 +15,8 @@ export declare class DataSource<T> implements IDataSource<T> {
15
15
  constructor(tableModel: TableModel<T>, mysqlDataSource: MysqlDataSource, sqlMap: TableSqlMap);
16
16
  /**
17
17
  * public for aop execute to implement sql hint append
18
- * @param sqlName
19
- * @param data
18
+ * @param sqlName - sql name
19
+ * @param data - sql data
20
20
  */
21
21
  generateSql(sqlName: string, data: object): Promise<ExecuteSql>;
22
22
  count(sqlName: string, data?: any): Promise<number>;
@@ -0,0 +1,82 @@
1
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
2
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
3
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
+ };
6
+ var _DataSource_instances, _DataSource_paginateCount;
7
+ import { TableModel } from '@eggjs/dal-decorator';
8
+ import { MysqlDataSource } from "./MySqlDataSource.js";
9
+ import { TableSqlMap } from "./TableSqlMap.js";
10
+ import { TableModelInstanceBuilder } from "./TableModelInstanceBuilder.js";
11
+ const PAGINATE_COUNT_WRAPPER = ['SELECT COUNT(0) as count FROM (', ') AS T'];
12
+ export class DataSource {
13
+ constructor(tableModel, mysqlDataSource, sqlMap) {
14
+ _DataSource_instances.add(this);
15
+ this.tableModel = tableModel;
16
+ this.mysqlDataSource = mysqlDataSource;
17
+ this.sqlMap = sqlMap;
18
+ }
19
+ /**
20
+ * public for aop execute to implement sql hint append
21
+ * @param sqlName - sql name
22
+ * @param data - sql data
23
+ */
24
+ async generateSql(sqlName, data) {
25
+ const sql = this.sqlMap.generate(sqlName, data, this.mysqlDataSource.timezone);
26
+ const sqlType = this.sqlMap.getType(sqlName);
27
+ const template = this.sqlMap.getTemplateString(sqlName);
28
+ return {
29
+ sql,
30
+ sqlType,
31
+ template,
32
+ };
33
+ }
34
+ async count(sqlName, data) {
35
+ const newData = Object.assign({ $$count: true }, data);
36
+ const executeSql = await this.generateSql(sqlName, newData);
37
+ return await __classPrivateFieldGet(this, _DataSource_instances, "m", _DataSource_paginateCount).call(this, executeSql.sql);
38
+ }
39
+ async execute(sqlName, data) {
40
+ const executeSql = await this.generateSql(sqlName, data);
41
+ const rows = await this.mysqlDataSource.query(executeSql.sql);
42
+ return rows.map((t) => {
43
+ return TableModelInstanceBuilder.buildInstance(this.tableModel, t);
44
+ });
45
+ }
46
+ async executeRaw(sqlName, data) {
47
+ const executeSql = await this.generateSql(sqlName, data);
48
+ return await this.mysqlDataSource.query(executeSql.sql);
49
+ }
50
+ async executeScalar(sqlName, data) {
51
+ const ret = await this.execute(sqlName, data);
52
+ if (!Array.isArray(ret))
53
+ return ret || null;
54
+ return ret[0] || null;
55
+ }
56
+ async executeRawScalar(sqlName, data) {
57
+ const ret = await this.executeRaw(sqlName, data);
58
+ if (!Array.isArray(ret))
59
+ return (ret || null);
60
+ return ret[0] || null;
61
+ }
62
+ async paginate(sqlName, data, currentPage, perPageCount) {
63
+ const limit = `LIMIT ${(currentPage - 1) * perPageCount}, ${perPageCount}`;
64
+ const sql = (await this.generateSql(sqlName, data)).sql + ' ' + limit;
65
+ const countSql = (await this.generateSql(sqlName, Object.assign({ $$count: true }, data))).sql;
66
+ const ret = await Promise.all([
67
+ this.mysqlDataSource.query(sql),
68
+ __classPrivateFieldGet(this, _DataSource_instances, "m", _DataSource_paginateCount).call(this, countSql),
69
+ ]);
70
+ return {
71
+ total: Number(ret[1]),
72
+ pageNum: currentPage,
73
+ rows: ret[0].map((t) => TableModelInstanceBuilder.buildInstance(this.tableModel, t)),
74
+ };
75
+ }
76
+ }
77
+ _DataSource_instances = new WeakSet(), _DataSource_paginateCount = async function _DataSource_paginateCount(baseSQL) {
78
+ const sql = `${PAGINATE_COUNT_WRAPPER[0]}${baseSQL}${PAGINATE_COUNT_WRAPPER[1]}`;
79
+ const result = await this.mysqlDataSource.query(sql);
80
+ return result[0].count;
81
+ };
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGF0YVNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9EYXRhU291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUdsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBUTNFLE1BQU0sc0JBQXNCLEdBQUcsQ0FBRSxpQ0FBaUMsRUFBRSxRQUFRLENBQUUsQ0FBQztBQUUvRSxNQUFNLE9BQU8sVUFBVTtJQUtyQixZQUFZLFVBQXlCLEVBQUUsZUFBZ0MsRUFBRSxNQUFtQjs7UUFDMUYsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDN0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxlQUFlLENBQUM7UUFDdkMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQWUsRUFBRSxJQUFZO1FBQzdDLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxRQUFTLENBQUMsQ0FBQztRQUNoRixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hELE9BQU87WUFDTCxHQUFHO1lBQ0gsT0FBTztZQUNQLFFBQVE7U0FDVCxDQUFDO0lBQ0osQ0FBQztJQUVELEtBQUssQ0FBQyxLQUFLLENB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
@@ -1,9 +1,9 @@
1
- import { DataSourceOptions } from './MySqlDataSource';
1
+ import { type DataSourceOptions } from './MySqlDataSource.ts';
2
2
  export declare class DatabaseForker {
3
3
  private readonly env;
4
4
  private readonly options;
5
5
  constructor(env: string, options: DataSourceOptions);
6
- shouldFork(): boolean | undefined;
6
+ shouldFork(): boolean;
7
7
  forkDb(moduleDir: string): Promise<void>;
8
8
  private forkTables;
9
9
  private doForkTable;