@eggjs/dal-runtime 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 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,5 @@
1
+ # `@eggjs/dal-runtime`
2
+
3
+ ## Usage
4
+
5
+ Please read [@eggjs/tegg-dal-plugin](../../plugin/dal-plugin)
@@ -0,0 +1,7 @@
1
+ export * from './src/SqlGenerator';
2
+ export * from './src/CodeGenerator';
3
+ export { TableSqlMap } from './src/TableSqlMap';
4
+ export * from './src/SqlMapLoader';
5
+ export * from './src/DataSource';
6
+ export * from './src/MySqlDataSource';
7
+ export * from './src/TableModelInstanceBuilder';
package/dist/index.js ADDED
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.TableSqlMap = void 0;
18
+ __exportStar(require("./src/SqlGenerator"), exports);
19
+ __exportStar(require("./src/CodeGenerator"), exports);
20
+ var TableSqlMap_1 = require("./src/TableSqlMap");
21
+ Object.defineProperty(exports, "TableSqlMap", { enumerable: true, get: function () { return TableSqlMap_1.TableSqlMap; } });
22
+ __exportStar(require("./src/SqlMapLoader"), exports);
23
+ __exportStar(require("./src/DataSource"), exports);
24
+ __exportStar(require("./src/MySqlDataSource"), exports);
25
+ __exportStar(require("./src/TableModelInstanceBuilder"), exports);
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHFEQUFtQztBQUNuQyxzREFBb0M7QUFDcEMsaURBQWdEO0FBQXZDLDBHQUFBLFdBQVcsT0FBQTtBQUNwQixxREFBbUM7QUFFbkMsbURBQWlDO0FBQ2pDLHdEQUFzQztBQUN0QyxrRUFBZ0QifQ==
@@ -0,0 +1,19 @@
1
+ import { SqlType, SqlMap, TableModel } from '@eggjs/dal-decorator';
2
+ import { type EggLogger } from 'egg';
3
+ export interface GenerateSqlMap {
4
+ name: string;
5
+ type: SqlType.DELETE | SqlType.UPDATE | SqlType.INSERT | SqlType.SELECT;
6
+ sql: string;
7
+ }
8
+ export declare class BaseSqlMapGenerator {
9
+ private readonly tableModel;
10
+ private readonly logger;
11
+ constructor(tableModel: TableModel, logger: EggLogger);
12
+ generateAllColumns(countIf: boolean): string;
13
+ generateFindByPrimary(): Array<GenerateSqlMap>;
14
+ generateFindByIndexes(): GenerateSqlMap[];
15
+ generateInsert(): string;
16
+ generateUpdate(): string | undefined;
17
+ generateDelete(): string | undefined;
18
+ load(): Record<string, SqlMap>;
19
+ }
@@ -0,0 +1,310 @@
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.BaseSqlMapGenerator = void 0;
7
+ const lodash_1 = __importDefault(require("lodash"));
8
+ const dal_decorator_1 = require("@eggjs/dal-decorator");
9
+ const TemplateUtil_1 = require("./TemplateUtil");
10
+ class BaseSqlMapGenerator {
11
+ constructor(tableModel, logger) {
12
+ this.tableModel = tableModel;
13
+ this.logger = logger;
14
+ }
15
+ generateAllColumns(countIf) {
16
+ const str = this.tableModel.columns.map(t => `\`${t.columnName}\``)
17
+ .join(',');
18
+ return countIf ? `{% if $$count == true %}0{% else %}${str}{% endif %}` : str;
19
+ }
20
+ generateFindByPrimary() {
21
+ const result = [];
22
+ const primary = this.tableModel.getPrimary();
23
+ if (!primary) {
24
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键查询语句。`);
25
+ return result;
26
+ }
27
+ let sql = `SELECT ${this.generateAllColumns(true)}
28
+ FROM \`${this.tableModel.name}\`
29
+ WHERE `;
30
+ sql += primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{$${indexKey.propertyName}}}`)
31
+ .join(' AND ');
32
+ if (primary.keys.length === 1) {
33
+ result.push({
34
+ type: dal_decorator_1.SqlType.SELECT,
35
+ name: `findBy${lodash_1.default.upperFirst(primary.keys[0].propertyName)}`,
36
+ sql,
37
+ });
38
+ }
39
+ result.push({
40
+ name: 'findByPrimary',
41
+ type: dal_decorator_1.SqlType.SELECT,
42
+ sql,
43
+ });
44
+ return result;
45
+ }
46
+ // TODO index 的左匹配
47
+ generateFindByIndexes() {
48
+ const sqlMaps = [];
49
+ for (const index of this.tableModel.indices) {
50
+ if (index.type === dal_decorator_1.IndexType.PRIMARY)
51
+ continue;
52
+ let sql = `SELECT ${this.generateAllColumns(true)}
53
+ FROM \`${this.tableModel.name}\`
54
+ WHERE `;
55
+ sql += index.keys.map(indexKey => {
56
+ const s = `\`${indexKey.columnName}\` {{ "IS" if $${indexKey.propertyName} == null else "=" }} {{$${indexKey.propertyName}}}`;
57
+ return s;
58
+ })
59
+ .join(' AND ');
60
+ const tempName = lodash_1.default.upperFirst(lodash_1.default.camelCase(index.keys.length === 1 ? index.keys[0].propertyName : index.name));
61
+ sqlMaps.push({
62
+ name: `findBy${tempName}`,
63
+ type: dal_decorator_1.SqlType.SELECT,
64
+ sql,
65
+ });
66
+ sqlMaps.push({
67
+ name: `findOneBy${tempName}`,
68
+ type: dal_decorator_1.SqlType.SELECT,
69
+ sql: `${sql} LIMIT 0, 1`,
70
+ });
71
+ }
72
+ return sqlMaps;
73
+ }
74
+ generateInsert() {
75
+ let sql = `INSERT INTO \`${this.tableModel.name}\` `;
76
+ sql += '{% set ___first = true %}';
77
+ const keys = [];
78
+ const values = [];
79
+ for (const column of this.tableModel.columns) {
80
+ const { propertyName, columnName, type } = column;
81
+ if (column.propertyName !== 'gmtCreate' && column.propertyName !== 'gmtModified') {
82
+ // Add filter for Spatial Type
83
+ // - toPoint
84
+ // - toLine
85
+ // - toPolygon
86
+ // - toGeometry
87
+ // - toMultiPoint
88
+ // - toMultiLine
89
+ // - toMultiPolygon
90
+ // - toGeometryCollection
91
+ keys.push((`
92
+ {% if $${propertyName} !== undefined %}
93
+ {% if ___first %}
94
+ {% set ___first = false %}
95
+ {% else %}
96
+ ,
97
+ {% endif %}
98
+
99
+ \`${columnName}\`
100
+ {% endif %}
101
+ `).trim());
102
+ if (TemplateUtil_1.TemplateUtil.isSpatialType(column)) {
103
+ const filter = TemplateUtil_1.TemplateUtil.getSpatialFilter(column.type.type);
104
+ values.push((`
105
+ {% if $${propertyName} !== undefined %}
106
+ {% if ___first %}
107
+ {% set ___first = false %}
108
+ {% else %}
109
+ ,
110
+ {% endif %}
111
+
112
+ {{$${propertyName} | ${filter}}}
113
+ {% endif %}
114
+ `).trim());
115
+ }
116
+ else if (column.type.type === dal_decorator_1.ColumnType.JSON) {
117
+ values.push((`
118
+ {% if $${propertyName} !== undefined %}
119
+ {% if ___first %}
120
+ {% set ___first = false %}
121
+ {% else %}
122
+ ,
123
+ {% endif %}
124
+
125
+ {{$${propertyName} | toJson}}
126
+ {% endif %}
127
+ `).trim());
128
+ }
129
+ else {
130
+ values.push((`
131
+ {% if $${propertyName} !== undefined %}
132
+ {% if ___first %}
133
+ {% set ___first = false %}
134
+ {% else %}
135
+ ,
136
+ {% endif %}
137
+
138
+ {{$${propertyName}}}
139
+ {% endif %}
140
+ `).trim());
141
+ }
142
+ }
143
+ else {
144
+ let now;
145
+ // Default value for gmtCreate/gmtModified
146
+ // int:UNIX_TEIMESTAMP
147
+ // bigint: ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)
148
+ // datetime/timestamp Now()
149
+ if (type.type === dal_decorator_1.ColumnType.INT) {
150
+ // 秒级时间戳
151
+ now = 'UNIX_TIMESTAMP()';
152
+ }
153
+ else if (type.type === dal_decorator_1.ColumnType.BIGINT) {
154
+ // 毫秒级时间戳
155
+ now = 'ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)';
156
+ }
157
+ else if (type.type === dal_decorator_1.ColumnType.DATETIME || type.type === dal_decorator_1.ColumnType.TIMESTAMP) {
158
+ now = type.precision ? `NOW(${type.precision})` : 'NOW()';
159
+ }
160
+ else {
161
+ this.logger.warn(`unknown type ${type.type} for ${propertyName}`);
162
+ }
163
+ keys.push((`
164
+ {% if ___first %}
165
+ {% set ___first = false %}
166
+ {% else %}
167
+ ,
168
+ {% endif %}
169
+
170
+ \`${columnName}\`
171
+ `).trim());
172
+ values.push((`
173
+ {% if ___first %}
174
+ {% set ___first = false %}
175
+ {% else %}
176
+ ,
177
+ {% endif %}
178
+
179
+ {{ $${propertyName} if $${propertyName} !== undefined else '${now}' }}
180
+ `).trim());
181
+ }
182
+ }
183
+ sql += `(${keys.join('')})`;
184
+ sql += '{% set ___first = true %}';
185
+ sql += `VALUES(${values.join('')});`;
186
+ return sql;
187
+ }
188
+ generateUpdate() {
189
+ const primary = this.tableModel.getPrimary();
190
+ if (!primary) {
191
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键更新语句。`);
192
+ return;
193
+ }
194
+ let sql = `UPDATE \`${this.tableModel.name}\` SET`;
195
+ sql += '{% set ___first = true %}';
196
+ const kv = [];
197
+ for (const column of this.tableModel.columns) {
198
+ const { type, propertyName, columnName } = column;
199
+ let now;
200
+ if (type.type === dal_decorator_1.ColumnType.INT) {
201
+ // 秒级时间戳
202
+ now = 'UNIX_TIMESTAMP()';
203
+ }
204
+ else if (type.type === dal_decorator_1.ColumnType.BIGINT) {
205
+ // 毫秒级时间戳
206
+ now = 'ROUND(UNIX_TIMESTAMP(CURTIME(4)) * 1000)';
207
+ }
208
+ else if (type.type === dal_decorator_1.ColumnType.TIMESTAMP || type.type === dal_decorator_1.ColumnType.DATETIME) {
209
+ now = type.precision ? `NOW(${type.precision})` : 'NOW()';
210
+ }
211
+ // 若无更新时间字段,则自动更新该字段
212
+ const temp = propertyName !== 'gmtModified' ?
213
+ `
214
+ {% if $${propertyName} !== undefined %}
215
+ {% if ___first %}
216
+ {% set ___first = false %}
217
+ {% else %}
218
+ ,
219
+ {% endif %}
220
+
221
+ \`${columnName}\` = {{$${propertyName}}}
222
+ {% endif %}
223
+ ` :
224
+ `
225
+ {% if ___first %}
226
+ {% set ___first = false %}
227
+ {% else %}
228
+ ,
229
+ {% endif %}
230
+
231
+ \`${columnName}\` =
232
+ {{ $${propertyName} if $${propertyName} !== undefined else '${now}' }}
233
+ `;
234
+ kv.push(temp);
235
+ }
236
+ sql += kv.join('');
237
+ sql += `WHERE ${primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{primary.${indexKey.propertyName}}}`)
238
+ .join(' AND ')}`;
239
+ return sql;
240
+ }
241
+ generateDelete() {
242
+ const primary = this.tableModel.getPrimary();
243
+ if (!primary) {
244
+ this.logger.warn(`表 \`${this.tableModel.name}\` 没有主键,无法生成主键删除语句。`);
245
+ return;
246
+ }
247
+ let sql = `DELETE
248
+ FROM \`${this.tableModel.name}\`
249
+ WHERE `;
250
+ sql += primary.keys.map(indexKey => `\`${indexKey.columnName}\` = {{${indexKey.propertyName}}}`)
251
+ .join(' AND ');
252
+ return sql;
253
+ }
254
+ load() {
255
+ const map = {};
256
+ map.allColumns = {
257
+ type: dal_decorator_1.SqlType.BLOCK,
258
+ content: this.generateAllColumns(false),
259
+ };
260
+ const sqlMaps = [
261
+ /**
262
+ * 以主键进行索引
263
+ *
264
+ * + `findByPrimary`
265
+ * + 若为单主键,则再加 `findBy键名`
266
+ */
267
+ ...this.generateFindByPrimary(),
268
+ /**
269
+ * findBy 各索引
270
+ *
271
+ * + 若为多列索引,则为 `findBy索引名`
272
+ * + 若为单列索引,则为 `findBy列名`
273
+ */
274
+ ...this.generateFindByIndexes(),
275
+ /**
276
+ * 插入
277
+ */
278
+ {
279
+ name: 'insert',
280
+ type: dal_decorator_1.SqlType.INSERT,
281
+ sql: this.generateInsert(),
282
+ },
283
+ /**
284
+ * 主键更新
285
+ */
286
+ {
287
+ name: 'update',
288
+ type: dal_decorator_1.SqlType.UPDATE,
289
+ sql: this.generateUpdate(),
290
+ },
291
+ /**
292
+ * 主键删除
293
+ */
294
+ {
295
+ name: 'delete',
296
+ type: dal_decorator_1.SqlType.DELETE,
297
+ sql: this.generateDelete(),
298
+ },
299
+ ];
300
+ for (const sqlMap of sqlMaps) {
301
+ map[sqlMap.name] = {
302
+ type: sqlMap.type,
303
+ sql: sqlMap.sql,
304
+ };
305
+ }
306
+ return map;
307
+ }
308
+ }
309
+ exports.BaseSqlMapGenerator = BaseSqlMapGenerator;
310
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFzZVNxbE1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXNlU3FsTWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLG9EQUF1QjtBQUN2Qix3REFBMEY7QUFFMUYsaURBQThDO0FBUTlDLE1BQWEsbUJBQW1CO0lBSTlCLFlBQVksVUFBc0IsRUFBRSxNQUFpQjtRQUNuRCxJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztRQUM3QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsa0JBQWtCLENBQUMsT0FBZ0I7UUFDakMsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsVUFBVSxJQUFJLENBQUM7YUFDaEUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsT0FBTyxPQUFPLENBQUMsQ0FBQyxDQUFDLHNDQUFzQyxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO0lBQ2hGLENBQUM7SUFFRCxxQkFBcUI7UUFDbkIsTUFBTSxNQUFNLEdBQTBCLEVBQUUsQ0FBQztRQUN6QyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQzdDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNiLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLHFCQUFxQixDQUFDLENBQUM7WUFDbkUsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQztRQUVELElBQUksR0FBRyxHQUFHLFVBQVUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQzt3QkFDN0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJO3NCQUN0QixDQUFDO1FBRW5CLEdBQUcsSUFBSSxPQUFP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
@@ -0,0 +1,19 @@
1
+ import { TableModel } from '@eggjs/dal-decorator';
2
+ export interface CodeGeneratorOptions {
3
+ moduleDir: string;
4
+ moduleName: string;
5
+ }
6
+ export declare enum Templates {
7
+ BASE_DAO = "base_dao",
8
+ DAO = "dao",
9
+ EXTENSION = "extension"
10
+ }
11
+ export declare class CodeGenerator {
12
+ private readonly moduleDir;
13
+ private readonly moduleName;
14
+ constructor(options: CodeGeneratorOptions);
15
+ private njkEnv;
16
+ createNunjucksEnv(): void;
17
+ genCode(tplName: Templates, filePath: string, tableModel: TableModel): string;
18
+ generate(tableModel: TableModel): Promise<void>;
19
+ }
@@ -0,0 +1,124 @@
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.CodeGenerator = exports.Templates = void 0;
7
+ const nunjucks_1 = __importDefault(require("nunjucks"));
8
+ const node_path_1 = __importDefault(require("node:path"));
9
+ const lodash_1 = __importDefault(require("lodash"));
10
+ const TemplateUtil_1 = require("./TemplateUtil");
11
+ const core_decorator_1 = require("@eggjs/core-decorator");
12
+ const promises_1 = __importDefault(require("node:fs/promises"));
13
+ const js_beautify_1 = require("js-beautify");
14
+ const SqlGenerator_1 = require("./SqlGenerator");
15
+ var Templates;
16
+ (function (Templates) {
17
+ Templates["BASE_DAO"] = "base_dao";
18
+ Templates["DAO"] = "dao";
19
+ Templates["EXTENSION"] = "extension";
20
+ })(Templates || (exports.Templates = Templates = {}));
21
+ class CodeGenerator {
22
+ constructor(options) {
23
+ this.moduleDir = options.moduleDir;
24
+ this.moduleName = options.moduleName;
25
+ this.createNunjucksEnv();
26
+ }
27
+ createNunjucksEnv() {
28
+ this.njkEnv = nunjucks_1.default.configure(node_path_1.default.join(__dirname, './templates'), {
29
+ autoescape: false,
30
+ });
31
+ this.njkEnv.addFilter('pascalCase', name => lodash_1.default.upperFirst(lodash_1.default.camelCase(name)));
32
+ this.njkEnv.addFilter('camelCase', name => lodash_1.default.camelCase(name));
33
+ this.njkEnv.addFilter('dbTypeToTSType', TemplateUtil_1.TemplateUtil.dbTypeToTsType);
34
+ }
35
+ genCode(tplName, filePath, tableModel) {
36
+ let tableModelAbsolutePath = core_decorator_1.PrototypeUtil.getFilePath(tableModel.clazz);
37
+ tableModelAbsolutePath = tableModelAbsolutePath.substring(0, tableModelAbsolutePath.length - 3);
38
+ const data = {
39
+ table: tableModel,
40
+ file: filePath,
41
+ fileName: node_path_1.default.basename(filePath),
42
+ clazzName: tableModel.clazz.name,
43
+ moduleName: this.moduleName,
44
+ id: tableModel.columns.find(t => t.propertyName === 'id'),
45
+ primaryIndex: tableModel.getPrimary(),
46
+ tableModelPath: TemplateUtil_1.TemplateUtil.importPath(tableModelAbsolutePath, node_path_1.default.dirname(filePath)),
47
+ columnMap: tableModel.columns.reduce((p, c) => {
48
+ p[c.propertyName] = c;
49
+ return p;
50
+ }, {}),
51
+ };
52
+ return this.njkEnv.render(`${tplName}.njk`, data);
53
+ }
54
+ async generate(tableModel) {
55
+ const dalDir = node_path_1.default.join(this.moduleDir, 'dal');
56
+ // const tableName = tableModel.name;
57
+ // const clazzName = tableModel.clazz.name;
58
+ const clazzFileName = node_path_1.default.basename(core_decorator_1.PrototypeUtil.getFilePath(tableModel.clazz));
59
+ const baseFileName = node_path_1.default.basename(clazzFileName, '.ts');
60
+ // 要动的一些文件
61
+ const paths = {
62
+ // e.g. app/dal/dao/base/example.ts
63
+ baseBizDAO: node_path_1.default.join(dalDir, `dao/base/Base${baseFileName}DAO.ts`),
64
+ // e.g. app/dal/dao/example.ts
65
+ bizDAO: node_path_1.default.join(dalDir, `dao/${baseFileName}DAO.ts`),
66
+ // e.g. app/dal/extension/example.ts
67
+ extension: node_path_1.default.join(dalDir, `extension/${baseFileName}Extension.ts`),
68
+ // e.g. app/dal/structure/example.json
69
+ structure: node_path_1.default.join(dalDir, `structure/${baseFileName}.json`),
70
+ // e.g. app/dal/structure/example.sql
71
+ structureSql: node_path_1.default.join(dalDir, `structure/${baseFileName}.sql`),
72
+ };
73
+ // 建立 structure 文件
74
+ await promises_1.default.mkdir(node_path_1.default.dirname(paths.structure), {
75
+ recursive: true,
76
+ });
77
+ await promises_1.default.writeFile(paths.structure, JSON.stringify(tableModel, null, 2), 'utf8');
78
+ const sqlGenerator = new SqlGenerator_1.SqlGenerator();
79
+ const structureSql = sqlGenerator.generate(tableModel);
80
+ await promises_1.default.writeFile(paths.structureSql, structureSql, 'utf8');
81
+ const codes = [{
82
+ templates: Templates.BASE_DAO,
83
+ filePath: paths.baseBizDAO,
84
+ beautify: true,
85
+ }, {
86
+ templates: Templates.DAO,
87
+ filePath: paths.bizDAO,
88
+ beautify: true,
89
+ }, {
90
+ templates: Templates.EXTENSION,
91
+ filePath: paths.extension,
92
+ beautify: false,
93
+ }];
94
+ for (const { templates, filePath, beautify } of codes) {
95
+ await promises_1.default.mkdir(node_path_1.default.dirname(filePath), {
96
+ recursive: true,
97
+ });
98
+ const code = this.genCode(templates, filePath, tableModel);
99
+ let beautified;
100
+ if (beautify) {
101
+ beautified = (0, js_beautify_1.js_beautify)(code, {
102
+ brace_style: 'preserve-inline',
103
+ indent_size: 2,
104
+ jslint_happy: true,
105
+ preserve_newlines: false,
106
+ });
107
+ }
108
+ else {
109
+ beautified = code;
110
+ }
111
+ beautified = beautified
112
+ .replace(/( )*\/\/ empty-line( )*/g, '')
113
+ .replace(/Promise( )*<( )*(.+?)( )*>/g, 'Promise<$3>')
114
+ .replace(/Optional( )*<( )*(.+?)( )*>/g, 'Optional<$3>')
115
+ .replace(/Record( )*<( )*(.+?)( )*>/g, 'Record<$3>')
116
+ .replace(/Partial( )*<( )*(.+?)( )*>/g, 'Partial<$3>')
117
+ .replace(/DataSource( )*<( )*(.+?)( )*>/g, 'DataSource<$3>')
118
+ .replace(/ \? :/g, '?:');
119
+ await promises_1.default.writeFile(filePath, beautified, 'utf8');
120
+ }
121
+ }
122
+ }
123
+ exports.CodeGenerator = CodeGenerator;
124
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29kZUdlbmVyYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db2RlR2VuZXJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHdEQUFzRDtBQUN0RCwwREFBNkI7QUFDN0Isb0RBQXVCO0FBQ3ZCLGlEQUE4QztBQUU5QywwREFBc0Q7QUFDdEQsZ0VBQWtDO0FBQ2xDLDZDQUEwQztBQUMxQyxpREFBOEM7QUFPOUMsSUFBWSxTQUlYO0FBSkQsV0FBWSxTQUFTO0lBQ25CLGtDQUFxQixDQUFBO0lBQ3JCLHdCQUFXLENBQUE7SUFDWCxvQ0FBdUIsQ0FBQTtBQUN6QixDQUFDLEVBSlcsU0FBUyx5QkFBVCxTQUFTLFFBSXBCO0FBRUQsTUFBYSxhQUFhO0lBSXhCLFlBQVksT0FBNkI7UUFDdkMsSUFBSSxDQUFDLFNBQVMsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDO1FBQ25DLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQztRQUNyQyxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBSUQsaUJBQWlCO1FBQ2YsSUFBSSxDQUFDLE1BQU0sR0FBRyxrQkFBUSxDQUFDLFNBQVMsQ0FBQyxtQkFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsYUFBYSxDQUFDLEVBQUU7WUFDcEUsVUFBVSxFQUFFLEtBQUs7U0FDbEIsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsZ0JBQUMsQ0FBQyxVQUFVLENBQUMsZ0JBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzdFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFDLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFD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
@@ -0,0 +1,22 @@
1
+ import { DataSource as IDataSource, PaginateData, SqlType, TableModel } from '@eggjs/dal-decorator';
2
+ import { MysqlDataSource } from './MySqlDataSource';
3
+ import { TableSqlMap } from './TableSqlMap';
4
+ export interface ExecuteSql {
5
+ sql: string;
6
+ template: string;
7
+ sqlType: SqlType;
8
+ }
9
+ export declare class DataSource<T> implements IDataSource<T> {
10
+ #private;
11
+ private readonly tableModel;
12
+ private readonly mysqlDataSource;
13
+ private readonly sqlMap;
14
+ constructor(tableModel: TableModel<T>, mysqlDataSource: MysqlDataSource, sqlMap: TableSqlMap);
15
+ private generateSql;
16
+ count(sqlName: string, data?: any): Promise<number>;
17
+ execute(sqlName: string, data?: any): Promise<Array<T>>;
18
+ executeRaw(sqlName: string, data?: any): Promise<Array<any>>;
19
+ executeScalar(sqlName: string, data?: any): Promise<T | null>;
20
+ executeRawScalar(sqlName: string, data?: any): Promise<any | null>;
21
+ paginate(sqlName: string, data: any, currentPage: number, perPageCount: number): Promise<PaginateData<T>>;
22
+ }