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.
Files changed (122) hide show
  1. package/cli.js +6 -5
  2. package/cli.js.map +1 -1
  3. package/code-generator2.d.ts.map +1 -1
  4. package/code-generator2.js +136 -102
  5. package/code-generator2.js.map +1 -1
  6. package/codegen/code-generator.d.ts +13 -0
  7. package/codegen/code-generator.d.ts.map +1 -0
  8. package/codegen/code-generator.js +107 -0
  9. package/codegen/code-generator.js.map +1 -0
  10. package/codegen/code-generator2.d.ts +10 -0
  11. package/codegen/code-generator2.d.ts.map +1 -0
  12. package/codegen/code-generator2.js +917 -0
  13. package/codegen/code-generator2.js.map +1 -0
  14. package/codegen/codegen-util.d.ts +1 -0
  15. package/codegen/codegen-util.d.ts.map +1 -0
  16. package/codegen/codegen-util.js +2 -0
  17. package/codegen/codegen-util.js.map +1 -0
  18. package/codegen/generic/codegen-util.d.ts +8 -0
  19. package/codegen/generic/codegen-util.d.ts.map +1 -0
  20. package/codegen/generic/codegen-util.js +89 -0
  21. package/codegen/generic/codegen-util.js.map +1 -0
  22. package/codegen/mysql2.d.ts +14 -0
  23. package/codegen/mysql2.d.ts.map +1 -0
  24. package/codegen/mysql2.js +608 -0
  25. package/codegen/mysql2.js.map +1 -0
  26. package/codegen/pg.d.ts +7 -0
  27. package/codegen/pg.d.ts.map +1 -0
  28. package/codegen/pg.js +707 -0
  29. package/codegen/pg.js.map +1 -0
  30. package/codegen/postgres-pg.d.ts +10 -0
  31. package/codegen/postgres-pg.d.ts.map +1 -0
  32. package/codegen/postgres-pg.js +917 -0
  33. package/codegen/postgres-pg.js.map +1 -0
  34. package/codegen/shared/codegen-util.d.ts +72 -0
  35. package/codegen/shared/codegen-util.d.ts.map +1 -0
  36. package/codegen/shared/codegen-util.js +487 -0
  37. package/codegen/shared/codegen-util.js.map +1 -0
  38. package/codegen/sqlite-code-generator.d.ts +15 -0
  39. package/codegen/sqlite-code-generator.d.ts.map +1 -0
  40. package/codegen/sqlite-code-generator.js +1049 -0
  41. package/codegen/sqlite-code-generator.js.map +1 -0
  42. package/codegen/sqlite.d.ts +11 -0
  43. package/codegen/sqlite.d.ts.map +1 -0
  44. package/codegen/sqlite.js +814 -0
  45. package/codegen/sqlite.js.map +1 -0
  46. package/describe-query.d.ts.map +1 -1
  47. package/describe-query.js +45 -32
  48. package/describe-query.js.map +1 -1
  49. package/dialects/postgres.d.ts +4 -1
  50. package/dialects/postgres.d.ts.map +1 -1
  51. package/dialects/postgres.js +4 -2
  52. package/dialects/postgres.js.map +1 -1
  53. package/drivers/sqlite.d.ts +4 -1
  54. package/drivers/sqlite.d.ts.map +1 -1
  55. package/drivers/sqlite.js +4 -1
  56. package/drivers/sqlite.js.map +1 -1
  57. package/drivers/types.d.ts +3 -1
  58. package/drivers/types.d.ts.map +1 -1
  59. package/generic/codegen-util.d.ts +8 -0
  60. package/generic/codegen-util.d.ts.map +1 -0
  61. package/generic/codegen-util.js +89 -0
  62. package/generic/codegen-util.js.map +1 -0
  63. package/mysql-mapping.d.ts +4 -1
  64. package/mysql-mapping.d.ts.map +1 -1
  65. package/mysql-mapping.js +5 -3
  66. package/mysql-mapping.js.map +1 -1
  67. package/mysql-query-analyzer/infer-column-nullability.js +1 -1
  68. package/mysql-query-analyzer/infer-column-nullability.js.map +1 -1
  69. package/mysql-query-analyzer/parse.d.ts.map +1 -1
  70. package/mysql-query-analyzer/parse.js +3 -2
  71. package/mysql-query-analyzer/parse.js.map +1 -1
  72. package/mysql-query-analyzer/select-columns.d.ts.map +1 -1
  73. package/mysql-query-analyzer/select-columns.js +1 -1
  74. package/mysql-query-analyzer/select-columns.js.map +1 -1
  75. package/mysql-query-analyzer/types.d.ts +3 -0
  76. package/mysql-query-analyzer/types.d.ts.map +1 -1
  77. package/package.json +12 -11
  78. package/postgres-pg.d.ts +10 -0
  79. package/postgres-pg.d.ts.map +1 -0
  80. package/postgres-pg.js +917 -0
  81. package/postgres-pg.js.map +1 -0
  82. package/postgres-query-analyzer/describe.d.ts +1 -1
  83. package/postgres-query-analyzer/describe.d.ts.map +1 -1
  84. package/postgres-query-analyzer/describe.js +86 -53
  85. package/postgres-query-analyzer/describe.js.map +1 -1
  86. package/postgres-query-analyzer/traverse.d.ts +1 -0
  87. package/postgres-query-analyzer/traverse.d.ts.map +1 -1
  88. package/postgres-query-analyzer/traverse.js +43 -21
  89. package/postgres-query-analyzer/traverse.js.map +1 -1
  90. package/postgres-query-analyzer/types.d.ts +1 -0
  91. package/postgres-query-analyzer/types.d.ts.map +1 -1
  92. package/postgres-query-analyzer/util.d.ts +9 -0
  93. package/postgres-query-analyzer/util.d.ts.map +1 -0
  94. package/postgres-query-analyzer/util.js +58 -0
  95. package/postgres-query-analyzer/util.js.map +1 -0
  96. package/rescript.d.ts +1 -0
  97. package/rescript.d.ts.map +1 -0
  98. package/rescript.js +2 -0
  99. package/rescript.js.map +1 -0
  100. package/sqlite-query-analyzer/parser.js +6 -3
  101. package/sqlite-query-analyzer/parser.js.map +1 -1
  102. package/sqlite-query-analyzer/replace-list-params.d.ts.map +1 -1
  103. package/sqlite-query-analyzer/replace-list-params.js.map +1 -1
  104. package/sqlite-query-analyzer/sqlite-code-generator.d.ts +15 -0
  105. package/sqlite-query-analyzer/sqlite-code-generator.d.ts.map +1 -0
  106. package/sqlite-query-analyzer/sqlite-code-generator.js +1049 -0
  107. package/sqlite-query-analyzer/sqlite-code-generator.js.map +1 -0
  108. package/sqlite-query-analyzer/sqlite-describe-nested-query.d.ts +1 -0
  109. package/sqlite-query-analyzer/sqlite-describe-nested-query.d.ts.map +1 -1
  110. package/sqlite-query-analyzer/sqlite-describe-nested-query.js.map +1 -1
  111. package/sqlite-query-analyzer/traverse.d.ts.map +1 -1
  112. package/sqlite-query-analyzer/traverse.js +6 -3
  113. package/sqlite-query-analyzer/traverse.js.map +1 -1
  114. package/sqlite.d.ts +43 -0
  115. package/sqlite.d.ts.map +1 -0
  116. package/sqlite.js +755 -0
  117. package/sqlite.js.map +1 -0
  118. package/ts-nested-descriptor.d.ts.map +1 -1
  119. package/ts-nested-descriptor.js +1 -1
  120. package/ts-nested-descriptor.js.map +1 -1
  121. package/types.d.ts +8 -1
  122. 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"}