@datachonk/cli 0.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 (86) hide show
  1. package/README.md +200 -0
  2. package/dist/__tests__/cache.test.d.ts +2 -0
  3. package/dist/__tests__/cache.test.d.ts.map +1 -0
  4. package/dist/__tests__/cache.test.js +40 -0
  5. package/dist/__tests__/cache.test.js.map +1 -0
  6. package/dist/__tests__/config.test.d.ts +2 -0
  7. package/dist/__tests__/config.test.d.ts.map +1 -0
  8. package/dist/__tests__/config.test.js +113 -0
  9. package/dist/__tests__/config.test.js.map +1 -0
  10. package/dist/__tests__/templates.test.d.ts +2 -0
  11. package/dist/__tests__/templates.test.d.ts.map +1 -0
  12. package/dist/__tests__/templates.test.js +51 -0
  13. package/dist/__tests__/templates.test.js.map +1 -0
  14. package/dist/commands/analyze.d.ts +10 -0
  15. package/dist/commands/analyze.d.ts.map +1 -0
  16. package/dist/commands/analyze.js +156 -0
  17. package/dist/commands/analyze.js.map +1 -0
  18. package/dist/commands/chat.d.ts +3 -0
  19. package/dist/commands/chat.d.ts.map +1 -0
  20. package/dist/commands/chat.js +121 -0
  21. package/dist/commands/chat.js.map +1 -0
  22. package/dist/commands/config.d.ts +2 -0
  23. package/dist/commands/config.d.ts.map +1 -0
  24. package/dist/commands/config.js +287 -0
  25. package/dist/commands/config.js.map +1 -0
  26. package/dist/commands/docs.d.ts +7 -0
  27. package/dist/commands/docs.d.ts.map +1 -0
  28. package/dist/commands/docs.js +208 -0
  29. package/dist/commands/docs.js.map +1 -0
  30. package/dist/commands/generate.d.ts +9 -0
  31. package/dist/commands/generate.d.ts.map +1 -0
  32. package/dist/commands/generate.js +130 -0
  33. package/dist/commands/generate.js.map +1 -0
  34. package/dist/commands/init.d.ts +7 -0
  35. package/dist/commands/init.d.ts.map +1 -0
  36. package/dist/commands/init.js +149 -0
  37. package/dist/commands/init.js.map +1 -0
  38. package/dist/commands/lineage.d.ts +9 -0
  39. package/dist/commands/lineage.d.ts.map +1 -0
  40. package/dist/commands/lineage.js +186 -0
  41. package/dist/commands/lineage.js.map +1 -0
  42. package/dist/commands/migrate.d.ts +3 -0
  43. package/dist/commands/migrate.d.ts.map +1 -0
  44. package/dist/commands/migrate.js +213 -0
  45. package/dist/commands/migrate.js.map +1 -0
  46. package/dist/commands/review.d.ts +8 -0
  47. package/dist/commands/review.d.ts.map +1 -0
  48. package/dist/commands/review.js +215 -0
  49. package/dist/commands/review.js.map +1 -0
  50. package/dist/commands/scan.d.ts +18 -0
  51. package/dist/commands/scan.d.ts.map +1 -0
  52. package/dist/commands/scan.js +335 -0
  53. package/dist/commands/scan.js.map +1 -0
  54. package/dist/commands/test.d.ts +3 -0
  55. package/dist/commands/test.d.ts.map +1 -0
  56. package/dist/commands/test.js +244 -0
  57. package/dist/commands/test.js.map +1 -0
  58. package/dist/index.d.ts +3 -0
  59. package/dist/index.d.ts.map +1 -0
  60. package/dist/index.js +232 -0
  61. package/dist/index.js.map +1 -0
  62. package/dist/utils/analyzer.d.ts +39 -0
  63. package/dist/utils/analyzer.d.ts.map +1 -0
  64. package/dist/utils/analyzer.js +310 -0
  65. package/dist/utils/analyzer.js.map +1 -0
  66. package/dist/utils/cache.d.ts +98 -0
  67. package/dist/utils/cache.d.ts.map +1 -0
  68. package/dist/utils/cache.js +253 -0
  69. package/dist/utils/cache.js.map +1 -0
  70. package/dist/utils/config.d.ts +56 -0
  71. package/dist/utils/config.d.ts.map +1 -0
  72. package/dist/utils/config.js +108 -0
  73. package/dist/utils/config.js.map +1 -0
  74. package/dist/utils/generators.d.ts +8 -0
  75. package/dist/utils/generators.d.ts.map +1 -0
  76. package/dist/utils/generators.js +265 -0
  77. package/dist/utils/generators.js.map +1 -0
  78. package/dist/utils/plugins.d.ts +94 -0
  79. package/dist/utils/plugins.d.ts.map +1 -0
  80. package/dist/utils/plugins.js +164 -0
  81. package/dist/utils/plugins.js.map +1 -0
  82. package/dist/utils/templates.d.ts +57 -0
  83. package/dist/utils/templates.d.ts.map +1 -0
  84. package/dist/utils/templates.js +458 -0
  85. package/dist/utils/templates.js.map +1 -0
  86. package/package.json +69 -0
@@ -0,0 +1,213 @@
1
+ import { Command } from "commander";
2
+ import chalk from "chalk";
3
+ import ora from "ora";
4
+ import * as fs from "fs";
5
+ import * as path from "path";
6
+ import { glob } from "glob";
7
+ const SQL_MAPPINGS = {
8
+ // Date functions
9
+ "GETDATE()": {
10
+ snowflake: "CURRENT_TIMESTAMP()",
11
+ bigquery: "CURRENT_TIMESTAMP()",
12
+ redshift: "GETDATE()",
13
+ databricks: "CURRENT_TIMESTAMP()",
14
+ postgres: "NOW()",
15
+ },
16
+ "DATEADD": {
17
+ snowflake: "DATEADD",
18
+ bigquery: "DATE_ADD",
19
+ redshift: "DATEADD",
20
+ databricks: "DATE_ADD",
21
+ postgres: "DATE + INTERVAL",
22
+ },
23
+ "DATEDIFF": {
24
+ snowflake: "DATEDIFF",
25
+ bigquery: "DATE_DIFF",
26
+ redshift: "DATEDIFF",
27
+ databricks: "DATEDIFF",
28
+ postgres: "DATE_PART",
29
+ },
30
+ "NVL": {
31
+ snowflake: "NVL",
32
+ bigquery: "IFNULL",
33
+ redshift: "NVL",
34
+ databricks: "NVL",
35
+ postgres: "COALESCE",
36
+ },
37
+ "DECODE": {
38
+ snowflake: "DECODE",
39
+ bigquery: "CASE",
40
+ redshift: "DECODE",
41
+ databricks: "CASE",
42
+ postgres: "CASE",
43
+ },
44
+ "TO_DATE": {
45
+ snowflake: "TO_DATE",
46
+ bigquery: "PARSE_DATE",
47
+ redshift: "TO_DATE",
48
+ databricks: "TO_DATE",
49
+ postgres: "TO_DATE",
50
+ },
51
+ "LISTAGG": {
52
+ snowflake: "LISTAGG",
53
+ bigquery: "STRING_AGG",
54
+ redshift: "LISTAGG",
55
+ databricks: "COLLECT_LIST",
56
+ postgres: "STRING_AGG",
57
+ },
58
+ "ROWNUM": {
59
+ snowflake: "ROW_NUMBER() OVER ()",
60
+ bigquery: "ROW_NUMBER() OVER ()",
61
+ redshift: "ROW_NUMBER() OVER ()",
62
+ databricks: "ROW_NUMBER() OVER ()",
63
+ postgres: "ROW_NUMBER() OVER ()",
64
+ },
65
+ };
66
+ export const migrateCommand = new Command("migrate")
67
+ .description("Migrate SQL syntax between warehouse platforms")
68
+ .option("-f, --from <warehouse>", "Source warehouse", "redshift")
69
+ .option("-t, --to <warehouse>", "Target warehouse", "snowflake")
70
+ .option("-p, --path <path>", "Path to migrate (file or directory)", ".")
71
+ .option("--dry-run", "Show changes without applying")
72
+ .option("-o, --output <path>", "Output directory for migrated files")
73
+ .action(async (options) => {
74
+ const from = options.from.toLowerCase();
75
+ const to = options.to.toLowerCase();
76
+ console.log(chalk.cyan.bold("\nšŸ”„ DataChonk SQL Migration Tool\n"));
77
+ console.log(chalk.gray(`Migrating from ${chalk.bold(from)} to ${chalk.bold(to)}\n`));
78
+ const spinner = ora("Discovering files...").start();
79
+ try {
80
+ const targetPath = path.resolve(options.path);
81
+ const stat = fs.statSync(targetPath);
82
+ let files = [];
83
+ if (stat.isDirectory()) {
84
+ files = await glob("**/*.sql", { cwd: targetPath });
85
+ files = files.map(f => path.join(targetPath, f));
86
+ }
87
+ else {
88
+ files = [targetPath];
89
+ }
90
+ spinner.succeed(`Found ${files.length} SQL file(s)`);
91
+ let totalChanges = 0;
92
+ const changedFiles = [];
93
+ for (const file of files) {
94
+ const originalContent = fs.readFileSync(file, "utf-8");
95
+ const { content: migratedContent, changes } = migrateSql(originalContent, from, to);
96
+ if (changes.length > 0) {
97
+ totalChanges += changes.length;
98
+ changedFiles.push(file);
99
+ console.log(chalk.bold(`\nšŸ“„ ${path.relative(process.cwd(), file)}`));
100
+ for (const change of changes) {
101
+ console.log(chalk.gray(` Line ${change.line}: `) +
102
+ chalk.red(change.from) +
103
+ chalk.gray(" → ") +
104
+ chalk.green(change.to));
105
+ }
106
+ if (!options.dryRun) {
107
+ const outputPath = options.output
108
+ ? path.join(options.output, path.relative(targetPath, file))
109
+ : file;
110
+ if (options.output) {
111
+ fs.mkdirSync(path.dirname(outputPath), { recursive: true });
112
+ }
113
+ fs.writeFileSync(outputPath, migratedContent);
114
+ console.log(chalk.green(` āœ“ Written to ${path.relative(process.cwd(), outputPath)}`));
115
+ }
116
+ }
117
+ }
118
+ // Summary
119
+ console.log("\n" + "─".repeat(60));
120
+ console.log(chalk.bold("Migration Summary:"));
121
+ console.log(` Files scanned: ${files.length}`);
122
+ console.log(` Files changed: ${changedFiles.length}`);
123
+ console.log(` Total changes: ${totalChanges}`);
124
+ if (options.dryRun) {
125
+ console.log(chalk.yellow("\n Dry run - no files were modified"));
126
+ }
127
+ // Provide additional guidance
128
+ console.log(chalk.cyan("\n\nšŸ“ Post-Migration Checklist:"));
129
+ console.log(chalk.gray(` 1. Review data type mappings (especially VARIANT, ARRAY, STRUCT)`));
130
+ console.log(chalk.gray(` 2. Update warehouse-specific functions not covered`));
131
+ console.log(chalk.gray(` 3. Test incremental logic and merge strategies`));
132
+ console.log(chalk.gray(` 4. Validate partition/cluster key syntax`));
133
+ console.log(chalk.gray(` 5. Run dbt compile to catch syntax errors\n`));
134
+ }
135
+ catch (error) {
136
+ spinner.fail("Migration failed");
137
+ console.error(error);
138
+ process.exit(1);
139
+ }
140
+ });
141
+ function migrateSql(content, from, to) {
142
+ const changes = [];
143
+ const lines = content.split("\n");
144
+ const migratedLines = lines.map((line, index) => {
145
+ let newLine = line;
146
+ // Apply mappings
147
+ for (const [pattern, mapping] of Object.entries(SQL_MAPPINGS)) {
148
+ const regex = new RegExp(pattern.replace(/[()]/g, "\\$&"), "gi");
149
+ if (regex.test(line)) {
150
+ const fromSyntax = mapping[from] || pattern;
151
+ const toSyntax = mapping[to];
152
+ if (fromSyntax !== toSyntax) {
153
+ const fromRegex = new RegExp(fromSyntax.replace(/[()]/g, "\\$&"), "gi");
154
+ if (fromRegex.test(line)) {
155
+ newLine = line.replace(fromRegex, toSyntax);
156
+ changes.push({
157
+ line: index + 1,
158
+ from: fromSyntax,
159
+ to: toSyntax,
160
+ });
161
+ }
162
+ }
163
+ }
164
+ }
165
+ // Warehouse-specific transformations
166
+ newLine = applyWarehouseSpecificMigrations(newLine, from, to, index + 1, changes);
167
+ return newLine;
168
+ });
169
+ return { content: migratedLines.join("\n"), changes };
170
+ }
171
+ function applyWarehouseSpecificMigrations(line, from, to, lineNum, changes) {
172
+ let newLine = line;
173
+ // Redshift to Snowflake specific
174
+ if (from === "redshift" && to === "snowflake") {
175
+ // IDENTITY columns
176
+ if (/IDENTITY\s*\(\s*\d+\s*,\s*\d+\s*\)/i.test(line)) {
177
+ newLine = line.replace(/IDENTITY\s*\(\s*\d+\s*,\s*\d+\s*\)/gi, "AUTOINCREMENT");
178
+ changes.push({ line: lineNum, from: "IDENTITY(x,x)", to: "AUTOINCREMENT" });
179
+ }
180
+ // DISTKEY/SORTKEY (Snowflake doesn't use these)
181
+ if (/DISTKEY\s*\([^)]+\)/i.test(line)) {
182
+ newLine = line.replace(/DISTKEY\s*\([^)]+\)/gi, "/* DISTKEY removed */");
183
+ changes.push({ line: lineNum, from: "DISTKEY", to: "/* removed */" });
184
+ }
185
+ if (/SORTKEY\s*\([^)]+\)/i.test(line)) {
186
+ newLine = line.replace(/SORTKEY\s*\([^)]+\)/gi, "/* SORTKEY removed */");
187
+ changes.push({ line: lineNum, from: "SORTKEY", to: "/* removed */" });
188
+ }
189
+ }
190
+ // BigQuery specific
191
+ if (to === "bigquery") {
192
+ // SAFE_DIVIDE instead of /
193
+ if (/\/\s*0/.test(line) || /divide.*by.*zero/i.test(line)) {
194
+ // Add comment suggesting SAFE_DIVIDE
195
+ changes.push({ line: lineNum, from: "division", to: "consider SAFE_DIVIDE()" });
196
+ }
197
+ // STRUCT syntax
198
+ if (/ROW\s*\(/i.test(line)) {
199
+ newLine = line.replace(/ROW\s*\(/gi, "STRUCT(");
200
+ changes.push({ line: lineNum, from: "ROW(", to: "STRUCT(" });
201
+ }
202
+ }
203
+ // Databricks specific
204
+ if (to === "databricks") {
205
+ // Delta Lake table format
206
+ if (/CREATE\s+TABLE/i.test(line) && !line.includes("USING DELTA")) {
207
+ newLine = line.replace(/(CREATE\s+TABLE)/i, "$1 /* Consider USING DELTA */");
208
+ changes.push({ line: lineNum, from: "CREATE TABLE", to: "USING DELTA suggested" });
209
+ }
210
+ }
211
+ return newLine;
212
+ }
213
+ //# sourceMappingURL=migrate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../src/commands/migrate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ interface ReviewOptions {
2
+ strict?: boolean;
3
+ json?: boolean;
4
+ local?: boolean;
5
+ }
6
+ export declare function reviewCommand(files: string[], options: ReviewOptions): Promise<void>;
7
+ export {};
8
+ //# sourceMappingURL=review.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.d.ts","sourceRoot":"","sources":["../../src/commands/review.ts"],"names":[],"mappings":"AAMA,UAAU,aAAa;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,wBAAsB,aAAa,CACjC,KAAK,EAAE,MAAM,EAAE,EACf,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,IAAI,CAAC,CAgRf"}
@@ -0,0 +1,215 @@
1
+ import chalk from "chalk";
2
+ import ora from "ora";
3
+ import { readFileSync, existsSync } from "fs";
4
+ import { execSync } from "child_process";
5
+ import { loadConfig } from "../utils/config.js";
6
+ export async function reviewCommand(files, options) {
7
+ const spinner = ora("Preparing code review...").start();
8
+ try {
9
+ const config = loadConfig(".");
10
+ const apiKey = config.ai?.apiKey || process.env.DATACHONK_API_KEY;
11
+ // If no files specified, get staged git files
12
+ if (files.length === 0) {
13
+ try {
14
+ const stagedFiles = execSync("git diff --cached --name-only --diff-filter=ACMR", {
15
+ encoding: "utf-8",
16
+ })
17
+ .split("\n")
18
+ .filter(f => f.endsWith(".sql") || f.endsWith(".yml"));
19
+ if (stagedFiles.length === 0) {
20
+ const modifiedFiles = execSync("git diff --name-only --diff-filter=ACMR", {
21
+ encoding: "utf-8",
22
+ })
23
+ .split("\n")
24
+ .filter(f => f.endsWith(".sql") || f.endsWith(".yml"));
25
+ files = modifiedFiles;
26
+ }
27
+ else {
28
+ files = stagedFiles;
29
+ }
30
+ }
31
+ catch {
32
+ spinner.fail("No files to review. Specify files or run in a git repository.");
33
+ process.exit(1);
34
+ }
35
+ }
36
+ if (files.length === 0) {
37
+ spinner.fail("No SQL files to review");
38
+ process.exit(1);
39
+ }
40
+ spinner.text = `Reviewing ${files.length} file(s)...`;
41
+ // Read file contents and diffs
42
+ const fileData = files
43
+ .filter(f => existsSync(f))
44
+ .map(file => {
45
+ const content = readFileSync(file, "utf-8");
46
+ let diff;
47
+ try {
48
+ diff = execSync(`git diff HEAD -- "${file}"`, { encoding: "utf-8" });
49
+ }
50
+ catch {
51
+ // Not in git or no diff
52
+ }
53
+ return { path: file, content, diff };
54
+ });
55
+ // Get PR info if available
56
+ let prTitle;
57
+ let prDescription;
58
+ let baseBranch;
59
+ try {
60
+ baseBranch = execSync("git rev-parse --abbrev-ref HEAD", { encoding: "utf-8" }).trim();
61
+ }
62
+ catch {
63
+ // Ignore
64
+ }
65
+ // Use AI-powered review via API
66
+ if (apiKey && !options.local) {
67
+ spinner.text = "Running AI-powered review...";
68
+ const { getApiUrl } = await import("../utils/config.js");
69
+ const baseUrl = getApiUrl();
70
+ const response = await fetch(`${baseUrl}/api/cli/review`, {
71
+ method: "POST",
72
+ headers: {
73
+ "Content-Type": "application/json",
74
+ "Authorization": `Bearer ${apiKey}`,
75
+ },
76
+ body: JSON.stringify({
77
+ files: fileData,
78
+ baseBranch,
79
+ prTitle,
80
+ prDescription,
81
+ warehouse: config.warehouse || "snowflake",
82
+ }),
83
+ });
84
+ if (!response.ok) {
85
+ throw new Error(`API error: ${response.status}`);
86
+ }
87
+ const review = await response.json();
88
+ spinner.succeed("AI review complete");
89
+ if (options.json) {
90
+ console.log(JSON.stringify(review, null, 2));
91
+ return;
92
+ }
93
+ // Print AI review
94
+ console.log("\n" + chalk.bold.cyan("AI Code Review"));
95
+ console.log(chalk.gray("─".repeat(60)));
96
+ // Overall verdict
97
+ const verdictColor = review.verdict === "approve" ? chalk.green :
98
+ review.verdict === "request_changes" ? chalk.red : chalk.yellow;
99
+ const verdictIcon = review.verdict === "approve" ? "āœ“" :
100
+ review.verdict === "request_changes" ? "āœ–" : "ā—‹";
101
+ console.log(`\n${verdictColor(`${verdictIcon} ${review.verdict.replace("_", " ").toUpperCase()}`)} Score: ${review.overallScore}/100\n`);
102
+ // Summary
103
+ console.log(chalk.white(review.summary));
104
+ // Strengths
105
+ if (review.strengths && review.strengths.length > 0) {
106
+ console.log(chalk.green.bold("\nStrengths:"));
107
+ for (const strength of review.strengths) {
108
+ console.log(chalk.green(` āœ“ ${strength}`));
109
+ }
110
+ }
111
+ // Comments/Issues
112
+ if (review.comments && review.comments.length > 0) {
113
+ console.log(chalk.yellow.bold("\nComments:"));
114
+ for (const comment of review.comments) {
115
+ const severityColor = comment.severity === "blocker" || comment.severity === "critical" ? chalk.red :
116
+ comment.severity === "major" ? chalk.hex("#FFA500") :
117
+ comment.severity === "minor" ? chalk.yellow :
118
+ chalk.cyan;
119
+ console.log(`\n ${severityColor(`[${comment.severity.toUpperCase()}]`)} ${chalk.bold(comment.category)}`);
120
+ console.log(chalk.gray(` File: ${comment.file}${comment.line ? `:${comment.line}` : ""}`));
121
+ console.log(` ${comment.message}`);
122
+ if (comment.suggestion) {
123
+ console.log(chalk.cyan(` Suggestion: ${comment.suggestion}`));
124
+ }
125
+ if (comment.codeExample) {
126
+ console.log(chalk.gray("\n Example:"));
127
+ console.log(chalk.white(` ${comment.codeExample.replace(/\n/g, "\n ")}`));
128
+ }
129
+ }
130
+ }
131
+ // Improvements
132
+ if (review.improvements && review.improvements.length > 0) {
133
+ console.log(chalk.blue.bold("\nRecommended Improvements:"));
134
+ for (const improvement of review.improvements) {
135
+ console.log(chalk.blue(` → ${improvement}`));
136
+ }
137
+ }
138
+ // Exit code based on verdict
139
+ if (review.verdict === "request_changes" && options.strict) {
140
+ process.exit(1);
141
+ }
142
+ return;
143
+ }
144
+ // Fallback to local review if no API key
145
+ spinner.text = "Running local review...";
146
+ const { parseModel, reviewCode } = await import("../utils/analyzer.js");
147
+ const reviews = [];
148
+ for (const file of fileData) {
149
+ const model = parseModel(file.content, file.path);
150
+ const review = reviewCode(model, file.content, config.warehouse || "snowflake", options.strict);
151
+ reviews.push({
152
+ file: file.path,
153
+ ...review,
154
+ });
155
+ }
156
+ spinner.succeed("Review complete");
157
+ if (options.json) {
158
+ console.log(JSON.stringify(reviews, null, 2));
159
+ return;
160
+ }
161
+ // Print local reviews
162
+ for (const review of reviews) {
163
+ console.log("\n" + chalk.bold(`šŸ“„ ${review.file}`));
164
+ console.log(chalk.gray("─".repeat(50)));
165
+ const scoreColor = review.score >= 80 ? chalk.green : review.score >= 60 ? chalk.yellow : chalk.red;
166
+ const statusIcon = review.overall === "approve" ? "āœ“" : review.overall === "request_changes" ? "āœ–" : "ā—‹";
167
+ const statusColor = review.overall === "approve" ? chalk.green : review.overall === "request_changes" ? chalk.red : chalk.yellow;
168
+ console.log(`${statusColor(statusIcon)} ${statusColor(review.overall.replace("_", " ").toUpperCase())} ${scoreColor(`Score: ${review.score}/100`)}`);
169
+ if (review.strengths.length > 0) {
170
+ console.log(chalk.green("\n Strengths:"));
171
+ for (const strength of review.strengths) {
172
+ console.log(chalk.green(` āœ“ ${strength}`));
173
+ }
174
+ }
175
+ if (review.issues.length > 0) {
176
+ console.log(chalk.red("\n Issues:"));
177
+ for (const issue of review.issues) {
178
+ const severityColor = issue.severity === "critical" ? chalk.red :
179
+ issue.severity === "high" ? chalk.hex("#FFA500") :
180
+ issue.severity === "medium" ? chalk.yellow :
181
+ chalk.gray;
182
+ console.log(` ${severityColor(`[${issue.severity.toUpperCase()}]`)} ${issue.title}`);
183
+ console.log(chalk.gray(` ${issue.description}`));
184
+ console.log(chalk.cyan(` Suggestion: ${issue.suggestion}`));
185
+ }
186
+ }
187
+ }
188
+ // Summary
189
+ const totalIssues = reviews.reduce((acc, r) => acc + r.issues.length, 0);
190
+ const avgScore = Math.round(reviews.reduce((acc, r) => acc + r.score, 0) / reviews.length);
191
+ const hasBlockers = reviews.some(r => r.overall === "request_changes");
192
+ console.log("\n" + chalk.bold("Summary"));
193
+ console.log(chalk.gray("─".repeat(50)));
194
+ console.log(`Files reviewed: ${reviews.length}`);
195
+ console.log(`Average score: ${avgScore}/100`);
196
+ console.log(`Total issues: ${totalIssues}`);
197
+ if (hasBlockers) {
198
+ console.log(chalk.red("\nāœ– Review found blocking issues"));
199
+ if (options.strict)
200
+ process.exit(1);
201
+ }
202
+ else if (totalIssues > 0) {
203
+ console.log(chalk.yellow("\n⚠ Review passed with suggestions"));
204
+ }
205
+ else {
206
+ console.log(chalk.green("\nāœ“ Review passed"));
207
+ }
208
+ }
209
+ catch (error) {
210
+ spinner.fail("Review failed");
211
+ console.error(chalk.red(error instanceof Error ? error.message : "Unknown error"));
212
+ process.exit(1);
213
+ }
214
+ }
215
+ //# sourceMappingURL=review.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.js","sourceRoot":"","sources":["../../src/commands/review.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ interface ScanOptions {
2
+ type?: string;
3
+ host?: string;
4
+ port?: string;
5
+ database?: string;
6
+ user?: string;
7
+ password?: string;
8
+ warehouse?: string;
9
+ account?: string;
10
+ project?: string;
11
+ schemas?: string;
12
+ output?: string;
13
+ sync?: boolean;
14
+ json?: boolean;
15
+ }
16
+ export declare function scanCommand(options: ScanOptions): Promise<void>;
17
+ export {};
18
+ //# sourceMappingURL=scan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scan.d.ts","sourceRoot":"","sources":["../../src/commands/scan.ts"],"names":[],"mappings":"AASA,UAAU,WAAW;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AA4CD,wBAAsB,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CA4VrE"}