@shaxpir/squilt 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/README.md +289 -1
  2. package/dist/ast/AlterTableQuery.d.ts +32 -0
  3. package/dist/ast/AlterTableQuery.js +60 -0
  4. package/dist/ast/BetweenExpression.d.ts +10 -0
  5. package/dist/ast/BetweenExpression.js +18 -0
  6. package/dist/ast/CastExpression.d.ts +13 -0
  7. package/dist/ast/CastExpression.js +25 -0
  8. package/dist/ast/CollateExpression.d.ts +18 -0
  9. package/dist/ast/CollateExpression.js +30 -0
  10. package/dist/ast/CreateIndexQuery.d.ts +25 -0
  11. package/dist/ast/CreateIndexQuery.js +64 -0
  12. package/dist/ast/CreateTableQuery.d.ts +57 -0
  13. package/dist/ast/CreateTableQuery.js +79 -0
  14. package/dist/ast/CreateViewQuery.d.ts +34 -0
  15. package/dist/ast/CreateViewQuery.js +61 -0
  16. package/dist/ast/CreateVirtualTableQuery.d.ts +32 -0
  17. package/dist/ast/CreateVirtualTableQuery.js +74 -0
  18. package/dist/ast/DeleteQuery.d.ts +17 -0
  19. package/dist/ast/DeleteQuery.js +43 -0
  20. package/dist/ast/DropIndexQuery.d.ts +14 -0
  21. package/dist/ast/DropIndexQuery.js +35 -0
  22. package/dist/ast/DropTableQuery.d.ts +14 -0
  23. package/dist/ast/DropTableQuery.js +35 -0
  24. package/dist/ast/DropViewQuery.d.ts +11 -0
  25. package/dist/ast/DropViewQuery.js +24 -0
  26. package/dist/ast/FunctionExpression.d.ts +21 -0
  27. package/dist/ast/FunctionExpression.js +40 -1
  28. package/dist/ast/FunctionName.d.ts +1 -1
  29. package/dist/ast/FunctionName.js +1 -1
  30. package/dist/ast/InsertQuery.d.ts +24 -1
  31. package/dist/ast/InsertQuery.js +49 -1
  32. package/dist/ast/Operator.d.ts +2 -0
  33. package/dist/ast/Operator.js +3 -1
  34. package/dist/ast/SelectQuery.d.ts +4 -0
  35. package/dist/ast/SelectQuery.js +11 -1
  36. package/dist/ast/SubqueryExpression.d.ts +18 -0
  37. package/dist/ast/SubqueryExpression.js +27 -0
  38. package/dist/ast/UpdateQuery.d.ts +24 -0
  39. package/dist/ast/UpdateQuery.js +51 -0
  40. package/dist/ast/WindowExpression.d.ts +51 -0
  41. package/dist/ast/WindowExpression.js +61 -0
  42. package/dist/ast/WindowSpecification.d.ts +46 -0
  43. package/dist/ast/WindowSpecification.js +60 -0
  44. package/dist/builder/QueryBuilder.d.ts +20 -0
  45. package/dist/builder/QueryBuilder.js +41 -1
  46. package/dist/builder/Shorthand.d.ts +51 -0
  47. package/dist/builder/Shorthand.js +125 -1
  48. package/dist/index.d.ts +17 -1
  49. package/dist/index.js +59 -3
  50. package/dist/renderer/CompactQueryRenderer.d.ts +34 -2
  51. package/dist/renderer/CompactQueryRenderer.js +272 -2
  52. package/dist/renderer/IndentedQueryRenderer.d.ts +34 -2
  53. package/dist/renderer/IndentedQueryRenderer.js +289 -3
  54. package/dist/renderer/QueryRenderer.d.ts +11 -1
  55. package/dist/renderer/QueryRenderer.js +1 -1
  56. package/dist/validate/CommonQueryValidator.d.ts +31 -1
  57. package/dist/validate/CommonQueryValidator.js +253 -4
  58. package/dist/validate/QueryValidator.d.ts +10 -1
  59. package/dist/validate/QueryValidator.js +1 -1
  60. package/dist/validate/SQLiteQueryValidator.d.ts +16 -1
  61. package/dist/validate/SQLiteQueryValidator.js +32 -3
  62. package/dist/visitor/ParamCollector.d.ts +30 -0
  63. package/dist/visitor/ParamCollector.js +109 -2
  64. package/dist/visitor/QueryIdentityTransformer.d.ts +30 -0
  65. package/dist/visitor/QueryIdentityTransformer.js +217 -2
  66. package/dist/visitor/SqlTreeNodeVisitor.d.ts +30 -0
  67. package/dist/visitor/SqlTreeNodeVisitor.js +1 -1
  68. package/package.json +4 -1
@@ -1,14 +1,29 @@
1
1
  import { AliasableExpression } from "../ast/Abstractions";
2
2
  import { Alias } from "../ast/Alias";
3
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
4
+ import { BetweenExpression } from "../ast/BetweenExpression";
3
5
  import { BinaryExpression } from "../ast/BinaryExpression";
4
6
  import { CaseExpression } from "../ast/CaseExpression";
7
+ import { CastExpression } from "../ast/CastExpression";
8
+ import { CollateExpression } from "../ast/CollateExpression";
9
+ import { SubqueryExpression } from "../ast/SubqueryExpression";
10
+ import { WindowExpression } from "../ast/WindowExpression";
5
11
  import { Column } from "../ast/Column";
6
12
  import { Concat } from "../ast/Concat";
13
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
14
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
15
+ import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
16
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
17
+ import { DeleteQuery } from "../ast/DeleteQuery";
18
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
19
+ import { DropTableQuery } from "../ast/DropTableQuery";
20
+ import { DropViewQuery } from "../ast/DropViewQuery";
7
21
  import { ExistsExpression } from "../ast/ExistsExpression";
8
22
  import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
23
  import { FunctionExpression } from "../ast/FunctionExpression";
10
24
  import { InExpression } from "../ast/InExpression";
11
25
  import { InsertQuery } from "../ast/InsertQuery";
26
+ import { UpdateQuery } from "../ast/UpdateQuery";
12
27
  import { Join } from "../ast/Join";
13
28
  import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
29
  import { OrderBy } from "../ast/OrderBy";
@@ -22,11 +37,21 @@ export declare class CommonQueryValidator implements QueryValidator, SqlTreeNode
22
37
  protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<void>;
23
38
  private columnCount;
24
39
  private isGrouped;
25
- validate(query: SelectQuery | InsertQuery): void;
40
+ validate(query: SelectQuery | InsertQuery | UpdateQuery | DeleteQuery | CreateTableQuery | CreateVirtualTableQuery | CreateIndexQuery | CreateViewQuery | AlterTableQuery | DropTableQuery | DropIndexQuery | DropViewQuery): void;
26
41
  protected reset(): void;
27
42
  private validateAlias;
28
43
  private validateIdentifier;
29
44
  visitInsertQuery(node: InsertQuery): void;
45
+ visitDeleteQuery(node: DeleteQuery): void;
46
+ visitUpdateQuery(node: UpdateQuery): void;
47
+ visitDropTableQuery(node: DropTableQuery): void;
48
+ visitDropIndexQuery(node: DropIndexQuery): void;
49
+ visitDropViewQuery(node: DropViewQuery): void;
50
+ visitCreateViewQuery(node: CreateViewQuery): void;
51
+ visitCreateIndexQuery(node: CreateIndexQuery): void;
52
+ visitAlterTableQuery(node: AlterTableQuery): void;
53
+ visitCreateTableQuery(node: CreateTableQuery): void;
54
+ visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): void;
30
55
  visitSelectQuery(node: SelectQuery): void;
31
56
  visitTableFrom(node: TableFrom): void;
32
57
  visitSubqueryFrom(node: SubqueryFrom): void;
@@ -37,10 +62,15 @@ export declare class CommonQueryValidator implements QueryValidator, SqlTreeNode
37
62
  visitOrderBy(node: OrderBy): void;
38
63
  visitWithClause(node: With): void;
39
64
  visitBinaryExpression(node: BinaryExpression): void;
65
+ visitBetweenExpression(node: BetweenExpression): void;
40
66
  visitUnaryExpression(node: UnaryExpression): void;
41
67
  visitInExpression(node: InExpression): void;
42
68
  visitConcat(node: Concat): void;
43
69
  visitCaseExpression(node: CaseExpression): void;
70
+ visitCastExpression(node: CastExpression): void;
71
+ visitCollateExpression(node: CollateExpression): void;
72
+ visitSubqueryExpression(node: SubqueryExpression): void;
73
+ visitWindowExpression(node: WindowExpression): void;
44
74
  visitFunctionExpression(node: FunctionExpression): void;
45
75
  visitParamExpression(_node: Param): void;
46
76
  visitStringLiteral(node: StringLiteral): void;
@@ -50,11 +50,195 @@ class CommonQueryValidator {
50
50
  if (node['_columns'].length === 0) {
51
51
  throw new Error('InsertQuery must specify at least one column');
52
52
  }
53
- if (node['_columns'].length !== node['_values'].length) {
54
- throw new Error('InsertQuery must have the same number of columns and values');
53
+ if (node['_fromSelect']) {
54
+ // INSERT ... SELECT - validate the subquery
55
+ if (node['_values'].length > 0) {
56
+ throw new Error('InsertQuery cannot have both VALUES and SELECT');
57
+ }
58
+ node['_fromSelect'].accept(this);
59
+ }
60
+ else {
61
+ // INSERT ... VALUES - validate column/value count match
62
+ if (node['_columns'].length !== node['_values'].length) {
63
+ throw new Error('InsertQuery must have the same number of columns and values');
64
+ }
65
+ node['_values'].forEach(val => val.accept(this));
55
66
  }
56
67
  node['_columns'].forEach(col => this.validateIdentifier(col, 'InsertQuery column'));
57
- node['_values'].forEach(val => val.accept(this));
68
+ // Validate ON CONFLICT clause
69
+ if (node['_onConflictColumns'].length > 0) {
70
+ // Cannot use both OR REPLACE and ON CONFLICT
71
+ if (node['_orReplace']) {
72
+ throw new Error('InsertQuery cannot use both OR REPLACE and ON CONFLICT');
73
+ }
74
+ // Must have either DO UPDATE or DO NOTHING
75
+ if (!node['_doNothing'] && node['_doUpdateSets'].length === 0) {
76
+ throw new Error('ON CONFLICT must specify either DO UPDATE or DO NOTHING');
77
+ }
78
+ // Cannot have both DO UPDATE and DO NOTHING
79
+ if (node['_doNothing'] && node['_doUpdateSets'].length > 0) {
80
+ throw new Error('ON CONFLICT cannot have both DO UPDATE and DO NOTHING');
81
+ }
82
+ node['_onConflictColumns'].forEach(col => this.validateIdentifier(col, 'ON CONFLICT column'));
83
+ node['_doUpdateSets'].forEach(s => {
84
+ this.validateIdentifier(s.column, 'DO UPDATE column');
85
+ s.value.accept(this);
86
+ });
87
+ if (node['_onConflictWhere']) {
88
+ node['_onConflictWhere'].accept(this);
89
+ }
90
+ }
91
+ else {
92
+ // If no conflict columns but has DO UPDATE or DO NOTHING, that's an error
93
+ if (node['_doNothing'] || node['_doUpdateSets'].length > 0) {
94
+ throw new Error('DO UPDATE or DO NOTHING requires ON CONFLICT columns');
95
+ }
96
+ }
97
+ node['_returning'].forEach(r => r.accept(this));
98
+ }
99
+ visitDeleteQuery(node) {
100
+ this.validateIdentifier(node['_tableName'], 'DeleteQuery');
101
+ if (node['_where']) {
102
+ node['_where'].accept(this);
103
+ }
104
+ node['_returning'].forEach(r => r.accept(this));
105
+ }
106
+ visitUpdateQuery(node) {
107
+ this.validateIdentifier(node['_tableName'], 'UpdateQuery');
108
+ if (node['_set'].length === 0) {
109
+ throw new Error('UpdateQuery must have at least one SET clause');
110
+ }
111
+ node['_set'].forEach(s => {
112
+ this.validateIdentifier(s.column, 'UpdateQuery column');
113
+ s.value.accept(this);
114
+ });
115
+ if (node['_where']) {
116
+ node['_where'].accept(this);
117
+ }
118
+ node['_returning'].forEach(r => r.accept(this));
119
+ }
120
+ visitDropTableQuery(node) {
121
+ this.validateIdentifier(node.tableName, 'DropTableQuery');
122
+ }
123
+ visitDropIndexQuery(node) {
124
+ this.validateIdentifier(node.indexName, 'DropIndexQuery');
125
+ }
126
+ visitDropViewQuery(node) {
127
+ this.validateIdentifier(node.viewName, 'DropViewQuery');
128
+ }
129
+ visitCreateViewQuery(node) {
130
+ this.validateIdentifier(node.viewName, 'CreateViewQuery view name');
131
+ for (const col of node.columns) {
132
+ this.validateIdentifier(col, 'CreateViewQuery column name');
133
+ }
134
+ if (!node.selectQuery) {
135
+ throw new Error('CreateViewQuery must have a SELECT query');
136
+ }
137
+ node.selectQuery.accept(this);
138
+ }
139
+ visitCreateIndexQuery(node) {
140
+ this.validateIdentifier(node.indexName, 'CreateIndexQuery index name');
141
+ this.validateIdentifier(node.tableName, 'CreateIndexQuery table name');
142
+ if (node.columns.length === 0) {
143
+ throw new Error('CreateIndexQuery must have at least one column');
144
+ }
145
+ for (const col of node.columns) {
146
+ this.validateIdentifier(col, 'CreateIndexQuery column');
147
+ }
148
+ if (node.whereExpression) {
149
+ node.whereExpression.accept(this);
150
+ }
151
+ }
152
+ visitAlterTableQuery(node) {
153
+ this.validateIdentifier(node.tableName, 'AlterTableQuery table name');
154
+ const op = node.operation;
155
+ if (!op) {
156
+ throw new Error('AlterTableQuery must have an operation');
157
+ }
158
+ switch (op.type) {
159
+ case 'ADD_COLUMN':
160
+ this.validateIdentifier(op.column.name, 'AlterTableQuery column name');
161
+ if (op.column.constraints.check) {
162
+ op.column.constraints.check.accept(this);
163
+ }
164
+ if (op.column.constraints.references) {
165
+ this.validateIdentifier(op.column.constraints.references.table, 'Foreign key reference table');
166
+ this.validateIdentifier(op.column.constraints.references.column, 'Foreign key reference column');
167
+ }
168
+ break;
169
+ case 'RENAME_COLUMN':
170
+ this.validateIdentifier(op.oldName, 'AlterTableQuery old column name');
171
+ this.validateIdentifier(op.newName, 'AlterTableQuery new column name');
172
+ break;
173
+ case 'DROP_COLUMN':
174
+ this.validateIdentifier(op.columnName, 'AlterTableQuery column name');
175
+ break;
176
+ case 'RENAME_TABLE':
177
+ this.validateIdentifier(op.newTableName, 'AlterTableQuery new table name');
178
+ break;
179
+ }
180
+ }
181
+ visitCreateTableQuery(node) {
182
+ this.validateIdentifier(node.tableName, 'CreateTableQuery');
183
+ if (node.columns.length === 0) {
184
+ throw new Error('CreateTableQuery must have at least one column');
185
+ }
186
+ const columnNames = new Set();
187
+ for (const col of node.columns) {
188
+ this.validateIdentifier(col.name, 'Column');
189
+ if (columnNames.has(col.name.toLowerCase())) {
190
+ throw new Error(`Duplicate column name '${col.name}' in CreateTableQuery`);
191
+ }
192
+ columnNames.add(col.name.toLowerCase());
193
+ // Validate check constraint expression
194
+ if (col.constraints.check) {
195
+ col.constraints.check.accept(this);
196
+ }
197
+ // Validate references table name
198
+ if (col.constraints.references) {
199
+ this.validateIdentifier(col.constraints.references.table, 'Foreign key reference table');
200
+ this.validateIdentifier(col.constraints.references.column, 'Foreign key reference column');
201
+ }
202
+ // Validate AUTOINCREMENT is only used with INTEGER PRIMARY KEY
203
+ if (col.constraints.autoIncrement && !col.constraints.primaryKey) {
204
+ throw new Error('AUTOINCREMENT can only be used with PRIMARY KEY');
205
+ }
206
+ if (col.constraints.autoIncrement && col.type !== 'INTEGER') {
207
+ throw new Error('AUTOINCREMENT can only be used with INTEGER type');
208
+ }
209
+ }
210
+ // Validate table constraints
211
+ for (const constraint of node.tableConstraints) {
212
+ if (constraint.name) {
213
+ this.validateIdentifier(constraint.name, 'Constraint name');
214
+ }
215
+ if (constraint.columns) {
216
+ for (const colName of constraint.columns) {
217
+ this.validateIdentifier(colName, 'Constraint column');
218
+ if (!columnNames.has(colName.toLowerCase())) {
219
+ throw new Error(`Constraint references unknown column '${colName}'`);
220
+ }
221
+ }
222
+ }
223
+ if (constraint.references) {
224
+ this.validateIdentifier(constraint.references.table, 'Foreign key reference table');
225
+ this.validateIdentifier(constraint.references.column, 'Foreign key reference column');
226
+ }
227
+ if (constraint.check) {
228
+ constraint.check.accept(this);
229
+ }
230
+ }
231
+ }
232
+ visitCreateVirtualTableQuery(node) {
233
+ this.validateIdentifier(node.tableName, 'CreateVirtualTableQuery');
234
+ // Virtual tables are database-specific, validated by dialect validators
235
+ // Basic validation: must have at least one column for FTS5
236
+ if (node.columns.length === 0) {
237
+ throw new Error('CreateVirtualTableQuery must have at least one column');
238
+ }
239
+ for (const col of node.columns) {
240
+ this.validateIdentifier(col, 'FTS5 column');
241
+ }
58
242
  }
59
243
  visitSelectQuery(node) {
60
244
  if (node['_columns'].length > 0 && node['_fromsAndJoins'].length === 0) {
@@ -94,6 +278,40 @@ class CommonQueryValidator {
94
278
  }
95
279
  }
96
280
  }
281
+ if (node['_intersect'].length > 0) {
282
+ if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {
283
+ throw new Error("A query with INTERSECT subqueries must have columns and a FROM clause in the main query");
284
+ }
285
+ let columnCounts = [];
286
+ if (node['_columns'].length > 0) {
287
+ columnCounts.push(node['_columns'].length);
288
+ }
289
+ columnCounts = columnCounts.concat(node['_intersect'].map(i => i['_columns'].length || 1));
290
+ if (columnCounts.length > 1) {
291
+ const firstCount = columnCounts[0];
292
+ if (columnCounts.some(count => count !== firstCount)) {
293
+ throw new Error('INTERSECT queries must have the same number of columns');
294
+ }
295
+ }
296
+ node['_intersect'].forEach(i => i.accept(this));
297
+ }
298
+ if (node['_except'].length > 0) {
299
+ if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {
300
+ throw new Error("A query with EXCEPT subqueries must have columns and a FROM clause in the main query");
301
+ }
302
+ let columnCounts = [];
303
+ if (node['_columns'].length > 0) {
304
+ columnCounts.push(node['_columns'].length);
305
+ }
306
+ columnCounts = columnCounts.concat(node['_except'].map(e => e['_columns'].length || 1));
307
+ if (columnCounts.length > 1) {
308
+ const firstCount = columnCounts[0];
309
+ if (columnCounts.some(count => count !== firstCount)) {
310
+ throw new Error('EXCEPT queries must have the same number of columns');
311
+ }
312
+ }
313
+ node['_except'].forEach(e => e.accept(this));
314
+ }
97
315
  node['_orderBy'].forEach(o => o.accept(this));
98
316
  if (node['_limit'] !== null && node['_limit'] !== undefined && node['_limit'] < 0) {
99
317
  throw new Error('LIMIT must be non-negative');
@@ -178,6 +396,20 @@ class CommonQueryValidator {
178
396
  node.left.accept(this);
179
397
  node.right.accept(this);
180
398
  }
399
+ visitBetweenExpression(node) {
400
+ if (!node.operand) {
401
+ throw new Error('BetweenExpression must have a valid operand');
402
+ }
403
+ if (!node.low) {
404
+ throw new Error('BetweenExpression must have a valid low bound');
405
+ }
406
+ if (!node.high) {
407
+ throw new Error('BetweenExpression must have a valid high bound');
408
+ }
409
+ node.operand.accept(this);
410
+ node.low.accept(this);
411
+ node.high.accept(this);
412
+ }
181
413
  visitUnaryExpression(node) {
182
414
  if (!node.operator) {
183
415
  throw new Error('UnaryExpression must have a valid operator');
@@ -225,6 +457,23 @@ class CommonQueryValidator {
225
457
  node.else.accept(this);
226
458
  }
227
459
  }
460
+ visitCastExpression(node) {
461
+ node.expression.accept(this);
462
+ }
463
+ visitCollateExpression(node) {
464
+ node.expression.accept(this);
465
+ }
466
+ visitSubqueryExpression(node) {
467
+ node.subquery.accept(this);
468
+ }
469
+ visitWindowExpression(node) {
470
+ // Validate the underlying function
471
+ node.function.accept(this);
472
+ // Validate partition by columns
473
+ node.windowSpec.partitionByColumns.forEach(c => c.accept(this));
474
+ // Validate order by clauses
475
+ node.windowSpec.orderByColumns.forEach(o => o.accept(this));
476
+ }
228
477
  visitFunctionExpression(node) {
229
478
  const noArgFunctions = ['RANDOM'];
230
479
  if (!noArgFunctions.includes(node.name) && node.args.length === 0) {
@@ -259,4 +508,4 @@ class CommonQueryValidator {
259
508
  }
260
509
  }
261
510
  exports.CommonQueryValidator = CommonQueryValidator;
262
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CommonQueryValidator.js","sourceRoot":"","sources":["../../src/validate/CommonQueryValidator.ts"],"names":[],"mappings":";;;AAAA,sDAA0D;AAI1D,0CAAuC;AAGvC,sCAA0E;AAI1E,sCAAmC;AAGnC,oDAAiD;AAGjD,sEAA8H;AAG9H,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC;IAChC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO;IACzE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK;IACtE,QAAQ,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM;IACxE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IACzE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;CACpD,CAAC,CAAC;AAEH,MAAa,oBAAoB;IAAjC;QACY,4BAAuB,GAAG,IAAI,mDAA8B,EAAQ,CAAC;QACrE,uBAAkB,GAAG,IAAI,8CAAyB,EAAQ,CAAC;QAE7D,gBAAW,GAAkB,IAAI,CAAC;QAClC,cAAS,GAAY,KAAK,CAAC;IAmQrC,CAAC;IAjQQ,QAAQ,CAAC,KAAgC;QAC9C,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAES,KAAK;QACb,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAEO,aAAa,CAAC,KAAyB,EAAE,OAAe;QAC9D,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,kBAAkB,OAAO,EAAE,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,KAAK,IAAI,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;YACxD,MAAM,IAAI,KAAK,CAAC,UAAU,KAAK,QAAQ,OAAO,+BAA+B,CAAC,CAAC;QACjF,CAAC;IACH,CAAC;IAEO,kBAAkB,CAAC,IAAY,EAAE,OAAe;QACtD,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CAAC,GAAG,OAAO,uBAAuB,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CAAC,GAAG,OAAO,UAAU,IAAI,gCAAgC,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,aAAa,CAAC,CAAC;QAC3D,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;QAClE,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC;YACvD,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;QACjF,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,oBAAoB,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvE,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAE7E,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACvE,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QAChD,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACzE,MAAM,IAAI,KAAK,CAAC,qFAAqF,CAAC,CAAC;YACzG,CAAC;YACD,IAAI,YAAY,GAAG,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAChC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,qBAAqB;YACnE,CAAC;YACD,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC;YACvF,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5B,MAAM,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;gBACnC,IAAI,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,UAAU,CAAC,EAAE,CAAC;oBACrD,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;gBACxE,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9C,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAClF,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACrF,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACjD,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,mCAAmC;IACnE,CAAC;IAED,cAAc,CAAC,IAAe;QAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IACvD,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,qBAAqB;QAC9C,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,uBAAuB;IACvD,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAmB,EAAE,QAAQ,CAAC,CAAC;QAC9D,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;IACrD,CAAC;IAED,UAAU,CAAC,IAAuC;QAChD,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QACtD,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,YAAY,WAAI,EAAE,CAAC;YAClC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACzC,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,YAAY,eAAM,EAAE,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC3C,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,YAAY,gBAAS,EAAE,CAAC;YAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAC9C,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,YAAY,mBAAY,EAAE,CAAC;YACjD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;QACjD,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,YAAY,mBAAY,EAAE,CAAC;YACjD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;QACjD,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,YAAY,kCAAmB,EAAE,CAAC;YACxD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACvB,CAAC;IAED,YAAY,CAAC,IAAa;QACxB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,qBAAqB;QAC9C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,uBAAuB;IACvD,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;QACrE,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;QACtE,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACvC,IAAI,IAAI,CAAC,MAAM,YAAY,yBAAW,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7B,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;YACpE,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACxB,IAAI,GAAG,CAAC,MAAM,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;oBACpC,MAAM,IAAI,KAAK,CAAC,uEAAuE,CAAC,CAAC;gBAC3F,CAAC;gBACD,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACtC,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACrB,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACpB,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED,uBAAuB,CAAC,IAAwB;QAC9C,MAAM,cAAc,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClE,MAAM,IAAI,KAAK,CAAC,YAAY,IAAI,CAAC,IAAI,iCAAiC,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACzC,CAAC;IAED,oBAAoB,CAAC,KAAY;QAC/B,gCAAgC;IAClC,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YACpD,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,KAAkB;QACjC,gCAAgC;IAClC,CAAC;IAED,qBAAqB,CAAC,IAAsB;QAC1C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,qBAAqB;QAC9C,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,uBAAuB;IACvD,CAAC;CACF;AAxQD,oDAwQC","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryValidator } from \"./QueryValidator\";\n\nconst RESERVED_KEYWORDS = new Set([\n  'SELECT', 'FROM', 'WHERE', 'JOIN', 'ON', 'GROUP', 'BY', 'HAVING', 'UNION',\n  'ORDER', 'LIMIT', 'OFFSET', 'TABLE', 'INDEX', 'VIEW', 'TRIGGER', 'KEY',\n  'COLUMN', 'CONSTRAINT', 'PRIMARY', 'FOREIGN', 'CHECK', 'DEFAULT', 'NULL',\n  'NOT', 'AND', 'OR', 'LIKE', 'IN', 'IS', 'BETWEEN', 'CASE', 'WHEN', 'THEN',\n  'ELSE', 'END', 'INSERT', 'INTO', 'VALUES', 'EXISTS'\n]);\n\nexport class CommonQueryValidator implements QueryValidator, SqlTreeNodeVisitor<void> {\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<void>();\n\n  private columnCount: number | null = null;\n  private isGrouped: boolean = false;\n\n  public validate(query: SelectQuery | InsertQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    this.columnCount = null;\n    this.isGrouped = false;\n  }\n\n  private validateAlias(alias: string | undefined, context: string): void {\n    if (alias && !alias.trim()) {\n      throw new Error(`Empty alias in ${context}`);\n    }\n    if (alias && RESERVED_KEYWORDS.has(alias.toUpperCase())) {\n      throw new Error(`Alias '${alias}' in ${context} is a reserved SQLite keyword`);\n    }\n  }\n\n  private validateIdentifier(name: string, context: string): void {\n    if (!name || !name.trim()) {\n      throw new Error(`${context} name cannot be empty`);\n    }\n    if (RESERVED_KEYWORDS.has(name.toUpperCase())) {\n      throw new Error(`${context} name '${name}' is a reserved SQLite keyword`);\n    }\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    this.validateIdentifier(node['_tableName'], 'InsertQuery');\n    if (node['_columns'].length === 0) {\n      throw new Error('InsertQuery must specify at least one column');\n    }\n    if (node['_columns'].length !== node['_values'].length) {\n      throw new Error('InsertQuery must have the same number of columns and values');\n    }\n    node['_columns'].forEach(col => this.validateIdentifier(col, 'InsertQuery column'));\n    node['_values'].forEach(val => val.accept(this));\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    if (node['_columns'].length > 0 && node['_fromsAndJoins'].length === 0) {\n      throw new Error('SELECT query with columns must have at least one FROM clause');\n    }\n\n    const prevCount = this.columnCount;\n    this.columnCount = node['_columns'].length > 0 ? node['_columns'].length : 1;\n\n    node['_with'].forEach(w => w.accept(this));\n    node['_fromsAndJoins'].forEach(item => this.fromLikeAndJoinAcceptor.accept(this, item));\n    node['_columns'].forEach(c => this.columnLikeAcceptor.accept(this, c));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    if (node['_groupBy'].length > 0) {\n      this.isGrouped = true;\n      node['_groupBy'].forEach(c => c.accept(this));\n    }\n    if (node['_having'] && !this.isGrouped) {\n      throw new Error('HAVING clause requires GROUP BY');\n    }\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    if (node['_union'].length > 0) {\n      if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {\n        throw new Error(\"A query with UNION subqueries must have columns and a FROM clause in the main query\");\n      }\n      let columnCounts = [];\n      if (node['_columns'].length > 0) {\n        columnCounts.push(node['_columns'].length); // Include main query\n      }\n      columnCounts = columnCounts.concat(node['_union'].map(u => u['_columns'].length || 1));\n      if (columnCounts.length > 1) {\n        const firstCount = columnCounts[0];\n        if (columnCounts.some(count => count !== firstCount)) {\n          throw new Error('UNION queries must have the same number of columns');\n        }\n      }\n    }\n    node['_orderBy'].forEach(o => o.accept(this));\n    if (node['_limit'] !== null && node['_limit'] !== undefined && node['_limit'] < 0) {\n      throw new Error('LIMIT must be non-negative');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && node['_offset'] < 0) {\n      throw new Error('OFFSET must be non-negative');\n    }\n\n    this.columnCount = prevCount; // Restore parent context if nested\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    this.validateIdentifier(node.tableName, 'TableFrom');\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): void {\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.subquery.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n  }\n\n  visitColumn(node: Column): void {\n    if (node.hasTableName()) {\n      this.validateIdentifier(node.tableName as string, 'Column');\n    }\n    this.validateIdentifier(node.columnName, 'Column');\n  }\n\n  visitAlias(node: Alias<From | AliasableExpression>): void {\n    if (!node.alias || !node.alias.trim()) {\n      throw new Error('Alias must have a non-empty name');\n    }\n    if (node.referent instanceof Join) {\n      this.validateAlias(node.alias, 'Join');\n    } else if (node.referent instanceof Column) {\n      this.validateAlias(node.alias, 'Column');\n    } else if (node.referent instanceof TableFrom) {\n      this.validateAlias(node.alias, 'TableFrom');\n    } else if (node.referent instanceof SubqueryFrom) {\n      this.validateAlias(node.alias, 'SubqueryFrom');\n    } else if (node.referent instanceof JsonEachFrom) {\n      this.validateAlias(node.alias, 'JsonEachFrom');\n    } else if (node.referent instanceof AliasableExpression) {\n      this.validateAlias(node.alias, 'Expression');\n    }\n    node.referent.accept(this);\n  }\n\n  visitJoinClause(node: Join): void {\n    this.validateIdentifier(node.tableName, 'JoinClause');\n    if (!node.on) {\n      throw new Error('JoinClause must have an ON condition');\n    }\n    node.on.accept(this);\n  }\n\n  visitOrderBy(node: OrderBy): void {\n    node.column.accept(this);\n  }\n\n  visitWithClause(node: With): void {\n    this.validateIdentifier(node.name, 'WithClause');\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.query.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n\n  visitBinaryExpression(node: BinaryExpression): void {\n    if (!node.operator) {\n      throw new Error('BinaryExpression must have a valid operator');\n    }\n    if (!node.left) {\n      throw new Error('BinaryExpression must have a valid left operand');\n    }\n    if (!node.right) {\n      throw new Error('BinaryExpression must have a valid right operand');\n    }\n    node.left.accept(this);\n    node.right.accept(this);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!node.operator) {\n      throw new Error('UnaryExpression must have a valid operator');\n    }\n    if (!node.operand) {\n      throw new Error('UnaryExpression must have a valid operand');\n    }\n    node.operand.accept(this);\n  }\n\n  visitInExpression(node: InExpression): void {\n    if (node.left.length === 0) {\n      throw new Error('IN expression must have at least one left expression');\n    }\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      if (node.values.length === 0) {\n        throw new Error('IN expression must have at least one value set');\n      }\n      node.values.forEach(set => {\n        if (set.length !== node.left.length) {\n          throw new Error('Value sets in IN expression must match the number of left expressions');\n        }\n        set.forEach(v => v.accept(this));\n      });\n    }\n  }\n\n  visitConcat(node: Concat): void {\n    if (node.expressions.length < 2) {\n      throw new Error('Concat must have at least two expressions');\n    }\n    node.expressions.forEach(e => e.accept(this));\n  }\n\n  visitCaseExpression(node: CaseExpression): void {\n    if (node.cases.length === 0) {\n      throw new Error('CaseExpression must have at least one WHEN/THEN pair');\n    }\n    node.cases.forEach(c => {\n      c.when.accept(this);\n      c.then.accept(this);\n    });\n    if (node.else) {\n      node.else.accept(this);\n    }\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    const noArgFunctions = ['RANDOM'];\n    if (!noArgFunctions.includes(node.name) && node.args.length === 0) {\n      throw new Error(`Function ${node.name} requires at least one argument`);\n    }\n    node.args.forEach(a => a.accept(this));\n  }\n\n  visitParamExpression(_node: Param): void {\n    // No specific validation needed\n  }\n\n  visitStringLiteral(node: StringLiteral): void {\n    if (node.value === null || node.value === undefined) {\n      throw new Error('StringLiteral value cannot be null or undefined');\n    }\n  }\n\n  visitNumberLiteral(node: NumberLiteral): void {\n    if (isNaN(node.value)) {\n      throw new Error('NumberLiteral value must be a valid number');\n    }\n  }\n\n  visitNullLiteral(_node: NullLiteral): void {\n    // No specific validation needed\n  }\n\n  visitExistsExpression(node: ExistsExpression): void {\n    if (!node.subquery) {\n      throw new Error('ExistsExpression must have a valid subquery');\n    }\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.subquery.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n}\n"]}
511
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CommonQueryValidator.js","sourceRoot":"","sources":["../../src/validate/CommonQueryValidator.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { BetweenExpression } from \"../ast/BetweenExpression\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { CastExpression } from \"../ast/CastExpression\";\nimport { CollateExpression } from \"../ast/CollateExpression\";\nimport { SubqueryExpression } from \"../ast/SubqueryExpression\";\nimport { WindowExpression } from \"../ast/WindowExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery } from \"../ast/CreateTableQuery\";\nimport { CreateVirtualTableQuery } from \"../ast/CreateVirtualTableQuery\";\nimport { CreateViewQuery } from \"../ast/CreateViewQuery\";\nimport { DeleteQuery } from \"../ast/DeleteQuery\";\nimport { DropIndexQuery } from \"../ast/DropIndexQuery\";\nimport { DropTableQuery } from \"../ast/DropTableQuery\";\nimport { DropViewQuery } from \"../ast/DropViewQuery\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryValidator } from \"./QueryValidator\";\n\nconst RESERVED_KEYWORDS = new Set([\n  'SELECT', 'FROM', 'WHERE', 'JOIN', 'ON', 'GROUP', 'BY', 'HAVING', 'UNION',\n  'ORDER', 'LIMIT', 'OFFSET', 'TABLE', 'INDEX', 'VIEW', 'TRIGGER', 'KEY',\n  'COLUMN', 'CONSTRAINT', 'PRIMARY', 'FOREIGN', 'CHECK', 'DEFAULT', 'NULL',\n  'NOT', 'AND', 'OR', 'LIKE', 'IN', 'IS', 'BETWEEN', 'CASE', 'WHEN', 'THEN',\n  'ELSE', 'END', 'INSERT', 'INTO', 'VALUES', 'EXISTS'\n]);\n\nexport class CommonQueryValidator implements QueryValidator, SqlTreeNodeVisitor<void> {\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<void>();\n\n  private columnCount: number | null = null;\n  private isGrouped: boolean = false;\n\n  public validate(query: SelectQuery | InsertQuery | UpdateQuery | DeleteQuery | CreateTableQuery | CreateVirtualTableQuery | CreateIndexQuery | CreateViewQuery | AlterTableQuery | DropTableQuery | DropIndexQuery | DropViewQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    this.columnCount = null;\n    this.isGrouped = false;\n  }\n\n  private validateAlias(alias: string | undefined, context: string): void {\n    if (alias && !alias.trim()) {\n      throw new Error(`Empty alias in ${context}`);\n    }\n    if (alias && RESERVED_KEYWORDS.has(alias.toUpperCase())) {\n      throw new Error(`Alias '${alias}' in ${context} is a reserved SQLite keyword`);\n    }\n  }\n\n  private validateIdentifier(name: string, context: string): void {\n    if (!name || !name.trim()) {\n      throw new Error(`${context} name cannot be empty`);\n    }\n    if (RESERVED_KEYWORDS.has(name.toUpperCase())) {\n      throw new Error(`${context} name '${name}' is a reserved SQLite keyword`);\n    }\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    this.validateIdentifier(node['_tableName'], 'InsertQuery');\n    if (node['_columns'].length === 0) {\n      throw new Error('InsertQuery must specify at least one column');\n    }\n    if (node['_fromSelect']) {\n      // INSERT ... SELECT - validate the subquery\n      if (node['_values'].length > 0) {\n        throw new Error('InsertQuery cannot have both VALUES and SELECT');\n      }\n      node['_fromSelect'].accept(this);\n    } else {\n      // INSERT ... VALUES - validate column/value count match\n      if (node['_columns'].length !== node['_values'].length) {\n        throw new Error('InsertQuery must have the same number of columns and values');\n      }\n      node['_values'].forEach(val => val.accept(this));\n    }\n    node['_columns'].forEach(col => this.validateIdentifier(col, 'InsertQuery column'));\n    // Validate ON CONFLICT clause\n    if (node['_onConflictColumns'].length > 0) {\n      // Cannot use both OR REPLACE and ON CONFLICT\n      if (node['_orReplace']) {\n        throw new Error('InsertQuery cannot use both OR REPLACE and ON CONFLICT');\n      }\n      // Must have either DO UPDATE or DO NOTHING\n      if (!node['_doNothing'] && node['_doUpdateSets'].length === 0) {\n        throw new Error('ON CONFLICT must specify either DO UPDATE or DO NOTHING');\n      }\n      // Cannot have both DO UPDATE and DO NOTHING\n      if (node['_doNothing'] && node['_doUpdateSets'].length > 0) {\n        throw new Error('ON CONFLICT cannot have both DO UPDATE and DO NOTHING');\n      }\n      node['_onConflictColumns'].forEach(col => this.validateIdentifier(col, 'ON CONFLICT column'));\n      node['_doUpdateSets'].forEach(s => {\n        this.validateIdentifier(s.column, 'DO UPDATE column');\n        s.value.accept(this);\n      });\n      if (node['_onConflictWhere']) {\n        node['_onConflictWhere'].accept(this);\n      }\n    } else {\n      // If no conflict columns but has DO UPDATE or DO NOTHING, that's an error\n      if (node['_doNothing'] || node['_doUpdateSets'].length > 0) {\n        throw new Error('DO UPDATE or DO NOTHING requires ON CONFLICT columns');\n      }\n    }\n    node['_returning'].forEach(r => r.accept(this));\n  }\n\n  visitDeleteQuery(node: DeleteQuery): void {\n    this.validateIdentifier(node['_tableName'], 'DeleteQuery');\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n  }\n\n  visitUpdateQuery(node: UpdateQuery): void {\n    this.validateIdentifier(node['_tableName'], 'UpdateQuery');\n    if (node['_set'].length === 0) {\n      throw new Error('UpdateQuery must have at least one SET clause');\n    }\n    node['_set'].forEach(s => {\n      this.validateIdentifier(s.column, 'UpdateQuery column');\n      s.value.accept(this);\n    });\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n  }\n\n  visitDropTableQuery(node: DropTableQuery): void {\n    this.validateIdentifier(node.tableName, 'DropTableQuery');\n  }\n\n  visitDropIndexQuery(node: DropIndexQuery): void {\n    this.validateIdentifier(node.indexName, 'DropIndexQuery');\n  }\n\n  visitDropViewQuery(node: DropViewQuery): void {\n    this.validateIdentifier(node.viewName, 'DropViewQuery');\n  }\n\n  visitCreateViewQuery(node: CreateViewQuery): void {\n    this.validateIdentifier(node.viewName, 'CreateViewQuery view name');\n\n    for (const col of node.columns) {\n      this.validateIdentifier(col, 'CreateViewQuery column name');\n    }\n\n    if (!node.selectQuery) {\n      throw new Error('CreateViewQuery must have a SELECT query');\n    }\n\n    node.selectQuery.accept(this);\n  }\n\n  visitCreateIndexQuery(node: CreateIndexQuery): void {\n    this.validateIdentifier(node.indexName, 'CreateIndexQuery index name');\n    this.validateIdentifier(node.tableName, 'CreateIndexQuery table name');\n\n    if (node.columns.length === 0) {\n      throw new Error('CreateIndexQuery must have at least one column');\n    }\n\n    for (const col of node.columns) {\n      this.validateIdentifier(col, 'CreateIndexQuery column');\n    }\n\n    if (node.whereExpression) {\n      node.whereExpression.accept(this);\n    }\n  }\n\n  visitAlterTableQuery(node: AlterTableQuery): void {\n    this.validateIdentifier(node.tableName, 'AlterTableQuery table name');\n\n    const op = node.operation;\n    if (!op) {\n      throw new Error('AlterTableQuery must have an operation');\n    }\n\n    switch (op.type) {\n      case 'ADD_COLUMN':\n        this.validateIdentifier(op.column.name, 'AlterTableQuery column name');\n        if (op.column.constraints.check) {\n          op.column.constraints.check.accept(this);\n        }\n        if (op.column.constraints.references) {\n          this.validateIdentifier(op.column.constraints.references.table, 'Foreign key reference table');\n          this.validateIdentifier(op.column.constraints.references.column, 'Foreign key reference column');\n        }\n        break;\n      case 'RENAME_COLUMN':\n        this.validateIdentifier(op.oldName, 'AlterTableQuery old column name');\n        this.validateIdentifier(op.newName, 'AlterTableQuery new column name');\n        break;\n      case 'DROP_COLUMN':\n        this.validateIdentifier(op.columnName, 'AlterTableQuery column name');\n        break;\n      case 'RENAME_TABLE':\n        this.validateIdentifier(op.newTableName, 'AlterTableQuery new table name');\n        break;\n    }\n  }\n\n  visitCreateTableQuery(node: CreateTableQuery): void {\n    this.validateIdentifier(node.tableName, 'CreateTableQuery');\n\n    if (node.columns.length === 0) {\n      throw new Error('CreateTableQuery must have at least one column');\n    }\n\n    const columnNames = new Set<string>();\n    for (const col of node.columns) {\n      this.validateIdentifier(col.name, 'Column');\n      if (columnNames.has(col.name.toLowerCase())) {\n        throw new Error(`Duplicate column name '${col.name}' in CreateTableQuery`);\n      }\n      columnNames.add(col.name.toLowerCase());\n\n      // Validate check constraint expression\n      if (col.constraints.check) {\n        col.constraints.check.accept(this);\n      }\n\n      // Validate references table name\n      if (col.constraints.references) {\n        this.validateIdentifier(col.constraints.references.table, 'Foreign key reference table');\n        this.validateIdentifier(col.constraints.references.column, 'Foreign key reference column');\n      }\n\n      // Validate AUTOINCREMENT is only used with INTEGER PRIMARY KEY\n      if (col.constraints.autoIncrement && !col.constraints.primaryKey) {\n        throw new Error('AUTOINCREMENT can only be used with PRIMARY KEY');\n      }\n      if (col.constraints.autoIncrement && col.type !== 'INTEGER') {\n        throw new Error('AUTOINCREMENT can only be used with INTEGER type');\n      }\n    }\n\n    // Validate table constraints\n    for (const constraint of node.tableConstraints) {\n      if (constraint.name) {\n        this.validateIdentifier(constraint.name, 'Constraint name');\n      }\n\n      if (constraint.columns) {\n        for (const colName of constraint.columns) {\n          this.validateIdentifier(colName, 'Constraint column');\n          if (!columnNames.has(colName.toLowerCase())) {\n            throw new Error(`Constraint references unknown column '${colName}'`);\n          }\n        }\n      }\n\n      if (constraint.references) {\n        this.validateIdentifier(constraint.references.table, 'Foreign key reference table');\n        this.validateIdentifier(constraint.references.column, 'Foreign key reference column');\n      }\n\n      if (constraint.check) {\n        constraint.check.accept(this);\n      }\n    }\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): void {\n    this.validateIdentifier(node.tableName, 'CreateVirtualTableQuery');\n    // Virtual tables are database-specific, validated by dialect validators\n    // Basic validation: must have at least one column for FTS5\n    if (node.columns.length === 0) {\n      throw new Error('CreateVirtualTableQuery must have at least one column');\n    }\n    for (const col of node.columns) {\n      this.validateIdentifier(col, 'FTS5 column');\n    }\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    if (node['_columns'].length > 0 && node['_fromsAndJoins'].length === 0) {\n      throw new Error('SELECT query with columns must have at least one FROM clause');\n    }\n\n    const prevCount = this.columnCount;\n    this.columnCount = node['_columns'].length > 0 ? node['_columns'].length : 1;\n\n    node['_with'].forEach(w => w.accept(this));\n    node['_fromsAndJoins'].forEach(item => this.fromLikeAndJoinAcceptor.accept(this, item));\n    node['_columns'].forEach(c => this.columnLikeAcceptor.accept(this, c));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    if (node['_groupBy'].length > 0) {\n      this.isGrouped = true;\n      node['_groupBy'].forEach(c => c.accept(this));\n    }\n    if (node['_having'] && !this.isGrouped) {\n      throw new Error('HAVING clause requires GROUP BY');\n    }\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    if (node['_union'].length > 0) {\n      if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {\n        throw new Error(\"A query with UNION subqueries must have columns and a FROM clause in the main query\");\n      }\n      let columnCounts = [];\n      if (node['_columns'].length > 0) {\n        columnCounts.push(node['_columns'].length); // Include main query\n      }\n      columnCounts = columnCounts.concat(node['_union'].map(u => u['_columns'].length || 1));\n      if (columnCounts.length > 1) {\n        const firstCount = columnCounts[0];\n        if (columnCounts.some(count => count !== firstCount)) {\n          throw new Error('UNION queries must have the same number of columns');\n        }\n      }\n    }\n    if (node['_intersect'].length > 0) {\n      if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {\n        throw new Error(\"A query with INTERSECT subqueries must have columns and a FROM clause in the main query\");\n      }\n      let columnCounts = [];\n      if (node['_columns'].length > 0) {\n        columnCounts.push(node['_columns'].length);\n      }\n      columnCounts = columnCounts.concat(node['_intersect'].map(i => i['_columns'].length || 1));\n      if (columnCounts.length > 1) {\n        const firstCount = columnCounts[0];\n        if (columnCounts.some(count => count !== firstCount)) {\n          throw new Error('INTERSECT queries must have the same number of columns');\n        }\n      }\n      node['_intersect'].forEach(i => i.accept(this));\n    }\n    if (node['_except'].length > 0) {\n      if (node['_columns'].length === 0 && node['_fromsAndJoins'].length === 0) {\n        throw new Error(\"A query with EXCEPT subqueries must have columns and a FROM clause in the main query\");\n      }\n      let columnCounts = [];\n      if (node['_columns'].length > 0) {\n        columnCounts.push(node['_columns'].length);\n      }\n      columnCounts = columnCounts.concat(node['_except'].map(e => e['_columns'].length || 1));\n      if (columnCounts.length > 1) {\n        const firstCount = columnCounts[0];\n        if (columnCounts.some(count => count !== firstCount)) {\n          throw new Error('EXCEPT queries must have the same number of columns');\n        }\n      }\n      node['_except'].forEach(e => e.accept(this));\n    }\n    node['_orderBy'].forEach(o => o.accept(this));\n    if (node['_limit'] !== null && node['_limit'] !== undefined && node['_limit'] < 0) {\n      throw new Error('LIMIT must be non-negative');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && node['_offset'] < 0) {\n      throw new Error('OFFSET must be non-negative');\n    }\n\n    this.columnCount = prevCount; // Restore parent context if nested\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    this.validateIdentifier(node.tableName, 'TableFrom');\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): void {\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.subquery.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n  }\n\n  visitColumn(node: Column): void {\n    if (node.hasTableName()) {\n      this.validateIdentifier(node.tableName as string, 'Column');\n    }\n    this.validateIdentifier(node.columnName, 'Column');\n  }\n\n  visitAlias(node: Alias<From | AliasableExpression>): void {\n    if (!node.alias || !node.alias.trim()) {\n      throw new Error('Alias must have a non-empty name');\n    }\n    if (node.referent instanceof Join) {\n      this.validateAlias(node.alias, 'Join');\n    } else if (node.referent instanceof Column) {\n      this.validateAlias(node.alias, 'Column');\n    } else if (node.referent instanceof TableFrom) {\n      this.validateAlias(node.alias, 'TableFrom');\n    } else if (node.referent instanceof SubqueryFrom) {\n      this.validateAlias(node.alias, 'SubqueryFrom');\n    } else if (node.referent instanceof JsonEachFrom) {\n      this.validateAlias(node.alias, 'JsonEachFrom');\n    } else if (node.referent instanceof AliasableExpression) {\n      this.validateAlias(node.alias, 'Expression');\n    }\n    node.referent.accept(this);\n  }\n\n  visitJoinClause(node: Join): void {\n    this.validateIdentifier(node.tableName, 'JoinClause');\n    if (!node.on) {\n      throw new Error('JoinClause must have an ON condition');\n    }\n    node.on.accept(this);\n  }\n\n  visitOrderBy(node: OrderBy): void {\n    node.column.accept(this);\n  }\n\n  visitWithClause(node: With): void {\n    this.validateIdentifier(node.name, 'WithClause');\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.query.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n\n  visitBinaryExpression(node: BinaryExpression): void {\n    if (!node.operator) {\n      throw new Error('BinaryExpression must have a valid operator');\n    }\n    if (!node.left) {\n      throw new Error('BinaryExpression must have a valid left operand');\n    }\n    if (!node.right) {\n      throw new Error('BinaryExpression must have a valid right operand');\n    }\n    node.left.accept(this);\n    node.right.accept(this);\n  }\n\n  visitBetweenExpression(node: BetweenExpression): void {\n    if (!node.operand) {\n      throw new Error('BetweenExpression must have a valid operand');\n    }\n    if (!node.low) {\n      throw new Error('BetweenExpression must have a valid low bound');\n    }\n    if (!node.high) {\n      throw new Error('BetweenExpression must have a valid high bound');\n    }\n    node.operand.accept(this);\n    node.low.accept(this);\n    node.high.accept(this);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!node.operator) {\n      throw new Error('UnaryExpression must have a valid operator');\n    }\n    if (!node.operand) {\n      throw new Error('UnaryExpression must have a valid operand');\n    }\n    node.operand.accept(this);\n  }\n\n  visitInExpression(node: InExpression): void {\n    if (node.left.length === 0) {\n      throw new Error('IN expression must have at least one left expression');\n    }\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      if (node.values.length === 0) {\n        throw new Error('IN expression must have at least one value set');\n      }\n      node.values.forEach(set => {\n        if (set.length !== node.left.length) {\n          throw new Error('Value sets in IN expression must match the number of left expressions');\n        }\n        set.forEach(v => v.accept(this));\n      });\n    }\n  }\n\n  visitConcat(node: Concat): void {\n    if (node.expressions.length < 2) {\n      throw new Error('Concat must have at least two expressions');\n    }\n    node.expressions.forEach(e => e.accept(this));\n  }\n\n  visitCaseExpression(node: CaseExpression): void {\n    if (node.cases.length === 0) {\n      throw new Error('CaseExpression must have at least one WHEN/THEN pair');\n    }\n    node.cases.forEach(c => {\n      c.when.accept(this);\n      c.then.accept(this);\n    });\n    if (node.else) {\n      node.else.accept(this);\n    }\n  }\n\n  visitCastExpression(node: CastExpression): void {\n    node.expression.accept(this);\n  }\n\n  visitCollateExpression(node: CollateExpression): void {\n    node.expression.accept(this);\n  }\n\n  visitSubqueryExpression(node: SubqueryExpression): void {\n    node.subquery.accept(this);\n  }\n\n  visitWindowExpression(node: WindowExpression): void {\n    // Validate the underlying function\n    node.function.accept(this);\n    // Validate partition by columns\n    node.windowSpec.partitionByColumns.forEach(c => c.accept(this));\n    // Validate order by clauses\n    node.windowSpec.orderByColumns.forEach(o => o.accept(this));\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    const noArgFunctions = ['RANDOM'];\n    if (!noArgFunctions.includes(node.name) && node.args.length === 0) {\n      throw new Error(`Function ${node.name} requires at least one argument`);\n    }\n    node.args.forEach(a => a.accept(this));\n  }\n\n  visitParamExpression(_node: Param): void {\n    // No specific validation needed\n  }\n\n  visitStringLiteral(node: StringLiteral): void {\n    if (node.value === null || node.value === undefined) {\n      throw new Error('StringLiteral value cannot be null or undefined');\n    }\n  }\n\n  visitNumberLiteral(node: NumberLiteral): void {\n    if (isNaN(node.value)) {\n      throw new Error('NumberLiteral value must be a valid number');\n    }\n  }\n\n  visitNullLiteral(_node: NullLiteral): void {\n    // No specific validation needed\n  }\n\n  visitExistsExpression(node: ExistsExpression): void {\n    if (!node.subquery) {\n      throw new Error('ExistsExpression must have a valid subquery');\n    }\n    const prevCount = this.columnCount;\n    this.columnCount = null; // Reset for subquery\n    node.subquery.accept(this);\n    this.columnCount = prevCount; // Restore parent count\n  }\n}\n"]}
@@ -1,6 +1,15 @@
1
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
2
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
3
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
4
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
5
+ import { DeleteQuery } from "../ast/DeleteQuery";
6
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
7
+ import { DropTableQuery } from "../ast/DropTableQuery";
8
+ import { DropViewQuery } from "../ast/DropViewQuery";
1
9
  import { InsertQuery } from "../ast/InsertQuery";
10
+ import { UpdateQuery } from "../ast/UpdateQuery";
2
11
  import { SelectQuery } from "../ast/SelectQuery";
3
12
  import { SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
4
13
  export interface QueryValidator extends SqlTreeNodeVisitor<void> {
5
- validate(node: SelectQuery | InsertQuery): void;
14
+ validate(node: SelectQuery | InsertQuery | UpdateQuery | DeleteQuery | CreateTableQuery | CreateIndexQuery | CreateViewQuery | AlterTableQuery | DropTableQuery | DropIndexQuery | DropViewQuery): void;
6
15
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUXVlcnlWYWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdmFsaWRhdGUvUXVlcnlWYWxpZGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluc2VydFF1ZXJ5IH0gZnJvbSBcIi4uL2FzdC9JbnNlcnRRdWVyeVwiO1xuaW1wb3J0IHsgU2VsZWN0UXVlcnkgfSBmcm9tIFwiLi4vYXN0L1NlbGVjdFF1ZXJ5XCI7XG5pbXBvcnQgeyBTcWxUcmVlTm9kZVZpc2l0b3IgfSBmcm9tIFwiLi4vdmlzaXRvci9TcWxUcmVlTm9kZVZpc2l0b3JcIjtcblxuZXhwb3J0IGludGVyZmFjZSBRdWVyeVZhbGlkYXRvciBleHRlbmRzIFNxbFRyZWVOb2RlVmlzaXRvcjx2b2lkPiB7XG4gIHZhbGlkYXRlKG5vZGU6IFNlbGVjdFF1ZXJ5IHwgSW5zZXJ0UXVlcnkpOiB2b2lkO1xufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUXVlcnlWYWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdmFsaWRhdGUvUXVlcnlWYWxpZGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFsdGVyVGFibGVRdWVyeSB9IGZyb20gXCIuLi9hc3QvQWx0ZXJUYWJsZVF1ZXJ5XCI7XG5pbXBvcnQgeyBDcmVhdGVJbmRleFF1ZXJ5IH0gZnJvbSBcIi4uL2FzdC9DcmVhdGVJbmRleFF1ZXJ5XCI7XG5pbXBvcnQgeyBDcmVhdGVUYWJsZVF1ZXJ5IH0gZnJvbSBcIi4uL2FzdC9DcmVhdGVUYWJsZVF1ZXJ5XCI7XG5pbXBvcnQgeyBDcmVhdGVWaWV3UXVlcnkgfSBmcm9tIFwiLi4vYXN0L0NyZWF0ZVZpZXdRdWVyeVwiO1xuaW1wb3J0IHsgRGVsZXRlUXVlcnkgfSBmcm9tIFwiLi4vYXN0L0RlbGV0ZVF1ZXJ5XCI7XG5pbXBvcnQgeyBEcm9wSW5kZXhRdWVyeSB9IGZyb20gXCIuLi9hc3QvRHJvcEluZGV4UXVlcnlcIjtcbmltcG9ydCB7IERyb3BUYWJsZVF1ZXJ5IH0gZnJvbSBcIi4uL2FzdC9Ecm9wVGFibGVRdWVyeVwiO1xuaW1wb3J0IHsgRHJvcFZpZXdRdWVyeSB9IGZyb20gXCIuLi9hc3QvRHJvcFZpZXdRdWVyeVwiO1xuaW1wb3J0IHsgSW5zZXJ0UXVlcnkgfSBmcm9tIFwiLi4vYXN0L0luc2VydFF1ZXJ5XCI7XG5pbXBvcnQgeyBVcGRhdGVRdWVyeSB9IGZyb20gXCIuLi9hc3QvVXBkYXRlUXVlcnlcIjtcbmltcG9ydCB7IFNlbGVjdFF1ZXJ5IH0gZnJvbSBcIi4uL2FzdC9TZWxlY3RRdWVyeVwiO1xuaW1wb3J0IHsgU3FsVHJlZU5vZGVWaXNpdG9yIH0gZnJvbSBcIi4uL3Zpc2l0b3IvU3FsVHJlZU5vZGVWaXNpdG9yXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUXVlcnlWYWxpZGF0b3IgZXh0ZW5kcyBTcWxUcmVlTm9kZVZpc2l0b3I8dm9pZD4ge1xuICB2YWxpZGF0ZShub2RlOiBTZWxlY3RRdWVyeSB8IEluc2VydFF1ZXJ5IHwgVXBkYXRlUXVlcnkgfCBEZWxldGVRdWVyeSB8IENyZWF0ZVRhYmxlUXVlcnkgfCBDcmVhdGVJbmRleFF1ZXJ5IHwgQ3JlYXRlVmlld1F1ZXJ5IHwgQWx0ZXJUYWJsZVF1ZXJ5IHwgRHJvcFRhYmxlUXVlcnkgfCBEcm9wSW5kZXhRdWVyeSB8IERyb3BWaWV3UXVlcnkpOiB2b2lkO1xufVxuIl19
@@ -1,4 +1,14 @@
1
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
2
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
3
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
4
+ import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
5
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
6
+ import { DeleteQuery } from "../ast/DeleteQuery";
7
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
8
+ import { DropTableQuery } from "../ast/DropTableQuery";
9
+ import { DropViewQuery } from "../ast/DropViewQuery";
1
10
  import { JsonEachFrom, TableFrom } from "../ast/From";
11
+ import { UpdateQuery } from "../ast/UpdateQuery";
2
12
  import { FunctionExpression } from "../ast/FunctionExpression";
3
13
  import { InExpression } from "../ast/InExpression";
4
14
  import { InsertQuery } from "../ast/InsertQuery";
@@ -9,13 +19,16 @@ import { With } from "../ast/With";
9
19
  import { SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
10
20
  import { CommonQueryValidator } from "./CommonQueryValidator";
11
21
  import { QueryValidator } from "./QueryValidator";
22
+ type ValidatableQuery = SelectQuery | InsertQuery | UpdateQuery | DeleteQuery | CreateTableQuery | CreateVirtualTableQuery | CreateIndexQuery | CreateViewQuery | AlterTableQuery | DropTableQuery | DropIndexQuery | DropViewQuery;
12
23
  export declare class SQLiteQueryValidator extends CommonQueryValidator implements QueryValidator, SqlTreeNodeVisitor<void> {
13
24
  private supportedFunctions;
14
25
  private supportedUnaryOperators;
15
26
  private isWithRecursive;
16
- validate(query: SelectQuery | InsertQuery): void;
27
+ validate(query: ValidatableQuery): void;
17
28
  protected reset(): void;
18
29
  visitInsertQuery(node: InsertQuery): void;
30
+ visitDeleteQuery(node: DeleteQuery): void;
31
+ visitUpdateQuery(node: UpdateQuery): void;
19
32
  visitSelectQuery(node: SelectQuery): void;
20
33
  visitJoinClause(node: Join): void;
21
34
  visitWithClause(node: With): void;
@@ -24,4 +37,6 @@ export declare class SQLiteQueryValidator extends CommonQueryValidator implement
24
37
  visitJsonEachFrom(node: JsonEachFrom): void;
25
38
  visitUnaryExpression(node: UnaryExpression): void;
26
39
  visitInExpression(node: InExpression): void;
40
+ visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): void;
27
41
  }
42
+ export {};