@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.
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFibGVTcWxNYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvVGFibGVTcWxNYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNwQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFHNUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQVFqRCxNQUFNLE9BQU8sV0FBVztJQU10QixZQUFZLElBQVksRUFBRSxHQUEyQjs7UUFDbkQsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFFZixNQUFNLEdBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFDLE1BQU0sU0FBUyxHQUFHLHVCQUFBLElBQUksb0RBQVMsTUFBYixJQUFJLEVBQVUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQztRQUMvQixJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQyxZQUFZLENBQUM7UUFFM0MsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDOUIscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUM7Z0JBQUUsU0FBUztZQUMvQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDdkMsQ0FBQztRQUVELEdBQUcsQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM3QyxHQUFHLENBQUMsU0FBUyxDQUFDLFNBQVMsRUFBRSxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDL0MsR0FBRyxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzdDLEdBQUcsQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNuRCxHQUFHLENBQUMsU0FBUyxDQUFDLFlBQVksRUFBRSxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDckQsR0FBRyxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3pELEdBQUcsQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2RCxHQUFHLENBQUMsU0FBUyxDQUFDLGdCQUFnQixFQUFFLFlBQVksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM3RCxHQUFHLENBQUMsU0FBUyxDQUFDLHNCQUFzQixFQUFFLFlBQVksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBQzNFLENBQUM7SUFzQ0QsUUFBUSxDQUFDLElBQVksRUFBRSxJQUFZLEVBQUUsUUFBZ0I7UUFDbkQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQyxxQkFBcUI7UUFDckIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2YsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxTQUFTLElBQUksSUFBSSxDQUFDLENBQUM7UUFDOUQsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDbkMsUUFBZ0IsQ0FBQyxHQUFHLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUMxQyxPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU8sQ0FBQyxJQUFZO1FBQ2xCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUMscUJBQXFCO1FBQ3JCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNmLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLElBQUksU0FBUyxJQUFJLElBQUksQ0FBQyxDQUFDO1FBQzlELENBQUM7UUFFRCxPQUFPLFNBQVMsQ0FBQyxJQUFJLENBQUM7SUFDeEIsQ0FBQztJQUVELGlCQUFpQixDQUFDLElBQVk7UUFDNUIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQyxxQkFBcUI7UUFDckIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2YsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxTQUFTLElBQUksSUFBSSxDQUFDLENBQUM7UUFDOUQsQ0FBQztRQUVELE9BQU8sU0FBUyxDQUFDLEdBQUcsQ0FBQztJQUN2QixDQUFDO0NBQ0Y7NkZBbkVVLEdBQTJCO0lBQ2xDLE1BQU0sR0FBRyxHQUFHO1FBQ1YsTUFBTSxFQUFFLEVBQUU7UUFDVixZQUFZLEVBQUUsRUFBRTtLQUlqQixDQUFDO0lBRUYsS0FBSyxNQUFNLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUN0QixxQkFBcUI7UUFDckIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDO1lBQUUsU0FBUztRQUV2QyxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFeEIsUUFBUSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDcEIsS0FBSyxPQUFPLENBQUMsS0FBSztnQkFDaEIsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxNQUFNLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztnQkFDdkMsTUFBTTtZQUNSLEtBQUssT0FBTyxDQUFDLE1BQU0sQ0FBQztZQUNwQixLQUFLLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDcEIsS0FBSyxPQUFPLENBQUMsTUFBTSxDQUFDO1lBQ3BCLEtBQUssT0FBTyxDQUFDLE1BQU0sQ0FBQztZQUNwQjtnQkFDRSxHQUFHLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxHQUFHO29CQUN0QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUk7b0JBQ2pCLFFBQVEsRUFBRSxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHLElBQUksRUFBRSxDQUFDO29CQUNqRSxHQUFHLEVBQUUsTUFBTSxDQUFDLEdBQUc7aUJBQ2hCLENBQUM7Z0JBQ0YsTUFBTTtRQUNWLENBQUM7SUFDSCxDQUFDO0lBRUQsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDIn0=
@@ -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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