activo 0.3.1 → 0.3.2

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 CHANGED
@@ -110,6 +110,7 @@ activo --model qwen2.5:7b
110
110
  | **의존성** | `dependency_check` | package.json, pom.xml 취약점 검사 |
111
111
  | **API** | `openapi_check` | OpenAPI/Swagger 스펙 분석 |
112
112
  | **Python** | `python_check` | Python/Django/Flask 분석 |
113
+ | **통합** | `analyze_all` | 디렉토리 전체 자동 분석 |
113
114
  | **RAG** | `index_codebase` | 벡터 인덱싱 |
114
115
  | | `semantic_search` | 의미 검색 |
115
116
  | | `find_similar_code` | 유사 코드 찾기 |
@@ -0,0 +1,3 @@
1
+ import { Tool } from "./types.js";
2
+ export declare const analyzeAllTools: Tool[];
3
+ //# sourceMappingURL=analyzeAll.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyzeAll.d.ts","sourceRoot":"","sources":["../../../src/core/tools/analyzeAll.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAc,MAAM,YAAY,CAAC;AA8H9C,eAAO,MAAM,eAAe,EAAE,IAAI,EA+WjC,CAAC"}
@@ -0,0 +1,472 @@
1
+ import * as fs from "fs";
2
+ import * as path from "path";
3
+ // 각 분석 도구 import
4
+ import { sqlTools } from "./sqlAnalysis.js";
5
+ import { mybatisTools } from "./mybatisAnalysis.js";
6
+ import { cssTools } from "./cssAnalysis.js";
7
+ import { htmlTools } from "./htmlAnalysis.js";
8
+ import { dependencyTools } from "./dependencyAnalysis.js";
9
+ import { openapiTools } from "./openapiAnalysis.js";
10
+ import { pythonTools } from "./pythonAnalysis.js";
11
+ import { javaTools } from "./javaAst.js";
12
+ import { frontendTools } from "./frontendAst.js";
13
+ import { astTools } from "./ast.js";
14
+ // 파일 수집
15
+ function collectFiles(dirPath, stats, maxDepth = 10, currentDepth = 0) {
16
+ if (currentDepth > maxDepth)
17
+ return;
18
+ try {
19
+ const items = fs.readdirSync(dirPath);
20
+ for (const item of items) {
21
+ const fullPath = path.join(dirPath, item);
22
+ try {
23
+ const stat = fs.statSync(fullPath);
24
+ if (stat.isDirectory()) {
25
+ // 제외할 디렉토리
26
+ const excludeDirs = [
27
+ "node_modules", "target", "build", "dist", ".git", ".svn",
28
+ "__pycache__", "venv", ".venv", "env", ".idea", ".vscode",
29
+ "out", "bin", "obj", ".gradle", ".m2"
30
+ ];
31
+ if (!item.startsWith(".") && !excludeDirs.includes(item)) {
32
+ collectFiles(fullPath, stats, maxDepth, currentDepth + 1);
33
+ }
34
+ }
35
+ else if (stat.isFile()) {
36
+ const ext = path.extname(item).toLowerCase();
37
+ switch (ext) {
38
+ case ".java":
39
+ stats.java.push(fullPath);
40
+ break;
41
+ case ".xml":
42
+ stats.xml.push(fullPath);
43
+ break;
44
+ case ".js":
45
+ stats.js.push(fullPath);
46
+ break;
47
+ case ".ts":
48
+ stats.ts.push(fullPath);
49
+ break;
50
+ case ".jsx":
51
+ stats.jsx.push(fullPath);
52
+ break;
53
+ case ".tsx":
54
+ stats.tsx.push(fullPath);
55
+ break;
56
+ case ".vue":
57
+ stats.vue.push(fullPath);
58
+ break;
59
+ case ".py":
60
+ stats.py.push(fullPath);
61
+ break;
62
+ case ".css":
63
+ stats.css.push(fullPath);
64
+ break;
65
+ case ".scss":
66
+ case ".less":
67
+ stats.scss.push(fullPath);
68
+ break;
69
+ case ".html":
70
+ case ".htm":
71
+ stats.html.push(fullPath);
72
+ break;
73
+ case ".jsp":
74
+ stats.jsp.push(fullPath);
75
+ break;
76
+ case ".json":
77
+ stats.json.push(fullPath);
78
+ break;
79
+ case ".yaml":
80
+ case ".yml":
81
+ stats.yaml.push(fullPath);
82
+ break;
83
+ }
84
+ }
85
+ }
86
+ catch (e) {
87
+ // 파일 접근 오류 무시
88
+ }
89
+ }
90
+ }
91
+ catch (e) {
92
+ // 디렉토리 접근 오류 무시
93
+ }
94
+ }
95
+ // 도구 실행 헬퍼
96
+ async function runTool(tool, args) {
97
+ try {
98
+ const result = await tool.handler(args);
99
+ if (result.success) {
100
+ const parsed = JSON.parse(result.content);
101
+ return {
102
+ tool: tool.name,
103
+ success: true,
104
+ summary: parsed,
105
+ };
106
+ }
107
+ else {
108
+ return {
109
+ tool: tool.name,
110
+ success: false,
111
+ summary: null,
112
+ error: result.error,
113
+ };
114
+ }
115
+ }
116
+ catch (e) {
117
+ return {
118
+ tool: tool.name,
119
+ success: false,
120
+ summary: null,
121
+ error: String(e),
122
+ };
123
+ }
124
+ }
125
+ // 도구 정의
126
+ export const analyzeAllTools = [
127
+ {
128
+ name: "analyze_all",
129
+ description: "디렉토리 전체를 자동으로 분석합니다. Java, MyBatis, SQL, JavaScript, TypeScript, React, Vue, Python, CSS, HTML 등 모든 파일 유형을 감지하고 적절한 분석 도구를 실행합니다. LLM 판단 없이 바로 실행됩니다.",
130
+ parameters: {
131
+ type: "object",
132
+ properties: {
133
+ path: {
134
+ type: "string",
135
+ description: "분석할 프로젝트 디렉토리 경로",
136
+ },
137
+ include: {
138
+ type: "array",
139
+ description: "분석할 파일 유형 (생략 시 모두 분석). 예: ['java', 'xml', 'js']",
140
+ items: { type: "string" },
141
+ },
142
+ exclude: {
143
+ type: "array",
144
+ description: "제외할 파일 유형. 예: ['css', 'html']",
145
+ items: { type: "string" },
146
+ },
147
+ },
148
+ required: ["path"],
149
+ },
150
+ handler: async (args) => {
151
+ const targetPath = args.path;
152
+ const include = args.include;
153
+ const exclude = args.exclude;
154
+ if (!fs.existsSync(targetPath)) {
155
+ return {
156
+ success: false,
157
+ content: "",
158
+ error: `경로를 찾을 수 없습니다: ${targetPath}`,
159
+ };
160
+ }
161
+ const stats = fs.statSync(targetPath);
162
+ if (!stats.isDirectory()) {
163
+ return {
164
+ success: false,
165
+ content: "",
166
+ error: `디렉토리가 아닙니다: ${targetPath}`,
167
+ };
168
+ }
169
+ // 파일 수집
170
+ const fileStats = {
171
+ java: [], xml: [], js: [], ts: [], jsx: [], tsx: [],
172
+ vue: [], py: [], css: [], scss: [], html: [], jsp: [],
173
+ json: [], yaml: [],
174
+ };
175
+ collectFiles(targetPath, fileStats);
176
+ // 분석할 유형 결정
177
+ const shouldAnalyze = (type) => {
178
+ if (exclude?.includes(type))
179
+ return false;
180
+ if (include && include.length > 0)
181
+ return include.includes(type);
182
+ return true;
183
+ };
184
+ const results = [];
185
+ const fileCounts = {};
186
+ // 파일 통계
187
+ Object.entries(fileStats).forEach(([type, files]) => {
188
+ if (files.length > 0) {
189
+ fileCounts[type] = files.length;
190
+ }
191
+ });
192
+ // Java 분석 (파일 단위 도구 - 샘플링)
193
+ if (fileStats.java.length > 0 && shouldAnalyze("java")) {
194
+ // Java AST 분석 (최대 10개 파일 샘플링)
195
+ const javaAnalyzeTool = javaTools.find(t => t.name === "java_analyze");
196
+ if (javaAnalyzeTool) {
197
+ const sampleFiles = fileStats.java.slice(0, 10);
198
+ const javaResults = [];
199
+ for (const file of sampleFiles) {
200
+ try {
201
+ const r = await javaAnalyzeTool.handler({ filepath: file, format: "json" });
202
+ if (r.success) {
203
+ javaResults.push({ file, result: JSON.parse(r.content) });
204
+ }
205
+ }
206
+ catch (e) { /* ignore */ }
207
+ }
208
+ if (javaResults.length > 0) {
209
+ results.push({
210
+ tool: "java_analyze",
211
+ success: true,
212
+ summary: {
213
+ analyzedFiles: javaResults.length,
214
+ totalJavaFiles: fileStats.java.length,
215
+ samples: javaResults,
216
+ },
217
+ });
218
+ }
219
+ }
220
+ // Spring 패턴 (파일 단위)
221
+ const springCheckTool = javaTools.find(t => t.name === "spring_check");
222
+ if (springCheckTool) {
223
+ const sampleFiles = fileStats.java.slice(0, 20);
224
+ const springResults = [];
225
+ for (const file of sampleFiles) {
226
+ try {
227
+ const r = await springCheckTool.handler({ filepath: file, format: "json" });
228
+ if (r.success) {
229
+ const parsed = JSON.parse(r.content);
230
+ if (parsed.annotations?.length > 0 || parsed.patterns?.length > 0) {
231
+ springResults.push({ file, result: parsed });
232
+ }
233
+ }
234
+ }
235
+ catch (e) { /* ignore */ }
236
+ }
237
+ if (springResults.length > 0) {
238
+ results.push({
239
+ tool: "spring_check",
240
+ success: true,
241
+ summary: {
242
+ springFiles: springResults.length,
243
+ samples: springResults.slice(0, 10),
244
+ },
245
+ });
246
+ }
247
+ }
248
+ // SQL in Java (디렉토리 단위)
249
+ const sqlCheckTool = sqlTools.find(t => t.name === "sql_check");
250
+ if (sqlCheckTool) {
251
+ results.push(await runTool(sqlCheckTool, { path: targetPath }));
252
+ }
253
+ }
254
+ // XML (MyBatis) 분석
255
+ if (fileStats.xml.length > 0 && shouldAnalyze("xml")) {
256
+ const mybatisCheckTool = mybatisTools.find(t => t.name === "mybatis_check");
257
+ if (mybatisCheckTool) {
258
+ results.push(await runTool(mybatisCheckTool, { path: targetPath }));
259
+ }
260
+ }
261
+ // JavaScript/TypeScript 분석 (파일 단위 도구 - 샘플링)
262
+ const jsFiles = [...fileStats.js, ...fileStats.ts, ...fileStats.jsx, ...fileStats.tsx];
263
+ if (jsFiles.length > 0 && (shouldAnalyze("js") || shouldAnalyze("ts"))) {
264
+ // AST 분석 (최대 10개 파일 샘플링)
265
+ const astAnalyzeTool = astTools.find(t => t.name === "ast_analyze");
266
+ if (astAnalyzeTool) {
267
+ const sampleFiles = jsFiles.slice(0, 10);
268
+ const astResults = [];
269
+ for (const file of sampleFiles) {
270
+ try {
271
+ const r = await astAnalyzeTool.handler({ filepath: file, format: "json" });
272
+ if (r.success) {
273
+ astResults.push({ file, result: JSON.parse(r.content) });
274
+ }
275
+ }
276
+ catch (e) { /* ignore */ }
277
+ }
278
+ if (astResults.length > 0) {
279
+ results.push({
280
+ tool: "ast_analyze",
281
+ success: true,
282
+ summary: {
283
+ analyzedFiles: astResults.length,
284
+ totalJsFiles: jsFiles.length,
285
+ samples: astResults,
286
+ },
287
+ });
288
+ }
289
+ }
290
+ // React 분석 (파일 단위)
291
+ const reactFiles = [...fileStats.jsx, ...fileStats.tsx];
292
+ if (reactFiles.length > 0 && shouldAnalyze("react")) {
293
+ const reactCheckTool = frontendTools.find(t => t.name === "react_check");
294
+ if (reactCheckTool) {
295
+ const sampleFiles = reactFiles.slice(0, 10);
296
+ const reactResults = [];
297
+ for (const file of sampleFiles) {
298
+ try {
299
+ const r = await reactCheckTool.handler({ filepath: file });
300
+ if (r.success) {
301
+ reactResults.push({ file, result: JSON.parse(r.content) });
302
+ }
303
+ }
304
+ catch (e) { /* ignore */ }
305
+ }
306
+ if (reactResults.length > 0) {
307
+ results.push({
308
+ tool: "react_check",
309
+ success: true,
310
+ summary: { analyzedFiles: reactResults.length, samples: reactResults },
311
+ });
312
+ }
313
+ }
314
+ }
315
+ // jQuery 분석 (파일 단위)
316
+ if (shouldAnalyze("jquery")) {
317
+ const jqueryCheckTool = frontendTools.find(t => t.name === "jquery_check");
318
+ if (jqueryCheckTool) {
319
+ const sampleFiles = jsFiles.slice(0, 10);
320
+ const jqueryResults = [];
321
+ for (const file of sampleFiles) {
322
+ try {
323
+ const r = await jqueryCheckTool.handler({ filepath: file });
324
+ if (r.success) {
325
+ const parsed = JSON.parse(r.content);
326
+ if (parsed.hasJQuery || parsed.deprecated?.length > 0) {
327
+ jqueryResults.push({ file, result: parsed });
328
+ }
329
+ }
330
+ }
331
+ catch (e) { /* ignore */ }
332
+ }
333
+ if (jqueryResults.length > 0) {
334
+ results.push({
335
+ tool: "jquery_check",
336
+ success: true,
337
+ summary: { filesWithJQuery: jqueryResults.length, samples: jqueryResults },
338
+ });
339
+ }
340
+ }
341
+ }
342
+ }
343
+ // Vue 분석 (파일 단위)
344
+ if (fileStats.vue.length > 0 && shouldAnalyze("vue")) {
345
+ const vueCheckTool = frontendTools.find(t => t.name === "vue_check");
346
+ if (vueCheckTool) {
347
+ const sampleFiles = fileStats.vue.slice(0, 10);
348
+ const vueResults = [];
349
+ for (const file of sampleFiles) {
350
+ try {
351
+ const r = await vueCheckTool.handler({ filepath: file });
352
+ if (r.success) {
353
+ vueResults.push({ file, result: JSON.parse(r.content) });
354
+ }
355
+ }
356
+ catch (e) { /* ignore */ }
357
+ }
358
+ if (vueResults.length > 0) {
359
+ results.push({
360
+ tool: "vue_check",
361
+ success: true,
362
+ summary: { analyzedFiles: vueResults.length, samples: vueResults },
363
+ });
364
+ }
365
+ }
366
+ }
367
+ // Python 분석
368
+ if (fileStats.py.length > 0 && shouldAnalyze("py")) {
369
+ const pythonCheckTool = pythonTools.find(t => t.name === "python_check");
370
+ if (pythonCheckTool) {
371
+ results.push(await runTool(pythonCheckTool, { path: targetPath }));
372
+ }
373
+ }
374
+ // CSS/SCSS 분석
375
+ const cssFiles = [...fileStats.css, ...fileStats.scss];
376
+ if (cssFiles.length > 0 && shouldAnalyze("css")) {
377
+ const cssCheckTool = cssTools.find(t => t.name === "css_check");
378
+ if (cssCheckTool) {
379
+ results.push(await runTool(cssCheckTool, { path: targetPath }));
380
+ }
381
+ }
382
+ // HTML/JSP 분석
383
+ const htmlFiles = [...fileStats.html, ...fileStats.jsp];
384
+ if (htmlFiles.length > 0 && shouldAnalyze("html")) {
385
+ const htmlCheckTool = htmlTools.find(t => t.name === "html_check");
386
+ if (htmlCheckTool) {
387
+ results.push(await runTool(htmlCheckTool, { path: targetPath }));
388
+ }
389
+ }
390
+ // 의존성 분석 (package.json, pom.xml)
391
+ const hasPackageJson = fileStats.json.some(f => f.endsWith("package.json"));
392
+ const hasPomXml = fileStats.xml.some(f => f.endsWith("pom.xml"));
393
+ if ((hasPackageJson || hasPomXml) && shouldAnalyze("dependency")) {
394
+ const dependencyCheckTool = dependencyTools.find(t => t.name === "dependency_check");
395
+ if (dependencyCheckTool) {
396
+ results.push(await runTool(dependencyCheckTool, { path: targetPath }));
397
+ }
398
+ }
399
+ // OpenAPI 분석
400
+ const hasOpenApi = [...fileStats.yaml, ...fileStats.json].some(f => f.includes("swagger") || f.includes("openapi") || f.includes("api-docs"));
401
+ if (hasOpenApi && shouldAnalyze("openapi")) {
402
+ const openapiCheckTool = openapiTools.find(t => t.name === "openapi_check");
403
+ if (openapiCheckTool) {
404
+ results.push(await runTool(openapiCheckTool, { path: targetPath }));
405
+ }
406
+ }
407
+ // 결과 요약
408
+ const successfulAnalyses = results.filter(r => r.success);
409
+ const failedAnalyses = results.filter(r => !r.success);
410
+ // 주요 이슈 추출
411
+ const issues = [];
412
+ for (const result of successfulAnalyses) {
413
+ const toolIssues = [];
414
+ const summary = result.summary;
415
+ // 각 도구별 이슈 추출
416
+ if (result.tool === "java_analyze" && summary.files) {
417
+ summary.files.forEach((f) => {
418
+ if (f.issues?.length > 0) {
419
+ toolIssues.push(...f.issues.slice(0, 3));
420
+ }
421
+ });
422
+ }
423
+ if (result.tool === "mybatis_check" && summary.injectionRisks > 0) {
424
+ toolIssues.push(`SQL Injection 위험 ${summary.injectionRisks}건`);
425
+ }
426
+ if (result.tool === "sql_check" && summary.queriesWithIssues > 0) {
427
+ toolIssues.push(`SQL 쿼리 이슈 ${summary.queriesWithIssues}건`);
428
+ }
429
+ if (result.tool === "spring_check" && summary.issues) {
430
+ toolIssues.push(...summary.issues.slice(0, 3));
431
+ }
432
+ if (result.tool === "dependency_check" && summary.securityConcerns > 0) {
433
+ toolIssues.push(`보안 취약점 ${summary.securityConcerns}건`);
434
+ }
435
+ if (result.tool === "css_check" && summary.totalImportant > 5) {
436
+ toolIssues.push(`!important 과다 사용 ${summary.totalImportant}회`);
437
+ }
438
+ if (result.tool === "html_check" && summary.averageA11yScore < 60) {
439
+ toolIssues.push(`접근성 점수 낮음 (${summary.averageA11yScore}%)`);
440
+ }
441
+ if (result.tool === "python_check" && summary.docstringCoverage < 50) {
442
+ toolIssues.push(`Python docstring 부족 (${summary.docstringCoverage}%)`);
443
+ }
444
+ if (toolIssues.length > 0) {
445
+ issues.push({ tool: result.tool, issues: toolIssues });
446
+ }
447
+ }
448
+ const output = {
449
+ path: targetPath,
450
+ fileStats: fileCounts,
451
+ totalFiles: Object.values(fileCounts).reduce((a, b) => a + b, 0),
452
+ analysesRun: results.length,
453
+ successful: successfulAnalyses.length,
454
+ failed: failedAnalyses.length,
455
+ issuesSummary: issues,
456
+ details: successfulAnalyses.map(r => ({
457
+ tool: r.tool,
458
+ summary: r.summary,
459
+ })),
460
+ errors: failedAnalyses.map(r => ({
461
+ tool: r.tool,
462
+ error: r.error,
463
+ })),
464
+ };
465
+ return {
466
+ success: true,
467
+ content: JSON.stringify(output, null, 2),
468
+ };
469
+ },
470
+ },
471
+ ];
472
+ //# sourceMappingURL=analyzeAll.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyzeAll.js","sourceRoot":"","sources":["../../../src/core/tools/analyzeAll.ts"],"names":[],"mappings":"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"}
@@ -15,6 +15,7 @@ export * from "./htmlAnalysis.js";
15
15
  export * from "./dependencyAnalysis.js";
16
16
  export * from "./openapiAnalysis.js";
17
17
  export * from "./pythonAnalysis.js";
18
+ export * from "./analyzeAll.js";
18
19
  export declare function getAllTools(): Tool[];
19
20
  export declare function getTool(name: string): Tool | undefined;
20
21
  export declare function executeTool(toolCall: ToolCall): Promise<ToolResult>;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAiBxD,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AAGpC,wBAAgB,WAAW,IAAI,IAAI,EAAE,CAEpC;AAGD,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAEtD;AAGD,wBAAsB,WAAW,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC,CAoBzE;AAGD,wBAAgB,kBAAkB,IAAI,KAAK,CAAC;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;CAChC,CAAC,CAMD"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAkBxD,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAGhC,wBAAgB,WAAW,IAAI,IAAI,EAAE,CAEpC;AAGD,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAEtD;AAGD,wBAAsB,WAAW,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC,CAoBzE;AAGD,wBAAgB,kBAAkB,IAAI,KAAK,CAAC;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;CAChC,CAAC,CAMD"}
@@ -13,6 +13,7 @@ import { htmlTools } from "./htmlAnalysis.js";
13
13
  import { dependencyTools } from "./dependencyAnalysis.js";
14
14
  import { openapiTools } from "./openapiAnalysis.js";
15
15
  import { pythonTools } from "./pythonAnalysis.js";
16
+ import { analyzeAllTools } from "./analyzeAll.js";
16
17
  export * from "./types.js";
17
18
  export * from "./builtIn.js";
18
19
  export * from "./standards.js";
@@ -29,9 +30,10 @@ export * from "./htmlAnalysis.js";
29
30
  export * from "./dependencyAnalysis.js";
30
31
  export * from "./openapiAnalysis.js";
31
32
  export * from "./pythonAnalysis.js";
33
+ export * from "./analyzeAll.js";
32
34
  // All available tools
33
35
  export function getAllTools() {
34
- return [...builtInTools, ...standardsTools, ...cacheTools, ...astTools, ...embeddingTools, ...memoryTools, ...javaTools, ...frontendTools, ...sqlTools, ...mybatisTools, ...cssTools, ...htmlTools, ...dependencyTools, ...openapiTools, ...pythonTools];
36
+ return [...builtInTools, ...standardsTools, ...cacheTools, ...astTools, ...embeddingTools, ...memoryTools, ...javaTools, ...frontendTools, ...sqlTools, ...mybatisTools, ...cssTools, ...htmlTools, ...dependencyTools, ...openapiTools, ...pythonTools, ...analyzeAllTools];
35
37
  }
36
38
  // Get tool by name
37
39
  export function getTool(name) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"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"}
@@ -13,6 +13,9 @@ export interface ToolParameter {
13
13
  description: string;
14
14
  enum?: string[];
15
15
  default?: unknown;
16
+ items?: {
17
+ type: string;
18
+ };
16
19
  }
17
20
  export interface ToolCall {
18
21
  id: string;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/core/tools/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,IAAI;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ,CAAC;QACf,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;KAC3C,CAAC;IACF,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;CACjE;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,GAAG,UAAU,GAAG,OAAO,CAAC;IACvC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/core/tools/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,IAAI;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ,CAAC;QACf,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;KAC3C,CAAC;IACF,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;CACjE;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CAC1B;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,GAAG,UAAU,GAAG,OAAO,CAAC;IACvC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "activo",
3
- "version": "0.3.1",
3
+ "version": "0.3.2",
4
4
  "description": "AI-powered code quality analyzer with React Ink TUI, Tool Calling, and MCP support",
5
5
  "repository": {
6
6
  "type": "git",
@@ -0,0 +1,494 @@
1
+ import { Tool, ToolResult } from "./types.js";
2
+ import * as fs from "fs";
3
+ import * as path from "path";
4
+
5
+ // 각 분석 도구 import
6
+ import { sqlTools } from "./sqlAnalysis.js";
7
+ import { mybatisTools } from "./mybatisAnalysis.js";
8
+ import { cssTools } from "./cssAnalysis.js";
9
+ import { htmlTools } from "./htmlAnalysis.js";
10
+ import { dependencyTools } from "./dependencyAnalysis.js";
11
+ import { openapiTools } from "./openapiAnalysis.js";
12
+ import { pythonTools } from "./pythonAnalysis.js";
13
+ import { javaTools } from "./javaAst.js";
14
+ import { frontendTools } from "./frontendAst.js";
15
+ import { astTools } from "./ast.js";
16
+
17
+ interface FileStats {
18
+ java: string[];
19
+ xml: string[];
20
+ js: string[];
21
+ ts: string[];
22
+ jsx: string[];
23
+ tsx: string[];
24
+ vue: string[];
25
+ py: string[];
26
+ css: string[];
27
+ scss: string[];
28
+ html: string[];
29
+ jsp: string[];
30
+ json: string[];
31
+ yaml: string[];
32
+ }
33
+
34
+ interface AnalysisResult {
35
+ tool: string;
36
+ success: boolean;
37
+ summary: any;
38
+ error?: string;
39
+ }
40
+
41
+ // 파일 수집
42
+ function collectFiles(dirPath: string, stats: FileStats, maxDepth: number = 10, currentDepth: number = 0): void {
43
+ if (currentDepth > maxDepth) return;
44
+
45
+ try {
46
+ const items = fs.readdirSync(dirPath);
47
+
48
+ for (const item of items) {
49
+ const fullPath = path.join(dirPath, item);
50
+
51
+ try {
52
+ const stat = fs.statSync(fullPath);
53
+
54
+ if (stat.isDirectory()) {
55
+ // 제외할 디렉토리
56
+ const excludeDirs = [
57
+ "node_modules", "target", "build", "dist", ".git", ".svn",
58
+ "__pycache__", "venv", ".venv", "env", ".idea", ".vscode",
59
+ "out", "bin", "obj", ".gradle", ".m2"
60
+ ];
61
+
62
+ if (!item.startsWith(".") && !excludeDirs.includes(item)) {
63
+ collectFiles(fullPath, stats, maxDepth, currentDepth + 1);
64
+ }
65
+ } else if (stat.isFile()) {
66
+ const ext = path.extname(item).toLowerCase();
67
+
68
+ switch (ext) {
69
+ case ".java": stats.java.push(fullPath); break;
70
+ case ".xml": stats.xml.push(fullPath); break;
71
+ case ".js": stats.js.push(fullPath); break;
72
+ case ".ts": stats.ts.push(fullPath); break;
73
+ case ".jsx": stats.jsx.push(fullPath); break;
74
+ case ".tsx": stats.tsx.push(fullPath); break;
75
+ case ".vue": stats.vue.push(fullPath); break;
76
+ case ".py": stats.py.push(fullPath); break;
77
+ case ".css": stats.css.push(fullPath); break;
78
+ case ".scss":
79
+ case ".less": stats.scss.push(fullPath); break;
80
+ case ".html":
81
+ case ".htm": stats.html.push(fullPath); break;
82
+ case ".jsp": stats.jsp.push(fullPath); break;
83
+ case ".json": stats.json.push(fullPath); break;
84
+ case ".yaml":
85
+ case ".yml": stats.yaml.push(fullPath); break;
86
+ }
87
+ }
88
+ } catch (e) {
89
+ // 파일 접근 오류 무시
90
+ }
91
+ }
92
+ } catch (e) {
93
+ // 디렉토리 접근 오류 무시
94
+ }
95
+ }
96
+
97
+ // 도구 실행 헬퍼
98
+ async function runTool(tool: Tool, args: Record<string, unknown>): Promise<AnalysisResult> {
99
+ try {
100
+ const result = await tool.handler(args);
101
+ if (result.success) {
102
+ const parsed = JSON.parse(result.content);
103
+ return {
104
+ tool: tool.name,
105
+ success: true,
106
+ summary: parsed,
107
+ };
108
+ } else {
109
+ return {
110
+ tool: tool.name,
111
+ success: false,
112
+ summary: null,
113
+ error: result.error,
114
+ };
115
+ }
116
+ } catch (e) {
117
+ return {
118
+ tool: tool.name,
119
+ success: false,
120
+ summary: null,
121
+ error: String(e),
122
+ };
123
+ }
124
+ }
125
+
126
+ // 도구 정의
127
+ export const analyzeAllTools: Tool[] = [
128
+ {
129
+ name: "analyze_all",
130
+ description:
131
+ "디렉토리 전체를 자동으로 분석합니다. Java, MyBatis, SQL, JavaScript, TypeScript, React, Vue, Python, CSS, HTML 등 모든 파일 유형을 감지하고 적절한 분석 도구를 실행합니다. LLM 판단 없이 바로 실행됩니다.",
132
+ parameters: {
133
+ type: "object",
134
+ properties: {
135
+ path: {
136
+ type: "string",
137
+ description: "분석할 프로젝트 디렉토리 경로",
138
+ },
139
+ include: {
140
+ type: "array",
141
+ description: "분석할 파일 유형 (생략 시 모두 분석). 예: ['java', 'xml', 'js']",
142
+ items: { type: "string" },
143
+ },
144
+ exclude: {
145
+ type: "array",
146
+ description: "제외할 파일 유형. 예: ['css', 'html']",
147
+ items: { type: "string" },
148
+ },
149
+ },
150
+ required: ["path"],
151
+ },
152
+ handler: async (args: Record<string, unknown>): Promise<ToolResult> => {
153
+ const targetPath = args.path as string;
154
+ const include = args.include as string[] | undefined;
155
+ const exclude = args.exclude as string[] | undefined;
156
+
157
+ if (!fs.existsSync(targetPath)) {
158
+ return {
159
+ success: false,
160
+ content: "",
161
+ error: `경로를 찾을 수 없습니다: ${targetPath}`,
162
+ };
163
+ }
164
+
165
+ const stats = fs.statSync(targetPath);
166
+ if (!stats.isDirectory()) {
167
+ return {
168
+ success: false,
169
+ content: "",
170
+ error: `디렉토리가 아닙니다: ${targetPath}`,
171
+ };
172
+ }
173
+
174
+ // 파일 수집
175
+ const fileStats: FileStats = {
176
+ java: [], xml: [], js: [], ts: [], jsx: [], tsx: [],
177
+ vue: [], py: [], css: [], scss: [], html: [], jsp: [],
178
+ json: [], yaml: [],
179
+ };
180
+
181
+ collectFiles(targetPath, fileStats);
182
+
183
+ // 분석할 유형 결정
184
+ const shouldAnalyze = (type: string): boolean => {
185
+ if (exclude?.includes(type)) return false;
186
+ if (include && include.length > 0) return include.includes(type);
187
+ return true;
188
+ };
189
+
190
+ const results: AnalysisResult[] = [];
191
+ const fileCounts: Record<string, number> = {};
192
+
193
+ // 파일 통계
194
+ Object.entries(fileStats).forEach(([type, files]) => {
195
+ if (files.length > 0) {
196
+ fileCounts[type] = files.length;
197
+ }
198
+ });
199
+
200
+ // Java 분석 (파일 단위 도구 - 샘플링)
201
+ if (fileStats.java.length > 0 && shouldAnalyze("java")) {
202
+ // Java AST 분석 (최대 10개 파일 샘플링)
203
+ const javaAnalyzeTool = javaTools.find(t => t.name === "java_analyze");
204
+ if (javaAnalyzeTool) {
205
+ const sampleFiles = fileStats.java.slice(0, 10);
206
+ const javaResults: any[] = [];
207
+ for (const file of sampleFiles) {
208
+ try {
209
+ const r = await javaAnalyzeTool.handler({ filepath: file, format: "json" });
210
+ if (r.success) {
211
+ javaResults.push({ file, result: JSON.parse(r.content) });
212
+ }
213
+ } catch (e) { /* ignore */ }
214
+ }
215
+ if (javaResults.length > 0) {
216
+ results.push({
217
+ tool: "java_analyze",
218
+ success: true,
219
+ summary: {
220
+ analyzedFiles: javaResults.length,
221
+ totalJavaFiles: fileStats.java.length,
222
+ samples: javaResults,
223
+ },
224
+ });
225
+ }
226
+ }
227
+
228
+ // Spring 패턴 (파일 단위)
229
+ const springCheckTool = javaTools.find(t => t.name === "spring_check");
230
+ if (springCheckTool) {
231
+ const sampleFiles = fileStats.java.slice(0, 20);
232
+ const springResults: any[] = [];
233
+ for (const file of sampleFiles) {
234
+ try {
235
+ const r = await springCheckTool.handler({ filepath: file, format: "json" });
236
+ if (r.success) {
237
+ const parsed = JSON.parse(r.content);
238
+ if (parsed.annotations?.length > 0 || parsed.patterns?.length > 0) {
239
+ springResults.push({ file, result: parsed });
240
+ }
241
+ }
242
+ } catch (e) { /* ignore */ }
243
+ }
244
+ if (springResults.length > 0) {
245
+ results.push({
246
+ tool: "spring_check",
247
+ success: true,
248
+ summary: {
249
+ springFiles: springResults.length,
250
+ samples: springResults.slice(0, 10),
251
+ },
252
+ });
253
+ }
254
+ }
255
+
256
+ // SQL in Java (디렉토리 단위)
257
+ const sqlCheckTool = sqlTools.find(t => t.name === "sql_check");
258
+ if (sqlCheckTool) {
259
+ results.push(await runTool(sqlCheckTool, { path: targetPath }));
260
+ }
261
+ }
262
+
263
+ // XML (MyBatis) 분석
264
+ if (fileStats.xml.length > 0 && shouldAnalyze("xml")) {
265
+ const mybatisCheckTool = mybatisTools.find(t => t.name === "mybatis_check");
266
+ if (mybatisCheckTool) {
267
+ results.push(await runTool(mybatisCheckTool, { path: targetPath }));
268
+ }
269
+ }
270
+
271
+ // JavaScript/TypeScript 분석 (파일 단위 도구 - 샘플링)
272
+ const jsFiles = [...fileStats.js, ...fileStats.ts, ...fileStats.jsx, ...fileStats.tsx];
273
+ if (jsFiles.length > 0 && (shouldAnalyze("js") || shouldAnalyze("ts"))) {
274
+ // AST 분석 (최대 10개 파일 샘플링)
275
+ const astAnalyzeTool = astTools.find(t => t.name === "ast_analyze");
276
+ if (astAnalyzeTool) {
277
+ const sampleFiles = jsFiles.slice(0, 10);
278
+ const astResults: any[] = [];
279
+ for (const file of sampleFiles) {
280
+ try {
281
+ const r = await astAnalyzeTool.handler({ filepath: file, format: "json" });
282
+ if (r.success) {
283
+ astResults.push({ file, result: JSON.parse(r.content) });
284
+ }
285
+ } catch (e) { /* ignore */ }
286
+ }
287
+ if (astResults.length > 0) {
288
+ results.push({
289
+ tool: "ast_analyze",
290
+ success: true,
291
+ summary: {
292
+ analyzedFiles: astResults.length,
293
+ totalJsFiles: jsFiles.length,
294
+ samples: astResults,
295
+ },
296
+ });
297
+ }
298
+ }
299
+
300
+ // React 분석 (파일 단위)
301
+ const reactFiles = [...fileStats.jsx, ...fileStats.tsx];
302
+ if (reactFiles.length > 0 && shouldAnalyze("react")) {
303
+ const reactCheckTool = frontendTools.find(t => t.name === "react_check");
304
+ if (reactCheckTool) {
305
+ const sampleFiles = reactFiles.slice(0, 10);
306
+ const reactResults: any[] = [];
307
+ for (const file of sampleFiles) {
308
+ try {
309
+ const r = await reactCheckTool.handler({ filepath: file });
310
+ if (r.success) {
311
+ reactResults.push({ file, result: JSON.parse(r.content) });
312
+ }
313
+ } catch (e) { /* ignore */ }
314
+ }
315
+ if (reactResults.length > 0) {
316
+ results.push({
317
+ tool: "react_check",
318
+ success: true,
319
+ summary: { analyzedFiles: reactResults.length, samples: reactResults },
320
+ });
321
+ }
322
+ }
323
+ }
324
+
325
+ // jQuery 분석 (파일 단위)
326
+ if (shouldAnalyze("jquery")) {
327
+ const jqueryCheckTool = frontendTools.find(t => t.name === "jquery_check");
328
+ if (jqueryCheckTool) {
329
+ const sampleFiles = jsFiles.slice(0, 10);
330
+ const jqueryResults: any[] = [];
331
+ for (const file of sampleFiles) {
332
+ try {
333
+ const r = await jqueryCheckTool.handler({ filepath: file });
334
+ if (r.success) {
335
+ const parsed = JSON.parse(r.content);
336
+ if (parsed.hasJQuery || parsed.deprecated?.length > 0) {
337
+ jqueryResults.push({ file, result: parsed });
338
+ }
339
+ }
340
+ } catch (e) { /* ignore */ }
341
+ }
342
+ if (jqueryResults.length > 0) {
343
+ results.push({
344
+ tool: "jquery_check",
345
+ success: true,
346
+ summary: { filesWithJQuery: jqueryResults.length, samples: jqueryResults },
347
+ });
348
+ }
349
+ }
350
+ }
351
+ }
352
+
353
+ // Vue 분석 (파일 단위)
354
+ if (fileStats.vue.length > 0 && shouldAnalyze("vue")) {
355
+ const vueCheckTool = frontendTools.find(t => t.name === "vue_check");
356
+ if (vueCheckTool) {
357
+ const sampleFiles = fileStats.vue.slice(0, 10);
358
+ const vueResults: any[] = [];
359
+ for (const file of sampleFiles) {
360
+ try {
361
+ const r = await vueCheckTool.handler({ filepath: file });
362
+ if (r.success) {
363
+ vueResults.push({ file, result: JSON.parse(r.content) });
364
+ }
365
+ } catch (e) { /* ignore */ }
366
+ }
367
+ if (vueResults.length > 0) {
368
+ results.push({
369
+ tool: "vue_check",
370
+ success: true,
371
+ summary: { analyzedFiles: vueResults.length, samples: vueResults },
372
+ });
373
+ }
374
+ }
375
+ }
376
+
377
+ // Python 분석
378
+ if (fileStats.py.length > 0 && shouldAnalyze("py")) {
379
+ const pythonCheckTool = pythonTools.find(t => t.name === "python_check");
380
+ if (pythonCheckTool) {
381
+ results.push(await runTool(pythonCheckTool, { path: targetPath }));
382
+ }
383
+ }
384
+
385
+ // CSS/SCSS 분석
386
+ const cssFiles = [...fileStats.css, ...fileStats.scss];
387
+ if (cssFiles.length > 0 && shouldAnalyze("css")) {
388
+ const cssCheckTool = cssTools.find(t => t.name === "css_check");
389
+ if (cssCheckTool) {
390
+ results.push(await runTool(cssCheckTool, { path: targetPath }));
391
+ }
392
+ }
393
+
394
+ // HTML/JSP 분석
395
+ const htmlFiles = [...fileStats.html, ...fileStats.jsp];
396
+ if (htmlFiles.length > 0 && shouldAnalyze("html")) {
397
+ const htmlCheckTool = htmlTools.find(t => t.name === "html_check");
398
+ if (htmlCheckTool) {
399
+ results.push(await runTool(htmlCheckTool, { path: targetPath }));
400
+ }
401
+ }
402
+
403
+ // 의존성 분석 (package.json, pom.xml)
404
+ const hasPackageJson = fileStats.json.some(f => f.endsWith("package.json"));
405
+ const hasPomXml = fileStats.xml.some(f => f.endsWith("pom.xml"));
406
+ if ((hasPackageJson || hasPomXml) && shouldAnalyze("dependency")) {
407
+ const dependencyCheckTool = dependencyTools.find(t => t.name === "dependency_check");
408
+ if (dependencyCheckTool) {
409
+ results.push(await runTool(dependencyCheckTool, { path: targetPath }));
410
+ }
411
+ }
412
+
413
+ // OpenAPI 분석
414
+ const hasOpenApi = [...fileStats.yaml, ...fileStats.json].some(f =>
415
+ f.includes("swagger") || f.includes("openapi") || f.includes("api-docs")
416
+ );
417
+ if (hasOpenApi && shouldAnalyze("openapi")) {
418
+ const openapiCheckTool = openapiTools.find(t => t.name === "openapi_check");
419
+ if (openapiCheckTool) {
420
+ results.push(await runTool(openapiCheckTool, { path: targetPath }));
421
+ }
422
+ }
423
+
424
+ // 결과 요약
425
+ const successfulAnalyses = results.filter(r => r.success);
426
+ const failedAnalyses = results.filter(r => !r.success);
427
+
428
+ // 주요 이슈 추출
429
+ const issues: { tool: string; issues: string[] }[] = [];
430
+
431
+ for (const result of successfulAnalyses) {
432
+ const toolIssues: string[] = [];
433
+ const summary = result.summary;
434
+
435
+ // 각 도구별 이슈 추출
436
+ if (result.tool === "java_analyze" && summary.files) {
437
+ summary.files.forEach((f: any) => {
438
+ if (f.issues?.length > 0) {
439
+ toolIssues.push(...f.issues.slice(0, 3));
440
+ }
441
+ });
442
+ }
443
+ if (result.tool === "mybatis_check" && summary.injectionRisks > 0) {
444
+ toolIssues.push(`SQL Injection 위험 ${summary.injectionRisks}건`);
445
+ }
446
+ if (result.tool === "sql_check" && summary.queriesWithIssues > 0) {
447
+ toolIssues.push(`SQL 쿼리 이슈 ${summary.queriesWithIssues}건`);
448
+ }
449
+ if (result.tool === "spring_check" && summary.issues) {
450
+ toolIssues.push(...summary.issues.slice(0, 3));
451
+ }
452
+ if (result.tool === "dependency_check" && summary.securityConcerns > 0) {
453
+ toolIssues.push(`보안 취약점 ${summary.securityConcerns}건`);
454
+ }
455
+ if (result.tool === "css_check" && summary.totalImportant > 5) {
456
+ toolIssues.push(`!important 과다 사용 ${summary.totalImportant}회`);
457
+ }
458
+ if (result.tool === "html_check" && summary.averageA11yScore < 60) {
459
+ toolIssues.push(`접근성 점수 낮음 (${summary.averageA11yScore}%)`);
460
+ }
461
+ if (result.tool === "python_check" && summary.docstringCoverage < 50) {
462
+ toolIssues.push(`Python docstring 부족 (${summary.docstringCoverage}%)`);
463
+ }
464
+
465
+ if (toolIssues.length > 0) {
466
+ issues.push({ tool: result.tool, issues: toolIssues });
467
+ }
468
+ }
469
+
470
+ const output = {
471
+ path: targetPath,
472
+ fileStats: fileCounts,
473
+ totalFiles: Object.values(fileCounts).reduce((a, b) => a + b, 0),
474
+ analysesRun: results.length,
475
+ successful: successfulAnalyses.length,
476
+ failed: failedAnalyses.length,
477
+ issuesSummary: issues,
478
+ details: successfulAnalyses.map(r => ({
479
+ tool: r.tool,
480
+ summary: r.summary,
481
+ })),
482
+ errors: failedAnalyses.map(r => ({
483
+ tool: r.tool,
484
+ error: r.error,
485
+ })),
486
+ };
487
+
488
+ return {
489
+ success: true,
490
+ content: JSON.stringify(output, null, 2),
491
+ };
492
+ },
493
+ },
494
+ ];
@@ -14,6 +14,7 @@ import { htmlTools } from "./htmlAnalysis.js";
14
14
  import { dependencyTools } from "./dependencyAnalysis.js";
15
15
  import { openapiTools } from "./openapiAnalysis.js";
16
16
  import { pythonTools } from "./pythonAnalysis.js";
17
+ import { analyzeAllTools } from "./analyzeAll.js";
17
18
 
18
19
  export * from "./types.js";
19
20
  export * from "./builtIn.js";
@@ -31,10 +32,11 @@ export * from "./htmlAnalysis.js";
31
32
  export * from "./dependencyAnalysis.js";
32
33
  export * from "./openapiAnalysis.js";
33
34
  export * from "./pythonAnalysis.js";
35
+ export * from "./analyzeAll.js";
34
36
 
35
37
  // All available tools
36
38
  export function getAllTools(): Tool[] {
37
- return [...builtInTools, ...standardsTools, ...cacheTools, ...astTools, ...embeddingTools, ...memoryTools, ...javaTools, ...frontendTools, ...sqlTools, ...mybatisTools, ...cssTools, ...htmlTools, ...dependencyTools, ...openapiTools, ...pythonTools];
39
+ return [...builtInTools, ...standardsTools, ...cacheTools, ...astTools, ...embeddingTools, ...memoryTools, ...javaTools, ...frontendTools, ...sqlTools, ...mybatisTools, ...cssTools, ...htmlTools, ...dependencyTools, ...openapiTools, ...pythonTools, ...analyzeAllTools];
38
40
  }
39
41
 
40
42
  // Get tool by name
@@ -14,6 +14,7 @@ export interface ToolParameter {
14
14
  description: string;
15
15
  enum?: string[];
16
16
  default?: unknown;
17
+ items?: { type: string };
17
18
  }
18
19
 
19
20
  export interface ToolCall {