feat(mcp): Implement complexity-report MCP command for displaying task complexity analysis reports

This commit is contained in:
Eyal Toledano
2025-03-31 14:20:00 -04:00
parent c58d4b51ef
commit 6f87faa9dc
9 changed files with 201 additions and 16 deletions

View File

@@ -0,0 +1,47 @@
/**
* tools/complexity-report.js
* Tool for displaying the complexity analysis report
*/
import { z } from "zod";
import {
handleApiResult,
createErrorResponse
} from "./utils.js";
import { complexityReportDirect } from "../core/task-master-core.js";
/**
* Register the complexityReport tool with the MCP server
* @param {Object} server - FastMCP server instance
*/
export function registerComplexityReportTool(server) {
server.addTool({
name: "complexity_report",
description: "Display the complexity analysis report in a readable format",
parameters: z.object({
file: z.string().optional().describe("Path to the report file (default: scripts/task-complexity-report.json)"),
projectRoot: z.string().optional().describe("Root directory of the project (default: current working directory)")
}),
execute: async (args, { log }) => {
try {
log.info(`Getting complexity report with args: ${JSON.stringify(args)}`);
// Call the direct function wrapper
const result = await complexityReportDirect(args, log);
// Log result
if (result.success) {
log.info(`Successfully retrieved complexity report${result.fromCache ? ' (from cache)' : ''}`);
} else {
log.error(`Failed to retrieve complexity report: ${result.error.message}`);
}
// Use handleApiResult to format the response
return handleApiResult(result, log, 'Error retrieving complexity report');
} catch (error) {
log.error(`Error in complexity-report tool: ${error.message}`);
return createErrorResponse(`Failed to retrieve complexity report: ${error.message}`);
}
},
});
}

View File

@@ -22,12 +22,25 @@ export function registerFixDependenciesTool(server) {
file: z.string().optional().describe("Path to the tasks file"),
projectRoot: z.string().optional().describe("Root directory of the project (default: current working directory)")
}),
handler: async ({ file, projectRoot }, { logger }) => {
execute: async (args, { log }) => {
try {
const result = await fixDependenciesDirect({ file, projectRoot }, logger);
return handleApiResult(result);
log.info(`Fixing dependencies with args: ${JSON.stringify(args)}`);
// Call the direct function wrapper
const result = await fixDependenciesDirect(args, log);
// Log result
if (result.success) {
log.info(`Successfully fixed dependencies: ${result.data.message}`);
} else {
log.error(`Failed to fix dependencies: ${result.error.message}`);
}
// Use handleApiResult to format the response
return handleApiResult(result, log, 'Error fixing dependencies');
} catch (error) {
return createErrorResponse(error);
log.error(`Error in fixDependencies tool: ${error.message}`);
return createErrorResponse(error.message);
}
}
});

View File

@@ -3,8 +3,8 @@
* Export all Task Master CLI tools for MCP server
*/
import logger from "../logger.js";
import { registerListTasksTool } from "./list-tasks.js";
import logger from "../logger.js";
import { registerSetTaskStatusTool } from "./set-task-status.js";
import { registerParsePRDTool } from "./parse-prd.js";
import { registerUpdateTool } from "./update.js";
@@ -23,6 +23,7 @@ import { registerExpandAllTool } from "./expand-all.js";
import { registerRemoveDependencyTool } from "./remove-dependency.js";
import { registerValidateDependenciesTool } from "./validate-dependencies.js";
import { registerFixDependenciesTool } from "./fix-dependencies.js";
import { registerComplexityReportTool } from "./complexity-report.js";
/**
* Register all Task Master tools with the MCP server
@@ -52,6 +53,7 @@ export function registerTaskMasterTools(server) {
registerRemoveDependencyTool(server);
registerValidateDependenciesTool(server);
registerFixDependenciesTool(server);
registerComplexityReportTool(server);
logger.info("Successfully registered all Task Master tools");
} catch (error) {

View File

@@ -22,13 +22,26 @@ export function registerValidateDependenciesTool(server) {
file: z.string().optional().describe("Path to the tasks file"),
projectRoot: z.string().optional().describe("Root directory of the project (default: current working directory)")
}),
handler: async ({ file, projectRoot }, { logger }) => {
execute: async (args, { log }) => {
try {
const result = await validateDependenciesDirect({ file, projectRoot }, logger);
return handleApiResult(result);
log.info(`Validating dependencies with args: ${JSON.stringify(args)}`);
// Call the direct function wrapper
const result = await validateDependenciesDirect(args, log);
// Log result
if (result.success) {
log.info(`Successfully validated dependencies: ${result.data.message}`);
} else {
log.error(`Failed to validate dependencies: ${result.error.message}`);
}
// Use handleApiResult to format the response
return handleApiResult(result, log, 'Error validating dependencies');
} catch (error) {
return createErrorResponse(error);
log.error(`Error in validateDependencies tool: ${error.message}`);
return createErrorResponse(error.message);
}
}
},
});
}