@eggjs/dal-runtime 4.0.0-beta.7 → 4.0.0-beta.9
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/dist/BaseSqlMap.d.ts +14 -17
- package/dist/BaseSqlMap.js +229 -172
- package/dist/CodeGenerator.d.ts +13 -16
- package/dist/CodeGenerator.js +138 -113
- package/dist/DaoLoader.d.ts +3 -7
- package/dist/DaoLoader.js +14 -16
- package/dist/DataSource.d.ts +26 -30
- package/dist/DataSource.js +80 -70
- package/dist/DatabaseForker.d.ts +11 -15
- package/dist/DatabaseForker.js +49 -46
- package/dist/MySqlDataSource.d.ts +21 -25
- package/dist/MySqlDataSource.js +60 -46
- package/dist/NunjucksConverter.d.ts +72 -75
- package/dist/NunjucksConverter.js +93 -90
- package/dist/NunjucksUtil.d.ts +4 -8
- package/dist/NunjucksUtil.js +65 -55
- package/dist/SqlGenerator.d.ts +8 -12
- package/dist/SqlGenerator.js +392 -224
- package/dist/SqlMapLoader.d.ts +9 -13
- package/dist/SqlMapLoader.js +18 -20
- package/dist/SqlUtil.d.ts +2 -5
- package/dist/SqlUtil.js +213 -185
- package/dist/TableModelInstanceBuilder.d.ts +5 -9
- package/dist/TableModelInstanceBuilder.js +23 -25
- package/dist/TableSqlMap.d.ts +18 -17
- package/dist/TableSqlMap.js +90 -79
- package/dist/TemplateUtil.d.ts +18 -21
- package/dist/TemplateUtil.js +85 -77
- package/dist/index.d.ts +15 -15
- package/dist/index.js +16 -16
- package/package.json +6 -6
package/dist/NunjucksUtil.js
CHANGED
|
@@ -1,64 +1,74 @@
|
|
|
1
|
+
import nunjucks, { Template } from 'nunjucks';
|
|
2
|
+
import sqlstring from 'sqlstring';
|
|
1
3
|
import { NunjucksConverter } from "./NunjucksConverter.js";
|
|
2
4
|
import { SqlUtil } from "./SqlUtil.js";
|
|
3
|
-
import nunjucks, { Template } from "nunjucks";
|
|
4
|
-
import sqlstring from "sqlstring";
|
|
5
|
-
|
|
6
|
-
//#region src/NunjucksUtil.ts
|
|
7
5
|
const compiler = nunjucks.compiler;
|
|
8
6
|
const envs = {};
|
|
9
|
-
const ROOT_RENDER_FUNC = Symbol(
|
|
10
|
-
const RUNTIME = Object.assign({}, nunjucks.runtime, {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
const ROOT_RENDER_FUNC = Symbol('rootRenderFunc');
|
|
8
|
+
const RUNTIME = Object.assign({}, nunjucks.runtime, {
|
|
9
|
+
escapeSQL: function escapeSQL(key, value) {
|
|
10
|
+
// 如果是预定义 block 则不转义
|
|
11
|
+
if (this.env.globals[key])
|
|
12
|
+
return value;
|
|
13
|
+
return sqlstring.escape(value, true, this.env.timezone);
|
|
14
|
+
},
|
|
15
|
+
});
|
|
14
16
|
function _replaceCodeWithSQLFeature(source) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
17
|
+
const funcs = [
|
|
18
|
+
'convertNormalVariableCode', // 普通变量
|
|
19
|
+
'convertTernaryCode', // 三目运算
|
|
20
|
+
'convertNestedObjectCode', // 对象中的变量,如 `user.id`
|
|
21
|
+
'convertValueInsideFor', // for 中的值需要转义
|
|
22
|
+
];
|
|
23
|
+
return funcs.reduce((source, func) => NunjucksConverter[func](source), source);
|
|
21
24
|
}
|
|
22
25
|
/**
|
|
23
|
-
* compile the string into function
|
|
24
|
-
* @see https://github.com/mozilla/nunjucks/blob/2fd547f/src/environment.js#L571-L592
|
|
25
|
-
*/
|
|
26
|
+
* compile the string into function
|
|
27
|
+
* @see https://github.com/mozilla/nunjucks/blob/2fd547f/src/environment.js#L571-L592
|
|
28
|
+
*/
|
|
26
29
|
function _compile() {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
30
|
+
let source = compiler.compile(this.tmplStr, this.env.asyncFilters, this.env.extensionsList, this.path, this.env.opts);
|
|
31
|
+
/**
|
|
32
|
+
* 将一些 Nunjucks 的 HTML 转义的代码转换成 SQL 防注入的代码
|
|
33
|
+
*/
|
|
34
|
+
source = _replaceCodeWithSQLFeature(source);
|
|
35
|
+
// eslint-disable-next-line
|
|
36
|
+
const props = (new Function(source))();
|
|
37
|
+
this.blocks = this._getBlocks(props);
|
|
38
|
+
this[ROOT_RENDER_FUNC] = props.root;
|
|
39
|
+
this.rootRenderFunc = function (env, context, frame, _runtime, cb) {
|
|
40
|
+
/**
|
|
41
|
+
* 1. 将 runtime 遗弃,用新的
|
|
42
|
+
* 2. 移除 SQL 语句中多余空白符
|
|
43
|
+
*/
|
|
44
|
+
return this[ROOT_RENDER_FUNC](env, context, frame, RUNTIME, function (err, ret) {
|
|
45
|
+
// istanbul ignore if
|
|
46
|
+
if (err)
|
|
47
|
+
return cb(err, ret);
|
|
48
|
+
return cb(err, SqlUtil.minify(ret || ''));
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
this.compiled = true;
|
|
47
52
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
53
|
+
export class NunjucksUtils {
|
|
54
|
+
static createEnv(modelName) {
|
|
55
|
+
if (envs[modelName])
|
|
56
|
+
return envs[modelName];
|
|
57
|
+
const env = envs[modelName] = nunjucks.configure({
|
|
58
|
+
autoescape: false,
|
|
59
|
+
});
|
|
60
|
+
return env;
|
|
61
|
+
}
|
|
62
|
+
static compile(modelName, sqlName, sql) {
|
|
63
|
+
// istanbul ignore if
|
|
64
|
+
if (!envs[modelName]) {
|
|
65
|
+
throw new Error(`you should create an Environment for ${modelName} first.`);
|
|
66
|
+
}
|
|
67
|
+
const template = new Template(sql, envs[modelName], `egg-dal:MySQL:${modelName}:${sqlName}`, false);
|
|
68
|
+
// 做一些 hack,使得支持 MySQL 的一些 Escape
|
|
69
|
+
template._compile = _compile;
|
|
70
|
+
template.compile();
|
|
71
|
+
return template;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTnVuanVja3NVdGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL051bmp1Y2tzVXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFFBQVEsRUFBRSxFQUFFLFFBQVEsRUFBb0IsTUFBTSxVQUFVLENBQUM7QUFDaEUsT0FBTyxTQUFTLE1BQU0sV0FBVyxDQUFDO0FBRWxDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFdkMsTUFBTSxRQUFRLEdBQUksUUFBZ0IsQ0FBQyxRQUFRLENBQUM7QUFDNUMsTUFBTSxJQUFJLEdBQWdDLEVBQUUsQ0FBQztBQUU3QyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQ2xELE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxPQUFPLEVBQUU7SUFDbEQsU0FBUyxFQUFFLFNBQVMsU0FBUyxDQUFZLEdBQVcsRUFBRSxLQUFjO1FBQ2xFLG9CQUFvQjtRQUNwQixJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQztZQUFFLE9BQU8sS0FBSyxDQUFDO1FBQ3hDLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDMUQsQ0FBQztDQUNGLENBQUMsQ0FBQztBQUVILFNBQVMsMEJBQTBCLENBQUMsTUFBYztJQUNoRCxNQUFNLEtBQUssR0FBRztRQUNaLDJCQUEyQixFQUFFLE9BQU87UUFDcEMsb0JBQW9CLEVBQUUsT0FBTztRQUM3Qix5QkFBeUIsRUFBRSxxQkFBcUI7UUFDaEQsdUJBQXVCLEVBQUUsY0FBYztLQUMvQixDQUFDO0lBRVgsT0FBTyxLQUFLLENBQUMsTUFBTSxDQUFD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
|
package/dist/SqlGenerator.d.ts
CHANGED
|
@@ -1,13 +1,9 @@
|
|
|
1
|
-
import { TableModel } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
private generateTableOptions;
|
|
10
|
-
generate(tableModel: TableModel): string;
|
|
1
|
+
import { TableModel } from '@eggjs/dal-decorator';
|
|
2
|
+
export declare class SqlGenerator {
|
|
3
|
+
private formatComment;
|
|
4
|
+
private generateColumn;
|
|
5
|
+
private generateColumnType;
|
|
6
|
+
private generateIndex;
|
|
7
|
+
private generateTableOptions;
|
|
8
|
+
generate(tableModel: TableModel): string;
|
|
11
9
|
}
|
|
12
|
-
//#endregion
|
|
13
|
-
export { SqlGenerator };
|