@eggjs/dal-runtime 4.0.0-beta.8 → 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 +15 -0
- package/dist/BaseSqlMap.js +304 -0
- package/dist/CodeGenerator.d.ts +14 -0
- package/dist/CodeGenerator.js +139 -0
- package/dist/DaoLoader.d.ts +4 -0
- package/dist/DaoLoader.js +14 -0
- package/dist/DataSource.d.ts +28 -0
- package/dist/DataSource.js +82 -0
- package/dist/DatabaseForker.d.ts +12 -0
- package/dist/DatabaseForker.js +50 -0
- package/dist/MySqlDataSource.d.ts +23 -0
- package/dist/MySqlDataSource.js +63 -0
- package/dist/NunjucksConverter.d.ts +73 -0
- package/dist/NunjucksConverter.js +93 -0
- package/dist/NunjucksUtil.d.ts +5 -0
- package/dist/NunjucksUtil.js +74 -0
- package/dist/SqlGenerator.d.ts +9 -0
- package/dist/SqlGenerator.js +392 -0
- package/dist/SqlMapLoader.d.ts +10 -0
- package/dist/SqlMapLoader.js +20 -0
- package/dist/SqlUtil.d.ts +3 -0
- package/dist/SqlUtil.js +221 -0
- package/dist/TableModelInstanceBuilder.d.ts +6 -0
- package/dist/TableModelInstanceBuilder.js +23 -0
- package/dist/TableSqlMap.d.ts +19 -0
- package/dist/TableSqlMap.js +92 -0
- package/dist/TemplateUtil.d.ts +19 -0
- package/dist/TemplateUtil.js +86 -0
- package/dist/index.d.ts +15 -244
- package/dist/index.js +16 -1267
- package/package.json +6 -6
package/dist/SqlUtil.js
ADDED
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
function isWhiteChar(ch) {
|
|
2
|
+
return ch === ' ' || ch === '\n' || ch === '\r' || ch === '\t';
|
|
3
|
+
}
|
|
4
|
+
const COMMENT_CHARS = '-#/';
|
|
5
|
+
const MUL_CHAR_LEADING_COMMENT_FIRST_CHAR = {
|
|
6
|
+
MAY_BE_FIRST_COMMENT: '-',
|
|
7
|
+
MAY_BE_FIRST_BLOCK_COMMENT: '/',
|
|
8
|
+
};
|
|
9
|
+
const MUL_CHAR_LEADING_COMMENT_VERIFIER = {
|
|
10
|
+
MAY_BE_FIRST_COMMENT: '-',
|
|
11
|
+
MAY_BE_FIRST_BLOCK_COMMENT: '*',
|
|
12
|
+
};
|
|
13
|
+
const MUL_CHAR_LEADING_COMMENT_NEXT_STATE = {
|
|
14
|
+
MAY_BE_FIRST_COMMENT: 'IN_COMMENT_WAIT_HINT',
|
|
15
|
+
MAY_BE_FIRST_BLOCK_COMMENT: 'IN_BLOCK_COMMENT_WAIT_HINT',
|
|
16
|
+
};
|
|
17
|
+
export class SqlUtil {
|
|
18
|
+
static minify(sql) {
|
|
19
|
+
let ret = '';
|
|
20
|
+
let state = 'START';
|
|
21
|
+
let tempNextState;
|
|
22
|
+
for (let i = 0; i < sql.length; i++) {
|
|
23
|
+
const ch = sql[i];
|
|
24
|
+
switch (state) {
|
|
25
|
+
case 'MAY_BE_FIRST_COMMENT':
|
|
26
|
+
case 'MAY_BE_FIRST_BLOCK_COMMENT':
|
|
27
|
+
switch (ch) {
|
|
28
|
+
case '"':
|
|
29
|
+
tempNextState = 'DOUBLE_QUOTE';
|
|
30
|
+
break;
|
|
31
|
+
case '\'':
|
|
32
|
+
tempNextState = 'SINGLE_QUOTE';
|
|
33
|
+
break;
|
|
34
|
+
case MUL_CHAR_LEADING_COMMENT_VERIFIER[state]:
|
|
35
|
+
tempNextState = MUL_CHAR_LEADING_COMMENT_NEXT_STATE[state];
|
|
36
|
+
break;
|
|
37
|
+
default:
|
|
38
|
+
tempNextState = 'CONTENT';
|
|
39
|
+
break;
|
|
40
|
+
}
|
|
41
|
+
if (ch !== MUL_CHAR_LEADING_COMMENT_VERIFIER[state]) {
|
|
42
|
+
ret += `${MUL_CHAR_LEADING_COMMENT_FIRST_CHAR[state]}${ch}`;
|
|
43
|
+
}
|
|
44
|
+
state = tempNextState;
|
|
45
|
+
break;
|
|
46
|
+
case 'IN_COMMENT_WAIT_HINT':
|
|
47
|
+
if (ch !== '+') {
|
|
48
|
+
state = 'IN_COMMENT';
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
state = 'IN_COMMENT_HINT';
|
|
52
|
+
ret += '--+';
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
case 'IN_BLOCK_COMMENT_WAIT_HINT':
|
|
56
|
+
if (ch !== '+') {
|
|
57
|
+
state = 'IN_BLOCK_COMMENT';
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
state = 'IN_BLOCK_COMMENT_HINT';
|
|
61
|
+
ret += '/*+';
|
|
62
|
+
}
|
|
63
|
+
break;
|
|
64
|
+
case 'MAY_BE_LAST_BLOCK_COMMENT':
|
|
65
|
+
if (ch === '/') {
|
|
66
|
+
if (ret && !isWhiteChar(ret[ret.length - 1]))
|
|
67
|
+
ret += ' ';
|
|
68
|
+
state = 'IN_SPACE';
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
state = 'IN_BLOCK_COMMENT';
|
|
72
|
+
}
|
|
73
|
+
break;
|
|
74
|
+
case 'MAY_BE_LAST_BLOCK_COMMENT_HINT':
|
|
75
|
+
ret += ch;
|
|
76
|
+
if (ch === '/') {
|
|
77
|
+
state = 'IN_SPACE';
|
|
78
|
+
if (isWhiteChar(sql[i + 1]))
|
|
79
|
+
ret += sql[i + 1];
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
state = 'IN_BLOCK_COMMENT_HINT';
|
|
83
|
+
}
|
|
84
|
+
break;
|
|
85
|
+
case 'IN_COMMENT':
|
|
86
|
+
if (ch === '\n' || ch === '\r') {
|
|
87
|
+
if (ret && !isWhiteChar(ret[ret.length - 1]))
|
|
88
|
+
ret += ' ';
|
|
89
|
+
state = 'IN_SPACE';
|
|
90
|
+
}
|
|
91
|
+
break;
|
|
92
|
+
case 'IN_COMMENT_HINT':
|
|
93
|
+
ret += ch;
|
|
94
|
+
if (ch === '\n' || ch === '\r') {
|
|
95
|
+
state = 'IN_SPACE';
|
|
96
|
+
}
|
|
97
|
+
break;
|
|
98
|
+
case 'IN_BLOCK_COMMENT':
|
|
99
|
+
if (ch === '*') {
|
|
100
|
+
state = 'MAY_BE_LAST_BLOCK_COMMENT';
|
|
101
|
+
}
|
|
102
|
+
break;
|
|
103
|
+
case 'IN_BLOCK_COMMENT_HINT':
|
|
104
|
+
ret += ch;
|
|
105
|
+
if (ch === '*') {
|
|
106
|
+
state = 'MAY_BE_LAST_BLOCK_COMMENT_HINT';
|
|
107
|
+
}
|
|
108
|
+
break;
|
|
109
|
+
case 'START':
|
|
110
|
+
if (isWhiteChar(ch))
|
|
111
|
+
continue;
|
|
112
|
+
switch (ch) {
|
|
113
|
+
case '"':
|
|
114
|
+
state = 'DOUBLE_QUOTE';
|
|
115
|
+
break;
|
|
116
|
+
case '\'':
|
|
117
|
+
state = 'SINGLE_QUOTE';
|
|
118
|
+
break;
|
|
119
|
+
case '-':
|
|
120
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
121
|
+
break;
|
|
122
|
+
case '#':
|
|
123
|
+
state = 'IN_COMMENT';
|
|
124
|
+
break;
|
|
125
|
+
case '/':
|
|
126
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
127
|
+
break;
|
|
128
|
+
default:
|
|
129
|
+
state = 'CONTENT';
|
|
130
|
+
break;
|
|
131
|
+
}
|
|
132
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
133
|
+
ret += ch;
|
|
134
|
+
break;
|
|
135
|
+
case 'DOUBLE_QUOTE':
|
|
136
|
+
case 'SINGLE_QUOTE':
|
|
137
|
+
switch (ch) {
|
|
138
|
+
case '\\':
|
|
139
|
+
state = `BACKSLASH_AFTER_${state}`;
|
|
140
|
+
break;
|
|
141
|
+
case '\'':
|
|
142
|
+
if (state === 'SINGLE_QUOTE') {
|
|
143
|
+
state = 'QUOTE_DONE';
|
|
144
|
+
}
|
|
145
|
+
break;
|
|
146
|
+
case '"':
|
|
147
|
+
if (state === 'DOUBLE_QUOTE') {
|
|
148
|
+
state = 'QUOTE_DONE';
|
|
149
|
+
}
|
|
150
|
+
break;
|
|
151
|
+
default: break;
|
|
152
|
+
}
|
|
153
|
+
ret += ch;
|
|
154
|
+
break;
|
|
155
|
+
case 'BACKSLASH_AFTER_SINGLE_QUOTE':
|
|
156
|
+
case 'BACKSLASH_AFTER_DOUBLE_QUOTE':
|
|
157
|
+
ret += ch;
|
|
158
|
+
state = state.substr(16);
|
|
159
|
+
break;
|
|
160
|
+
case 'QUOTE_DONE':
|
|
161
|
+
case 'CONTENT':
|
|
162
|
+
switch (ch) {
|
|
163
|
+
case '\'':
|
|
164
|
+
state = 'SINGLE_QUOTE';
|
|
165
|
+
break;
|
|
166
|
+
case '"':
|
|
167
|
+
state = 'DOUBLE_QUOTE';
|
|
168
|
+
break;
|
|
169
|
+
case '-':
|
|
170
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
171
|
+
break;
|
|
172
|
+
case '#':
|
|
173
|
+
state = 'IN_COMMENT';
|
|
174
|
+
break;
|
|
175
|
+
case '/':
|
|
176
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
177
|
+
break;
|
|
178
|
+
default:
|
|
179
|
+
if (isWhiteChar(ch)) {
|
|
180
|
+
state = 'IN_SPACE';
|
|
181
|
+
ret += ' ';
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
state = 'CONTENT';
|
|
185
|
+
}
|
|
186
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
187
|
+
ret += ch;
|
|
188
|
+
break;
|
|
189
|
+
case 'IN_SPACE':
|
|
190
|
+
switch (ch) {
|
|
191
|
+
case '\'':
|
|
192
|
+
state = 'SINGLE_QUOTE';
|
|
193
|
+
break;
|
|
194
|
+
case '"':
|
|
195
|
+
state = 'DOUBLE_QUOTE';
|
|
196
|
+
break;
|
|
197
|
+
case '-':
|
|
198
|
+
state = 'MAY_BE_FIRST_COMMENT';
|
|
199
|
+
break;
|
|
200
|
+
case '#':
|
|
201
|
+
state = 'IN_COMMENT';
|
|
202
|
+
break;
|
|
203
|
+
case '/':
|
|
204
|
+
state = 'MAY_BE_FIRST_BLOCK_COMMENT';
|
|
205
|
+
break;
|
|
206
|
+
default:
|
|
207
|
+
if (isWhiteChar(ch))
|
|
208
|
+
continue;
|
|
209
|
+
state = 'CONTENT';
|
|
210
|
+
}
|
|
211
|
+
if (!COMMENT_CHARS.includes(ch))
|
|
212
|
+
ret += ch;
|
|
213
|
+
break;
|
|
214
|
+
default:
|
|
215
|
+
throw new Error('Unexpected state machine while minifying SQL.');
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
return ret.trim();
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsVXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9TcWxVdGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFNBQVMsV0FBVyxDQUFDLEVBQVU7SUFDN0IsT0FBTyxFQUFFLEtBQUssR0FBRyxJQUFJLEVBQUUsS0FBSyxJQUFJLElBQUksRUFBRSxLQUFLLElBQUksSUFBSSxFQUFFLEtBQUssSUFBSSxDQUFDO0FBQ2pFLENBQUM7QUFFRCxNQUFNLGFBQWEsR0FBRyxLQUFLLENBQUM7QUFDNUIsTUFBTSxtQ0FBbUMsR0FBRztJQUMxQyxvQkFBb0IsRUFBRSxHQUFHO0lBQ3pCLDBCQUEwQixFQUFFLEdBQUc7Q0FDaEMsQ0FBQztBQUNGLE1BQU0saUNBQWlDLEdBQUc7SUFDeEMsb0JBQW9CLEVBQUUsR0FBRztJQUN6QiwwQkFBMEIsRUFBRSxHQUFHO0NBQ2hDLENBQUM7QUFDRixNQUFNLG1DQUFtQyxHQUFHO0lBQzFDLG9CQUFvQixFQUFFLHNCQUFzQjtJQUM1QywwQkFBMEIsRUFBRSw0QkFBNEI7Q0FDekQsQ0FBQztBQUVGLE1BQU0sT0FBTyxPQUFPO0lBQ2xCLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBVztRQUN2QixJQUFJLEdBQUcsR0FBRyxFQUFFLENBQUM7UUFFYixJQUFJLEtBQUssR0FBRyxPQUFPLENBQUM7UUFDcEIsSUFBSSxhQUFhLENBQUM7UUFDbEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNwQyxNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsUUFBUSxLQUFLLEVBQUUsQ0FBQztnQkFDZCxLQUFLLHNCQUFzQixDQUFDO2dCQUM1QixLQUFLLDRCQUE0QjtvQkFDL0IsUUFBUSxFQUFFLEVBQUUsQ0FBQzt3QkFDWCxLQUFLLEdBQUc7NEJBQUUsYUFBYSxHQUFHLGNBQWMs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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,23 @@
|
|
|
1
|
+
import { TableModel } from '@eggjs/dal-decorator';
|
|
2
|
+
export class TableModelInstanceBuilder {
|
|
3
|
+
constructor(tableModel, row) {
|
|
4
|
+
for (const [key, value] of Object.entries(row)) {
|
|
5
|
+
const column = tableModel.columns.find(t => t.columnName === key);
|
|
6
|
+
Reflect.set(this, column?.propertyName ?? key, value);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
static buildInstance(tableModel, row) {
|
|
10
|
+
return Reflect.construct(TableModelInstanceBuilder, [tableModel, row], tableModel.clazz);
|
|
11
|
+
}
|
|
12
|
+
static buildRow(instance, tableModel) {
|
|
13
|
+
const result = {};
|
|
14
|
+
for (const column of tableModel.columns) {
|
|
15
|
+
const columnValue = Reflect.get(instance, column.propertyName);
|
|
16
|
+
if (typeof columnValue !== 'undefined') {
|
|
17
|
+
result[`$${column.propertyName}`] = columnValue;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVNb2RlbEluc3RhbmNlQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9UYWJsZU1vZGVsSW5zdGFuY2VCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVsRCxNQUFNLE9BQU8seUJBQXlCO0lBQ3BDLFlBQVksVUFBc0IsRUFBRSxHQUF3QjtRQUMxRCxLQUFLLE1BQU0sQ0FBRSxHQUFHLEVBQUUsS0FBSyxDQUFFLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2pELE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxHQUFHLENBQUMsQ0FBQztZQUNsRSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsWUFBWSxJQUFJLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUN4RCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxhQUFhLENBQUksVUFBeUIsRUFBRSxHQUF3QjtRQUN6RSxPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMseUJBQXlCLEVBQUUsQ0FBRSxVQUFVLEVBQUUsR0FBRyxDQUFFLEVBQUUsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdGLENBQUM7SUFFRCxNQUFNLENBQUMsUUFBUSxDQUFtQixRQUFXLEVBQUUsVUFBeUI7UUFDdEUsTUFBTSxNQUFNLEdBQVEsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssTUFBTSxNQUFNLElBQUksVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3hDLE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMvRCxJQUFJLE9BQU8sV0FBVyxLQUFLLFdBQVcsRUFBRSxDQUFDO2dCQUN2QyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsWUFBWSxFQUFFLENBQUMsR0FBRyxXQUFXLENBQUM7WUFDbEQsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0NBQ0YifQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Template } from 'nunjucks';
|
|
2
|
+
import { SqlType } from '@eggjs/tegg-types';
|
|
3
|
+
import type { SqlMap } from '@eggjs/tegg-types';
|
|
4
|
+
export interface SqlGenerator {
|
|
5
|
+
type: SqlType;
|
|
6
|
+
template: Template;
|
|
7
|
+
raw: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class TableSqlMap {
|
|
10
|
+
#private;
|
|
11
|
+
readonly name: string;
|
|
12
|
+
private readonly map;
|
|
13
|
+
private readonly blocks;
|
|
14
|
+
private readonly sqlGenerator;
|
|
15
|
+
constructor(name: string, map: Record<string, SqlMap>);
|
|
16
|
+
generate(name: string, data: object, timezone: string): string;
|
|
17
|
+
getType(name: string): SqlType;
|
|
18
|
+
getTemplateString(name: string): string;
|
|
19
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
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 _TableSqlMap_instances, _TableSqlMap_extract;
|
|
7
|
+
import { Template } from 'nunjucks';
|
|
8
|
+
import { SqlType } from '@eggjs/tegg-types';
|
|
9
|
+
import { NunjucksUtils } from "./NunjucksUtil.js";
|
|
10
|
+
import { TemplateUtil } from "./TemplateUtil.js";
|
|
11
|
+
export class TableSqlMap {
|
|
12
|
+
constructor(name, map) {
|
|
13
|
+
_TableSqlMap_instances.add(this);
|
|
14
|
+
this.name = name;
|
|
15
|
+
this.map = map;
|
|
16
|
+
const env = NunjucksUtils.createEnv(name);
|
|
17
|
+
const extracted = __classPrivateFieldGet(this, _TableSqlMap_instances, "m", _TableSqlMap_extract).call(this, this.map);
|
|
18
|
+
this.blocks = extracted.blocks;
|
|
19
|
+
this.sqlGenerator = extracted.sqlGenerator;
|
|
20
|
+
for (const key in this.blocks) {
|
|
21
|
+
// istanbul ignore if
|
|
22
|
+
if (!this.blocks.hasOwnProperty(key))
|
|
23
|
+
continue;
|
|
24
|
+
env.addGlobal(key, this.blocks[key]);
|
|
25
|
+
}
|
|
26
|
+
env.addFilter('toJson', TemplateUtil.toJson);
|
|
27
|
+
env.addFilter('toPoint', TemplateUtil.toPoint);
|
|
28
|
+
env.addFilter('toLine', TemplateUtil.toLine);
|
|
29
|
+
env.addFilter('toPolygon', TemplateUtil.toPolygon);
|
|
30
|
+
env.addFilter('toGeometry', TemplateUtil.toGeometry);
|
|
31
|
+
env.addFilter('toMultiPoint', TemplateUtil.toMultiPoint);
|
|
32
|
+
env.addFilter('toMultiLine', TemplateUtil.toMultiLine);
|
|
33
|
+
env.addFilter('toMultiPolygon', TemplateUtil.toMultiPolygon);
|
|
34
|
+
env.addFilter('toGeometryCollection', TemplateUtil.toGeometryCollection);
|
|
35
|
+
}
|
|
36
|
+
generate(name, data, timezone) {
|
|
37
|
+
const generator = this.sqlGenerator[name];
|
|
38
|
+
// istanbul ignore if
|
|
39
|
+
if (!generator) {
|
|
40
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
41
|
+
}
|
|
42
|
+
const template = generator.template;
|
|
43
|
+
template.env.timezone = timezone;
|
|
44
|
+
return template.render(data);
|
|
45
|
+
}
|
|
46
|
+
getType(name) {
|
|
47
|
+
const generator = this.sqlGenerator[name];
|
|
48
|
+
// istanbul ignore if
|
|
49
|
+
if (!generator) {
|
|
50
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
51
|
+
}
|
|
52
|
+
return generator.type;
|
|
53
|
+
}
|
|
54
|
+
getTemplateString(name) {
|
|
55
|
+
const generator = this.sqlGenerator[name];
|
|
56
|
+
// istanbul ignore if
|
|
57
|
+
if (!generator) {
|
|
58
|
+
throw new Error(`No sql map named '${name}' in '${name}'.`);
|
|
59
|
+
}
|
|
60
|
+
return generator.raw;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
_TableSqlMap_instances = new WeakSet(), _TableSqlMap_extract = function _TableSqlMap_extract(map) {
|
|
64
|
+
const ret = {
|
|
65
|
+
blocks: {},
|
|
66
|
+
sqlGenerator: {},
|
|
67
|
+
};
|
|
68
|
+
for (const key in map) {
|
|
69
|
+
// istanbul ignore if
|
|
70
|
+
if (!map.hasOwnProperty(key))
|
|
71
|
+
continue;
|
|
72
|
+
const sqlMap = map[key];
|
|
73
|
+
switch (sqlMap.type) {
|
|
74
|
+
case SqlType.BLOCK:
|
|
75
|
+
ret.blocks[key] = sqlMap.content || '';
|
|
76
|
+
break;
|
|
77
|
+
case SqlType.INSERT:
|
|
78
|
+
case SqlType.SELECT:
|
|
79
|
+
case SqlType.UPDATE:
|
|
80
|
+
case SqlType.DELETE:
|
|
81
|
+
default:
|
|
82
|
+
ret.sqlGenerator[key] = {
|
|
83
|
+
type: sqlMap.type,
|
|
84
|
+
template: NunjucksUtils.compile(this.name, key, sqlMap.sql || ''),
|
|
85
|
+
raw: sqlMap.sql,
|
|
86
|
+
};
|
|
87
|
+
break;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return ret;
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVTcWxNYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvVGFibGVTcWxNYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNwQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFHNUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQVFqRCxNQUFNLE9BQU8sV0FBVztJQU10QixZQUFZLElBQVksRUFBRSxHQUEyQjs7UUFDbkQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFFZixNQUFNLEdBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFDLE1BQU0sU0FBUyxHQUFHLHVCQUFBLElBQUksb0RBQVMsTUFBYixJQUFJLEVBQVUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQztRQUMvQixJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQyxZQUFZLENBQUM7UUFFM0MsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDOUIscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUM7Z0JBQUUsU0FBUztZQUMvQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDdkMsQ0FBQztRQUVELEdBQUcsQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxNQUFN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
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ColumnModel } from '@eggjs/dal-decorator';
|
|
2
|
+
import { ColumnType } from '@eggjs/tegg-types';
|
|
3
|
+
import type { Geometry, GeometryCollection, Line, MultiLine, MultiPoint, MultiPolygon, Point, Polygon } from '@eggjs/tegg-types';
|
|
4
|
+
export declare class TemplateUtil {
|
|
5
|
+
static isSpatialType(columnModel: ColumnModel): boolean;
|
|
6
|
+
static importPath(tableModelPath: string, currentPath: string): string;
|
|
7
|
+
static dbTypeToTsType(columnType: ColumnType): string;
|
|
8
|
+
static toJson(value: any): string;
|
|
9
|
+
static toPoint(point: Point): string;
|
|
10
|
+
static toLine(val: Line): string;
|
|
11
|
+
static toPolygon(val: Polygon): string;
|
|
12
|
+
static toGeometry(val: Geometry): string;
|
|
13
|
+
static toMultiPoint(val: MultiPoint): string;
|
|
14
|
+
static toMultiLine(val: MultiLine): string;
|
|
15
|
+
static toMultiPolygon(val: MultiPolygon): string;
|
|
16
|
+
static toGeometryCollection(val: GeometryCollection): string;
|
|
17
|
+
static spatialFilter: Record<ColumnType, string>;
|
|
18
|
+
static getSpatialFilter(columnType: ColumnType): string;
|
|
19
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { ColumnModel, SpatialHelper } from '@eggjs/dal-decorator';
|
|
3
|
+
import { ColumnType } from '@eggjs/tegg-types';
|
|
4
|
+
export class TemplateUtil {
|
|
5
|
+
static isSpatialType(columnModel) {
|
|
6
|
+
switch (columnModel.type.type) {
|
|
7
|
+
case ColumnType.GEOMETRY:
|
|
8
|
+
case ColumnType.POINT:
|
|
9
|
+
case ColumnType.LINESTRING:
|
|
10
|
+
case ColumnType.POLYGON:
|
|
11
|
+
case ColumnType.MULTIPOINT:
|
|
12
|
+
case ColumnType.MULTILINESTRING:
|
|
13
|
+
case ColumnType.MULTIPOLYGON:
|
|
14
|
+
case ColumnType.GEOMETRYCOLLECTION: {
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
default: {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
static importPath(tableModelPath, currentPath) {
|
|
23
|
+
return path.relative(currentPath, tableModelPath);
|
|
24
|
+
}
|
|
25
|
+
static dbTypeToTsType(columnType) {
|
|
26
|
+
return `ColumnTsType['${columnType}']`;
|
|
27
|
+
}
|
|
28
|
+
static toJson(value) {
|
|
29
|
+
return JSON.stringify(JSON.stringify(value));
|
|
30
|
+
}
|
|
31
|
+
static toPoint(point) {
|
|
32
|
+
if (typeof point.x !== 'number' || typeof point.y !== 'number') {
|
|
33
|
+
throw new Error(`invalidate point ${JSON.stringify(point)}`);
|
|
34
|
+
}
|
|
35
|
+
return `Point(${point.x}, ${point.y})`;
|
|
36
|
+
}
|
|
37
|
+
static toLine(val) {
|
|
38
|
+
const points = val.map(t => TemplateUtil.toPoint(t));
|
|
39
|
+
return `LINESTRING(${points.join(',')})`;
|
|
40
|
+
}
|
|
41
|
+
static toPolygon(val) {
|
|
42
|
+
const lines = val.map(t => TemplateUtil.toLine(t));
|
|
43
|
+
return `POLYGON(${lines.join(',')})`;
|
|
44
|
+
}
|
|
45
|
+
static toGeometry(val) {
|
|
46
|
+
const type = SpatialHelper.getGeometryType(val);
|
|
47
|
+
const filterName = TemplateUtil.getSpatialFilter(type);
|
|
48
|
+
return TemplateUtil[filterName](val);
|
|
49
|
+
}
|
|
50
|
+
static toMultiPoint(val) {
|
|
51
|
+
const points = val.map(t => TemplateUtil.toPoint(t));
|
|
52
|
+
return `MULTIPOINT(${points.join(',')})`;
|
|
53
|
+
}
|
|
54
|
+
static toMultiLine(val) {
|
|
55
|
+
const lines = val.map(t => TemplateUtil.toLine(t));
|
|
56
|
+
return `MULTILINESTRING(${lines.join(',')})`;
|
|
57
|
+
}
|
|
58
|
+
static toMultiPolygon(val) {
|
|
59
|
+
const polygon = val.map(t => TemplateUtil.toPolygon(t));
|
|
60
|
+
return `MULTIPOLYGON(${polygon.join(',')})`;
|
|
61
|
+
}
|
|
62
|
+
static toGeometryCollection(val) {
|
|
63
|
+
const geometries = val.map(t => {
|
|
64
|
+
return TemplateUtil.toGeometry(t);
|
|
65
|
+
});
|
|
66
|
+
return `GEOMETRYCOLLECTION(${geometries.join(',')})`;
|
|
67
|
+
}
|
|
68
|
+
static getSpatialFilter(columnType) {
|
|
69
|
+
const filter = TemplateUtil.spatialFilter[columnType];
|
|
70
|
+
if (!filter) {
|
|
71
|
+
throw new Error(`type ${columnType} is not spatial type`);
|
|
72
|
+
}
|
|
73
|
+
return filter;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
TemplateUtil.spatialFilter = {
|
|
77
|
+
[ColumnType.POINT]: 'toPoint',
|
|
78
|
+
[ColumnType.LINESTRING]: 'toLine',
|
|
79
|
+
[ColumnType.POLYGON]: 'toPolygon',
|
|
80
|
+
[ColumnType.GEOMETRY]: 'toGeometry',
|
|
81
|
+
[ColumnType.MULTIPOINT]: 'toMultiPoint',
|
|
82
|
+
[ColumnType.MULTILINESTRING]: 'toMultiLine',
|
|
83
|
+
[ColumnType.MULTIPOLYGON]: 'toMultiPolygon',
|
|
84
|
+
[ColumnType.GEOMETRYCOLLECTION]: 'toGeometryCollection',
|
|
85
|
+
};
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGVtcGxhdGVVdGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL1RlbXBsYXRlVXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLElBQUksTUFBTSxXQUFXLENBQUM7QUFFN0IsT0FBTyxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFZL0MsTUFBTSxPQUFPLFlBQVk7SUFDdkIsTUFBTSxDQUFDLGFBQWEsQ0FBQyxXQUF3QjtRQUMzQyxRQUFRLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDOUIsS0FBSyxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQ3pCLEtBQUssVUFBVSxDQUFDLEtBQUssQ0FBQztZQUN0QixLQUFLLFVBQVUsQ0FBQyxVQUFVLENBQUM7WUFDM0IsS0FBSyxVQUFVLENBQUMsT0FBTyxDQUFDO1lBQ3hCLEtBQUssVUFBVSxDQUFDLFVBQVUsQ0FBQztZQUMzQixLQUFLLFVBQVUsQ0FBQyxlQUFlLENBQUM7WUFDaEMsS0FBSyxVQUFVLENBQUMsWUFBWSxDQUFDO1lBQzdCLEtBQUssVUFBVSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztnQkFDbkMsT0FBTyxJQUFJLENBQUM7WUFDZCxDQUFDO1lBQ0QsT0FBTyxDQUFDLENBQUMsQ0FBQztnQkFDUixPQUFPLEtBQUssQ0FBQztZQUNmLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxVQUFVLENBQUMsY0FBc0IsRUFBRSxXQUFtQjtRQUMzRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRCxNQUFNLENBQUMsY0FBYyxDQUFDLFVBQXNCO1FBQzFDLE9BQU8saUJBQWlCLFVBQVUsSUFBSSxDQUFDO0lBQ3pDLENBQUM7SUFFRCxNQUFN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
|