@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 +21 -0
- package/README.md +5 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +26 -0
- package/dist/src/BaseSqlMap.d.ts +19 -0
- package/dist/src/BaseSqlMap.js +310 -0
- package/dist/src/CodeGenerator.d.ts +19 -0
- package/dist/src/CodeGenerator.js +124 -0
- package/dist/src/DataSource.d.ts +22 -0
- package/dist/src/DataSource.js +78 -0
- package/dist/src/MySqlDataSource.d.ts +15 -0
- package/dist/src/MySqlDataSource.js +33 -0
- package/dist/src/NunjucksConverter.d.ts +73 -0
- package/dist/src/NunjucksConverter.js +97 -0
- package/dist/src/NunjucksUtil.d.ts +5 -0
- package/dist/src/NunjucksUtil.js +104 -0
- package/dist/src/SqlGenerator.d.ts +9 -0
- package/dist/src/SqlGenerator.js +379 -0
- package/dist/src/SqlMapLoader.d.ts +10 -0
- package/dist/src/SqlMapLoader.js +35 -0
- package/dist/src/SqlUtil.d.ts +3 -0
- package/dist/src/SqlUtil.js +225 -0
- package/dist/src/TableModelInstanceBuilder.d.ts +6 -0
- package/dist/src/TableModelInstanceBuilder.js +26 -0
- package/dist/src/TableSqlMap.d.ts +18 -0
- package/dist/src/TableSqlMap.js +95 -0
- package/dist/src/TemplateUtil.d.ts +26 -0
- package/dist/src/TemplateUtil.js +92 -0
- package/package.json +63 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SqlUtil = void 0;
|
|
4
|
+
function isWhiteChar(ch) {
|
|
5
|
+
return ch === ' ' || ch === '\n' || ch === '\r' || ch === '\t';
|
|
6
|
+
}
|
|
7
|
+
const COMMENT_CHARS = '-#/';
|
|
8
|
+
const MUL_CHAR_LEADING_COMMENT_FIRST_CHAR = {
|
|
9
|
+
MAY_BE_FIRST_COMMENT: '-',
|
|
10
|
+
MAY_BE_FIRST_BLOCK_COMMENT: '/',
|
|
11
|
+
};
|
|
12
|
+
const MUL_CHAR_LEADING_COMMENT_VERIFIER = {
|
|
13
|
+
MAY_BE_FIRST_COMMENT: '-',
|
|
14
|
+
MAY_BE_FIRST_BLOCK_COMMENT: '*',
|
|
15
|
+
};
|
|
16
|
+
const MUL_CHAR_LEADING_COMMENT_NEXT_STATE = {
|
|
17
|
+
MAY_BE_FIRST_COMMENT: 'IN_COMMENT_WAIT_HINT',
|
|
18
|
+
MAY_BE_FIRST_BLOCK_COMMENT: 'IN_BLOCK_COMMENT_WAIT_HINT',
|
|
19
|
+
};
|
|
20
|
+
class SqlUtil {
|
|
21
|
+
static minify(sql) {
|
|
22
|
+
let ret = '';
|
|
23
|
+
let state = 'START';
|
|
24
|
+
let tempNextState;
|
|
25
|
+
for (let i = 0; i < sql.length; i++) {
|
|
26
|
+
const ch = sql[i];
|
|
27
|
+
switch (state) {
|
|
28
|
+
case 'MAY_BE_FIRST_COMMENT':
|
|
29
|
+
case 'MAY_BE_FIRST_BLOCK_COMMENT':
|
|
30
|
+
switch (ch) {
|
|
31
|
+
case '"':
|
|
32
|
+
tempNextState = 'DOUBLE_QUOTE';
|
|
33
|
+
break;
|
|
34
|
+
case '\'':
|
|
35
|
+
tempNextState = 'SINGLE_QUOTE';
|
|
36
|
+
break;
|
|
37
|
+
case MUL_CHAR_LEADING_COMMENT_VERIFIER[state]:
|
|
38
|
+
tempNextState = MUL_CHAR_LEADING_COMMENT_NEXT_STATE[state];
|
|
39
|
+
break;
|
|
40
|
+
default:
|
|
41
|
+
tempNextState = 'CONTENT';
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
if (ch !== MUL_CHAR_LEADING_COMMENT_VERIFIER[state]) {
|
|
45
|
+
ret += `${MUL_CHAR_LEADING_COMMENT_FIRST_CHAR[state]}${ch}`;
|
|
46
|
+
}
|
|
47
|
+
state = tempNextState;
|
|
48
|
+
break;
|
|
49
|
+
case 'IN_COMMENT_WAIT_HINT':
|
|
50
|
+
if (ch !== '+') {
|
|
51
|
+
state = 'IN_COMMENT';
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
state = 'IN_COMMENT_HINT';
|
|
55
|
+
ret += '--+';
|
|
56
|
+
}
|
|
57
|
+
break;
|
|
58
|
+
case 'IN_BLOCK_COMMENT_WAIT_HINT':
|
|
59
|
+
if (ch !== '+') {
|
|
60
|
+
state = 'IN_BLOCK_COMMENT';
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
state = 'IN_BLOCK_COMMENT_HINT';
|
|
64
|
+
ret += '/*+';
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
case 'MAY_BE_LAST_BLOCK_COMMENT':
|
|
68
|
+
if (ch === '/') {
|
|
69
|
+
if (ret && !isWhiteChar(ret[ret.length - 1]))
|
|
70
|
+
ret += ' ';
|
|
71
|
+
state = 'IN_SPACE';
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
state = 'IN_BLOCK_COMMENT';
|
|
75
|
+
}
|
|
76
|
+
break;
|
|
77
|
+
case 'MAY_BE_LAST_BLOCK_COMMENT_HINT':
|
|
78
|
+
ret += ch;
|
|
79
|
+
if (ch === '/') {
|
|
80
|
+
state = 'IN_SPACE';
|
|
81
|
+
if (isWhiteChar(sql[i + 1]))
|
|
82
|
+
ret += sql[i + 1];
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
state = 'IN_BLOCK_COMMENT_HINT';
|
|
86
|
+
}
|
|
87
|
+
break;
|
|
88
|
+
case 'IN_COMMENT':
|
|
89
|
+
if (ch === '\n' || ch === '\r') {
|
|
90
|
+
if (ret && !isWhiteChar(ret[ret.length - 1]))
|
|
91
|
+
ret += ' ';
|
|
92
|
+
state = 'IN_SPACE';
|
|
93
|
+
}
|
|
94
|
+
break;
|
|
95
|
+
case 'IN_COMMENT_HINT':
|
|
96
|
+
ret += ch;
|
|
97
|
+
if (ch === '\n' || ch === '\r') {
|
|
98
|
+
state = 'IN_SPACE';
|
|
99
|
+
}
|
|
100
|
+
break;
|
|
101
|
+
case 'IN_BLOCK_COMMENT':
|
|
102
|
+
if (ch === '*') {
|
|
103
|
+
state = 'MAY_BE_LAST_BLOCK_COMMENT';
|
|
104
|
+
}
|
|
105
|
+
break;
|
|
106
|
+
case 'IN_BLOCK_COMMENT_HINT':
|
|
107
|
+
ret += ch;
|
|
108
|
+
if (ch === '*') {
|
|
109
|
+
state = 'MAY_BE_LAST_BLOCK_COMMENT_HINT';
|
|
110
|
+
}
|
|
111
|
+
break;
|
|
112
|
+
case 'START':
|
|
113
|
+
if (isWhiteChar(ch))
|
|
114
|
+
continue;
|
|
115
|
+
switch (ch) {
|
|
116
|
+
case '"':
|
|
117
|
+
state = 'DOUBLE_QUOTE';
|
|
118
|
+
break;
|
|
119
|
+
case '\'':
|
|
120
|
+
state = 'SINGLE_QUOTE';
|
|
121
|
+
break;
|
|
122
|
+
case '-':
|
|
123
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
124
|
+
break;
|
|
125
|
+
case '#':
|
|
126
|
+
state = 'IN_COMMENT';
|
|
127
|
+
break;
|
|
128
|
+
case '/':
|
|
129
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
130
|
+
break;
|
|
131
|
+
default:
|
|
132
|
+
state = 'CONTENT';
|
|
133
|
+
break;
|
|
134
|
+
}
|
|
135
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
136
|
+
ret += ch;
|
|
137
|
+
break;
|
|
138
|
+
case 'DOUBLE_QUOTE':
|
|
139
|
+
case 'SINGLE_QUOTE':
|
|
140
|
+
switch (ch) {
|
|
141
|
+
case '\\':
|
|
142
|
+
state = `BACKSLASH_AFTER_${state}`;
|
|
143
|
+
break;
|
|
144
|
+
case '\'':
|
|
145
|
+
if (state === 'SINGLE_QUOTE') {
|
|
146
|
+
state = 'QUOTE_DONE';
|
|
147
|
+
}
|
|
148
|
+
break;
|
|
149
|
+
case '"':
|
|
150
|
+
if (state === 'DOUBLE_QUOTE') {
|
|
151
|
+
state = 'QUOTE_DONE';
|
|
152
|
+
}
|
|
153
|
+
break;
|
|
154
|
+
default: break;
|
|
155
|
+
}
|
|
156
|
+
ret += ch;
|
|
157
|
+
break;
|
|
158
|
+
case 'BACKSLASH_AFTER_SINGLE_QUOTE':
|
|
159
|
+
case 'BACKSLASH_AFTER_DOUBLE_QUOTE':
|
|
160
|
+
ret += ch;
|
|
161
|
+
state = state.substr(16);
|
|
162
|
+
break;
|
|
163
|
+
case 'QUOTE_DONE':
|
|
164
|
+
case 'CONTENT':
|
|
165
|
+
switch (ch) {
|
|
166
|
+
case '\'':
|
|
167
|
+
state = 'SINGLE_QUOTE';
|
|
168
|
+
break;
|
|
169
|
+
case '"':
|
|
170
|
+
state = 'DOUBLE_QUOTE';
|
|
171
|
+
break;
|
|
172
|
+
case '-':
|
|
173
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
174
|
+
break;
|
|
175
|
+
case '#':
|
|
176
|
+
state = 'IN_COMMENT';
|
|
177
|
+
break;
|
|
178
|
+
case '/':
|
|
179
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
180
|
+
break;
|
|
181
|
+
default:
|
|
182
|
+
if (isWhiteChar(ch)) {
|
|
183
|
+
state = 'IN_SPACE';
|
|
184
|
+
ret += ' ';
|
|
185
|
+
continue;
|
|
186
|
+
}
|
|
187
|
+
state = 'CONTENT';
|
|
188
|
+
}
|
|
189
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
190
|
+
ret += ch;
|
|
191
|
+
break;
|
|
192
|
+
case 'IN_SPACE':
|
|
193
|
+
switch (ch) {
|
|
194
|
+
case '\'':
|
|
195
|
+
state = 'SINGLE_QUOTE';
|
|
196
|
+
break;
|
|
197
|
+
case '"':
|
|
198
|
+
state = 'DOUBLE_QUOTE';
|
|
199
|
+
break;
|
|
200
|
+
case '-':
|
|
201
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
202
|
+
break;
|
|
203
|
+
case '#':
|
|
204
|
+
state = 'IN_COMMENT';
|
|
205
|
+
break;
|
|
206
|
+
case '/':
|
|
207
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
208
|
+
break;
|
|
209
|
+
default:
|
|
210
|
+
if (isWhiteChar(ch))
|
|
211
|
+
continue;
|
|
212
|
+
state = 'CONTENT';
|
|
213
|
+
}
|
|
214
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
215
|
+
ret += ch;
|
|
216
|
+
break;
|
|
217
|
+
default:
|
|
218
|
+
throw new Error('Unexpected state machine while minifying SQL.');
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
return ret.trim();
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
exports.SqlUtil = SqlUtil;
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsVXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9TcWxVdGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLFNBQVMsV0FBVyxDQUFDLEVBQUU7SUFDckIsT0FBTyxFQUFFLEtBQUssR0FBRyxJQUFJLEVBQUUsS0FBSyxJQUFJLElBQUksRUFBRSxLQUFLLElBQUksSUFBSSxFQUFFLEtBQUssSUFBSSxDQUFDO0FBQ2pFLENBQUM7QUFFRCxNQUFNLGFBQWEsR0FBRyxLQUFLLENBQUM7QUFDNUIsTUFBTSxtQ0FBbUMsR0FBRztJQUMxQyxvQkFBb0IsRUFBRSxHQUFHO0lBQ3pCLDBCQUEwQixFQUFFLEdBQUc7Q0FDaEMsQ0FBQztBQUNGLE1BQU0saUNBQWlDLEdBQUc7SUFDeEMsb0JBQW9CLEVBQUUsR0FBRztJQUN6QiwwQkFBMEIsRUFBRSxHQUFHO0NBQ2hDLENBQUM7QUFDRixNQUFNLG1DQUFtQyxHQUFHO0lBQzFDLG9CQUFvQixFQUFFLHNCQUFzQjtJQUM1QywwQkFBMEIsRUFBRSw0QkFBNEI7Q0FDekQsQ0FBQztBQUVGLE1BQWEsT0FBTztJQUNsQixNQUFNLENBQUMsTUFBTSxDQUFDLEdBQVc7UUFDdkIsSUFBSSxHQUFHLEdBQUcsRUFBRSxDQUFDO1FBRWIsSUFBSSxLQUFLLEdBQUcsT0FBTyxDQUFDO1FBQ3BCLElBQUksYUFBYSxDQUFDO1FBQ2xCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDcEMsTUFBTSxFQUFFLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xCLFFBQVEsS0FBSyxFQUFFLENBQUM7Z0JBQ2QsS0FBSyxzQkFBc0IsQ0FBQztnQkFDNUIsS0FBSyw0QkFBNEI7b0JBQy9CLFFBQVEsRUFBRSxFQUFFLENBQUM7d0JBQ1gsS0FBSyxHQUFHOzRCQUFFLGFBQWEsR0FBRyxjQUFj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
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { TableModel } from '@eggjs/dal-decorator';
|
|
2
|
+
export declare class TableModelInstanceBuilder {
|
|
3
|
+
constructor(tableModel: TableModel, row: Record<string, any>);
|
|
4
|
+
static buildInstance<T>(tableModel: TableModel<T>, row: Record<string, any>): any;
|
|
5
|
+
static buildRow<T extends object>(instance: T, tableModel: TableModel<T>): any;
|
|
6
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TableModelInstanceBuilder = void 0;
|
|
4
|
+
class TableModelInstanceBuilder {
|
|
5
|
+
constructor(tableModel, row) {
|
|
6
|
+
for (const [key, value] of Object.entries(row)) {
|
|
7
|
+
const column = tableModel.columns.find(t => t.columnName === key);
|
|
8
|
+
Reflect.set(this, column?.propertyName ?? key, value);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
static buildInstance(tableModel, row) {
|
|
12
|
+
return Reflect.construct(TableModelInstanceBuilder, [tableModel, row], tableModel.clazz);
|
|
13
|
+
}
|
|
14
|
+
static buildRow(instance, tableModel) {
|
|
15
|
+
const result = {};
|
|
16
|
+
for (const column of tableModel.columns) {
|
|
17
|
+
const columnValue = Reflect.get(instance, column.propertyName);
|
|
18
|
+
if (typeof columnValue !== 'undefined') {
|
|
19
|
+
result[`$${column.propertyName}`] = columnValue;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.TableModelInstanceBuilder = TableModelInstanceBuilder;
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVNb2RlbEluc3RhbmNlQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9UYWJsZU1vZGVsSW5zdGFuY2VCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLE1BQWEseUJBQXlCO0lBQ3BDLFlBQVksVUFBc0IsRUFBRSxHQUF3QjtRQUMxRCxLQUFLLE1BQU0sQ0FBRSxHQUFHLEVBQUUsS0FBSyxDQUFFLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2pELE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxHQUFHLENBQUMsQ0FBQztZQUNsRSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsWUFBWSxJQUFJLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUN4RCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxhQUFhLENBQUksVUFBeUIsRUFBRSxHQUF3QjtRQUN6RSxPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMseUJBQXlCLEVBQUUsQ0FBRSxVQUFVLEVBQUUsR0FBRyxDQUFFLEVBQUUsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdGLENBQUM7SUFFRCxNQUFNLENBQUMsUUFBUSxDQUFtQixRQUFXLEVBQUUsVUFBeUI7UUFDdEUsTUFBTSxNQUFNLEdBQVEsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssTUFBTSxNQUFNLElBQUksVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3hDLE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMvRCxJQUFJLE9BQU8sV0FBVyxLQUFLLFdBQVcsRUFBRSxDQUFDO2dCQUN2QyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsWUFBWSxFQUFFLENBQUMsR0FBRyxXQUFXLENBQUM7WUFDbEQsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0NBQ0Y7QUF0QkQsOERBc0JDIn0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Template } from 'nunjucks';
|
|
2
|
+
import { SqlMap, SqlType } from '@eggjs/dal-decorator';
|
|
3
|
+
export interface SqlGenerator {
|
|
4
|
+
type: SqlType;
|
|
5
|
+
template: Template;
|
|
6
|
+
raw: string;
|
|
7
|
+
}
|
|
8
|
+
export declare class TableSqlMap {
|
|
9
|
+
#private;
|
|
10
|
+
readonly name: string;
|
|
11
|
+
private readonly map;
|
|
12
|
+
private readonly blocks;
|
|
13
|
+
private readonly sqlGenerator;
|
|
14
|
+
constructor(name: string, map: Record<string, SqlMap>);
|
|
15
|
+
generate(name: string, data: object, timezone: string): string;
|
|
16
|
+
getType(name: string): SqlType;
|
|
17
|
+
getTemplateString(name: string): string;
|
|
18
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
3
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
4
|
+
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");
|
|
5
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
6
|
+
};
|
|
7
|
+
var _TableSqlMap_instances, _TableSqlMap_extract;
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.TableSqlMap = void 0;
|
|
10
|
+
const NunjucksUtil_1 = require("./NunjucksUtil");
|
|
11
|
+
const TemplateUtil_1 = require("./TemplateUtil");
|
|
12
|
+
const dal_decorator_1 = require("@eggjs/dal-decorator");
|
|
13
|
+
class TableSqlMap {
|
|
14
|
+
constructor(name, map) {
|
|
15
|
+
_TableSqlMap_instances.add(this);
|
|
16
|
+
this.name = name;
|
|
17
|
+
this.map = map;
|
|
18
|
+
const env = NunjucksUtil_1.NunjucksUtils.createEnv(name);
|
|
19
|
+
const extracted = __classPrivateFieldGet(this, _TableSqlMap_instances, "m", _TableSqlMap_extract).call(this, this.map);
|
|
20
|
+
this.blocks = extracted.blocks;
|
|
21
|
+
this.sqlGenerator = extracted.sqlGenerator;
|
|
22
|
+
for (const key in this.blocks) {
|
|
23
|
+
// istanbul ignore if
|
|
24
|
+
if (!this.blocks.hasOwnProperty(key))
|
|
25
|
+
continue;
|
|
26
|
+
env.addGlobal(key, this.blocks[key]);
|
|
27
|
+
}
|
|
28
|
+
env.addFilter('toJson', TemplateUtil_1.TemplateUtil.toJson);
|
|
29
|
+
env.addFilter('toPoint', TemplateUtil_1.TemplateUtil.toPoint);
|
|
30
|
+
env.addFilter('toLine', TemplateUtil_1.TemplateUtil.toLine);
|
|
31
|
+
env.addFilter('toPolygon', TemplateUtil_1.TemplateUtil.toPolygon);
|
|
32
|
+
env.addFilter('toGeometry', TemplateUtil_1.TemplateUtil.toGeometry);
|
|
33
|
+
env.addFilter('toMultiPoint', TemplateUtil_1.TemplateUtil.toMultiPoint);
|
|
34
|
+
env.addFilter('toMultiLine', TemplateUtil_1.TemplateUtil.toMultiLine);
|
|
35
|
+
env.addFilter('toMultiPolygon', TemplateUtil_1.TemplateUtil.toMultiPolygon);
|
|
36
|
+
env.addFilter('toGeometryCollection', TemplateUtil_1.TemplateUtil.toGeometryCollection);
|
|
37
|
+
}
|
|
38
|
+
generate(name, data, timezone) {
|
|
39
|
+
const generator = this.sqlGenerator[name];
|
|
40
|
+
// istanbul ignore if
|
|
41
|
+
if (!generator) {
|
|
42
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
43
|
+
}
|
|
44
|
+
const template = generator.template;
|
|
45
|
+
template.env.timezone = timezone;
|
|
46
|
+
return template.render(data);
|
|
47
|
+
}
|
|
48
|
+
getType(name) {
|
|
49
|
+
const generator = this.sqlGenerator[name];
|
|
50
|
+
// istanbul ignore if
|
|
51
|
+
if (!generator) {
|
|
52
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
53
|
+
}
|
|
54
|
+
return generator.type;
|
|
55
|
+
}
|
|
56
|
+
getTemplateString(name) {
|
|
57
|
+
const generator = this.sqlGenerator[name];
|
|
58
|
+
// istanbul ignore if
|
|
59
|
+
if (!generator) {
|
|
60
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
61
|
+
}
|
|
62
|
+
return generator.raw;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.TableSqlMap = TableSqlMap;
|
|
66
|
+
_TableSqlMap_instances = new WeakSet(), _TableSqlMap_extract = function _TableSqlMap_extract(map) {
|
|
67
|
+
const ret = {
|
|
68
|
+
blocks: {},
|
|
69
|
+
sqlGenerator: {},
|
|
70
|
+
};
|
|
71
|
+
for (const key in map) {
|
|
72
|
+
// istanbul ignore if
|
|
73
|
+
if (!map.hasOwnProperty(key))
|
|
74
|
+
continue;
|
|
75
|
+
const sqlMap = map[key];
|
|
76
|
+
switch (sqlMap.type) {
|
|
77
|
+
case dal_decorator_1.SqlType.BLOCK:
|
|
78
|
+
ret.blocks[key] = sqlMap.content || '';
|
|
79
|
+
break;
|
|
80
|
+
case dal_decorator_1.SqlType.INSERT:
|
|
81
|
+
case dal_decorator_1.SqlType.SELECT:
|
|
82
|
+
case dal_decorator_1.SqlType.UPDATE:
|
|
83
|
+
case dal_decorator_1.SqlType.DELETE:
|
|
84
|
+
default:
|
|
85
|
+
ret.sqlGenerator[key] = {
|
|
86
|
+
type: sqlMap.type,
|
|
87
|
+
template: NunjucksUtil_1.NunjucksUtils.compile(this.name, key, sqlMap.sql || ''),
|
|
88
|
+
raw: sqlMap.sql,
|
|
89
|
+
};
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return ret;
|
|
94
|
+
};
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVTcWxNYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvVGFibGVTcWxNYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBRUEsaURBQStDO0FBQy9DLGlEQUE4QztBQUM5Qyx3REFBdUQ7QUFRdkQsTUFBYSxXQUFXO0lBTXRCLFlBQVksSUFBWSxFQUFFLEdBQTJCOztRQUNuRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUVmLE1BQU0sR0FBRyxHQUFHLDRCQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFDLE1BQU0sU0FBUyxHQUFHLHVCQUFBLElBQUksb0RBQVMsTUFBYixJQUFJLEVBQVUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQztRQUMvQixJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQyxZQUFZLENBQUM7UUFFM0MsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDOUIscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUM7Z0JBQUUsU0FBUztZQUMvQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDdkMsQ0FBQztRQUVELEdBQUcsQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLDJCQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0MsR0FBRyxDQUFDLFNBQVMsQ0FBQyxTQUFTLEVBQUUsMkJBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMvQyxHQUFHLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSwyQkFBWSxDQUFDLE1BQU0sQ0FB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
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ColumnModel, ColumnType, Geometry, GeometryCollection, Line, MultiLine, MultiPoint, MultiPolygon, Point, Polygon } from '@eggjs/dal-decorator';
|
|
2
|
+
export declare class TemplateUtil {
|
|
3
|
+
static isSpatialType(columnModel: ColumnModel): boolean;
|
|
4
|
+
static importPath(tableModelPath: string, currentPath: string): string;
|
|
5
|
+
static dbTypeToTsType(columnType: ColumnType): string;
|
|
6
|
+
static toJson(value: any): string;
|
|
7
|
+
static toPoint(point: Point): string;
|
|
8
|
+
static toLine(val: Line): string;
|
|
9
|
+
static toPolygon(val: Polygon): string;
|
|
10
|
+
static toGeometry(val: Geometry): string;
|
|
11
|
+
static toMultiPoint(val: MultiPoint): string;
|
|
12
|
+
static toMultiLine(val: MultiLine): string;
|
|
13
|
+
static toMultiPolygon(val: MultiPolygon): string;
|
|
14
|
+
static toGeometryCollection(val: GeometryCollection): string;
|
|
15
|
+
static spatialFilter: {
|
|
16
|
+
POINT: string;
|
|
17
|
+
LINESTRING: string;
|
|
18
|
+
POLYGON: string;
|
|
19
|
+
GEOMETRY: string;
|
|
20
|
+
MULTIPOINT: string;
|
|
21
|
+
MULTILINESTRING: string;
|
|
22
|
+
MULTIPOLYGON: string;
|
|
23
|
+
GEOMETRYCOLLECTION: string;
|
|
24
|
+
};
|
|
25
|
+
static getSpatialFilter(columnType: ColumnType): any;
|
|
26
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
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.TemplateUtil = void 0;
|
|
7
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
8
|
+
const dal_decorator_1 = require("@eggjs/dal-decorator");
|
|
9
|
+
class TemplateUtil {
|
|
10
|
+
static isSpatialType(columnModel) {
|
|
11
|
+
switch (columnModel.type.type) {
|
|
12
|
+
case dal_decorator_1.ColumnType.GEOMETRY:
|
|
13
|
+
case dal_decorator_1.ColumnType.POINT:
|
|
14
|
+
case dal_decorator_1.ColumnType.LINESTRING:
|
|
15
|
+
case dal_decorator_1.ColumnType.POLYGON:
|
|
16
|
+
case dal_decorator_1.ColumnType.MULTIPOINT:
|
|
17
|
+
case dal_decorator_1.ColumnType.MULTILINESTRING:
|
|
18
|
+
case dal_decorator_1.ColumnType.MULTIPOLYGON:
|
|
19
|
+
case dal_decorator_1.ColumnType.GEOMETRYCOLLECTION: {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
default: {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
static importPath(tableModelPath, currentPath) {
|
|
28
|
+
return node_path_1.default.relative(currentPath, tableModelPath);
|
|
29
|
+
}
|
|
30
|
+
static dbTypeToTsType(columnType) {
|
|
31
|
+
return `ColumnTsType['${columnType}']`;
|
|
32
|
+
}
|
|
33
|
+
static toJson(value) {
|
|
34
|
+
return JSON.stringify(JSON.stringify(value));
|
|
35
|
+
}
|
|
36
|
+
static toPoint(point) {
|
|
37
|
+
if (typeof point.x !== 'number' || typeof point.y !== 'number') {
|
|
38
|
+
throw new Error(`invalidate point ${JSON.stringify(point)}`);
|
|
39
|
+
}
|
|
40
|
+
return `Point(${point.x}, ${point.y})`;
|
|
41
|
+
}
|
|
42
|
+
static toLine(val) {
|
|
43
|
+
const points = val.map(t => TemplateUtil.toPoint(t));
|
|
44
|
+
return `LINESTRING(${points.join(',')})`;
|
|
45
|
+
}
|
|
46
|
+
static toPolygon(val) {
|
|
47
|
+
const lines = val.map(t => TemplateUtil.toLine(t));
|
|
48
|
+
return `POLYGON(${lines.join(',')})`;
|
|
49
|
+
}
|
|
50
|
+
static toGeometry(val) {
|
|
51
|
+
const type = dal_decorator_1.SpatialHelper.getGeometryType(val);
|
|
52
|
+
const filterName = TemplateUtil.getSpatialFilter(type);
|
|
53
|
+
return TemplateUtil[filterName](val);
|
|
54
|
+
}
|
|
55
|
+
static toMultiPoint(val) {
|
|
56
|
+
const points = val.map(t => TemplateUtil.toPoint(t));
|
|
57
|
+
return `MULTIPOINT(${points.join(',')})`;
|
|
58
|
+
}
|
|
59
|
+
static toMultiLine(val) {
|
|
60
|
+
const lines = val.map(t => TemplateUtil.toLine(t));
|
|
61
|
+
return `MULTILINESTRING(${lines.join(',')})`;
|
|
62
|
+
}
|
|
63
|
+
static toMultiPolygon(val) {
|
|
64
|
+
const polygon = val.map(t => TemplateUtil.toPolygon(t));
|
|
65
|
+
return `MULTIPOLYGON(${polygon.join(',')})`;
|
|
66
|
+
}
|
|
67
|
+
static toGeometryCollection(val) {
|
|
68
|
+
const geometries = val.map(t => {
|
|
69
|
+
return TemplateUtil.toGeometry(t);
|
|
70
|
+
});
|
|
71
|
+
return `GEOMETRYCOLLECTION(${geometries.join(',')})`;
|
|
72
|
+
}
|
|
73
|
+
static getSpatialFilter(columnType) {
|
|
74
|
+
const filter = TemplateUtil.spatialFilter[columnType];
|
|
75
|
+
if (!filter) {
|
|
76
|
+
throw new Error(`type ${columnType} is not spatial type`);
|
|
77
|
+
}
|
|
78
|
+
return filter;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
exports.TemplateUtil = TemplateUtil;
|
|
82
|
+
TemplateUtil.spatialFilter = {
|
|
83
|
+
[dal_decorator_1.ColumnType.POINT]: 'toPoint',
|
|
84
|
+
[dal_decorator_1.ColumnType.LINESTRING]: 'toLine',
|
|
85
|
+
[dal_decorator_1.ColumnType.POLYGON]: 'toPolygon',
|
|
86
|
+
[dal_decorator_1.ColumnType.GEOMETRY]: 'toGeometry',
|
|
87
|
+
[dal_decorator_1.ColumnType.MULTIPOINT]: 'toMultiPoint',
|
|
88
|
+
[dal_decorator_1.ColumnType.MULTILINESTRING]: 'toMultiLine',
|
|
89
|
+
[dal_decorator_1.ColumnType.MULTIPOLYGON]: 'toMultiPolygon',
|
|
90
|
+
[dal_decorator_1.ColumnType.GEOMETRYCOLLECTION]: 'toGeometryCollection',
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGVtcGxhdGVVdGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL1RlbXBsYXRlVXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSwwREFBNkI7QUFDN0Isd0RBVThCO0FBRTlCLE1BQWEsWUFBWTtJQUN2QixNQUFNLENBQUMsYUFBYSxDQUFDLFdBQXdCO1FBQzNDLFFBQVEsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUM5QixLQUFLLDBCQUFVLENBQUMsUUFBUSxDQUFDO1lBQ3pCLEtBQUssMEJBQVUsQ0FBQyxLQUFLLENBQUM7WUFDdEIsS0FBSywwQkFBVSxDQUFDLFVBQVUsQ0FBQztZQUMzQixLQUFLLDBCQUFVLENBQUMsT0FBTyxDQUFDO1lBQ3hCLEtBQUssMEJBQVUsQ0FBQyxVQUFVLENBQUM7WUFDM0IsS0FBSywwQkFBVSxDQUFDLGVBQWUsQ0FBQztZQUNoQyxLQUFLLDBCQUFVLENBQUMsWUFBWSxDQUFDO1lBQzdCLEtBQUssMEJBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7Z0JBQ25DLE9BQU8sSUFBSSxDQUFDO1lBQ2QsQ0FBQztZQUNELE9BQU8sQ0FBQyxDQUFDLENBQUM7Z0JBQ1IsT0FBTyxLQUFLLENBQUM7WUFDZixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLGNBQXNCLEVBQUUsV0FBbUI7UUFDM0QsT0FBTyxtQkFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsY0FBYyxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsVUFBc0I7UUFDMUMsT0FBTyxpQkFBaUIsVUFBVSxJQUFJLENBQUM7SUFDekMsQ0FBQztJQUVELE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBVTtRQUN0QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxD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
|
package/package.json
ADDED
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@eggjs/dal-runtime",
|
|
3
|
+
"version": "3.33.0",
|
|
4
|
+
"description": "tegg dal decorator",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"egg",
|
|
7
|
+
"typescript",
|
|
8
|
+
"decorator",
|
|
9
|
+
"tegg",
|
|
10
|
+
"dal"
|
|
11
|
+
],
|
|
12
|
+
"main": "dist/index.js",
|
|
13
|
+
"files": [
|
|
14
|
+
"dist/**/*.js",
|
|
15
|
+
"dist/**/*.d.ts"
|
|
16
|
+
],
|
|
17
|
+
"typings": "dist/index.d.ts",
|
|
18
|
+
"scripts": {
|
|
19
|
+
"test": "cross-env NODE_ENV=test NODE_OPTIONS='--no-deprecation' mocha",
|
|
20
|
+
"clean": "tsc -b --clean",
|
|
21
|
+
"tsc": "npm run clean && tsc -p ./tsconfig.json",
|
|
22
|
+
"tsc:pub": "npm run clean && tsc -p ./tsconfig.pub.json",
|
|
23
|
+
"prepublishOnly": "npm run tsc:pub"
|
|
24
|
+
},
|
|
25
|
+
"author": "killagu <killa123@126.com>",
|
|
26
|
+
"license": "MIT",
|
|
27
|
+
"homepage": "https://github.com/eggjs/tegg",
|
|
28
|
+
"bugs": {
|
|
29
|
+
"url": "https://github.com/eggjs/tegg/issues"
|
|
30
|
+
},
|
|
31
|
+
"repository": {
|
|
32
|
+
"type": "git",
|
|
33
|
+
"url": "git@github.com:eggjs/tegg.git",
|
|
34
|
+
"directory": "core/dal-decorator"
|
|
35
|
+
},
|
|
36
|
+
"engines": {
|
|
37
|
+
"node": ">=14.0.0"
|
|
38
|
+
},
|
|
39
|
+
"dependencies": {
|
|
40
|
+
"@eggjs/dal-decorator": "^3.33.0",
|
|
41
|
+
"@eggjs/rds": "^1.0.0",
|
|
42
|
+
"js-beautify": "^1.15.1",
|
|
43
|
+
"lodash": "^4.17.21",
|
|
44
|
+
"nunjucks": "^3.2.4",
|
|
45
|
+
"sdk-base": "^4.2.1",
|
|
46
|
+
"sqlstring": "^2.3.3"
|
|
47
|
+
},
|
|
48
|
+
"publishConfig": {
|
|
49
|
+
"access": "public"
|
|
50
|
+
},
|
|
51
|
+
"devDependencies": {
|
|
52
|
+
"@eggjs/tegg": "^3.33.0",
|
|
53
|
+
"@types/lodash": "^4.17.0",
|
|
54
|
+
"@types/mocha": "^10.0.1",
|
|
55
|
+
"@types/node": "^20.2.4",
|
|
56
|
+
"@types/nunjucks": "^3.2.6",
|
|
57
|
+
"cross-env": "^7.0.3",
|
|
58
|
+
"mocha": "^10.2.0",
|
|
59
|
+
"ts-node": "^10.9.1",
|
|
60
|
+
"typescript": "^5.0.4"
|
|
61
|
+
},
|
|
62
|
+
"gitHead": "8415595364405be14730f6151ded8763bfb12454"
|
|
63
|
+
}
|