typesql-cli 0.8.0-alpha.5 → 0.8.0-alpha.7

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 (60) hide show
  1. package/cli.js +36 -39
  2. package/cli.js.map +1 -1
  3. package/code-generator.d.ts +4 -4
  4. package/code-generator.d.ts.map +1 -1
  5. package/code-generator.js +17 -19
  6. package/code-generator.js.map +1 -1
  7. package/describe-query.d.ts +2 -3
  8. package/describe-query.d.ts.map +1 -1
  9. package/describe-query.js +3 -2
  10. package/describe-query.js.map +1 -1
  11. package/mysql-query-analyzer/collect-constraints.d.ts +2 -2
  12. package/mysql-query-analyzer/collect-constraints.d.ts.map +1 -1
  13. package/mysql-query-analyzer/collect-constraints.js +1 -1
  14. package/mysql-query-analyzer/collect-constraints.js.map +1 -1
  15. package/mysql-query-analyzer/traverse.d.ts +19 -0
  16. package/mysql-query-analyzer/traverse.d.ts.map +1 -1
  17. package/mysql-query-analyzer/traverse.js +15 -15
  18. package/mysql-query-analyzer/traverse.js.map +1 -1
  19. package/mysql-query-analyzer/types.d.ts +1 -1
  20. package/mysql-query-analyzer/types.d.ts.map +1 -1
  21. package/mysql-query-analyzer/unify.d.ts.map +1 -1
  22. package/mysql-query-analyzer/unify.js +8 -0
  23. package/mysql-query-analyzer/unify.js.map +1 -1
  24. package/package.json +1 -1
  25. package/queryExectutor.d.ts +8 -15
  26. package/queryExectutor.d.ts.map +1 -1
  27. package/queryExectutor.js +119 -121
  28. package/queryExectutor.js.map +1 -1
  29. package/sql-generator.d.ts +5 -4
  30. package/sql-generator.d.ts.map +1 -1
  31. package/sql-generator.js +24 -21
  32. package/sql-generator.js.map +1 -1
  33. package/sqlite-query-analyzer/code-generator.d.ts +3 -1
  34. package/sqlite-query-analyzer/code-generator.d.ts.map +1 -1
  35. package/sqlite-query-analyzer/code-generator.js +88 -29
  36. package/sqlite-query-analyzer/code-generator.js.map +1 -1
  37. package/sqlite-query-analyzer/parser.d.ts +2 -0
  38. package/sqlite-query-analyzer/parser.d.ts.map +1 -1
  39. package/sqlite-query-analyzer/parser.js +155 -31
  40. package/sqlite-query-analyzer/parser.js.map +1 -1
  41. package/sqlite-query-analyzer/query-executor.d.ts +7 -3
  42. package/sqlite-query-analyzer/query-executor.d.ts.map +1 -1
  43. package/sqlite-query-analyzer/query-executor.js +65 -6
  44. package/sqlite-query-analyzer/query-executor.js.map +1 -1
  45. package/sqlite-query-analyzer/sql-generator.d.ts +6 -0
  46. package/sqlite-query-analyzer/sql-generator.d.ts.map +1 -0
  47. package/sqlite-query-analyzer/sql-generator.js +96 -0
  48. package/sqlite-query-analyzer/sql-generator.js.map +1 -0
  49. package/sqlite-query-analyzer/sqlite-crud-generator.d.ts +6 -0
  50. package/sqlite-query-analyzer/sqlite-crud-generator.d.ts.map +1 -0
  51. package/sqlite-query-analyzer/sqlite-crud-generator.js +96 -0
  52. package/sqlite-query-analyzer/sqlite-crud-generator.js.map +1 -0
  53. package/sqlite-query-analyzer/traverse.d.ts +4 -4
  54. package/sqlite-query-analyzer/traverse.d.ts.map +1 -1
  55. package/sqlite-query-analyzer/traverse.js +384 -82
  56. package/sqlite-query-analyzer/traverse.js.map +1 -1
  57. package/sqlite-query-analyzer/types.d.ts +1 -1
  58. package/sqlite-query-analyzer/types.d.ts.map +1 -1
  59. package/types.d.ts +15 -1
  60. package/types.d.ts.map +1 -1
@@ -8,24 +8,26 @@ const Either_1 = require("fp-ts/lib/Either");
8
8
  const parser_1 = require("./parser");
9
9
  const code_generator_1 = require("../code-generator");
10
10
  const code_block_writer_1 = __importDefault(require("code-block-writer"));
11
- function generateTsCode(sql, queryName, sqliteDbSchema) {
12
- const queryInfo = (0, parser_1.parseSql)(sql, sqliteDbSchema);
11
+ function generateTsCode(db, sql, queryName, sqliteDbSchema, isCrud = false) {
12
+ const queryInfo = (0, parser_1.prepareAndParse)(db, sql, sqliteDbSchema);
13
13
  if ((0, Either_1.isLeft)(queryInfo)) {
14
- return 'invalid';
14
+ return (0, Either_1.left)('//Invalid sql');
15
15
  }
16
16
  const tsDescriptor = createTsDescriptor(queryInfo.right);
17
- const code = generateCodeFromTsDescriptor(queryName, tsDescriptor);
18
- return code;
17
+ const code = generateCodeFromTsDescriptor(queryName, tsDescriptor, isCrud);
18
+ return (0, Either_1.right)(code);
19
19
  }
20
20
  exports.generateTsCode = generateTsCode;
21
21
  function createTsDescriptor(queryInfo) {
22
+ var _a;
22
23
  const tsDescriptor = {
23
24
  sql: queryInfo.sql,
24
- queryType: "Select",
25
+ queryType: queryInfo.queryType,
25
26
  multipleRowsResult: queryInfo.multipleRowsResult,
26
27
  columns: queryInfo.columns.map(col => mapColumnToTsFieldDescriptor(col)),
27
28
  parameterNames: [],
28
- parameters: queryInfo.parameters.map(param => mapParameterToTsFieldDescriptor(param))
29
+ parameters: queryInfo.parameters.map(param => mapParameterToTsFieldDescriptor(param)),
30
+ data: (_a = queryInfo.data) === null || _a === void 0 ? void 0 : _a.map(param => mapParameterToTsFieldDescriptor(param)),
29
31
  };
30
32
  return tsDescriptor;
31
33
  }
@@ -55,14 +57,20 @@ function mapColumnType(sqliteType) {
55
57
  return 'number';
56
58
  case 'REAL':
57
59
  return 'number';
60
+ case 'DATE':
61
+ return 'Date';
62
+ case 'BLOB':
63
+ return 'any';
58
64
  }
59
65
  }
60
- function generateCodeFromTsDescriptor(queryName, tsDescriptor) {
66
+ function generateCodeFromTsDescriptor(queryName, tsDescriptor, isCrud) {
67
+ var _a;
61
68
  const writer = new code_block_writer_1.default({
62
69
  useTabs: true
63
70
  });
64
71
  const camelCaseName = (0, code_generator_1.convertToCamelCaseName)(queryName);
65
72
  const capitalizedName = (0, code_generator_1.capitalize)(camelCaseName);
73
+ const queryType = tsDescriptor.queryType;
66
74
  const sql = tsDescriptor.sql;
67
75
  const dataTypeName = capitalizedName + 'Data';
68
76
  const paramsTypeName = capitalizedName + 'Params';
@@ -73,12 +81,30 @@ function generateCodeFromTsDescriptor(queryName, tsDescriptor) {
73
81
  const orderByTypeName = capitalizedName + 'OrderBy';
74
82
  const generateOrderBy = tsDescriptor.orderByColumns != null && tsDescriptor.orderByColumns.length > 0;
75
83
  const uniqueParams = (0, code_generator_1.removeDuplicatedParameters2)(tsDescriptor.parameters);
84
+ const uniqueUpdateParams = (0, code_generator_1.removeDuplicatedParameters2)(tsDescriptor.data || []);
85
+ const isUpdateCrud = isCrud && queryType == 'Update';
76
86
  writer.writeLine(`import { Database } from 'better-sqlite3';`);
87
+ if (uniqueUpdateParams.length > 0) {
88
+ writer.blankLine();
89
+ writer.write(`export type ${dataTypeName} =`).block(() => {
90
+ uniqueUpdateParams.forEach((field, index) => {
91
+ const optionalOp = field.notNull ? '' : '?';
92
+ if (!isUpdateCrud) {
93
+ writer.writeLine(`${field.name}${optionalOp}: ${field.tsType};`);
94
+ }
95
+ else if (index % 2 != 0) { //updateCrud-> :nameSet, :name, valueSet, :value...
96
+ const orNull = field.notNull ? '' : ' | null';
97
+ writer.writeLine(`${field.name}${optionalOp}: ${field.tsType}${orNull};`);
98
+ }
99
+ });
100
+ });
101
+ }
77
102
  if (uniqueParams.length > 0) {
78
103
  writer.blankLine();
79
104
  writer.write(`export type ${paramsTypeName} =`).block(() => {
80
105
  uniqueParams.forEach((field) => {
81
- writer.writeLine(`${field.name}: ${field.tsType};`);
106
+ const optionalOp = field.notNull ? '' : '?';
107
+ writer.writeLine(`${field.name}${optionalOp}: ${field.tsType};`);
82
108
  });
83
109
  });
84
110
  }
@@ -91,31 +117,64 @@ function generateCodeFromTsDescriptor(queryName, tsDescriptor) {
91
117
  });
92
118
  writer.blankLine();
93
119
  let functionArguments = `db: Database`;
120
+ functionArguments += queryType == 'Update' ? `, data: ${dataTypeName}` : '';
94
121
  functionArguments += tsDescriptor.parameters.length > 0 || generateOrderBy ? ', params: ' + paramsTypeName : '';
95
- const queryParams = tsDescriptor.parameters.length > 0 ? '[' + tsDescriptor.parameters.map(param => 'params.' + param.name).join(', ') + ']' : '';
122
+ const allParameters = (((_a = tsDescriptor.data) === null || _a === void 0 ? void 0 : _a.map((param, index) => {
123
+ if (isUpdateCrud && index % 2 == 0) {
124
+ const nextField = tsDescriptor.data[index + 1];
125
+ return `data.${nextField.name} !== undefined ? 1 : 0`;
126
+ }
127
+ else {
128
+ return 'data.' + toParamValue(param);
129
+ }
130
+ })) || [])
131
+ .concat(tsDescriptor.parameters.map(param => 'params.' + toParamValue(param)));
132
+ const queryParams = allParameters.length > 0 ? '[' + allParameters.join(', ') + ']' : '';
96
133
  const returnType = tsDescriptor.multipleRowsResult ? `${resultTypeName}[]` : `${resultTypeName} | null`;
97
- writer.write(`export function ${camelCaseName}(${functionArguments}): ${returnType}`).block(() => {
98
- const sqlSplit = sql.split('\n');
99
- writer.write('const sql = `').newLine();
100
- sqlSplit.forEach(sqlLine => {
101
- writer.indent().write(sqlLine).newLine();
134
+ if (queryType == 'Select') {
135
+ writer.write(`export function ${camelCaseName}(${functionArguments}): ${returnType}`).block(() => {
136
+ const sqlSplit = sql.split('\n');
137
+ writer.write('const sql = `').newLine();
138
+ sqlSplit.forEach(sqlLine => {
139
+ writer.indent().write(sqlLine).newLine();
140
+ });
141
+ writer.indent().write('`').newLine();
142
+ writer.write('return db.prepare(sql)').newLine();
143
+ writer.indent().write('.raw(true)').newLine();
144
+ writer.indent().write(`.all(${queryParams})`).newLine();
145
+ writer.indent().write(`.map(data => mapArrayTo${resultTypeName}(data))${tsDescriptor.multipleRowsResult ? '' : '[0]'};`);
102
146
  });
103
- writer.indent().write('`').newLine();
104
- writer.write('return db.prepare(sql)').newLine();
105
- writer.indent().write('.raw(true)').newLine();
106
- writer.indent().write(`.all(${queryParams})`).newLine();
107
- writer.indent().write(`.map(data => mapArrayTo${resultTypeName}(data))${tsDescriptor.multipleRowsResult ? '' : '[0]'};`);
108
- });
109
- writer.blankLine();
110
- writer.write(`function mapArrayTo${resultTypeName}(data: any) `).block(() => {
111
- writer.write(`const result: ${resultTypeName} = `).block(() => {
112
- tsDescriptor.columns.forEach((col, index) => {
113
- const separator = index < tsDescriptor.columns.length - 1 ? ',' : '';
114
- writer.writeLine(`${col.name}: data[${index}]${separator}`);
147
+ }
148
+ if (queryType == 'Insert' || queryType == 'Update' || queryType == 'Delete') {
149
+ writer.write(`export function ${camelCaseName}(${functionArguments}): ${resultTypeName}`).block(() => {
150
+ const sqlSplit = sql.split('\n');
151
+ writer.write('const sql = `').newLine();
152
+ sqlSplit.forEach(sqlLine => {
153
+ writer.indent().write(sqlLine).newLine();
115
154
  });
155
+ writer.indent().write('`').newLine();
156
+ writer.write('return db.prepare(sql)').newLine();
157
+ writer.indent().write(`.run(${queryParams}) as ${resultTypeName};`);
116
158
  });
117
- writer.writeLine('return result;');
118
- });
159
+ }
160
+ if (queryType == 'Select') {
161
+ writer.blankLine();
162
+ writer.write(`function mapArrayTo${resultTypeName}(data: any) `).block(() => {
163
+ writer.write(`const result: ${resultTypeName} = `).block(() => {
164
+ tsDescriptor.columns.forEach((col, index) => {
165
+ const separator = index < tsDescriptor.columns.length - 1 ? ',' : '';
166
+ writer.writeLine(`${col.name}: data[${index}]${separator}`);
167
+ });
168
+ });
169
+ writer.writeLine('return result;');
170
+ });
171
+ }
119
172
  return writer.toString();
120
173
  }
174
+ function toParamValue(param) {
175
+ if (param.tsType == 'Date') {
176
+ return param.name + '.toISOString()';
177
+ }
178
+ return param.name;
179
+ }
121
180
  //# sourceMappingURL=code-generator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"code-generator.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/code-generator.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"code-generator.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/code-generator.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,7 @@
1
1
  import { Either } from "fp-ts/lib/Either";
2
2
  import { SchemaDef, TypeSqlError } from "../types";
3
3
  import { ColumnSchema } from "../mysql-query-analyzer/types";
4
+ import { Database } from "better-sqlite3";
5
+ export declare function prepareAndParse(db: Database, sql: string, dbSchema: ColumnSchema[]): import("fp-ts/lib/Either").Left<TypeSqlError> | import("fp-ts/lib/Either").Right<SchemaDef>;
4
6
  export declare function parseSql(sql: string, dbSchema: ColumnSchema[]): Either<TypeSqlError, SchemaDef>;
5
7
  //# sourceMappingURL=parser.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"parser.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAS,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGjE,OAAO,EAAc,YAAY,EAAqC,MAAM,+BAA+B,CAAC;AAK5G,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,SAAS,CAAC,CAU/F"}
1
+ {"version":3,"file":"parser.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAuB,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGjE,OAAO,EAAc,YAAY,EAAqC,MAAM,+BAA+B,CAAC;AAK5G,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,wBAAgB,eAAe,CAAC,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,+FAUlF;AAED,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,SAAS,CAAC,CAO/F"}
@@ -1,20 +1,33 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseSql = void 0;
3
+ exports.parseSql = exports.prepareAndParse = void 0;
4
4
  const Either_1 = require("fp-ts/lib/Either");
5
5
  const sqlite_1 = require("@wsporto/ts-mysql-parser/dist/sqlite");
6
6
  const traverse_1 = require("./traverse");
7
7
  const collect_constraints_1 = require("../mysql-query-analyzer/collect-constraints");
8
8
  const unify_1 = require("../mysql-query-analyzer/unify");
9
9
  const describe_query_1 = require("../describe-query");
10
+ const query_executor_1 = require("./query-executor");
11
+ function prepareAndParse(db, sql, dbSchema) {
12
+ const { sql: processedSql } = (0, describe_query_1.preprocessSql)(sql);
13
+ const explainSqlResult = (0, query_executor_1.explainSql)(db, processedSql);
14
+ if ((0, Either_1.isLeft)(explainSqlResult)) {
15
+ return (0, Either_1.left)({
16
+ name: 'Invalid sql',
17
+ description: explainSqlResult.left.description
18
+ });
19
+ }
20
+ return parseSql(sql, dbSchema);
21
+ }
22
+ exports.prepareAndParse = prepareAndParse;
10
23
  function parseSql(sql, dbSchema) {
11
24
  const { sql: processedSql, namedParameters } = (0, describe_query_1.preprocessSql)(sql);
12
- const parser = (0, sqlite_1.parseSql)(sql);
25
+ const parser = (0, sqlite_1.parseSql)(processedSql);
13
26
  const sql_stmt = parser.sql_stmt();
14
- return describeSQL(processedSql, sql_stmt, dbSchema, namedParameters);
27
+ return createSchemaDefinition(processedSql, sql_stmt, dbSchema, namedParameters);
15
28
  }
16
29
  exports.parseSql = parseSql;
17
- function describeSQL(sql, sql_stmtContext, dbSchema, namedParameters) {
30
+ function createSchemaDefinition(sql, sql_stmtContext, dbSchema, namedParameters) {
18
31
  const traverseContext = {
19
32
  dbSchema,
20
33
  withSchema: [],
@@ -34,34 +47,145 @@ function describeSQL(sql, sql_stmtContext, dbSchema, namedParameters) {
34
47
  const queryResult = (0, traverse_1.traverse_Sql_stmtContext)(sql_stmtContext, traverseContext);
35
48
  const substitutions = {}; //TODO - DUPLICADO
36
49
  (0, unify_1.unify)(traverseContext.constraints, substitutions);
37
- const columnResult = queryResult.columns.map((col) => {
38
- const columnType = (0, collect_constraints_1.getVarType)(substitutions, col.type);
39
- const columnNotNull = col.notNull;
40
- const colInfo = {
41
- columnName: col.name,
42
- type: (0, describe_query_1.verifyNotInferred)(columnType),
43
- notNull: columnNotNull,
44
- table: col.table
50
+ if (queryResult.queryType == 'Select') {
51
+ const columnResult = queryResult.columns.map((col) => {
52
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, col.type);
53
+ const columnNotNull = col.notNull;
54
+ const colInfo = {
55
+ columnName: col.name,
56
+ type: (0, describe_query_1.verifyNotInferred)(columnType),
57
+ notNull: columnNotNull,
58
+ table: col.table
59
+ };
60
+ return colInfo;
61
+ });
62
+ const paramsResult = traverseContext.parameters.map((param, index) => {
63
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param.type);
64
+ const columnNotNull = param.notNull;
65
+ const colInfo = {
66
+ name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
67
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
68
+ notNull: columnNotNull
69
+ };
70
+ return colInfo;
71
+ });
72
+ const schemaDef = {
73
+ sql,
74
+ queryType: queryResult.queryType,
75
+ multipleRowsResult: queryResult.multipleRowsResult,
76
+ columns: columnResult,
77
+ parameters: paramsResult,
45
78
  };
46
- return colInfo;
47
- });
48
- const paramsResult = traverseContext.parameters.map((param, index) => {
49
- const columnType = (0, collect_constraints_1.getVarType)(substitutions, param);
50
- const columnNotNull = true; // param.notNull;
51
- const colInfo = {
52
- name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
53
- columnType: (0, describe_query_1.verifyNotInferred)(columnType),
54
- notNull: columnNotNull
79
+ return (0, Either_1.right)(schemaDef);
80
+ }
81
+ if (queryResult.queryType == 'Insert') {
82
+ const insertColumnResult = [
83
+ {
84
+ columnName: 'changes',
85
+ type: 'INTEGER',
86
+ notNull: true
87
+ },
88
+ {
89
+ columnName: 'lastInsertRowid',
90
+ type: 'INTEGER',
91
+ notNull: true
92
+ }
93
+ ];
94
+ const paramsResult = queryResult.columns.map((param, index) => {
95
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param.type);
96
+ const columnNotNull = param.notNull;
97
+ const colInfo = {
98
+ name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
99
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
100
+ notNull: columnNotNull
101
+ };
102
+ return colInfo;
103
+ });
104
+ const schemaDef = {
105
+ sql,
106
+ queryType: queryResult.queryType,
107
+ multipleRowsResult: false,
108
+ columns: insertColumnResult,
109
+ parameters: paramsResult
55
110
  };
56
- return colInfo;
57
- });
58
- const schemaDef = {
59
- sql,
60
- queryType: "Select",
61
- multipleRowsResult: (0, traverse_1.isMultipleRowResult)(sql_stmtContext, queryResult.fromColumns),
62
- columns: columnResult,
63
- parameters: paramsResult
64
- };
65
- return (0, Either_1.right)(schemaDef);
111
+ return (0, Either_1.right)(schemaDef);
112
+ }
113
+ if (queryResult.queryType == 'Update') {
114
+ const updateColumnResult = [
115
+ {
116
+ columnName: 'changes',
117
+ type: 'INTEGER',
118
+ notNull: true
119
+ },
120
+ {
121
+ columnName: 'lastInsertRowid',
122
+ type: 'INTEGER',
123
+ notNull: true
124
+ }
125
+ ];
126
+ const paramsResult = queryResult.columns.map((param, index) => {
127
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param.type);
128
+ const columnNotNull = param.notNull;
129
+ const colInfo = {
130
+ name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
131
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
132
+ notNull: columnNotNull
133
+ };
134
+ return colInfo;
135
+ });
136
+ const whereParams = queryResult.params.map((param, index) => {
137
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param.type);
138
+ const columnNotNull = param.notNull;
139
+ const paramIndex = index + queryResult.columns.length;
140
+ const colInfo = {
141
+ name: namedParameters && namedParameters[paramIndex] ? namedParameters[paramIndex] : 'param' + (index + 1),
142
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
143
+ notNull: columnNotNull
144
+ };
145
+ return colInfo;
146
+ });
147
+ const schemaDef = {
148
+ sql,
149
+ queryType: queryResult.queryType,
150
+ multipleRowsResult: false,
151
+ columns: updateColumnResult,
152
+ data: paramsResult,
153
+ parameters: whereParams
154
+ };
155
+ return (0, Either_1.right)(schemaDef);
156
+ }
157
+ if (queryResult.queryType == 'Delete') {
158
+ const deleteColumnResult = [
159
+ {
160
+ columnName: 'changes',
161
+ type: 'INTEGER',
162
+ notNull: true
163
+ },
164
+ {
165
+ columnName: 'lastInsertRowid',
166
+ type: 'INTEGER',
167
+ notNull: true
168
+ }
169
+ ];
170
+ const whereParams = queryResult.params.map((param, index) => {
171
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param.type);
172
+ const columnNotNull = param.notNull;
173
+ const colInfo = {
174
+ name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
175
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
176
+ notNull: columnNotNull
177
+ };
178
+ return colInfo;
179
+ });
180
+ const schemaDef = {
181
+ sql,
182
+ queryType: queryResult.queryType,
183
+ multipleRowsResult: false,
184
+ columns: deleteColumnResult,
185
+ parameters: whereParams
186
+ };
187
+ return (0, Either_1.right)(schemaDef);
188
+ }
189
+ throw Error('query not supported: ' + sql_stmtContext.getText());
66
190
  }
67
191
  //# sourceMappingURL=parser.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":";;;AAAA,6CAAiD;AAEjD,iEAAgG;AAChG,yCAA2E;AAE3E,qFAAyE;AACzE,yDAAsD;AACtD,sDAAqE;AAErE,SAAgB,QAAQ,CAAC,GAAW,EAAE,QAAwB;IAE1D,MAAM,EAAE,GAAG,EAAE,YAAY,EAAE,eAAe,EAAE,GAAG,IAAA,8BAAa,EAAC,GAAG,CAAC,CAAC;IAElE,MAAM,MAAM,GAAG,IAAA,iBAAW,EAAC,GAAG,CAAC,CAAC;IAEhC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;IAEnC,OAAO,WAAW,CAAC,YAAY,EAAE,QAAQ,EAAE,QAAQ,EAAE,eAAe,CAAC,CAAC;AAE1E,CAAC;AAVD,4BAUC;AAED,SAAS,WAAW,CAAC,GAAW,EAAE,eAAgC,EAAE,QAAwB,EAAE,eAAyB;IAEnH,MAAM,eAAe,GAAoB;QACrC,QAAQ;QACR,UAAU,EAAE,EAAE;QACd,WAAW,EAAE,EAAE;QACf,UAAU,EAAE,EAAE;QACd,WAAW,EAAE,EAAE;QACf,eAAe,EAAE,EAAE;QACnB,QAAQ,EAAE,KAAK;QACf,KAAK,EAAE,KAAK;QACZ,cAAc,EAAE;YACZ,IAAI,EAAE,EAAE;YACR,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,EAAE;YACR,KAAK,EAAE,EAAE;SACZ;KACJ,CAAA;IAED,MAAM,WAAW,GAAG,IAAA,mCAAwB,EAAC,eAAe,EAAE,eAAe,CAAC,CAAC;IAE/E,MAAM,aAAa,GAAqB,EAAE,CAAA,CAAC,kBAAkB;IAC7D,IAAA,aAAK,EAAC,eAAe,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IAClD,MAAM,YAAY,GAAG,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QACjD,MAAM,UAAU,GAAG,IAAA,gCAAU,EAAC,aAAa,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;QACvD,MAAM,aAAa,GAAG,GAAG,CAAC,OAAO,CAAC;QAClC,MAAM,OAAO,GAAe;YACxB,UAAU,EAAE,GAAG,CAAC,IAAI;YACpB,IAAI,EAAE,IAAA,kCAAiB,EAAC,UAAU,CAAC;YACnC,OAAO,EAAE,aAAa;YACtB,KAAK,EAAE,GAAG,CAAC,KAAK;SACnB,CAAA;QACD,OAAO,OAAO,CAAC;IACnB,CAAC,CAAC,CAAA;IACF,MAAM,YAAY,GAAG,eAAe,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QACjE,MAAM,UAAU,GAAG,IAAA,gCAAU,EAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QACpD,MAAM,aAAa,GAAG,IAAI,CAAC,CAAA,iBAAiB;QAC5C,MAAM,OAAO,GAAiB;YAC1B,IAAI,EAAE,eAAe,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC;YAChG,UAAU,EAAE,IAAA,kCAAiB,EAAC,UAAU,CAAC;YACzC,OAAO,EAAE,aAAa;SACzB,CAAA;QACD,OAAO,OAAO,CAAC;IACnB,CAAC,CAAC,CAAA;IAEF,MAAM,SAAS,GAAc;QACzB,GAAG;QACH,SAAS,EAAE,QAAQ;QACnB,kBAAkB,EAAE,IAAA,8BAAmB,EAAC,eAAe,EAAE,WAAW,CAAC,WAAW,CAAC;QACjF,OAAO,EAAE,YAAY;QACrB,UAAU,EAAE,YAAY;KAC3B,CAAA;IACD,OAAO,IAAA,cAAK,EAAC,SAAS,CAAC,CAAC;AAC5B,CAAC"}
1
+ {"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,9 @@
1
1
  import { Either } from "fp-ts/lib/Either";
2
- import { TypeSqlError } from "../types";
3
- import { ColumnSchema } from "../mysql-query-analyzer/types";
4
- export declare function loadDbSchema(databaseUri: string): Either<TypeSqlError, ColumnSchema[]>;
2
+ import { DatabaseClient, TypeSqlError } from "../types";
3
+ import { ColumnSchema, Table } from "../mysql-query-analyzer/types";
4
+ import { Database as DatabaseType } from 'better-sqlite3';
5
+ export declare function createSqliteClient(databaseUri: string): Either<TypeSqlError, DatabaseClient>;
6
+ export declare function loadDbSchema(db: DatabaseType): Either<TypeSqlError, ColumnSchema[]>;
7
+ export declare function selectSqliteTablesFromSchema(db: DatabaseType): Either<TypeSqlError, Table[]>;
8
+ export declare function explainSql(db: DatabaseType, sql: string): Either<TypeSqlError, boolean>;
5
9
  //# sourceMappingURL=query-executor.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"query-executor.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAS,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAG7D,wBAAgB,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC,YAAY,EAAE,YAAY,EAAE,CAAC,CAoBtF"}
1
+ {"version":3,"file":"query-executor.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAe,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAiB,EAAE,QAAQ,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEpE,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC,YAAY,EAAE,cAAc,CAAC,CAM5F;AAED,wBAAgB,YAAY,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAAC,YAAY,EAAE,YAAY,EAAE,CAAC,CAiCnF;AAED,wBAAgB,4BAA4B,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAAC,YAAY,EAAE,KAAK,EAAE,CAAC,CAsB5F;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,YAAY,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,CAYvF"}
@@ -3,11 +3,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.loadDbSchema = void 0;
6
+ exports.explainSql = exports.selectSqliteTablesFromSchema = exports.loadDbSchema = exports.createSqliteClient = void 0;
7
7
  const Either_1 = require("fp-ts/lib/Either");
8
8
  const better_sqlite3_1 = __importDefault(require("better-sqlite3"));
9
- function loadDbSchema(databaseUri) {
9
+ function createSqliteClient(databaseUri) {
10
10
  const db = new better_sqlite3_1.default(databaseUri);
11
+ return (0, Either_1.right)({
12
+ type: 'sqlite',
13
+ client: db
14
+ });
15
+ }
16
+ exports.createSqliteClient = createSqliteClient;
17
+ function loadDbSchema(db) {
11
18
  const sql = `
12
19
  WITH all_tables AS (
13
20
  SELECT name FROM sqlite_schema WHERE type = 'table'
@@ -16,14 +23,66 @@ function loadDbSchema(databaseUri) {
16
23
  '' AS schema,
17
24
  t.name as 'table',
18
25
  ti.name as 'column',
19
- ti.type as column_type,
26
+ CASE
27
+ WHEN ti.type LIKE '%INT%' THEN 'INTEGER'
28
+ WHEN ti.type LIKE '%CHAR%' OR ti.type LIKE '%CLOB%' OR ti.type like '%TEXT%' THEN 'TEXT'
29
+ WHEN ti.type LIKE '%BLOB%' OR ti.type = '' THEN 'BLOB'
30
+ WHEN ti.type LIKE '%REAL%' OR ti.type LIKE '%FLOA%' OR ti.type like '%DOUB%' THEN 'REAL'
31
+ ELSE 'NUMERIC'
32
+ END as column_type,
20
33
  ti.'notnull' or ti.pk = 1 as 'notNull',
21
34
  IIF(ti.pk = 1, 'PRI', '') as columnKey
22
35
  FROM all_tables t INNER JOIN pragma_table_info(t.name) ti
23
36
  `;
24
- const result = db.prepare(sql)
25
- .all();
26
- return (0, Either_1.right)(result);
37
+ try {
38
+ const result = db.prepare(sql)
39
+ .all();
40
+ return (0, Either_1.right)(result.map(col => (Object.assign(Object.assign({}, col), { notNull: !!col.notNull }))));
41
+ }
42
+ catch (err_) {
43
+ const err = err_;
44
+ return (0, Either_1.left)({
45
+ name: err.name,
46
+ description: err.message
47
+ });
48
+ }
27
49
  }
28
50
  exports.loadDbSchema = loadDbSchema;
51
+ function selectSqliteTablesFromSchema(db) {
52
+ const sql = `
53
+ SELECT
54
+ '' as schema,
55
+ name as 'table'
56
+ FROM sqlite_schema
57
+ WHERE type='table'
58
+ ORDER BY name
59
+ `;
60
+ try {
61
+ const result = db.prepare(sql)
62
+ .all();
63
+ return (0, Either_1.right)(result);
64
+ }
65
+ catch (e) {
66
+ const err = e;
67
+ return (0, Either_1.left)({
68
+ name: err.name,
69
+ description: err.message
70
+ });
71
+ }
72
+ }
73
+ exports.selectSqliteTablesFromSchema = selectSqliteTablesFromSchema;
74
+ function explainSql(db, sql) {
75
+ try {
76
+ db.prepare(sql);
77
+ return (0, Either_1.right)(true);
78
+ }
79
+ catch (err_) {
80
+ const err = err_;
81
+ return (0, Either_1.left)({
82
+ name: err.name,
83
+ description: err.message
84
+ });
85
+ }
86
+ }
87
+ exports.explainSql = explainSql;
29
88
  //# sourceMappingURL=query-executor.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"query-executor.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAiD;AAGjD,oEAAsC;AAEtC,SAAgB,YAAY,CAAC,WAAmB;IAE/C,MAAM,EAAE,GAAG,IAAI,wBAAQ,CAAC,WAAW,CAAC,CAAC;IACrC,MAAM,GAAG,GAAG;;;;;;;;;;;;GAYV,CAAA;IAEF,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;SAC5B,GAAG,EAAoB,CAAC;IAC1B,OAAO,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC;AACtB,CAAC;AApBD,oCAoBC"}
1
+ {"version":3,"file":"query-executor.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAuD;AAGvD,oEAAoE;AAEpE,SAAgB,kBAAkB,CAAC,WAAmB;IACrD,MAAM,EAAE,GAAG,IAAI,wBAAQ,CAAC,WAAW,CAAC,CAAC;IACrC,OAAO,IAAA,cAAK,EAAC;QACZ,IAAI,EAAE,QAAQ;QACd,MAAM,EAAE,EAAE;KACV,CAAC,CAAC;AACJ,CAAC;AAND,gDAMC;AAED,SAAgB,YAAY,CAAC,EAAgB;IAE5C,MAAM,GAAG,GAAG;;;;;;;;;;;;;;;;;;GAkBV,CAAA;IACF,IAAI,CAAC;QACJ,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;aAC5B,GAAG,EAAoB,CAAC;QAC1B,OAAO,IAAA,cAAK,EAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,iCAAM,GAAG,KAAE,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,IAAG,CAAC,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,IAAI,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,IAAa,CAAC;QAC1B,OAAO,IAAA,aAAI,EAAC;YACX,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,OAAO;SACxB,CAAC,CAAA;IACH,CAAC;AACF,CAAC;AAjCD,oCAiCC;AAED,SAAgB,4BAA4B,CAAC,EAAgB;IAC5D,MAAM,GAAG,GAAG;;;;;;;KAOR,CAAA;IAEJ,IAAI,CAAC;QACJ,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;aAC5B,GAAG,EAAa,CAAC;QACnB,OAAO,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC;IACtB,CAAC;IACD,OAAO,CAAC,EAAE,CAAC;QACV,MAAM,GAAG,GAAG,CAAU,CAAC;QACvB,OAAO,IAAA,aAAI,EAAC;YACX,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,OAAO;SACxB,CAAC,CAAC;IACJ,CAAC;AACF,CAAC;AAtBD,oEAsBC;AAED,SAAgB,UAAU,CAAC,EAAgB,EAAE,GAAW;IACvD,IAAI,CAAC;QACJ,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAChB,OAAO,IAAA,cAAK,EAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IACD,OAAO,IAAI,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,IAAa,CAAC;QAC1B,OAAO,IAAA,aAAI,EAAC;YACX,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,OAAO;SACxB,CAAC,CAAA;IACH,CAAC;AACF,CAAC;AAZD,gCAYC"}
@@ -0,0 +1,6 @@
1
+ import { ColumnSchema } from "./mysql-query-analyzer/types";
2
+ export declare function generateSelectStatement(tableName: string, columns: ColumnSchema[]): string;
3
+ export declare function generateInsertStatement(tableName: string, dbSchema: ColumnSchema[]): string;
4
+ export declare function generateUpdateStatement(tableName: string, dbSchema: ColumnSchema[]): string;
5
+ export declare function generateDeleteStatement(tableName: string, dbSchema: ColumnSchema[]): string;
6
+ //# sourceMappingURL=sql-generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-generator.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/sql-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAG5D,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,UAuBjF;AAED,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,UAwBlF;AAED,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,UAsBlF;AAED,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,UAclF"}