claude-mpm 4.20.3__py3-none-any.whl → 4.25.10__py3-none-any.whl
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.
Potentially problematic release.
This version of claude-mpm might be problematic. Click here for more details.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/BASE_PM.md +23 -6
- claude_mpm/agents/OUTPUT_STYLE.md +3 -48
- claude_mpm/agents/PM_INSTRUCTIONS.md +1783 -34
- claude_mpm/agents/WORKFLOW.md +75 -2
- claude_mpm/agents/base_agent.json +6 -3
- claude_mpm/agents/frontmatter_validator.py +1 -1
- claude_mpm/agents/templates/api_qa.json +5 -2
- claude_mpm/agents/templates/circuit_breakers.md +108 -2
- claude_mpm/agents/templates/documentation.json +33 -6
- claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
- claude_mpm/agents/templates/php-engineer.json +10 -4
- claude_mpm/agents/templates/pm_red_flags.md +89 -19
- claude_mpm/agents/templates/project_organizer.json +7 -3
- claude_mpm/agents/templates/qa.json +2 -1
- claude_mpm/agents/templates/react_engineer.json +1 -0
- claude_mpm/agents/templates/research.json +82 -12
- claude_mpm/agents/templates/security.json +4 -4
- claude_mpm/agents/templates/tauri_engineer.json +274 -0
- claude_mpm/agents/templates/ticketing.json +10 -6
- claude_mpm/agents/templates/version_control.json +4 -2
- claude_mpm/agents/templates/web_qa.json +2 -1
- claude_mpm/cli/README.md +253 -0
- claude_mpm/cli/__init__.py +11 -1
- claude_mpm/cli/commands/aggregate.py +1 -1
- claude_mpm/cli/commands/analyze.py +3 -3
- claude_mpm/cli/commands/cleanup.py +1 -1
- claude_mpm/cli/commands/configure_agent_display.py +4 -4
- claude_mpm/cli/commands/debug.py +12 -12
- claude_mpm/cli/commands/hook_errors.py +277 -0
- claude_mpm/cli/commands/mcp_install_commands.py +1 -1
- claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
- claude_mpm/cli/commands/mpm_init/README.md +365 -0
- claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
- claude_mpm/cli/commands/mpm_init/core.py +573 -0
- claude_mpm/cli/commands/mpm_init/display.py +341 -0
- claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
- claude_mpm/cli/commands/mpm_init/modes.py +397 -0
- claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
- claude_mpm/cli/commands/mpm_init_cli.py +396 -0
- claude_mpm/cli/commands/mpm_init_handler.py +67 -1
- claude_mpm/cli/commands/run.py +124 -128
- claude_mpm/cli/commands/skills.py +522 -34
- claude_mpm/cli/executor.py +56 -0
- claude_mpm/cli/interactive/agent_wizard.py +5 -5
- claude_mpm/cli/parsers/base_parser.py +28 -0
- claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
- claude_mpm/cli/parsers/skills_parser.py +138 -0
- claude_mpm/cli/startup.py +111 -8
- claude_mpm/cli/startup_display.py +480 -0
- claude_mpm/cli/utils.py +1 -1
- claude_mpm/cli_module/commands.py +1 -1
- claude_mpm/cli_module/refactoring_guide.md +253 -0
- claude_mpm/commands/mpm-help.md +3 -0
- claude_mpm/commands/mpm-init.md +19 -3
- claude_mpm/commands/mpm-resume.md +372 -0
- claude_mpm/commands/mpm-tickets.md +56 -7
- claude_mpm/commands/mpm.md +1 -0
- claude_mpm/config/agent_capabilities.yaml +658 -0
- claude_mpm/config/async_logging_config.yaml +145 -0
- claude_mpm/constants.py +12 -0
- claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
- claude_mpm/core/api_validator.py +1 -1
- claude_mpm/core/claude_runner.py +14 -1
- claude_mpm/core/config.py +8 -0
- claude_mpm/core/constants.py +1 -1
- claude_mpm/core/framework/processors/metadata_processor.py +1 -1
- claude_mpm/core/hook_error_memory.py +381 -0
- claude_mpm/core/hook_manager.py +41 -2
- claude_mpm/core/interactive_session.py +48 -3
- claude_mpm/core/interfaces.py +56 -1
- claude_mpm/core/logger.py +3 -1
- claude_mpm/core/oneshot_session.py +39 -0
- claude_mpm/d2/.gitignore +22 -0
- claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
- claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
- claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
- claude_mpm/d2/QUICKSTART.md +186 -0
- claude_mpm/d2/README.md +232 -0
- claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
- claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
- claude_mpm/d2/TESTING.md +288 -0
- claude_mpm/d2/index.html +118 -0
- claude_mpm/d2/package.json +19 -0
- claude_mpm/d2/src/App.svelte +110 -0
- claude_mpm/d2/src/components/Header.svelte +153 -0
- claude_mpm/d2/src/components/MainContent.svelte +74 -0
- claude_mpm/d2/src/components/Sidebar.svelte +85 -0
- claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
- claude_mpm/d2/src/lib/socketio.js +144 -0
- claude_mpm/d2/src/main.js +7 -0
- claude_mpm/d2/src/stores/events.js +114 -0
- claude_mpm/d2/src/stores/socket.js +108 -0
- claude_mpm/d2/src/stores/theme.js +65 -0
- claude_mpm/d2/svelte.config.js +12 -0
- claude_mpm/d2/vite.config.js +15 -0
- claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
- claude_mpm/dashboard/BUILD_NUMBER +1 -0
- claude_mpm/dashboard/README.md +121 -0
- claude_mpm/dashboard/VERSION +1 -0
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
- claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
- claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
- claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
- claude_mpm/dashboard/react/entries/events.tsx +165 -0
- claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
- claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
- claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
- claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
- claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
- claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
- claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
- claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
- claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
- claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
- claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
- claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
- claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
- claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
- claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
- claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
- claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
- claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
- claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
- claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
- claude_mpm/dashboard/static/built/connection-manager.js +76 -76
- claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
- claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
- claude_mpm/dashboard/static/built/react/events.js.map +1 -0
- claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
- claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
- claude_mpm/dashboard/static/built/shared/logger.js +16 -16
- claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
- claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
- claude_mpm/dashboard/static/css/activity.css +69 -69
- claude_mpm/dashboard/static/css/connection-status.css +10 -10
- claude_mpm/dashboard/static/css/dashboard.css +15 -15
- claude_mpm/dashboard/static/index.html +22 -22
- claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
- claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
- claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
- claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
- claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
- claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
- claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
- claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
- claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
- claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
- claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
- claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
- claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
- claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
- claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
- claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
- claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
- claude_mpm/dashboard/static/js/connection-manager.js +76 -76
- claude_mpm/dashboard/static/js/dashboard.js +76 -58
- claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
- claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
- claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
- claude_mpm/dashboard/static/js/shared/logger.js +16 -16
- claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
- claude_mpm/dashboard/static/js/socket-client.js +138 -121
- claude_mpm/dashboard/static/navigation-test-results.md +118 -0
- claude_mpm/dashboard/static/production/main.html +21 -21
- claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
- claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
- claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
- claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
- claude_mpm/dashboard/templates/code_simple.html +23 -23
- claude_mpm/dashboard/templates/index.html +18 -18
- claude_mpm/hooks/README.md +143 -0
- claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
- claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
- claude_mpm/hooks/claude_hooks/installer.py +45 -0
- claude_mpm/hooks/templates/README.md +180 -0
- claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
- claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
- claude_mpm/hooks/templates/settings.json.example +147 -0
- claude_mpm/schemas/agent_schema.json +596 -0
- claude_mpm/schemas/frontmatter_schema.json +165 -0
- claude_mpm/scripts/claude-hook-handler.sh +3 -3
- claude_mpm/scripts/start_activity_logging.py +3 -1
- claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
- claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
- claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
- claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
- claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
- claude_mpm/services/agents/local_template_manager.py +3 -1
- claude_mpm/services/cli/session_pause_manager.py +504 -0
- claude_mpm/services/cli/session_resume_helper.py +36 -16
- claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
- claude_mpm/services/core/base.py +26 -11
- claude_mpm/services/core/interfaces.py +56 -1
- claude_mpm/services/core/models/agent_config.py +3 -0
- claude_mpm/services/core/models/process.py +4 -0
- claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
- claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
- claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
- claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
- claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
- claude_mpm/services/diagnostics/models.py +21 -0
- claude_mpm/services/event_bus/README.md +244 -0
- claude_mpm/services/event_bus/direct_relay.py +3 -3
- claude_mpm/services/event_bus/event_bus.py +36 -3
- claude_mpm/services/event_bus/relay.py +23 -7
- claude_mpm/services/events/README.md +303 -0
- claude_mpm/services/events/consumers/logging.py +1 -2
- claude_mpm/services/framework_claude_md_generator/README.md +119 -0
- claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
- claude_mpm/services/local_ops/__init__.py +2 -0
- claude_mpm/services/local_ops/process_manager.py +1 -1
- claude_mpm/services/local_ops/resource_monitor.py +2 -2
- claude_mpm/services/mcp_gateway/README.md +185 -0
- claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
- claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
- claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
- claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
- claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
- claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
- claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
- claude_mpm/services/memory/failure_tracker.py +19 -4
- claude_mpm/services/memory/optimizer.py +1 -1
- claude_mpm/services/model/model_router.py +8 -9
- claude_mpm/services/monitor/daemon.py +1 -1
- claude_mpm/services/monitor/server.py +2 -2
- claude_mpm/services/native_agent_converter.py +356 -0
- claude_mpm/services/port_manager.py +1 -1
- claude_mpm/services/project/documentation_manager.py +2 -1
- claude_mpm/services/project/toolchain_analyzer.py +3 -1
- claude_mpm/services/runner_configuration_service.py +1 -0
- claude_mpm/services/self_upgrade_service.py +165 -7
- claude_mpm/services/skills_config.py +547 -0
- claude_mpm/services/skills_deployer.py +955 -0
- claude_mpm/services/socketio/handlers/connection.py +1 -1
- claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
- claude_mpm/services/socketio/handlers/git.py +2 -2
- claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
- claude_mpm/services/static/.gitkeep +2 -0
- claude_mpm/services/system_instructions_service.py +1 -3
- claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
- claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
- claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
- claude_mpm/services/version_control/VERSION +1 -0
- claude_mpm/services/version_control/conflict_resolution.py +6 -4
- claude_mpm/services/visualization/mermaid_generator.py +2 -3
- claude_mpm/skills/__init__.py +3 -3
- claude_mpm/skills/agent_skills_injector.py +42 -49
- claude_mpm/skills/bundled/.gitkeep +2 -0
- claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +4 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +108 -114
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
- claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +46 -41
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
- claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +36 -73
- claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +100 -125
- claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +28 -72
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +11 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +272 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
- claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +13 -1
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/internal-comms/SKILL.md +11 -0
- claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +109 -277
- claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +17 -10
- claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +92 -39
- claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
- claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/skill-creator/SKILL.md +135 -155
- claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
- claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
- claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
- claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
- claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
- claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +13 -12
- claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +5 -3
- claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +19 -12
- claude_mpm/skills/bundled/performance-profiling.md +6 -0
- claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
- claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
- claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
- claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
- claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
- claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
- claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
- claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
- claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
- claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
- claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
- claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
- claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
- claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +21 -25
- claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +86 -250
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
- claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +145 -57
- claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
- claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +6 -6
- claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +13 -9
- claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +8 -8
- claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
- claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
- claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +37 -15
- claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
- claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
- claude_mpm/skills/skills_registry.py +44 -48
- claude_mpm/skills/skills_service.py +117 -108
- claude_mpm/templates/questions/EXAMPLES.md +501 -0
- claude_mpm/templates/questions/__init__.py +43 -0
- claude_mpm/templates/questions/base.py +193 -0
- claude_mpm/templates/questions/pr_strategy.py +314 -0
- claude_mpm/templates/questions/project_init.py +388 -0
- claude_mpm/templates/questions/ticket_mgmt.py +397 -0
- claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
- claude_mpm/tools/__main__.py +8 -8
- claude_mpm/tools/code_tree_analyzer/README.md +64 -0
- claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
- claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
- claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
- claude_mpm/tools/code_tree_analyzer/core.py +380 -0
- claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
- claude_mpm/tools/code_tree_analyzer/events.py +168 -0
- claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
- claude_mpm/tools/code_tree_analyzer/models.py +39 -0
- claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
- claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
- claude_mpm/utils/agent_dependency_loader.py +3 -3
- claude_mpm/utils/dependency_cache.py +3 -1
- claude_mpm/utils/gitignore.py +241 -0
- claude_mpm/utils/log_cleanup.py +3 -3
- claude_mpm/utils/robust_installer.py +3 -5
- claude_mpm/utils/structured_questions.py +619 -0
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/METADATA +218 -31
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +409 -246
- claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
- claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
- claude_mpm/cli/commands/mpm_init.py +0 -2093
- claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
- claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
- claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
- claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
- claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
- claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
- claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
- claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
- claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
- claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
- claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
- claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
- claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
- claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
- claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
- claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
- claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
- claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
- claude_mpm/dashboard/static/dist/dashboard.js +0 -2
- claude_mpm/dashboard/static/dist/react/events.js +0 -30
- claude_mpm/dashboard/static/dist/socket-client.js +0 -2
- claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/common-failures.md +0 -213
- claude_mpm/tools/code_tree_analyzer.py +0 -1825
- /claude_mpm/skills/bundled/collaboration/requesting-code-review/{code-reviewer.md → references/code-reviewer-template.md} +0 -0
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
|
@@ -1,328 +1,160 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: mcp-builder
|
|
3
|
-
description:
|
|
3
|
+
description: Create high-quality MCP servers that enable LLMs to effectively interact with external services. Use when building MCP integrations for APIs or services in Python (FastMCP) or Node/TypeScript (MCP SDK).
|
|
4
4
|
license: Complete terms in LICENSE.txt
|
|
5
|
+
progressive_disclosure:
|
|
6
|
+
entry_point:
|
|
7
|
+
summary: "Build agent-friendly MCP servers through research-driven design, thoughtful implementation, and evaluation-based iteration"
|
|
8
|
+
when_to_use: "When integrating external APIs/services via MCP protocol. Prioritize agent workflows over API wrappers, optimize for context efficiency, design actionable errors."
|
|
9
|
+
quick_start: "1. Research protocol & API docs 2. Plan agent-centric tools 3. Implement with validation 4. Create evaluations 5. Iterate based on agent feedback"
|
|
10
|
+
references:
|
|
11
|
+
- design_principles.md
|
|
12
|
+
- workflow.md
|
|
13
|
+
- mcp_best_practices.md
|
|
14
|
+
- python_mcp_server.md
|
|
15
|
+
- node_mcp_server.md
|
|
16
|
+
- evaluation.md
|
|
5
17
|
---
|
|
6
18
|
|
|
7
19
|
# MCP Server Development Guide
|
|
8
20
|
|
|
9
21
|
## Overview
|
|
10
22
|
|
|
11
|
-
|
|
23
|
+
Build high-quality MCP (Model Context Protocol) servers that enable LLMs to accomplish real-world tasks through well-designed tools. Quality is measured not by API coverage, but by how effectively agents can use your tools to complete realistic workflows.
|
|
12
24
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Process
|
|
16
|
-
|
|
17
|
-
## 🚀 High-Level Workflow
|
|
18
|
-
|
|
19
|
-
Creating a high-quality MCP server involves four main phases:
|
|
20
|
-
|
|
21
|
-
### Phase 1: Deep Research and Planning
|
|
22
|
-
|
|
23
|
-
#### 1.1 Understand Agent-Centric Design Principles
|
|
24
|
-
|
|
25
|
-
Before diving into implementation, understand how to design tools for AI agents by reviewing these principles:
|
|
26
|
-
|
|
27
|
-
**Build for Workflows, Not Just API Endpoints:**
|
|
28
|
-
- Don't simply wrap existing API endpoints - build thoughtful, high-impact workflow tools
|
|
29
|
-
- Consolidate related operations (e.g., `schedule_event` that both checks availability and creates event)
|
|
30
|
-
- Focus on tools that enable complete tasks, not just individual API calls
|
|
31
|
-
- Consider what workflows agents actually need to accomplish
|
|
32
|
-
|
|
33
|
-
**Optimize for Limited Context:**
|
|
34
|
-
- Agents have constrained context windows - make every token count
|
|
35
|
-
- Return high-signal information, not exhaustive data dumps
|
|
36
|
-
- Provide "concise" vs "detailed" response format options
|
|
37
|
-
- Default to human-readable identifiers over technical codes (names over IDs)
|
|
38
|
-
- Consider the agent's context budget as a scarce resource
|
|
39
|
-
|
|
40
|
-
**Design Actionable Error Messages:**
|
|
41
|
-
- Error messages should guide agents toward correct usage patterns
|
|
42
|
-
- Suggest specific next steps: "Try using filter='active_only' to reduce results"
|
|
43
|
-
- Make errors educational, not just diagnostic
|
|
44
|
-
- Help agents learn proper tool usage through clear feedback
|
|
45
|
-
|
|
46
|
-
**Follow Natural Task Subdivisions:**
|
|
47
|
-
- Tool names should reflect how humans think about tasks
|
|
48
|
-
- Group related tools with consistent prefixes for discoverability
|
|
49
|
-
- Design tools around natural workflows, not just API structure
|
|
50
|
-
|
|
51
|
-
**Use Evaluation-Driven Development:**
|
|
52
|
-
- Create realistic evaluation scenarios early
|
|
53
|
-
- Let agent feedback drive tool improvements
|
|
54
|
-
- Prototype quickly and iterate based on actual agent performance
|
|
55
|
-
|
|
56
|
-
#### 1.3 Study MCP Protocol Documentation
|
|
25
|
+
**Core insight:** MCP servers expose tools for AI agents, not human users. Design for agent constraints (limited context, no visual UI, workflow-oriented) rather than human convenience.
|
|
57
26
|
|
|
58
|
-
|
|
27
|
+
## When to Use This Skill
|
|
59
28
|
|
|
60
|
-
|
|
29
|
+
Activate when:
|
|
30
|
+
- Building MCP servers for external API integration
|
|
31
|
+
- Adding tools to existing MCP servers
|
|
32
|
+
- Improving MCP server tool design for better agent usability
|
|
33
|
+
- Creating evaluations to test MCP server effectiveness
|
|
34
|
+
- Debugging why agents struggle with your MCP tools
|
|
61
35
|
|
|
62
|
-
|
|
36
|
+
**Language Support:**
|
|
37
|
+
- Python: FastMCP framework (recommended for rapid development)
|
|
38
|
+
- Node/TypeScript: MCP SDK (recommended for production services)
|
|
63
39
|
|
|
64
|
-
|
|
40
|
+
## The Iron Law
|
|
65
41
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
- **MCP Best Practices**: [📋 View Best Practices](./reference/mcp_best_practices.md) - Core guidelines for all MCP servers
|
|
69
|
-
|
|
70
|
-
**For Python implementations, also load:**
|
|
71
|
-
- **Python SDK Documentation**: Use WebFetch to load `https://raw.githubusercontent.com/modelcontextprotocol/python-sdk/main/README.md`
|
|
72
|
-
- [🐍 Python Implementation Guide](./reference/python_mcp_server.md) - Python-specific best practices and examples
|
|
73
|
-
|
|
74
|
-
**For Node/TypeScript implementations, also load:**
|
|
75
|
-
- **TypeScript SDK Documentation**: Use WebFetch to load `https://raw.githubusercontent.com/modelcontextprotocol/typescript-sdk/main/README.md`
|
|
76
|
-
- [⚡ TypeScript Implementation Guide](./reference/node_mcp_server.md) - Node/TypeScript-specific best practices and examples
|
|
77
|
-
|
|
78
|
-
#### 1.5 Exhaustively Study API Documentation
|
|
79
|
-
|
|
80
|
-
To integrate a service, read through **ALL** available API documentation:
|
|
81
|
-
- Official API reference documentation
|
|
82
|
-
- Authentication and authorization requirements
|
|
83
|
-
- Rate limiting and pagination patterns
|
|
84
|
-
- Error responses and status codes
|
|
85
|
-
- Available endpoints and their parameters
|
|
86
|
-
- Data models and schemas
|
|
87
|
-
|
|
88
|
-
**To gather comprehensive information, use web search and the WebFetch tool as needed.**
|
|
89
|
-
|
|
90
|
-
#### 1.6 Create a Comprehensive Implementation Plan
|
|
42
|
+
```
|
|
43
|
+
DESIGN FOR AGENTS, NOT HUMANS
|
|
91
44
|
|
|
92
|
-
|
|
45
|
+
Every tool must optimize for:
|
|
46
|
+
- Context efficiency (agents have limited tokens)
|
|
47
|
+
- Workflow completion (not just API calls)
|
|
48
|
+
- Actionable errors (guide agents to success)
|
|
49
|
+
- Natural task subdivision (how agents think)
|
|
50
|
+
```
|
|
93
51
|
|
|
94
|
-
|
|
95
|
-
- List the most valuable endpoints/operations to implement
|
|
96
|
-
- Prioritize tools that enable the most common and important use cases
|
|
97
|
-
- Consider which tools work together to enable complex workflows
|
|
52
|
+
If your tools are just thin API wrappers, you're violating the Iron Law.
|
|
98
53
|
|
|
99
|
-
|
|
100
|
-
- Identify common API request patterns
|
|
101
|
-
- Plan pagination helpers
|
|
102
|
-
- Design filtering and formatting utilities
|
|
103
|
-
- Plan error handling strategies
|
|
54
|
+
## Core Principles
|
|
104
55
|
|
|
105
|
-
**
|
|
106
|
-
- Define input validation models (Pydantic for Python, Zod for TypeScript)
|
|
107
|
-
- Design consistent response formats (e.g., JSON or Markdown), and configurable levels of detail (e.g., Detailed or Concise)
|
|
108
|
-
- Plan for large-scale usage (thousands of users/resources)
|
|
109
|
-
- Implement character limits and truncation strategies (e.g., 25,000 tokens)
|
|
56
|
+
1. **Agent-Centric Design First**: Study design principles before coding. Tools should enable workflows, not mirror APIs.
|
|
110
57
|
|
|
111
|
-
**
|
|
112
|
-
- Plan graceful failure modes
|
|
113
|
-
- Design clear, actionable, LLM-friendly, natural language error messages which prompt further action
|
|
114
|
-
- Consider rate limiting and timeout scenarios
|
|
115
|
-
- Handle authentication and authorization errors
|
|
58
|
+
2. **Research-Driven Planning**: Load MCP docs, SDK docs, and exhaustive API documentation before writing code.
|
|
116
59
|
|
|
117
|
-
|
|
60
|
+
3. **Evaluation-Based Iteration**: Create realistic evaluations early. Let agent feedback drive improvements.
|
|
118
61
|
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
Now that you have a comprehensive plan, begin implementation following language-specific best practices.
|
|
122
|
-
|
|
123
|
-
#### 2.1 Set Up Project Structure
|
|
124
|
-
|
|
125
|
-
**For Python:**
|
|
126
|
-
- Create a single `.py` file or organize into modules if complex (see [🐍 Python Guide](./reference/python_mcp_server.md))
|
|
127
|
-
- Use the MCP Python SDK for tool registration
|
|
128
|
-
- Define Pydantic models for input validation
|
|
129
|
-
|
|
130
|
-
**For Node/TypeScript:**
|
|
131
|
-
- Create proper project structure (see [⚡ TypeScript Guide](./reference/node_mcp_server.md))
|
|
132
|
-
- Set up `package.json` and `tsconfig.json`
|
|
133
|
-
- Use MCP TypeScript SDK
|
|
134
|
-
- Define Zod schemas for input validation
|
|
135
|
-
|
|
136
|
-
#### 2.2 Implement Core Infrastructure First
|
|
137
|
-
|
|
138
|
-
**To begin implementation, create shared utilities before implementing tools:**
|
|
139
|
-
- API request helper functions
|
|
140
|
-
- Error handling utilities
|
|
141
|
-
- Response formatting functions (JSON and Markdown)
|
|
142
|
-
- Pagination helpers
|
|
143
|
-
- Authentication/token management
|
|
144
|
-
|
|
145
|
-
#### 2.3 Implement Tools Systematically
|
|
146
|
-
|
|
147
|
-
For each tool in the plan:
|
|
148
|
-
|
|
149
|
-
**Define Input Schema:**
|
|
150
|
-
- Use Pydantic (Python) or Zod (TypeScript) for validation
|
|
151
|
-
- Include proper constraints (min/max length, regex patterns, min/max values, ranges)
|
|
152
|
-
- Provide clear, descriptive field descriptions
|
|
153
|
-
- Include diverse examples in field descriptions
|
|
154
|
-
|
|
155
|
-
**Write Comprehensive Docstrings/Descriptions:**
|
|
156
|
-
- One-line summary of what the tool does
|
|
157
|
-
- Detailed explanation of purpose and functionality
|
|
158
|
-
- Explicit parameter types with examples
|
|
159
|
-
- Complete return type schema
|
|
160
|
-
- Usage examples (when to use, when not to use)
|
|
161
|
-
- Error handling documentation, which outlines how to proceed given specific errors
|
|
162
|
-
|
|
163
|
-
**Implement Tool Logic:**
|
|
164
|
-
- Use shared utilities to avoid code duplication
|
|
165
|
-
- Follow async/await patterns for all I/O
|
|
166
|
-
- Implement proper error handling
|
|
167
|
-
- Support multiple response formats (JSON and Markdown)
|
|
168
|
-
- Respect pagination parameters
|
|
169
|
-
- Check character limits and truncate appropriately
|
|
170
|
-
|
|
171
|
-
**Add Tool Annotations:**
|
|
172
|
-
- `readOnlyHint`: true (for read-only operations)
|
|
173
|
-
- `destructiveHint`: false (for non-destructive operations)
|
|
174
|
-
- `idempotentHint`: true (if repeated calls have same effect)
|
|
175
|
-
- `openWorldHint`: true (if interacting with external systems)
|
|
176
|
-
|
|
177
|
-
#### 2.4 Follow Language-Specific Best Practices
|
|
178
|
-
|
|
179
|
-
**At this point, load the appropriate language guide:**
|
|
180
|
-
|
|
181
|
-
**For Python: Load [🐍 Python Implementation Guide](./reference/python_mcp_server.md) and ensure the following:**
|
|
182
|
-
- Using MCP Python SDK with proper tool registration
|
|
183
|
-
- Pydantic v2 models with `model_config`
|
|
184
|
-
- Type hints throughout
|
|
185
|
-
- Async/await for all I/O operations
|
|
186
|
-
- Proper imports organization
|
|
187
|
-
- Module-level constants (CHARACTER_LIMIT, API_BASE_URL)
|
|
188
|
-
|
|
189
|
-
**For Node/TypeScript: Load [⚡ TypeScript Implementation Guide](./reference/node_mcp_server.md) and ensure the following:**
|
|
190
|
-
- Using `server.registerTool` properly
|
|
191
|
-
- Zod schemas with `.strict()`
|
|
192
|
-
- TypeScript strict mode enabled
|
|
193
|
-
- No `any` types - use proper types
|
|
194
|
-
- Explicit Promise<T> return types
|
|
195
|
-
- Build process configured (`npm run build`)
|
|
62
|
+
4. **Context Optimization**: Every response token matters. Default to concise, offer detailed when needed.
|
|
196
63
|
|
|
197
|
-
|
|
64
|
+
5. **Actionable Errors**: Error messages should teach agents correct usage patterns.
|
|
198
65
|
|
|
199
|
-
|
|
66
|
+
## Quick Start
|
|
200
67
|
|
|
201
|
-
|
|
68
|
+
### Phase 1: Research and Planning (40% of effort)
|
|
69
|
+
1. **Study Design Principles**: Load [design_principles.md](./reference/design_principles.md) to understand agent-centric design
|
|
70
|
+
2. **Load Protocol Docs**: Fetch `https://modelcontextprotocol.io/llms-full.txt` for MCP specification
|
|
71
|
+
3. **Study SDK Docs**: Load Python or TypeScript SDK documentation from GitHub
|
|
72
|
+
4. **Study API Exhaustively**: Read ALL API documentation, endpoints, authentication, rate limits
|
|
73
|
+
5. **Create Implementation Plan**: Define tools, shared utilities, pagination strategy, error handling
|
|
202
74
|
|
|
203
|
-
|
|
75
|
+
See [workflow.md](./reference/workflow.md) for complete Phase 1 steps.
|
|
204
76
|
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
- **Type Safety**: Full type coverage (Python type hints, TypeScript types)
|
|
211
|
-
- **Documentation**: Every tool has comprehensive docstrings/descriptions
|
|
77
|
+
### Phase 2: Implementation (30% of effort)
|
|
78
|
+
1. **Setup Project**: Create structure following language-specific guide
|
|
79
|
+
2. **Build Shared Utilities**: API helpers, error handlers, formatters BEFORE tools
|
|
80
|
+
3. **Implement Tools**: Use Pydantic (Python) or Zod (TypeScript) for validation
|
|
81
|
+
4. **Follow Best Practices**: Load language-specific guide for patterns
|
|
212
82
|
|
|
213
|
-
|
|
83
|
+
See [workflow.md](./reference/workflow.md) for complete Phase 2 steps and language guides.
|
|
214
84
|
|
|
215
|
-
|
|
85
|
+
### Phase 3: Review and Refine (15% of effort)
|
|
86
|
+
1. **Code Quality Review**: Check DRY, composability, consistency, type safety
|
|
87
|
+
2. **Test Build**: Verify syntax, imports, build process
|
|
88
|
+
3. **Quality Checklist**: Use language-specific checklist
|
|
216
89
|
|
|
217
|
-
|
|
218
|
-
- Use the evaluation harness (see Phase 4) - recommended approach
|
|
219
|
-
- Run the server in tmux to keep it outside your main process
|
|
220
|
-
- Use a timeout when testing: `timeout 5s python server.py`
|
|
90
|
+
See [workflow.md](./reference/workflow.md) for complete Phase 3 steps.
|
|
221
91
|
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
92
|
+
### Phase 4: Create Evaluations (15% of effort)
|
|
93
|
+
1. **Understand Purpose**: Evaluations test if agents can answer realistic questions using your tools
|
|
94
|
+
2. **Create 10 Questions**: Complex, read-only, independent, verifiable questions
|
|
95
|
+
3. **Verify Answers**: Solve yourself to ensure stability and correctness
|
|
96
|
+
4. **Run Evaluation**: Use provided scripts to test agent effectiveness
|
|
227
97
|
|
|
228
|
-
|
|
229
|
-
- Run `npm run build` and ensure it completes without errors
|
|
230
|
-
- Verify dist/index.js is created
|
|
231
|
-
- To manually test: Run server in tmux, then test with evaluation harness in main process
|
|
232
|
-
- Or use the evaluation harness directly (it manages the server for stdio transport)
|
|
98
|
+
See [evaluation.md](./reference/evaluation.md) for complete evaluation guidelines.
|
|
233
99
|
|
|
234
|
-
|
|
100
|
+
## Navigation
|
|
235
101
|
|
|
236
|
-
|
|
237
|
-
-
|
|
238
|
-
- Node/TypeScript: see "Quality Checklist" in [⚡ TypeScript Guide](./reference/node_mcp_server.md)
|
|
102
|
+
### Core Design and Workflow
|
|
103
|
+
- **[🎯 Design Principles](./reference/design_principles.md)** - Agent-centric design philosophy: workflows over APIs, context optimization, actionable errors, natural task subdivision. Read FIRST before implementation.
|
|
239
104
|
|
|
240
|
-
|
|
105
|
+
- **[🔄 Complete Workflow](./reference/workflow.md)** - Detailed 4-phase development process with step-by-step instructions, decision trees, and when to load each reference file.
|
|
241
106
|
|
|
242
|
-
###
|
|
107
|
+
### Universal MCP Guidelines
|
|
108
|
+
- **[📋 MCP Best Practices](./reference/mcp_best_practices.md)** - Naming conventions, response formats, pagination, character limits, security, tool annotations, error handling. Applies to all MCP servers.
|
|
243
109
|
|
|
244
|
-
|
|
110
|
+
### Language-Specific Implementation
|
|
111
|
+
- **[🐍 Python Implementation](./reference/python_mcp_server.md)** - FastMCP patterns, Pydantic validation, async/await, complete examples, quality checklist. Load during Phase 2 for Python servers.
|
|
245
112
|
|
|
246
|
-
**
|
|
113
|
+
- **[⚡ TypeScript Implementation](./reference/node_mcp_server.md)** - MCP SDK patterns, Zod validation, project structure, complete examples, quality checklist. Load during Phase 2 for TypeScript servers.
|
|
247
114
|
|
|
248
|
-
|
|
115
|
+
### Evaluation and Testing
|
|
116
|
+
- **[✅ Evaluation Guide](./reference/evaluation.md)** - Creating realistic questions, answer verification, XML format, running evaluations, interpreting results. Load during Phase 4.
|
|
249
117
|
|
|
250
|
-
|
|
118
|
+
## Key Reminders
|
|
251
119
|
|
|
252
|
-
|
|
120
|
+
- **Research First**: Spend 40% of time researching before coding
|
|
121
|
+
- **Agent-Centric**: Design for AI workflows, not API completeness
|
|
122
|
+
- **Context Efficient**: Every token counts - default concise, offer detailed
|
|
123
|
+
- **Actionable Errors**: Guide agents to correct usage
|
|
124
|
+
- **Shared Utilities**: Extract common code - avoid duplication
|
|
125
|
+
- **Evaluation-Driven**: Create evals early, iterate based on feedback
|
|
126
|
+
- **MCP Servers Block**: Never run servers directly - use evaluation harness or tmux
|
|
253
127
|
|
|
254
|
-
|
|
128
|
+
## Red Flags - STOP
|
|
255
129
|
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
130
|
+
If you catch yourself:
|
|
131
|
+
- "Just wrapping these API endpoints directly"
|
|
132
|
+
- "Returning all available data fields"
|
|
133
|
+
- "Error message just says what failed" (not how to fix)
|
|
134
|
+
- Starting implementation without reading design principles
|
|
135
|
+
- Coding before loading MCP protocol documentation
|
|
136
|
+
- Creating tools without knowing agent use cases
|
|
137
|
+
- Skipping evaluation creation
|
|
138
|
+
- Running `python server.py` directly (will hang forever)
|
|
260
139
|
|
|
261
|
-
|
|
140
|
+
**ALL of these mean: STOP. Return to design principles and workflow.**
|
|
262
141
|
|
|
263
|
-
|
|
264
|
-
- **Independent**: Not dependent on other questions
|
|
265
|
-
- **Read-only**: Only non-destructive operations required
|
|
266
|
-
- **Complex**: Requiring multiple tool calls and deep exploration
|
|
267
|
-
- **Realistic**: Based on real use cases humans would care about
|
|
268
|
-
- **Verifiable**: Single, clear answer that can be verified by string comparison
|
|
269
|
-
- **Stable**: Answer won't change over time
|
|
142
|
+
## Integration with Other Skills
|
|
270
143
|
|
|
271
|
-
|
|
144
|
+
- **systematic-debugging**: Debug MCP server issues methodically
|
|
145
|
+
- **test-driven-development**: Create failing tests before implementation
|
|
146
|
+
- **verification-before-completion**: Verify build succeeds before claiming completion
|
|
147
|
+
- **defense-in-depth**: Add input validation at multiple layers
|
|
272
148
|
|
|
273
|
-
|
|
149
|
+
## Real-World Impact
|
|
274
150
|
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
<!-- More qa_pairs... -->
|
|
282
|
-
</evaluation>
|
|
283
|
-
```
|
|
151
|
+
From MCP server development experience:
|
|
152
|
+
- Well-designed servers: 80-90% task completion rate by agents
|
|
153
|
+
- API wrapper approach: 30-40% task completion rate
|
|
154
|
+
- Context-optimized responses: 3x more information in same token budget
|
|
155
|
+
- Actionable errors: 60% reduction in agent retry attempts
|
|
156
|
+
- Evaluation-driven iteration: 2-3x improvement in agent success rate
|
|
284
157
|
|
|
285
158
|
---
|
|
286
159
|
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
## 📚 Documentation Library
|
|
290
|
-
|
|
291
|
-
Load these resources as needed during development:
|
|
292
|
-
|
|
293
|
-
### Core MCP Documentation (Load First)
|
|
294
|
-
- **MCP Protocol**: Fetch from `https://modelcontextprotocol.io/llms-full.txt` - Complete MCP specification
|
|
295
|
-
- [📋 MCP Best Practices](./reference/mcp_best_practices.md) - Universal MCP guidelines including:
|
|
296
|
-
- Server and tool naming conventions
|
|
297
|
-
- Response format guidelines (JSON vs Markdown)
|
|
298
|
-
- Pagination best practices
|
|
299
|
-
- Character limits and truncation strategies
|
|
300
|
-
- Tool development guidelines
|
|
301
|
-
- Security and error handling standards
|
|
302
|
-
|
|
303
|
-
### SDK Documentation (Load During Phase 1/2)
|
|
304
|
-
- **Python SDK**: Fetch from `https://raw.githubusercontent.com/modelcontextprotocol/python-sdk/main/README.md`
|
|
305
|
-
- **TypeScript SDK**: Fetch from `https://raw.githubusercontent.com/modelcontextprotocol/typescript-sdk/main/README.md`
|
|
306
|
-
|
|
307
|
-
### Language-Specific Implementation Guides (Load During Phase 2)
|
|
308
|
-
- [🐍 Python Implementation Guide](./reference/python_mcp_server.md) - Complete Python/FastMCP guide with:
|
|
309
|
-
- Server initialization patterns
|
|
310
|
-
- Pydantic model examples
|
|
311
|
-
- Tool registration with `@mcp.tool`
|
|
312
|
-
- Complete working examples
|
|
313
|
-
- Quality checklist
|
|
314
|
-
|
|
315
|
-
- [⚡ TypeScript Implementation Guide](./reference/node_mcp_server.md) - Complete TypeScript guide with:
|
|
316
|
-
- Project structure
|
|
317
|
-
- Zod schema patterns
|
|
318
|
-
- Tool registration with `server.registerTool`
|
|
319
|
-
- Complete working examples
|
|
320
|
-
- Quality checklist
|
|
321
|
-
|
|
322
|
-
### Evaluation Guide (Load During Phase 4)
|
|
323
|
-
- [✅ Evaluation Guide](./reference/evaluation.md) - Complete evaluation creation guide with:
|
|
324
|
-
- Question creation guidelines
|
|
325
|
-
- Answer verification strategies
|
|
326
|
-
- XML format specifications
|
|
327
|
-
- Example questions and answers
|
|
328
|
-
- Running an evaluation with the provided scripts
|
|
160
|
+
**Remember:** The quality of an MCP server is measured by how well it enables LLMs to accomplish realistic tasks, not by how comprehensively it wraps an API.
|