typesql-cli 0.20.0 → 0.21.1
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/cli.js +6 -5
- package/cli.js.map +1 -1
- package/code-generator2.d.ts.map +1 -1
- package/code-generator2.js +136 -102
- package/code-generator2.js.map +1 -1
- package/codegen/code-generator.d.ts +13 -0
- package/codegen/code-generator.d.ts.map +1 -0
- package/codegen/code-generator.js +107 -0
- package/codegen/code-generator.js.map +1 -0
- package/codegen/code-generator2.d.ts +10 -0
- package/codegen/code-generator2.d.ts.map +1 -0
- package/codegen/code-generator2.js +917 -0
- package/codegen/code-generator2.js.map +1 -0
- package/codegen/codegen-util.d.ts +1 -0
- package/codegen/codegen-util.d.ts.map +1 -0
- package/codegen/codegen-util.js +2 -0
- package/codegen/codegen-util.js.map +1 -0
- package/codegen/generic/codegen-util.d.ts +8 -0
- package/codegen/generic/codegen-util.d.ts.map +1 -0
- package/codegen/generic/codegen-util.js +89 -0
- package/codegen/generic/codegen-util.js.map +1 -0
- package/codegen/mysql2.d.ts +14 -0
- package/codegen/mysql2.d.ts.map +1 -0
- package/codegen/mysql2.js +608 -0
- package/codegen/mysql2.js.map +1 -0
- package/codegen/pg.d.ts +7 -0
- package/codegen/pg.d.ts.map +1 -0
- package/codegen/pg.js +707 -0
- package/codegen/pg.js.map +1 -0
- package/codegen/postgres-pg.d.ts +10 -0
- package/codegen/postgres-pg.d.ts.map +1 -0
- package/codegen/postgres-pg.js +917 -0
- package/codegen/postgres-pg.js.map +1 -0
- package/codegen/shared/codegen-util.d.ts +72 -0
- package/codegen/shared/codegen-util.d.ts.map +1 -0
- package/codegen/shared/codegen-util.js +487 -0
- package/codegen/shared/codegen-util.js.map +1 -0
- package/codegen/sqlite-code-generator.d.ts +15 -0
- package/codegen/sqlite-code-generator.d.ts.map +1 -0
- package/codegen/sqlite-code-generator.js +1049 -0
- package/codegen/sqlite-code-generator.js.map +1 -0
- package/codegen/sqlite.d.ts +11 -0
- package/codegen/sqlite.d.ts.map +1 -0
- package/codegen/sqlite.js +814 -0
- package/codegen/sqlite.js.map +1 -0
- package/describe-query.d.ts.map +1 -1
- package/describe-query.js +45 -32
- package/describe-query.js.map +1 -1
- package/dialects/postgres.d.ts +4 -1
- package/dialects/postgres.d.ts.map +1 -1
- package/dialects/postgres.js +4 -2
- package/dialects/postgres.js.map +1 -1
- package/drivers/sqlite.d.ts +4 -1
- package/drivers/sqlite.d.ts.map +1 -1
- package/drivers/sqlite.js +4 -1
- package/drivers/sqlite.js.map +1 -1
- package/drivers/types.d.ts +3 -1
- package/drivers/types.d.ts.map +1 -1
- package/generic/codegen-util.d.ts +8 -0
- package/generic/codegen-util.d.ts.map +1 -0
- package/generic/codegen-util.js +89 -0
- package/generic/codegen-util.js.map +1 -0
- package/mysql-mapping.d.ts +4 -1
- package/mysql-mapping.d.ts.map +1 -1
- package/mysql-mapping.js +5 -3
- package/mysql-mapping.js.map +1 -1
- package/mysql-query-analyzer/infer-column-nullability.js +1 -1
- package/mysql-query-analyzer/infer-column-nullability.js.map +1 -1
- package/mysql-query-analyzer/parse.d.ts.map +1 -1
- package/mysql-query-analyzer/parse.js +3 -2
- package/mysql-query-analyzer/parse.js.map +1 -1
- package/mysql-query-analyzer/select-columns.d.ts.map +1 -1
- package/mysql-query-analyzer/select-columns.js +1 -1
- package/mysql-query-analyzer/select-columns.js.map +1 -1
- package/mysql-query-analyzer/types.d.ts +3 -0
- package/mysql-query-analyzer/types.d.ts.map +1 -1
- package/package.json +12 -11
- package/postgres-pg.d.ts +10 -0
- package/postgres-pg.d.ts.map +1 -0
- package/postgres-pg.js +917 -0
- package/postgres-pg.js.map +1 -0
- package/postgres-query-analyzer/describe.d.ts +1 -1
- package/postgres-query-analyzer/describe.d.ts.map +1 -1
- package/postgres-query-analyzer/describe.js +86 -53
- package/postgres-query-analyzer/describe.js.map +1 -1
- package/postgres-query-analyzer/traverse.d.ts +1 -0
- package/postgres-query-analyzer/traverse.d.ts.map +1 -1
- package/postgres-query-analyzer/traverse.js +43 -21
- package/postgres-query-analyzer/traverse.js.map +1 -1
- package/postgres-query-analyzer/types.d.ts +1 -0
- package/postgres-query-analyzer/types.d.ts.map +1 -1
- package/postgres-query-analyzer/util.d.ts +9 -0
- package/postgres-query-analyzer/util.d.ts.map +1 -0
- package/postgres-query-analyzer/util.js +58 -0
- package/postgres-query-analyzer/util.js.map +1 -0
- package/rescript.d.ts +1 -0
- package/rescript.d.ts.map +1 -0
- package/rescript.js +2 -0
- package/rescript.js.map +1 -0
- package/sqlite-query-analyzer/parser.js +6 -3
- package/sqlite-query-analyzer/parser.js.map +1 -1
- package/sqlite-query-analyzer/replace-list-params.d.ts.map +1 -1
- package/sqlite-query-analyzer/replace-list-params.js.map +1 -1
- package/sqlite-query-analyzer/sqlite-code-generator.d.ts +15 -0
- package/sqlite-query-analyzer/sqlite-code-generator.d.ts.map +1 -0
- package/sqlite-query-analyzer/sqlite-code-generator.js +1049 -0
- package/sqlite-query-analyzer/sqlite-code-generator.js.map +1 -0
- package/sqlite-query-analyzer/sqlite-describe-nested-query.d.ts +1 -0
- package/sqlite-query-analyzer/sqlite-describe-nested-query.d.ts.map +1 -1
- package/sqlite-query-analyzer/sqlite-describe-nested-query.js.map +1 -1
- package/sqlite-query-analyzer/traverse.d.ts.map +1 -1
- package/sqlite-query-analyzer/traverse.js +6 -3
- package/sqlite-query-analyzer/traverse.js.map +1 -1
- package/sqlite.d.ts +43 -0
- package/sqlite.d.ts.map +1 -0
- package/sqlite.js +755 -0
- package/sqlite.js.map +1 -0
- package/ts-nested-descriptor.d.ts.map +1 -1
- package/ts-nested-descriptor.js +1 -1
- package/ts-nested-descriptor.js.map +1 -1
- package/types.d.ts +8 -1
- package/types.d.ts.map +1 -1
@@ -0,0 +1,487 @@
|
|
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.createCodeBlockWriter = createCodeBlockWriter;
|
7
|
+
exports.capitalize = capitalize;
|
8
|
+
exports.convertToCamelCaseName = convertToCamelCaseName;
|
9
|
+
exports.createTypeNames = createTypeNames;
|
10
|
+
exports.generateRelationType = generateRelationType;
|
11
|
+
exports.removeDuplicatedParameters2 = removeDuplicatedParameters2;
|
12
|
+
exports.renameInvalidNames = renameInvalidNames;
|
13
|
+
exports.escapeInvalidTsField = escapeInvalidTsField;
|
14
|
+
exports.hasStringColumn = hasStringColumn;
|
15
|
+
exports.writeBuildOrderByBlock = writeBuildOrderByBlock;
|
16
|
+
exports.writeDynamicQueryParamType = writeDynamicQueryParamType;
|
17
|
+
exports.writeSelectFragements = writeSelectFragements;
|
18
|
+
exports.writeDynamicQueryOperators = writeDynamicQueryOperators;
|
19
|
+
exports.writeWhereConditionFunction = writeWhereConditionFunction;
|
20
|
+
exports.writeWhereConditionsToObjectFunction = writeWhereConditionsToObjectFunction;
|
21
|
+
exports.writeBuildSqlFunction = writeBuildSqlFunction;
|
22
|
+
exports.writeMapToResultFunction = writeMapToResultFunction;
|
23
|
+
exports.writeOrderByToObjectFunction = writeOrderByToObjectFunction;
|
24
|
+
exports.writeNestedTypes = writeNestedTypes;
|
25
|
+
exports.writeCollectFunction = writeCollectFunction;
|
26
|
+
exports.writeGroupByFunction = writeGroupByFunction;
|
27
|
+
const code_block_writer_1 = __importDefault(require("code-block-writer"));
|
28
|
+
const os_1 = require("os");
|
29
|
+
const camelcase_1 = __importDefault(require("camelcase"));
|
30
|
+
function createCodeBlockWriter() {
|
31
|
+
const writer = new code_block_writer_1.default({
|
32
|
+
useTabs: true,
|
33
|
+
newLine: os_1.EOL
|
34
|
+
});
|
35
|
+
return writer;
|
36
|
+
}
|
37
|
+
function capitalize(name) {
|
38
|
+
return capitalizeStr(name);
|
39
|
+
}
|
40
|
+
function convertToCamelCaseName(name) {
|
41
|
+
const camelCaseStr = (0, camelcase_1.default)(name);
|
42
|
+
return camelCaseStr;
|
43
|
+
}
|
44
|
+
function createTypeNames(queryName) {
|
45
|
+
const camelCaseName = convertToCamelCaseName(queryName);
|
46
|
+
const capitalizedName = capitalize(camelCaseName);
|
47
|
+
const dataTypeName = `${capitalizedName}Data`;
|
48
|
+
const resultTypeName = `${capitalizedName}Result`;
|
49
|
+
const paramsTypeName = `${capitalizedName}Params`;
|
50
|
+
const orderByTypeName = `${capitalizedName}OrderBy`;
|
51
|
+
const dynamicParamsTypeName = `${capitalizedName}DynamicParams`;
|
52
|
+
const selectColumnsTypeName = `${capitalizedName}Select`;
|
53
|
+
const whereTypeName = `${capitalizedName}Where`;
|
54
|
+
return {
|
55
|
+
camelCaseName,
|
56
|
+
capitalizedName,
|
57
|
+
dataTypeName,
|
58
|
+
resultTypeName,
|
59
|
+
paramsTypeName,
|
60
|
+
orderByTypeName,
|
61
|
+
dynamicParamsTypeName,
|
62
|
+
selectColumnsTypeName,
|
63
|
+
whereTypeName
|
64
|
+
};
|
65
|
+
}
|
66
|
+
function generateRelationType(functionName, relationName) {
|
67
|
+
return `${capitalizeStr(functionName)}Nested${capitalizeStr(relationName)}`;
|
68
|
+
}
|
69
|
+
function capitalizeStr(name) {
|
70
|
+
if (name.length === 0)
|
71
|
+
return name;
|
72
|
+
return name.charAt(0).toUpperCase() + name.slice(1);
|
73
|
+
}
|
74
|
+
//TODO - remove duplicated code
|
75
|
+
function removeDuplicatedParameters2(parameters) {
|
76
|
+
const columnsCount = new Map();
|
77
|
+
parameters.forEach((param) => {
|
78
|
+
const dupParam = columnsCount.get(param.name);
|
79
|
+
if (dupParam != null) {
|
80
|
+
//duplicated - two parameter null and notNull, resturn the null param (notNull == false)
|
81
|
+
if (param.notNull === false) {
|
82
|
+
columnsCount.set(param.name, param);
|
83
|
+
}
|
84
|
+
// return param;
|
85
|
+
}
|
86
|
+
else {
|
87
|
+
columnsCount.set(param.name, param);
|
88
|
+
}
|
89
|
+
});
|
90
|
+
return [...columnsCount.values()];
|
91
|
+
}
|
92
|
+
function renameInvalidNames(columnNames) {
|
93
|
+
const columnsCount = new Map();
|
94
|
+
return columnNames.map((columnName) => {
|
95
|
+
if (columnsCount.has(columnName)) {
|
96
|
+
const count = columnsCount.get(columnName) + 1;
|
97
|
+
columnsCount.set(columnName, count);
|
98
|
+
const newName = `${columnName}_${count}`;
|
99
|
+
return escapeInvalidTsField(newName);
|
100
|
+
}
|
101
|
+
columnsCount.set(columnName, 1);
|
102
|
+
return escapeInvalidTsField(columnName);
|
103
|
+
});
|
104
|
+
}
|
105
|
+
function escapeInvalidTsField(columnName) {
|
106
|
+
const validPattern = /^[a-zA-Z0-9_$]+$/g;
|
107
|
+
if (!validPattern.test(columnName)) {
|
108
|
+
return `"${columnName}"`;
|
109
|
+
}
|
110
|
+
return columnName;
|
111
|
+
}
|
112
|
+
function hasStringColumn(columns) {
|
113
|
+
return columns.some((c) => c.tsType === 'string');
|
114
|
+
}
|
115
|
+
function writeBuildOrderByBlock(writer, orderByColumns, orderByTypeName) {
|
116
|
+
writer.writeLine(`const orderByColumns = [${orderByColumns.map(col => `'${col}'`).join(', ')}] as const;`);
|
117
|
+
writer.blankLine();
|
118
|
+
writer.write(`export type ${orderByTypeName} =`).block(() => {
|
119
|
+
writer.writeLine('column: typeof orderByColumns[number];');
|
120
|
+
writer.writeLine(`direction: 'asc' | 'desc';`);
|
121
|
+
});
|
122
|
+
writer.blankLine();
|
123
|
+
writer.write(`function buildOrderBy(orderBy: ${orderByTypeName}[]): string`).block(() => {
|
124
|
+
writer.write('if (!Array.isArray(orderBy) || orderBy.length === 0)').block(() => {
|
125
|
+
writer.writeLine(`throw new Error('orderBy must be a non-empty array');`);
|
126
|
+
});
|
127
|
+
writer.blankLine();
|
128
|
+
writer.write('for (const { column, direction } of orderBy)').block(() => {
|
129
|
+
writer.write('if (!orderByColumns.includes(column))').block(() => {
|
130
|
+
writer.writeLine('throw new Error(`Invalid orderBy column: ${column}`);');
|
131
|
+
});
|
132
|
+
writer.write(`if (direction !== 'asc' && direction !== 'desc')`).block(() => {
|
133
|
+
writer.writeLine('throw new Error(`Invalid orderBy direction: ${direction}`);');
|
134
|
+
});
|
135
|
+
});
|
136
|
+
writer.blankLine();
|
137
|
+
writer.writeLine('return orderBy');
|
138
|
+
writer.indent().write('.map(({ column, direction }) => `"${column}" ${direction.toUpperCase()}`)').newLine();
|
139
|
+
writer.indent().write(`.join(', ');`).newLine();
|
140
|
+
});
|
141
|
+
}
|
142
|
+
function writeDynamicQueryParamType(writer, queryName, hasParams, orderByField) {
|
143
|
+
const { dynamicParamsTypeName, selectColumnsTypeName, paramsTypeName, whereTypeName, orderByTypeName } = createTypeNames(queryName);
|
144
|
+
writer.write(`export type ${dynamicParamsTypeName} = `).block(() => {
|
145
|
+
writer.writeLine(`select?: ${selectColumnsTypeName};`);
|
146
|
+
if (hasParams) {
|
147
|
+
writer.writeLine(`params: ${paramsTypeName};`);
|
148
|
+
}
|
149
|
+
writer.writeLine(`where?: ${whereTypeName}[];`);
|
150
|
+
if (orderByField) {
|
151
|
+
writer.writeLine(`${orderByField}: ${orderByTypeName}[];`);
|
152
|
+
}
|
153
|
+
});
|
154
|
+
}
|
155
|
+
function writeSelectFragements(writer, selectFragements, columns) {
|
156
|
+
writer.write('const selectFragments = ').inlineBlock(() => {
|
157
|
+
selectFragements.forEach((fragment, index) => {
|
158
|
+
const field = columns[index].name;
|
159
|
+
writer.writeLine(`${field}: \`${fragment.fragmentWitoutAlias}\`,`);
|
160
|
+
});
|
161
|
+
});
|
162
|
+
writer.write(' as const;');
|
163
|
+
}
|
164
|
+
function writeDynamicQueryOperators(writer, whereTypeName, columns) {
|
165
|
+
writer.writeLine(`const NumericOperatorList = ['=', '<>', '>', '<', '>=', '<='] as const;`);
|
166
|
+
writer.writeLine('type NumericOperator = typeof NumericOperatorList[number];');
|
167
|
+
if (hasStringColumn(columns)) {
|
168
|
+
writer.writeLine(`type StringOperator = '=' | '<>' | '>' | '<' | '>=' | '<=' | 'LIKE';`);
|
169
|
+
}
|
170
|
+
writer.writeLine(`type SetOperator = 'IN' | 'NOT IN';`);
|
171
|
+
writer.writeLine(`type BetweenOperator = 'BETWEEN';`);
|
172
|
+
writer.blankLine();
|
173
|
+
writer.write(`export type ${whereTypeName} =`).indent(() => {
|
174
|
+
for (const col of columns) {
|
175
|
+
if (col.tsType === 'string') {
|
176
|
+
writer.writeLine(`| { column: '${col.name}'; op: StringOperator; value: ${col.tsType} | null }`);
|
177
|
+
}
|
178
|
+
else {
|
179
|
+
writer.writeLine(`| { column: '${col.name}'; op: NumericOperator; value: ${col.tsType} | null }`);
|
180
|
+
}
|
181
|
+
writer.writeLine(`| { column: '${col.name}'; op: SetOperator; value: ${col.tsType}[] }`);
|
182
|
+
writer.writeLine(`| { column: '${col.name}'; op: BetweenOperator; value: [${col.tsType} | null, ${col.tsType} | null] }`);
|
183
|
+
}
|
184
|
+
});
|
185
|
+
}
|
186
|
+
function writeWhereConditionFunction(writer, whereTypeName, columns) {
|
187
|
+
writer.write(`function whereCondition(condition: ${whereTypeName}, placeholder: () => string): WhereConditionResult | null `).block(() => {
|
188
|
+
writer.writeLine('const selectFragment = selectFragments[condition.column];');
|
189
|
+
writer.writeLine('const { op, value } = condition;');
|
190
|
+
writer.blankLine();
|
191
|
+
if (hasStringColumn(columns)) {
|
192
|
+
writer.write(`if (op === 'LIKE') `).block(() => {
|
193
|
+
writer.write('return ').block(() => {
|
194
|
+
writer.writeLine("sql: `${selectFragment} LIKE ${placeholder()}`,");
|
195
|
+
writer.writeLine('hasValue: value != null,');
|
196
|
+
writer.writeLine('values: [value]');
|
197
|
+
});
|
198
|
+
});
|
199
|
+
}
|
200
|
+
writer.write(`if (op === 'BETWEEN') `).block(() => {
|
201
|
+
writer.writeLine('const [from, to] = Array.isArray(value) ? value : [null, null];');
|
202
|
+
writer.write('return ').block(() => {
|
203
|
+
writer.writeLine('sql: `${selectFragment} BETWEEN ${placeholder()} AND ${placeholder()}`,');
|
204
|
+
writer.writeLine('hasValue: from != null && to != null,');
|
205
|
+
writer.writeLine('values: [from, to]');
|
206
|
+
});
|
207
|
+
});
|
208
|
+
writer.write(`if (op === 'IN' || op === 'NOT IN') `).block(() => {
|
209
|
+
writer.write('if (!Array.isArray(value) || value.length === 0)').block(() => {
|
210
|
+
writer.writeLine(`return { sql: '', hasValue: false, values: [] };`);
|
211
|
+
});
|
212
|
+
writer.write('return ').block(() => {
|
213
|
+
writer.writeLine("sql: `${selectFragment} ${op} (${value.map(() => placeholder()).join(', ')})`,");
|
214
|
+
writer.writeLine('hasValue: true,');
|
215
|
+
writer.writeLine('values: value');
|
216
|
+
});
|
217
|
+
});
|
218
|
+
writer.write('if (NumericOperatorList.includes(op)) ').block(() => {
|
219
|
+
writer.write('return ').block(() => {
|
220
|
+
writer.writeLine('sql: `${selectFragment} ${op} ${placeholder()}`,');
|
221
|
+
writer.writeLine('hasValue: value != null,');
|
222
|
+
writer.writeLine('values: [value]');
|
223
|
+
});
|
224
|
+
});
|
225
|
+
writer.writeLine('return null;');
|
226
|
+
});
|
227
|
+
}
|
228
|
+
function writeWhereConditionsToObjectFunction(writer, whereTypeName) {
|
229
|
+
writer.write(`function whereConditionsToObject(whereConditions?: ${whereTypeName}[])`).block(() => {
|
230
|
+
writer.writeLine('const obj = {} as any;');
|
231
|
+
writer.write('whereConditions?.forEach(condition => ').inlineBlock(() => {
|
232
|
+
writer.writeLine('const where = whereCondition(condition);');
|
233
|
+
writer.write('if (where?.hasValue) ').block(() => {
|
234
|
+
writer.writeLine('obj[condition.column] = true;');
|
235
|
+
});
|
236
|
+
});
|
237
|
+
writer.write(');');
|
238
|
+
writer.writeLine('return obj;');
|
239
|
+
});
|
240
|
+
}
|
241
|
+
function writeBuildSqlFunction(writer, params) {
|
242
|
+
const { dynamicParamsTypeName, dynamicQueryInfo, columns, parameters, dialect, hasOrderBy, toDrive } = params;
|
243
|
+
const optional = hasOrderBy ? '' : '?';
|
244
|
+
const paramsVar = parameters.length > 0 ? ', params' : '';
|
245
|
+
writer.write(`function buildSql(queryParams${optional}: ${dynamicParamsTypeName})`).block(() => {
|
246
|
+
writer.writeLine(`const { select, where${paramsVar} } = queryParams || {};`);
|
247
|
+
writer.blankLine();
|
248
|
+
if (hasOrderBy) {
|
249
|
+
writer.writeLine('const orderBy = orderByToObject(queryParams.orderBy);');
|
250
|
+
}
|
251
|
+
writer.writeLine('const selectedSqlFragments: string[] = [];');
|
252
|
+
writer.writeLine('const paramsValues: any[] = [];');
|
253
|
+
writer.blankLine();
|
254
|
+
writer.writeLine('const whereColumns = new Set(where?.map(w => w.column) || []);');
|
255
|
+
writer.blankLine();
|
256
|
+
if (dynamicQueryInfo.with.length > 0) {
|
257
|
+
writer.writeLine(`const withFragments: string[] = [];`);
|
258
|
+
dynamicQueryInfo.with.forEach((withFragment) => {
|
259
|
+
var _a;
|
260
|
+
const selectConditions = withFragment.dependOnFields.map((fieldIndex) => `(!select || select.${columns[fieldIndex].name} === true)`);
|
261
|
+
const whereConditions = withFragment.dependOnFields.map((fieldIndex) => `whereColumns.has('${columns[fieldIndex].name}')`);
|
262
|
+
const orderByConditions = ((_a = withFragment.dependOnOrderBy) === null || _a === void 0 ? void 0 : _a.map((orderBy) => `orderBy['${orderBy}'] != null`)) || [];
|
263
|
+
const allConditions = [...selectConditions, ...whereConditions, ...orderByConditions];
|
264
|
+
const paramValues = withFragment.parameters.map((paramIndex) => {
|
265
|
+
const param = parameters[paramIndex];
|
266
|
+
return toDrive('params?', param);
|
267
|
+
});
|
268
|
+
if (allConditions.length > 0) {
|
269
|
+
writer.writeLine(`if (`);
|
270
|
+
writer.indent().write(`${allConditions.join(`${os_1.EOL}\t|| `)}`).newLine();
|
271
|
+
writer.write(') ').inlineBlock(() => {
|
272
|
+
writer.write(`withFragments.push(\`${withFragment.fragment}\`);`);
|
273
|
+
paramValues.forEach((paramValues) => {
|
274
|
+
writer.writeLine(`paramsValues.push(${paramValues});`);
|
275
|
+
});
|
276
|
+
}).newLine();
|
277
|
+
}
|
278
|
+
else {
|
279
|
+
writer.writeLine(`withFragments.push(\`${withFragment.fragment}\`);`);
|
280
|
+
paramValues.forEach((paramValues) => {
|
281
|
+
writer.writeLine(`paramsValues.push(${paramValues});`);
|
282
|
+
});
|
283
|
+
}
|
284
|
+
});
|
285
|
+
}
|
286
|
+
dynamicQueryInfo.select.forEach((select, index) => {
|
287
|
+
writer.write(`if (!select || select.${columns[index].name} === true)`).block(() => {
|
288
|
+
writer.writeLine(`selectedSqlFragments.push(\`${select.fragment}\`);`);
|
289
|
+
select.parameters.forEach((param) => {
|
290
|
+
writer.writeLine(`paramsValues.push(params?.${param} ?? null);`);
|
291
|
+
});
|
292
|
+
});
|
293
|
+
});
|
294
|
+
writer.blankLine();
|
295
|
+
writer.writeLine('const fromSqlFragments: string[] = [];');
|
296
|
+
dynamicQueryInfo.from.forEach((from, index) => {
|
297
|
+
var _a;
|
298
|
+
const selectConditions = from.dependOnFields.map((fieldIndex) => `(!select || select.${columns[fieldIndex].name} === true)`);
|
299
|
+
const whereConditions = from.dependOnFields.map((fieldIndex) => `whereColumns.has('${columns[fieldIndex].name}')`);
|
300
|
+
const orderByConditions = ((_a = from.dependOnOrderBy) === null || _a === void 0 ? void 0 : _a.map((orderBy) => `orderBy['${orderBy}'] != null`)) || [];
|
301
|
+
const allConditions = [...selectConditions, ...whereConditions, ...orderByConditions];
|
302
|
+
const paramValues = from.parameters.map((paramIndex) => {
|
303
|
+
const param = parameters[paramIndex];
|
304
|
+
return toDrive('params?', param);
|
305
|
+
});
|
306
|
+
if (index != 0 && allConditions.length > 0) {
|
307
|
+
writer.blankLine();
|
308
|
+
writer.writeLine(`if (`);
|
309
|
+
writer.indent().write(`${allConditions.join(`${os_1.EOL}\t|| `)}`).newLine();
|
310
|
+
writer.write(') ').inlineBlock(() => {
|
311
|
+
writer.write(`fromSqlFragments.push(\`${from.fragment}\`);`);
|
312
|
+
});
|
313
|
+
paramValues.forEach((paramValues) => {
|
314
|
+
writer.writeLine(`paramsValues.push(${paramValues});`);
|
315
|
+
});
|
316
|
+
}
|
317
|
+
else {
|
318
|
+
writer.writeLine(`fromSqlFragments.push(\`${from.fragment}\`);`);
|
319
|
+
paramValues.forEach((paramValues) => {
|
320
|
+
writer.writeLine(`paramsValues.push(${paramValues});`);
|
321
|
+
});
|
322
|
+
}
|
323
|
+
});
|
324
|
+
writer.blankLine();
|
325
|
+
writer.writeLine('const whereSqlFragments: string[] = [];');
|
326
|
+
writer.blankLine();
|
327
|
+
dynamicQueryInfo.where.forEach((fragment) => {
|
328
|
+
const paramValues = fragment.parameters.map((paramIndex) => {
|
329
|
+
const param = parameters[paramIndex];
|
330
|
+
return `${toDrive('params?', param)} ?? null`;
|
331
|
+
});
|
332
|
+
writer.writeLine(`whereSqlFragments.push(\`${fragment.fragment}\`);`);
|
333
|
+
paramValues.forEach((paramValues) => {
|
334
|
+
writer.writeLine(`paramsValues.push(${paramValues});`);
|
335
|
+
});
|
336
|
+
});
|
337
|
+
if (dialect === 'postgres' && (dynamicQueryInfo === null || dynamicQueryInfo === void 0 ? void 0 : dynamicQueryInfo.limitOffset)) {
|
338
|
+
dynamicQueryInfo === null || dynamicQueryInfo === void 0 ? void 0 : dynamicQueryInfo.limitOffset.parameters.forEach((param) => {
|
339
|
+
writer.writeLine(`paramsValues.push(params?.${param} ?? null);`);
|
340
|
+
});
|
341
|
+
writer.blankLine();
|
342
|
+
}
|
343
|
+
if (dialect === 'sqlite') {
|
344
|
+
writer.writeLine(`const placeholder = () => '?';`);
|
345
|
+
}
|
346
|
+
else if (dialect === 'postgres') {
|
347
|
+
writer.writeLine(`let currentIndex = paramsValues.length;`);
|
348
|
+
writer.writeLine('const placeholder = () => `$${++currentIndex}`;');
|
349
|
+
}
|
350
|
+
writer.blankLine();
|
351
|
+
writer.write('where?.forEach(condition => ').inlineBlock(() => {
|
352
|
+
writer.writeLine('const whereClause = whereCondition(condition, placeholder);');
|
353
|
+
dynamicQueryInfo.select.forEach((select, index) => {
|
354
|
+
if (select.parameters.length > 0) {
|
355
|
+
writer.write(`if (condition.column === '${columns[index].name}')`).block(() => {
|
356
|
+
select.parameters.forEach((param) => {
|
357
|
+
writer.writeLine(`paramsValues.push(params?.${param} ?? null);`);
|
358
|
+
});
|
359
|
+
});
|
360
|
+
}
|
361
|
+
});
|
362
|
+
writer.write('if (whereClause?.hasValue)').block(() => {
|
363
|
+
writer.writeLine(`whereSqlFragments.push(whereClause.sql);`);
|
364
|
+
writer.write('paramsValues.push(...whereClause.values);');
|
365
|
+
});
|
366
|
+
});
|
367
|
+
writer.write(');').newLine();
|
368
|
+
if (dynamicQueryInfo.with.length > 0) {
|
369
|
+
writer.blankLine();
|
370
|
+
writer.writeLine('const withSql = withFragments.length > 0');
|
371
|
+
writer.indent().write('? `WITH${EOL}${withFragments.join(`,${EOL}`)}${EOL}`').newLine();
|
372
|
+
writer.indent().write(`: '';`).newLine();
|
373
|
+
}
|
374
|
+
writer.blankLine();
|
375
|
+
writer.writeLine('const whereSql = whereSqlFragments.length > 0 ? `WHERE ${whereSqlFragments.join(\' AND \')}` : \'\';');
|
376
|
+
writer.blankLine();
|
377
|
+
if (dynamicQueryInfo.with.length > 0) {
|
378
|
+
writer.writeLine('const sql = `${withSql}SELECT');
|
379
|
+
}
|
380
|
+
else {
|
381
|
+
writer.writeLine('const sql = `SELECT');
|
382
|
+
}
|
383
|
+
writer.indent().write('${selectedSqlFragments.join(`,${EOL}`)}').newLine();
|
384
|
+
writer.indent().write('${fromSqlFragments.join(EOL)}').newLine();
|
385
|
+
;
|
386
|
+
writer.indent().write('${whereSql}');
|
387
|
+
if (hasOrderBy) {
|
388
|
+
writer.newLine();
|
389
|
+
writer.indent().write('ORDER BY ${buildOrderBy(queryParams.orderBy)}');
|
390
|
+
}
|
391
|
+
const limitOffset = dynamicQueryInfo === null || dynamicQueryInfo === void 0 ? void 0 : dynamicQueryInfo.limitOffset;
|
392
|
+
if (limitOffset) {
|
393
|
+
writer.newLine();
|
394
|
+
writer.indent().write(`${limitOffset.fragment}`);
|
395
|
+
}
|
396
|
+
writer.write('`;');
|
397
|
+
if (dialect === 'sqlite' && (dynamicQueryInfo === null || dynamicQueryInfo === void 0 ? void 0 : dynamicQueryInfo.limitOffset)) {
|
398
|
+
writer.blankLine();
|
399
|
+
dynamicQueryInfo === null || dynamicQueryInfo === void 0 ? void 0 : dynamicQueryInfo.limitOffset.parameters.forEach((param) => {
|
400
|
+
writer.writeLine(`paramsValues.push(params?.${param} ?? null);`);
|
401
|
+
});
|
402
|
+
}
|
403
|
+
writer.blankLine();
|
404
|
+
writer.writeLine('return { sql, paramsValues };');
|
405
|
+
});
|
406
|
+
}
|
407
|
+
function writeMapToResultFunction(writer, params) {
|
408
|
+
const { columns, resultTypeName, selectColumnsTypeName, fromDriver } = params;
|
409
|
+
writer.write(`function mapArrayTo${resultTypeName}(data: any, select?: ${selectColumnsTypeName})`).block(() => {
|
410
|
+
writer.writeLine(`const result = {} as ${resultTypeName};`);
|
411
|
+
writer.writeLine('let rowIndex = -1;');
|
412
|
+
columns.forEach((tsField) => {
|
413
|
+
writer.write(`if (!select || select.${tsField.name} === true)`).block(() => {
|
414
|
+
writer.writeLine('rowIndex++;');
|
415
|
+
writer.writeLine(`result.${tsField.name} = ${fromDriver('data[rowIndex]', tsField)};`);
|
416
|
+
});
|
417
|
+
});
|
418
|
+
writer.write('return result;');
|
419
|
+
});
|
420
|
+
}
|
421
|
+
function writeOrderByToObjectFunction(writer, dynamicParamsTypeName) {
|
422
|
+
writer.write(`function orderByToObject(orderBy: ${dynamicParamsTypeName}['orderBy'])`).block(() => {
|
423
|
+
writer.writeLine('const obj = {} as any;');
|
424
|
+
writer.write('orderBy?.forEach(order => ').inlineBlock(() => {
|
425
|
+
writer.writeLine('obj[order.column] = true;');
|
426
|
+
});
|
427
|
+
writer.write(');');
|
428
|
+
writer.writeLine('return obj;');
|
429
|
+
});
|
430
|
+
}
|
431
|
+
function writeNestedTypes(writer, relations, captalizedName) {
|
432
|
+
relations.forEach((relation) => {
|
433
|
+
const relationType = generateRelationType(captalizedName, relation.name);
|
434
|
+
writer.blankLine();
|
435
|
+
writer.write(`export type ${relationType} = `).block(() => {
|
436
|
+
const uniqueNameFields = renameInvalidNames(relation.fields.map((f) => f.name));
|
437
|
+
relation.fields.forEach((field, index) => {
|
438
|
+
const nullable = field.notNull ? '' : ' | null';
|
439
|
+
writer.writeLine(`${uniqueNameFields[index]}: ${field.tsType}${nullable};`);
|
440
|
+
});
|
441
|
+
relation.relations.forEach((field) => {
|
442
|
+
const nestedRelationType = generateRelationType(captalizedName, field.tsType);
|
443
|
+
const nullable = field.notNull ? '' : ' | null';
|
444
|
+
writer.writeLine(`${field.name}: ${nestedRelationType}${nullable};`);
|
445
|
+
});
|
446
|
+
});
|
447
|
+
});
|
448
|
+
}
|
449
|
+
function writeCollectFunction(writer, relation, columns, capitalizedName, resultTypeName) {
|
450
|
+
const relationType = generateRelationType(capitalizedName, relation.name);
|
451
|
+
const collectFunctionName = `collect${relationType}`;
|
452
|
+
writer.blankLine();
|
453
|
+
writer.write(`function ${collectFunctionName}(selectResult: ${resultTypeName}[]): ${relationType}[]`).block(() => {
|
454
|
+
const groupBy = columns[relation.groupIndex].name;
|
455
|
+
writer.writeLine(`const grouped = groupBy(selectResult.filter(r => r.${groupBy} != null), r => r.${groupBy});`);
|
456
|
+
writer
|
457
|
+
.write('return [...grouped.values()].map(row => (')
|
458
|
+
.inlineBlock(() => {
|
459
|
+
relation.fields.forEach((field, index) => {
|
460
|
+
const uniqueNameFields = renameInvalidNames(relation.fields.map((f) => f.name));
|
461
|
+
const separator = ',';
|
462
|
+
const fieldName = columns[field.index].name;
|
463
|
+
writer.writeLine(`${uniqueNameFields[index]}: row[0].${fieldName}!${separator}`);
|
464
|
+
});
|
465
|
+
relation.relations.forEach((fieldRelation) => {
|
466
|
+
const relationType = generateRelationType(capitalizedName, fieldRelation.name);
|
467
|
+
const orNull = fieldRelation.notNull ? '' : ' ?? null';
|
468
|
+
const cardinality = fieldRelation.list ? '' : `[0]${orNull}`;
|
469
|
+
writer.writeLine(`${fieldRelation.name}: collect${relationType}(row)${cardinality},`);
|
470
|
+
});
|
471
|
+
})
|
472
|
+
.write('))');
|
473
|
+
});
|
474
|
+
}
|
475
|
+
function writeGroupByFunction(writer) {
|
476
|
+
writer.write('const groupBy = <T, Q>(array: T[], predicate: (value: T, index: number, array: T[]) => Q) =>').block(() => {
|
477
|
+
writer
|
478
|
+
.write('return array.reduce((map, value, index, array) => ')
|
479
|
+
.inlineBlock(() => {
|
480
|
+
writer.writeLine('const key = predicate(value, index, array);');
|
481
|
+
writer.writeLine('map.get(key)?.push(value) ?? map.set(key, [value]);');
|
482
|
+
writer.writeLine('return map;');
|
483
|
+
})
|
484
|
+
.write(', new Map<Q, T[]>());');
|
485
|
+
});
|
486
|
+
}
|
487
|
+
//# sourceMappingURL=codegen-util.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"codegen-util.js","sourceRoot":"","sources":["../../../../src/codegen/shared/codegen-util.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { type Either } from 'fp-ts/lib/Either';
|
2
|
+
import type { ColumnInfo, ColumnSchema } from '../mysql-query-analyzer/types';
|
3
|
+
import CodeBlockWriter from 'code-block-writer';
|
4
|
+
import type { BunDialect, CrudQueryType, D1Dialect, LibSqlClient, SQLiteClient, SQLiteDialect, TsFieldDescriptor, TypeSqlError } from '../types';
|
5
|
+
import type { Field2 } from '../sqlite-query-analyzer/sqlite-describe-nested-query';
|
6
|
+
import { type RelationType2, type TsField2 } from '../ts-nested-descriptor';
|
7
|
+
import { PostgresColumnInfo } from '../postgres-query-analyzer/types';
|
8
|
+
export declare function validateAndGenerateCode(client: SQLiteDialect | LibSqlClient | BunDialect | D1Dialect, sql: string, queryName: string, sqliteDbSchema: ColumnSchema[], isCrud?: boolean): Either<TypeSqlError, string>;
|
9
|
+
export declare function generateCrud(client: SQLiteClient, queryType: CrudQueryType, tableName: string, dbSchema: ColumnSchema[]): string;
|
10
|
+
export declare function getQueryName(queryType: CrudQueryType, tableName: string): string;
|
11
|
+
export declare function generateTsCode(sql: string, queryName: string, sqliteDbSchema: ColumnSchema[], client: SQLiteClient, isCrud?: boolean): Either<TypeSqlError, string>;
|
12
|
+
export declare function mapPostgrsFieldToTsField(columns: PostgresColumnInfo[], field: Field2): TsField2;
|
13
|
+
export declare function mapFieldToTsField(columns: ColumnInfo[], field: Field2, client: SQLiteClient): TsField2;
|
14
|
+
export declare function writeCollectFunction(writer: CodeBlockWriter, relation: RelationType2, columns: TsFieldDescriptor[], capitalizedName: string, resultTypeName: string): void;
|
15
|
+
//# sourceMappingURL=sqlite-code-generator.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"sqlite-code-generator.d.ts","sourceRoot":"","sources":["../../../src/codegen/sqlite-code-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAuB,MAAM,kBAAkB,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAe9E,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EACX,UAAU,EACV,aAAa,EACb,SAAS,EACT,YAAY,EAGZ,YAAY,EACZ,aAAa,EAEb,iBAAiB,EAEjB,YAAY,EACZ,MAAM,UAAU,CAAC;AAElB,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uDAAuD,CAAC;AACpF,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,QAAQ,EAAoB,MAAM,yBAAyB,CAAC;AAO9F,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAwBtE,wBAAgB,uBAAuB,CACtC,MAAM,EAAE,aAAa,GAAG,YAAY,GAAG,UAAU,GAAG,SAAS,EAC7D,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,MAAM,EACjB,cAAc,EAAE,YAAY,EAAE,EAC9B,MAAM,UAAQ,GACZ,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAW9B;AAcD,wBAAgB,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,UA2BvH;AAED,wBAAgB,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,UAavE;AAED,wBAAgB,cAAc,CAC7B,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,MAAM,EACjB,cAAc,EAAE,YAAY,EAAE,EAC9B,MAAM,EAAE,YAAY,EACpB,MAAM,UAAQ,GACZ,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAQ9B;AA+FD,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,kBAAkB,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,QAAQ,CAQ/F;AAED,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,GAAG,QAAQ,CAQtG;AAurBD,wBAAgB,oBAAoB,CACnC,MAAM,EAAE,eAAe,EACvB,QAAQ,EAAE,aAAa,EACvB,OAAO,EAAE,iBAAiB,EAAE,EAC5B,eAAe,EAAE,MAAM,EACvB,cAAc,EAAE,MAAM,QAyBtB"}
|