@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.
- package/README.md +289 -1
- package/dist/ast/AlterTableQuery.d.ts +32 -0
- package/dist/ast/AlterTableQuery.js +60 -0
- package/dist/ast/BetweenExpression.d.ts +10 -0
- package/dist/ast/BetweenExpression.js +18 -0
- package/dist/ast/CastExpression.d.ts +13 -0
- package/dist/ast/CastExpression.js +25 -0
- package/dist/ast/CollateExpression.d.ts +18 -0
- package/dist/ast/CollateExpression.js +30 -0
- package/dist/ast/CreateIndexQuery.d.ts +25 -0
- package/dist/ast/CreateIndexQuery.js +64 -0
- package/dist/ast/CreateTableQuery.d.ts +57 -0
- package/dist/ast/CreateTableQuery.js +79 -0
- package/dist/ast/CreateViewQuery.d.ts +34 -0
- package/dist/ast/CreateViewQuery.js +61 -0
- package/dist/ast/CreateVirtualTableQuery.d.ts +32 -0
- package/dist/ast/CreateVirtualTableQuery.js +74 -0
- package/dist/ast/DeleteQuery.d.ts +17 -0
- package/dist/ast/DeleteQuery.js +43 -0
- package/dist/ast/DropIndexQuery.d.ts +14 -0
- package/dist/ast/DropIndexQuery.js +35 -0
- package/dist/ast/DropTableQuery.d.ts +14 -0
- package/dist/ast/DropTableQuery.js +35 -0
- package/dist/ast/DropViewQuery.d.ts +11 -0
- package/dist/ast/DropViewQuery.js +24 -0
- package/dist/ast/FunctionExpression.d.ts +21 -0
- package/dist/ast/FunctionExpression.js +40 -1
- package/dist/ast/FunctionName.d.ts +1 -1
- package/dist/ast/FunctionName.js +1 -1
- package/dist/ast/InsertQuery.d.ts +24 -1
- package/dist/ast/InsertQuery.js +49 -1
- package/dist/ast/Operator.d.ts +2 -0
- package/dist/ast/Operator.js +3 -1
- package/dist/ast/SelectQuery.d.ts +4 -0
- package/dist/ast/SelectQuery.js +11 -1
- package/dist/ast/SubqueryExpression.d.ts +18 -0
- package/dist/ast/SubqueryExpression.js +27 -0
- package/dist/ast/UpdateQuery.d.ts +24 -0
- package/dist/ast/UpdateQuery.js +51 -0
- package/dist/ast/WindowExpression.d.ts +51 -0
- package/dist/ast/WindowExpression.js +61 -0
- package/dist/ast/WindowSpecification.d.ts +46 -0
- package/dist/ast/WindowSpecification.js +60 -0
- package/dist/builder/QueryBuilder.d.ts +20 -0
- package/dist/builder/QueryBuilder.js +41 -1
- package/dist/builder/Shorthand.d.ts +51 -0
- package/dist/builder/Shorthand.js +125 -1
- package/dist/index.d.ts +17 -1
- package/dist/index.js +59 -3
- package/dist/renderer/CompactQueryRenderer.d.ts +34 -2
- package/dist/renderer/CompactQueryRenderer.js +272 -2
- package/dist/renderer/IndentedQueryRenderer.d.ts +34 -2
- package/dist/renderer/IndentedQueryRenderer.js +289 -3
- package/dist/renderer/QueryRenderer.d.ts +11 -1
- package/dist/renderer/QueryRenderer.js +1 -1
- package/dist/validate/CommonQueryValidator.d.ts +31 -1
- package/dist/validate/CommonQueryValidator.js +253 -4
- package/dist/validate/QueryValidator.d.ts +10 -1
- package/dist/validate/QueryValidator.js +1 -1
- package/dist/validate/SQLiteQueryValidator.d.ts +16 -1
- package/dist/validate/SQLiteQueryValidator.js +32 -3
- package/dist/visitor/ParamCollector.d.ts +30 -0
- package/dist/visitor/ParamCollector.js +109 -2
- package/dist/visitor/QueryIdentityTransformer.d.ts +30 -0
- package/dist/visitor/QueryIdentityTransformer.js +217 -2
- package/dist/visitor/SqlTreeNodeVisitor.d.ts +30 -0
- package/dist/visitor/SqlTreeNodeVisitor.js +1 -1
- package/package.json +4 -1
|
@@ -13,7 +13,7 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
|
|
|
13
13
|
'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',
|
|
14
14
|
'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',
|
|
15
15
|
'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',
|
|
16
|
-
'LAST_INSERT_ROWID',
|
|
16
|
+
'LAST_INSERT_ROWID', 'CONCAT',
|
|
17
17
|
// Aggregate functions
|
|
18
18
|
'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',
|
|
19
19
|
// Date and time functions
|
|
@@ -22,7 +22,13 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
|
|
|
22
22
|
'json', 'json_array', 'json_object', 'json_extract', 'json_insert',
|
|
23
23
|
'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',
|
|
24
24
|
'json_quote', 'json_patch', 'json_array_length', 'json_group_array',
|
|
25
|
-
'json_group_object', 'json_each', 'json_tree'
|
|
25
|
+
'json_group_object', 'json_each', 'json_tree',
|
|
26
|
+
// Window functions
|
|
27
|
+
'ROW_NUMBER', 'RANK', 'DENSE_RANK', 'NTILE',
|
|
28
|
+
'LAG', 'LEAD', 'FIRST_VALUE', 'LAST_VALUE', 'NTH_VALUE',
|
|
29
|
+
'CUME_DIST', 'PERCENT_RANK',
|
|
30
|
+
// FTS5 functions
|
|
31
|
+
'bm25', 'highlight', 'snippet', 'offsets', 'matchinfo'
|
|
26
32
|
]);
|
|
27
33
|
this.supportedUnaryOperators = new Set([
|
|
28
34
|
Operator_1.Operator.NOT, Operator_1.Operator.PLUS, Operator_1.Operator.MINUS,
|
|
@@ -42,6 +48,14 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
|
|
|
42
48
|
super.visitInsertQuery(node);
|
|
43
49
|
// SQLite-specific validation (if any) can be added here
|
|
44
50
|
}
|
|
51
|
+
visitDeleteQuery(node) {
|
|
52
|
+
super.visitDeleteQuery(node);
|
|
53
|
+
// SQLite-specific validation (if any) can be added here
|
|
54
|
+
}
|
|
55
|
+
visitUpdateQuery(node) {
|
|
56
|
+
super.visitUpdateQuery(node);
|
|
57
|
+
// SQLite-specific validation (if any) can be added here
|
|
58
|
+
}
|
|
45
59
|
visitSelectQuery(node) {
|
|
46
60
|
super.visitSelectQuery(node);
|
|
47
61
|
if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {
|
|
@@ -91,6 +105,21 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
|
|
|
91
105
|
visitInExpression(node) {
|
|
92
106
|
super.visitInExpression(node);
|
|
93
107
|
}
|
|
108
|
+
visitCreateVirtualTableQuery(node) {
|
|
109
|
+
super.visitCreateVirtualTableQuery(node);
|
|
110
|
+
// FTS5-specific validation
|
|
111
|
+
if (node.module === 'fts5') {
|
|
112
|
+
// Validate content table reference if specified
|
|
113
|
+
if (node.options.content) {
|
|
114
|
+
// Content table name should be a valid identifier
|
|
115
|
+
// Note: we can't validate that the table exists at this point
|
|
116
|
+
}
|
|
117
|
+
// If contentRowid is specified, content must also be specified
|
|
118
|
+
if (node.options.contentRowid && !node.options.content) {
|
|
119
|
+
throw new Error('FTS5 content_rowid requires content option to be specified');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
94
123
|
}
|
|
95
124
|
exports.SQLiteQueryValidator = SQLiteQueryValidator;
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SQLiteQueryValidator.js","sourceRoot":"","sources":["../../src/validate/SQLiteQueryValidator.ts"],"names":[],"mappings":";;;AAKA,sCAA6C;AAC7C,8CAA2C;AAK3C,iEAA8D;AAG9D,MAAa,oBACX,SAAQ,2CAAoB;IAD9B;;QAIU,uBAAkB,GAAsB,IAAI,GAAG,CAAC;YACtD,wBAAwB;YACxB,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY;YAChE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO;YAC9D,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU;YACjE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,SAAS;YACpE,mBAAmB;YACnB,sBAAsB;YACtB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc;YAC5D,0BAA0B;YAC1B,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU;YACnD,kBAAkB;YAClB,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,aAAa;YAClE,cAAc,EAAE,UAAU,EAAE,aAAa,EAAE,WAAW,EAAE,YAAY;YACpE,YAAY,EAAE,YAAY,EAAE,mBAAmB,EAAE,kBAAkB;YACnE,mBAAmB,EAAE,WAAW,EAAE,WAAW;SAC9C,CAAC,CAAC;QAEK,4BAAuB,GAAgB,IAAI,GAAG,CAAC;YACrD,mBAAQ,CAAC,GAAG,EAAE,mBAAQ,CAAC,IAAI,EAAE,mBAAQ,CAAC,KAAK;YAC3C,mBAAQ,CAAC,OAAO,EAAE,mBAAQ,CAAC,WAAW;SACvC,CAAC,CAAC;QAEK,oBAAe,GAAY,KAAK,CAAC;IAyE3C,CAAC;IAvEQ,QAAQ,CAAC,KAAgC;QAC9C,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAES,KAAK;QACb,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC7B,wDAAwD;IAC1D,CAAC;IAED,gBAAgB,CAAC,IAAiB;QAChC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;YACjG,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,SAAS,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;YACpG,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,IAAI,IAAI,CAAC,IAAI,KAAK,eAAQ,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,KAAK,eAAQ,CAAC,IAAI,EAAE,CAAC;YAChE,MAAM,IAAI,KAAK,CAAC,2BAA2B,IAAI,CAAC,IAAI,OAAO,CAAC,CAAC;QAC/D,CAAC;QACD,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,eAAe,CAAC,IAAU;QACxB,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC;QAC3C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;QAChF,CAAC;QACD,IAAI,CAAC,eAAe,GAAG,aAAa,CAAC;QACrC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,uBAAuB,CAAC,IAAwB;QAC9C,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,YAAY,IAAI,CAAC,IAAI,6BAA6B,CAAC,CAAC;QACtE,CAAC;QACD,KAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,cAAc,CAAC,IAAe;QAC5B,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;QACD,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,oBAAoB,CAAC,IAAqB;QACxC,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrD,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,CAAC,QAAQ,6BAA6B,CAAC,CAAC;QAChF,CAAC;QACD,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,IAAkB;QAClC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;CACF;AApGD,oDAoGC","sourcesContent":["import { JsonEachFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { Operator } from \"../ast/Operator\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { CommonQueryValidator } from \"./CommonQueryValidator\";\nimport { QueryValidator } from \"./QueryValidator\";\n\nexport class SQLiteQueryValidator\n  extends CommonQueryValidator\n  implements QueryValidator, SqlTreeNodeVisitor<void>\n{\n  private supportedFunctions: Set<FunctionName> = new Set([\n    // Core scalar functions\n    'ABS', 'CEIL', 'FLOOR', 'ROUND', 'TRUNC', 'RANDOM', 'RANDOMBLOB',\n    'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',\n    'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',\n    'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',\n    'LAST_INSERT_ROWID',\n    // Aggregate functions\n    'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',\n    // Date and time functions\n    'DATE', 'TIME', 'DATETIME', 'JULIANDAY', 'STRFTIME',\n    // JSON1 functions\n    'json', 'json_array', 'json_object', 'json_extract', 'json_insert',\n    'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',\n    'json_quote', 'json_patch', 'json_array_length', 'json_group_array',\n    'json_group_object', 'json_each', 'json_tree'\n  ]);\n\n  private supportedUnaryOperators: Set<string> = new Set([\n    Operator.NOT, Operator.PLUS, Operator.MINUS,\n    Operator.IS_NULL, Operator.IS_NOT_NULL,\n  ]);\n\n  private isWithRecursive: boolean = false;\n\n  public validate(query: SelectQuery | InsertQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    super.reset();\n    this.isWithRecursive = false;\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    super.visitInsertQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    super.visitSelectQuery(node);\n    if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {\n      throw new Error('SQLite LIMIT must be an integer');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && !Number.isInteger(node['_offset'])) {\n      throw new Error('SQLite OFFSET must be an integer');\n    }\n  }\n\n  visitJoinClause(node: Join): void {\n    if (node.type === JoinType.RIGHT || node.type === JoinType.FULL) {\n      throw new Error(`SQLite does not support ${node.type} JOIN`);\n    }\n    super.visitJoinClause(node);\n  }\n\n  visitWithClause(node: With): void {\n    const prevRecursive = this.isWithRecursive;\n    this.isWithRecursive = false;\n    node.query.accept(this);\n    if (this.isWithRecursive) {\n      throw new Error('Recursive WITH clauses are not supported in this validator');\n    }\n    this.isWithRecursive = prevRecursive;\n    super.visitWithClause(node);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    if (!this.supportedFunctions.has(node.name)) {\n      throw new Error(`Function ${node.name} is not supported in SQLite`);\n    }\n    super.visitFunctionExpression(node);\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    if (this.isWithRecursive) {\n      throw new Error('Recursive reference to WITH clause detected');\n    }\n    super.visitTableFrom(node);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    super.visitJsonEachFrom(node);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!this.supportedUnaryOperators.has(node.operator)) {\n      throw new Error(`Unary operator ${node.operator} is not supported in SQLite`);\n    }\n    super.visitUnaryExpression(node);\n  }\n\n  visitInExpression(node: InExpression): void {\n    super.visitInExpression(node);\n  }\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SQLiteQueryValidator.js","sourceRoot":"","sources":["../../src/validate/SQLiteQueryValidator.ts"],"names":[],"mappings":"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","sourcesContent":["import { AlterTableQuery } from \"../ast/AlterTableQuery\";\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 { JsonEachFrom, TableFrom } from \"../ast/From\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { Operator } from \"../ast/Operator\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { CommonQueryValidator } from \"./CommonQueryValidator\";\nimport { QueryValidator } from \"./QueryValidator\";\n\ntype ValidatableQuery =\n  | SelectQuery\n  | InsertQuery\n  | UpdateQuery\n  | DeleteQuery\n  | CreateTableQuery\n  | CreateVirtualTableQuery\n  | CreateIndexQuery\n  | CreateViewQuery\n  | AlterTableQuery\n  | DropTableQuery\n  | DropIndexQuery\n  | DropViewQuery;\n\nexport class SQLiteQueryValidator\n  extends CommonQueryValidator\n  implements QueryValidator, SqlTreeNodeVisitor<void>\n{\n  private supportedFunctions: Set<FunctionName> = new Set([\n    // Core scalar functions\n    'ABS', 'CEIL', 'FLOOR', 'ROUND', 'TRUNC', 'RANDOM', 'RANDOMBLOB',\n    'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',\n    'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',\n    'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',\n    'LAST_INSERT_ROWID', 'CONCAT',\n    // Aggregate functions\n    'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',\n    // Date and time functions\n    'DATE', 'TIME', 'DATETIME', 'JULIANDAY', 'STRFTIME',\n    // JSON1 functions\n    'json', 'json_array', 'json_object', 'json_extract', 'json_insert',\n    'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',\n    'json_quote', 'json_patch', 'json_array_length', 'json_group_array',\n    'json_group_object', 'json_each', 'json_tree',\n    // Window functions\n    'ROW_NUMBER', 'RANK', 'DENSE_RANK', 'NTILE',\n    'LAG', 'LEAD', 'FIRST_VALUE', 'LAST_VALUE', 'NTH_VALUE',\n    'CUME_DIST', 'PERCENT_RANK',\n    // FTS5 functions\n    'bm25', 'highlight', 'snippet', 'offsets', 'matchinfo'\n  ]);\n\n  private supportedUnaryOperators: Set<string> = new Set([\n    Operator.NOT, Operator.PLUS, Operator.MINUS,\n    Operator.IS_NULL, Operator.IS_NOT_NULL,\n  ]);\n\n  private isWithRecursive: boolean = false;\n\n  public validate(query: ValidatableQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    super.reset();\n    this.isWithRecursive = false;\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    super.visitInsertQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitDeleteQuery(node: DeleteQuery): void {\n    super.visitDeleteQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitUpdateQuery(node: UpdateQuery): void {\n    super.visitUpdateQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    super.visitSelectQuery(node);\n    if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {\n      throw new Error('SQLite LIMIT must be an integer');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && !Number.isInteger(node['_offset'])) {\n      throw new Error('SQLite OFFSET must be an integer');\n    }\n  }\n\n  visitJoinClause(node: Join): void {\n    if (node.type === JoinType.RIGHT || node.type === JoinType.FULL) {\n      throw new Error(`SQLite does not support ${node.type} JOIN`);\n    }\n    super.visitJoinClause(node);\n  }\n\n  visitWithClause(node: With): void {\n    const prevRecursive = this.isWithRecursive;\n    this.isWithRecursive = false;\n    node.query.accept(this);\n    if (this.isWithRecursive) {\n      throw new Error('Recursive WITH clauses are not supported in this validator');\n    }\n    this.isWithRecursive = prevRecursive;\n    super.visitWithClause(node);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    if (!this.supportedFunctions.has(node.name)) {\n      throw new Error(`Function ${node.name} is not supported in SQLite`);\n    }\n    super.visitFunctionExpression(node);\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    if (this.isWithRecursive) {\n      throw new Error('Recursive reference to WITH clause detected');\n    }\n    super.visitTableFrom(node);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    super.visitJsonEachFrom(node);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!this.supportedUnaryOperators.has(node.operator)) {\n      throw new Error(`Unary operator ${node.operator} is not supported in SQLite`);\n    }\n    super.visitUnaryExpression(node);\n  }\n\n  visitInExpression(node: InExpression): void {\n    super.visitInExpression(node);\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): void {\n    super.visitCreateVirtualTableQuery(node);\n\n    // FTS5-specific validation\n    if (node.module === 'fts5') {\n      // Validate content table reference if specified\n      if (node.options.content) {\n        // Content table name should be a valid identifier\n        // Note: we can't validate that the table exists at this point\n      }\n\n      // If contentRowid is specified, content must also be specified\n      if (node.options.contentRowid && !node.options.content) {\n        throw new Error('FTS5 content_rowid requires content option to be specified');\n      }\n    }\n  }\n}\n"]}
|
|
@@ -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";
|
|
@@ -23,6 +38,16 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
|
|
|
23
38
|
private readonly params;
|
|
24
39
|
constructor(keyValuePairs: Record<string, any>);
|
|
25
40
|
visitInsertQuery(node: InsertQuery): any[];
|
|
41
|
+
visitDeleteQuery(node: DeleteQuery): any[];
|
|
42
|
+
visitUpdateQuery(node: UpdateQuery): any[];
|
|
43
|
+
visitDropTableQuery(_node: DropTableQuery): any[];
|
|
44
|
+
visitDropIndexQuery(_node: DropIndexQuery): any[];
|
|
45
|
+
visitDropViewQuery(_node: DropViewQuery): any[];
|
|
46
|
+
visitCreateViewQuery(node: CreateViewQuery): any[];
|
|
47
|
+
visitCreateIndexQuery(node: CreateIndexQuery): any[];
|
|
48
|
+
visitAlterTableQuery(node: AlterTableQuery): any[];
|
|
49
|
+
visitCreateTableQuery(node: CreateTableQuery): any[];
|
|
50
|
+
visitCreateVirtualTableQuery(_node: CreateVirtualTableQuery): any[];
|
|
26
51
|
visitSelectQuery(node: SelectQuery): any[];
|
|
27
52
|
visitTableFrom(_node: TableFrom): any[];
|
|
28
53
|
visitSubqueryFrom(node: SubqueryFrom): any[];
|
|
@@ -33,6 +58,7 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
|
|
|
33
58
|
visitOrderBy(node: OrderBy): any[];
|
|
34
59
|
visitWithClause(node: With): any[];
|
|
35
60
|
visitBinaryExpression(node: BinaryExpression): any[];
|
|
61
|
+
visitBetweenExpression(node: BetweenExpression): any[];
|
|
36
62
|
visitUnaryExpression(node: UnaryExpression): any[];
|
|
37
63
|
visitInExpression(node: InExpression): any[];
|
|
38
64
|
visitConcat(node: Concat): any[];
|
|
@@ -43,4 +69,8 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
|
|
|
43
69
|
visitNumberLiteral(_node: NumberLiteral): any[];
|
|
44
70
|
visitNullLiteral(_node: NullLiteral): any[];
|
|
45
71
|
visitExistsExpression(node: ExistsExpression): any[];
|
|
72
|
+
visitCastExpression(node: CastExpression): any[];
|
|
73
|
+
visitCollateExpression(node: CollateExpression): any[];
|
|
74
|
+
visitSubqueryExpression(node: SubqueryExpression): any[];
|
|
75
|
+
visitWindowExpression(node: WindowExpression): any[];
|
|
46
76
|
}
|
|
@@ -11,7 +11,85 @@ class ParamCollectingVisitor {
|
|
|
11
11
|
this.keyValuePairs = keyValuePairs;
|
|
12
12
|
}
|
|
13
13
|
visitInsertQuery(node) {
|
|
14
|
-
node['
|
|
14
|
+
if (node['_fromSelect']) {
|
|
15
|
+
node['_fromSelect'].accept(this);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
node['_values'].forEach(v => v.accept(this));
|
|
19
|
+
}
|
|
20
|
+
// Collect params from ON CONFLICT clause
|
|
21
|
+
node['_doUpdateSets'].forEach(s => s.value.accept(this));
|
|
22
|
+
if (node['_onConflictWhere']) {
|
|
23
|
+
node['_onConflictWhere'].accept(this);
|
|
24
|
+
}
|
|
25
|
+
node['_returning'].forEach(r => r.accept(this));
|
|
26
|
+
return this.params;
|
|
27
|
+
}
|
|
28
|
+
visitDeleteQuery(node) {
|
|
29
|
+
if (node['_where']) {
|
|
30
|
+
node['_where'].accept(this);
|
|
31
|
+
}
|
|
32
|
+
node['_returning'].forEach(r => r.accept(this));
|
|
33
|
+
return this.params;
|
|
34
|
+
}
|
|
35
|
+
visitUpdateQuery(node) {
|
|
36
|
+
node['_set'].forEach(s => s.value.accept(this));
|
|
37
|
+
if (node['_where']) {
|
|
38
|
+
node['_where'].accept(this);
|
|
39
|
+
}
|
|
40
|
+
node['_returning'].forEach(r => r.accept(this));
|
|
41
|
+
return this.params;
|
|
42
|
+
}
|
|
43
|
+
visitDropTableQuery(_node) {
|
|
44
|
+
// DROP TABLE has no parameters
|
|
45
|
+
return this.params;
|
|
46
|
+
}
|
|
47
|
+
visitDropIndexQuery(_node) {
|
|
48
|
+
// DROP INDEX has no parameters
|
|
49
|
+
return this.params;
|
|
50
|
+
}
|
|
51
|
+
visitDropViewQuery(_node) {
|
|
52
|
+
// DROP VIEW has no parameters
|
|
53
|
+
return this.params;
|
|
54
|
+
}
|
|
55
|
+
visitCreateViewQuery(node) {
|
|
56
|
+
// Collect params from the SELECT query
|
|
57
|
+
if (node.selectQuery) {
|
|
58
|
+
node.selectQuery.accept(this);
|
|
59
|
+
}
|
|
60
|
+
return this.params;
|
|
61
|
+
}
|
|
62
|
+
visitCreateIndexQuery(node) {
|
|
63
|
+
// Collect params from WHERE expression
|
|
64
|
+
if (node.whereExpression) {
|
|
65
|
+
node.whereExpression.accept(this);
|
|
66
|
+
}
|
|
67
|
+
return this.params;
|
|
68
|
+
}
|
|
69
|
+
visitAlterTableQuery(node) {
|
|
70
|
+
// Collect params from ADD COLUMN CHECK constraint
|
|
71
|
+
const op = node.operation;
|
|
72
|
+
if (op && op.type === 'ADD_COLUMN' && op.column.constraints.check) {
|
|
73
|
+
op.column.constraints.check.accept(this);
|
|
74
|
+
}
|
|
75
|
+
return this.params;
|
|
76
|
+
}
|
|
77
|
+
visitCreateTableQuery(node) {
|
|
78
|
+
// Collect params from CHECK constraints
|
|
79
|
+
for (const col of node.columns) {
|
|
80
|
+
if (col.constraints.check) {
|
|
81
|
+
col.constraints.check.accept(this);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
for (const constraint of node.tableConstraints) {
|
|
85
|
+
if (constraint.check) {
|
|
86
|
+
constraint.check.accept(this);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
return this.params;
|
|
90
|
+
}
|
|
91
|
+
visitCreateVirtualTableQuery(_node) {
|
|
92
|
+
// CREATE VIRTUAL TABLE has no parameters
|
|
15
93
|
return this.params;
|
|
16
94
|
}
|
|
17
95
|
visitSelectQuery(node) {
|
|
@@ -26,6 +104,8 @@ class ParamCollectingVisitor {
|
|
|
26
104
|
node['_having'].accept(this);
|
|
27
105
|
}
|
|
28
106
|
node['_union'].forEach(u => u.accept(this));
|
|
107
|
+
node['_intersect'].forEach(i => i.accept(this));
|
|
108
|
+
node['_except'].forEach(e => e.accept(this));
|
|
29
109
|
node['_orderBy'].forEach(o => o.accept(this));
|
|
30
110
|
return this.params;
|
|
31
111
|
}
|
|
@@ -67,6 +147,12 @@ class ParamCollectingVisitor {
|
|
|
67
147
|
node.right.accept(this);
|
|
68
148
|
return this.params;
|
|
69
149
|
}
|
|
150
|
+
visitBetweenExpression(node) {
|
|
151
|
+
node.operand.accept(this);
|
|
152
|
+
node.low.accept(this);
|
|
153
|
+
node.high.accept(this);
|
|
154
|
+
return this.params;
|
|
155
|
+
}
|
|
70
156
|
visitUnaryExpression(node) {
|
|
71
157
|
node.operand.accept(this);
|
|
72
158
|
return this.params;
|
|
@@ -124,6 +210,27 @@ class ParamCollectingVisitor {
|
|
|
124
210
|
node.subquery.accept(this);
|
|
125
211
|
return this.params;
|
|
126
212
|
}
|
|
213
|
+
visitCastExpression(node) {
|
|
214
|
+
node.expression.accept(this);
|
|
215
|
+
return this.params;
|
|
216
|
+
}
|
|
217
|
+
visitCollateExpression(node) {
|
|
218
|
+
node.expression.accept(this);
|
|
219
|
+
return this.params;
|
|
220
|
+
}
|
|
221
|
+
visitSubqueryExpression(node) {
|
|
222
|
+
node.subquery.accept(this);
|
|
223
|
+
return this.params;
|
|
224
|
+
}
|
|
225
|
+
visitWindowExpression(node) {
|
|
226
|
+
// Collect params from the underlying function
|
|
227
|
+
node.function.accept(this);
|
|
228
|
+
// Collect params from partition by columns
|
|
229
|
+
node.windowSpec.partitionByColumns.forEach(c => c.accept(this));
|
|
230
|
+
// Collect params from order by clauses
|
|
231
|
+
node.windowSpec.orderByColumns.forEach(o => o.accept(this));
|
|
232
|
+
return this.params;
|
|
233
|
+
}
|
|
127
234
|
}
|
|
128
235
|
exports.ParamCollectingVisitor = ParamCollectingVisitor;
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ParamCollector.js","sourceRoot":"","sources":["../../src/visitor/ParamCollector.ts"],"names":[],"mappings":"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","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 \"./SqlTreeNodeVisitor\";\n\nexport class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]> {\n\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<any[]>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<any[]>();\n\n  private readonly keyValuePairs: Record<string, any>;\n  private readonly params: any[] = [];\n\n  constructor(keyValuePairs: Record<string, any>) {\n    this.keyValuePairs = keyValuePairs;\n  }\n\n  visitInsertQuery(node: InsertQuery): any[] {\n    node['_values'].forEach(v => v.accept(this));\n    return this.params;\n  }\n\n  visitSelectQuery(node: SelectQuery): any[] {\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    node['_groupBy'].forEach(c => c.accept(this));\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    node['_union'].forEach(u => u.accept(this));\n    node['_orderBy'].forEach(o => o.accept(this));\n    return this.params;\n  }\n\n  visitTableFrom(_node: TableFrom): any[] {\n    return this.params;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): any[] {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n    return this.params;\n  }\n\n  visitColumn(_node: Column): any[] {\n    return this.params;\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): any[] {\n    node.referent.accept(this);\n    return this.params;\n  }\n\n  visitJoinClause(node: Join): any[] {\n    node.on.accept(this);\n    return this.params;\n  }\n\n  visitOrderBy(node: OrderBy): any[] {\n    node.column.accept(this);\n    return this.params;\n  }\n\n  visitWithClause(node: With): any[] {\n    node.query.accept(this);\n    return this.params;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): any[] {\n    node.left.accept(this);\n    node.right.accept(this);\n    return this.params;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): any[] {\n    node.operand.accept(this);\n    return this.params;\n  }\n\n  visitInExpression(node: InExpression): any[] {\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      node.values.forEach(set => set.forEach(v => v.accept(this)));\n    }\n    return this.params;\n  }\n\n  visitConcat(node: Concat): any[] {\n    node.expressions.forEach(e => e.accept(this));\n    return this.params;\n  }\n\n  visitCaseExpression(node: CaseExpression): any[] {\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    return this.params;\n  }\n\n  visitFunctionExpression(node: FunctionExpression): any[] {\n    node.args.forEach(a => a.accept(this));\n    return this.params;\n  }\n\n  visitParamExpression(node: Param): any[] {\n    if (node.paramName) {\n      if (!this.keyValuePairs || typeof this.keyValuePairs !== 'object' || !(node.paramName in this.keyValuePairs)) {\n        throw new Error(`No value provided for parameter: ${node.paramName}`);\n      }\n      this.params.push(this.keyValuePairs[node.paramName]);\n    } else {\n      this.params.push(undefined);\n    }\n    return this.params;\n  }\n\n  visitStringLiteral(_node: StringLiteral): any[] {\n    return this.params;\n  }\n\n  visitNumberLiteral(_node: NumberLiteral): any[] {\n    return this.params;\n  }\n\n  visitNullLiteral(_node: NullLiteral): any[] {\n    return this.params;\n  }\n\n  visitExistsExpression(node: ExistsExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n}\n"]}
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ParamCollector.js","sourceRoot":"","sources":["../../src/visitor/ParamCollector.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 \"./SqlTreeNodeVisitor\";\n\nexport class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]> {\n\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<any[]>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<any[]>();\n\n  private readonly keyValuePairs: Record<string, any>;\n  private readonly params: any[] = [];\n\n  constructor(keyValuePairs: Record<string, any>) {\n    this.keyValuePairs = keyValuePairs;\n  }\n\n  visitInsertQuery(node: InsertQuery): any[] {\n    if (node['_fromSelect']) {\n      node['_fromSelect'].accept(this);\n    } else {\n      node['_values'].forEach(v => v.accept(this));\n    }\n    // Collect params from ON CONFLICT clause\n    node['_doUpdateSets'].forEach(s => s.value.accept(this));\n    if (node['_onConflictWhere']) {\n      node['_onConflictWhere'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitDeleteQuery(node: DeleteQuery): any[] {\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitUpdateQuery(node: UpdateQuery): any[] {\n    node['_set'].forEach(s => s.value.accept(this));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitDropTableQuery(_node: DropTableQuery): any[] {\n    // DROP TABLE has no parameters\n    return this.params;\n  }\n\n  visitDropIndexQuery(_node: DropIndexQuery): any[] {\n    // DROP INDEX has no parameters\n    return this.params;\n  }\n\n  visitDropViewQuery(_node: DropViewQuery): any[] {\n    // DROP VIEW has no parameters\n    return this.params;\n  }\n\n  visitCreateViewQuery(node: CreateViewQuery): any[] {\n    // Collect params from the SELECT query\n    if (node.selectQuery) {\n      node.selectQuery.accept(this);\n    }\n    return this.params;\n  }\n\n  visitCreateIndexQuery(node: CreateIndexQuery): any[] {\n    // Collect params from WHERE expression\n    if (node.whereExpression) {\n      node.whereExpression.accept(this);\n    }\n    return this.params;\n  }\n\n  visitAlterTableQuery(node: AlterTableQuery): any[] {\n    // Collect params from ADD COLUMN CHECK constraint\n    const op = node.operation;\n    if (op && op.type === 'ADD_COLUMN' && op.column.constraints.check) {\n      op.column.constraints.check.accept(this);\n    }\n    return this.params;\n  }\n\n  visitCreateTableQuery(node: CreateTableQuery): any[] {\n    // Collect params from CHECK constraints\n    for (const col of node.columns) {\n      if (col.constraints.check) {\n        col.constraints.check.accept(this);\n      }\n    }\n    for (const constraint of node.tableConstraints) {\n      if (constraint.check) {\n        constraint.check.accept(this);\n      }\n    }\n    return this.params;\n  }\n\n  visitCreateVirtualTableQuery(_node: CreateVirtualTableQuery): any[] {\n    // CREATE VIRTUAL TABLE has no parameters\n    return this.params;\n  }\n\n  visitSelectQuery(node: SelectQuery): any[] {\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    node['_groupBy'].forEach(c => c.accept(this));\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    node['_union'].forEach(u => u.accept(this));\n    node['_intersect'].forEach(i => i.accept(this));\n    node['_except'].forEach(e => e.accept(this));\n    node['_orderBy'].forEach(o => o.accept(this));\n    return this.params;\n  }\n\n  visitTableFrom(_node: TableFrom): any[] {\n    return this.params;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): any[] {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n    return this.params;\n  }\n\n  visitColumn(_node: Column): any[] {\n    return this.params;\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): any[] {\n    node.referent.accept(this);\n    return this.params;\n  }\n\n  visitJoinClause(node: Join): any[] {\n    node.on.accept(this);\n    return this.params;\n  }\n\n  visitOrderBy(node: OrderBy): any[] {\n    node.column.accept(this);\n    return this.params;\n  }\n\n  visitWithClause(node: With): any[] {\n    node.query.accept(this);\n    return this.params;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): any[] {\n    node.left.accept(this);\n    node.right.accept(this);\n    return this.params;\n  }\n\n  visitBetweenExpression(node: BetweenExpression): any[] {\n    node.operand.accept(this);\n    node.low.accept(this);\n    node.high.accept(this);\n    return this.params;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): any[] {\n    node.operand.accept(this);\n    return this.params;\n  }\n\n  visitInExpression(node: InExpression): any[] {\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      node.values.forEach(set => set.forEach(v => v.accept(this)));\n    }\n    return this.params;\n  }\n\n  visitConcat(node: Concat): any[] {\n    node.expressions.forEach(e => e.accept(this));\n    return this.params;\n  }\n\n  visitCaseExpression(node: CaseExpression): any[] {\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    return this.params;\n  }\n\n  visitFunctionExpression(node: FunctionExpression): any[] {\n    node.args.forEach(a => a.accept(this));\n    return this.params;\n  }\n\n  visitParamExpression(node: Param): any[] {\n    if (node.paramName) {\n      if (!this.keyValuePairs || typeof this.keyValuePairs !== 'object' || !(node.paramName in this.keyValuePairs)) {\n        throw new Error(`No value provided for parameter: ${node.paramName}`);\n      }\n      this.params.push(this.keyValuePairs[node.paramName]);\n    } else {\n      this.params.push(undefined);\n    }\n    return this.params;\n  }\n\n  visitStringLiteral(_node: StringLiteral): any[] {\n    return this.params;\n  }\n\n  visitNumberLiteral(_node: NumberLiteral): any[] {\n    return this.params;\n  }\n\n  visitNullLiteral(_node: NullLiteral): any[] {\n    return this.params;\n  }\n\n  visitExistsExpression(node: ExistsExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitCastExpression(node: CastExpression): any[] {\n    node.expression.accept(this);\n    return this.params;\n  }\n\n  visitCollateExpression(node: CollateExpression): any[] {\n    node.expression.accept(this);\n    return this.params;\n  }\n\n  visitSubqueryExpression(node: SubqueryExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitWindowExpression(node: WindowExpression): any[] {\n    // Collect params from the underlying function\n    node.function.accept(this);\n    // Collect params from partition by columns\n    node.windowSpec.partitionByColumns.forEach(c => c.accept(this));\n    // Collect params from order by clauses\n    node.windowSpec.orderByColumns.forEach(o => o.accept(this));\n    return this.params;\n  }\n}\n"]}
|
|
@@ -1,14 +1,29 @@
|
|
|
1
1
|
import { Aliasable, SqlTreeNode } 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 { 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";
|
|
@@ -23,6 +38,16 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
|
|
|
23
38
|
protected flatList2D(results: (SqlTreeNode | SqlTreeNode[])[][]): SqlTreeNode[][];
|
|
24
39
|
visitSelectQuery(node: SelectQuery): SqlTreeNode | SqlTreeNode[];
|
|
25
40
|
visitInsertQuery(node: InsertQuery): SqlTreeNode | SqlTreeNode[];
|
|
41
|
+
visitDeleteQuery(node: DeleteQuery): SqlTreeNode | SqlTreeNode[];
|
|
42
|
+
visitUpdateQuery(node: UpdateQuery): SqlTreeNode | SqlTreeNode[];
|
|
43
|
+
visitDropTableQuery(node: DropTableQuery): SqlTreeNode | SqlTreeNode[];
|
|
44
|
+
visitDropIndexQuery(node: DropIndexQuery): SqlTreeNode | SqlTreeNode[];
|
|
45
|
+
visitDropViewQuery(node: DropViewQuery): SqlTreeNode | SqlTreeNode[];
|
|
46
|
+
visitCreateViewQuery(node: CreateViewQuery): SqlTreeNode | SqlTreeNode[];
|
|
47
|
+
visitCreateIndexQuery(node: CreateIndexQuery): SqlTreeNode | SqlTreeNode[];
|
|
48
|
+
visitAlterTableQuery(node: AlterTableQuery): SqlTreeNode | SqlTreeNode[];
|
|
49
|
+
visitCreateTableQuery(node: CreateTableQuery): SqlTreeNode | SqlTreeNode[];
|
|
50
|
+
visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): SqlTreeNode | SqlTreeNode[];
|
|
26
51
|
visitTableFrom(node: TableFrom): SqlTreeNode | SqlTreeNode[];
|
|
27
52
|
visitSubqueryFrom(node: SubqueryFrom): SqlTreeNode | SqlTreeNode[];
|
|
28
53
|
visitJsonEachFrom(node: JsonEachFrom): SqlTreeNode | SqlTreeNode[];
|
|
@@ -32,6 +57,7 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
|
|
|
32
57
|
visitOrderBy(node: OrderBy): SqlTreeNode | SqlTreeNode[];
|
|
33
58
|
visitWithClause(node: With): SqlTreeNode | SqlTreeNode[];
|
|
34
59
|
visitBinaryExpression(node: BinaryExpression): SqlTreeNode | SqlTreeNode[];
|
|
60
|
+
visitBetweenExpression(node: BetweenExpression): SqlTreeNode | SqlTreeNode[];
|
|
35
61
|
visitUnaryExpression(node: UnaryExpression): SqlTreeNode | SqlTreeNode[];
|
|
36
62
|
visitInExpression(node: InExpression): SqlTreeNode | SqlTreeNode[];
|
|
37
63
|
visitConcat(node: Concat): SqlTreeNode | SqlTreeNode[];
|
|
@@ -42,4 +68,8 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
|
|
|
42
68
|
visitNumberLiteral(node: NumberLiteral): SqlTreeNode | SqlTreeNode[];
|
|
43
69
|
visitNullLiteral(node: NullLiteral): SqlTreeNode | SqlTreeNode[];
|
|
44
70
|
visitExistsExpression(node: ExistsExpression): SqlTreeNode | SqlTreeNode[];
|
|
71
|
+
visitCastExpression(node: CastExpression): SqlTreeNode | SqlTreeNode[];
|
|
72
|
+
visitCollateExpression(node: CollateExpression): SqlTreeNode | SqlTreeNode[];
|
|
73
|
+
visitSubqueryExpression(node: SubqueryExpression): SqlTreeNode | SqlTreeNode[];
|
|
74
|
+
visitWindowExpression(node: WindowExpression): SqlTreeNode | SqlTreeNode[];
|
|
45
75
|
}
|