@eggjs/dal-runtime 4.0.0-beta.4 → 4.0.0-beta.5

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