dev-env-setup
Automates setup of local development environments for Python, Node.js, Flutter, Android, and more on macOS and Linux. Can be used as a standalone CLI or as an MCP server for AI assistant integration.
README
Dev Environment Setup Tool
A production-ready dual-mode tool that automates the setup of local development environments for Python, Node.js, Flutter, Android, and more across macOS and Linux systems.
๐ฏ Two Modes:
- CLI Mode: Standalone command-line tool (
devenvcommand) - MCP Mode: Model Context Protocol server for AI assistant integration
โจ Features
- Dual Mode Operation: Use as standalone CLI or MCP server
- Cross-Platform Support: Works on both macOS and Linux distributions
- Intelligent Package Manager Detection: Automatically detects and uses the appropriate package manager (Homebrew, apt, dnf, yum, pacman, zypper)
- Modular Architecture: Clean, testable, and extensible codebase
- Comprehensive Tool Support: Python, Node.js, Git, Docker, Java, Go, Rust, Flutter, and more
- Automated Installation: One-command setup for entire development stacks
- Environment Validation: Check what's installed and get recommendations
- Shell Configuration: Automatically configures environment variables and PATH
- CI/CD Ready: GitHub Actions workflows included
- Unit Tested: Comprehensive test coverage for reliability
๐ Quick Start
Installation
npm install -g @cmwen/mcp-dev-env-setup
CLI Mode
Use the devenv command for standalone operation:
# Check installed tools
devenv check
# Get system information
devenv info
# List available tools
devenv list
# Install a tool
devenv install python
devenv install nodejs
# Install multiple tools
devenv install-all
# Get help
devenv --help
See CLI.md for complete CLI documentation.
MCP Mode
Configure in your MCP client (e.g., Claude Desktop):
{
"mcpServers": {
"dev-env-setup": {
"command": "npx",
"args": ["-y", "mcp-dev-env-setup"]
}
}
}
Or run directly in MCP STDIO mode:
devenv --mcp
# or
devenv --stdio
๐ Supported Tools
Languages
- Python - Python 3 with pip
- Java - OpenJDK 17
- Go - Go programming language
- Rust - Rust with cargo
Runtimes & Tools
- Node.js - JavaScript runtime (via nvm or package manager)
- Git - Version control
- Docker - Container platform
SDKs & Frameworks
- Flutter - Mobile app development SDK
- Android Studio - Android development tools
๐ฅ๏ธ Supported Systems
Operating Systems
- macOS (Intel and Apple Silicon)
- Linux distributions:
- Debian/Ubuntu (apt)
- Fedora (dnf)
- RHEL/CentOS (yum)
- Arch Linux (pacman)
- openSUSE (zypper)
Package Managers
- Homebrew (macOS)
- apt (Debian/Ubuntu)
- dnf (Fedora)
- yum (RHEL/CentOS)
- pacman (Arch)
- zypper (openSUSE)
๐ง Available MCP Tools
1. check_environment
Check which development tools are currently installed on your system.
// Returns status of all tools with versions
2. install_python
Install Python 3 and pip using the system package manager.
3. install_nodejs
Install Node.js with optional version specification.
{
"version": "lts" // or "18", "20", etc.
}
4. install_flutter
Install Flutter SDK for mobile app development.
5. install_android
Install Android Studio and development tools (including Java).
6. setup_all
Install all development environments at once with optional skip list.
{
"skip": ["python", "flutter"] // Optional: tools to skip
}
๐ Documentation
- CLI Usage Guide - Complete CLI command reference and examples
- API Documentation - Complete API reference for all modules
- AI Agents Guide - Guide for AI agents to use and extend this project
- Development Guide - Setup, development workflow, and contribution guidelines
- Quick Start Guide - Get started in minutes
- Usage Examples - Common usage patterns
- Changelog - Version history and migration guides
๐๏ธ Architecture
The project follows a modular architecture:
src/
โโโ core/ # Core business logic
โ โโโ package-manager.ts # OS and package manager detection
โ โโโ tool-config.ts # Tool definitions and configurations
โโโ installers/ # Installation modules
โ โโโ unified-installer.ts # Unified installation logic
โโโ validators/ # Validation modules
โ โโโ environment-validator.ts # Environment checking
โโโ utils/ # Utility functions
โ โโโ shell.ts # Shell command execution
โ โโโ check.ts # Environment checking utilities
โโโ __tests__/ # Unit tests
Key Modules
- Package Manager Detection: Automatically detects your OS and package manager
- Tool Configuration: Defines installation methods for each tool across all platforms
- Unified Installer: Provides a single interface for installing any tool
- Environment Validator: Checks system status and provides recommendations
๐งช Testing
# Run all tests
npm test
# Run tests in watch mode
npm run test:watch
# Run tests with coverage
npm run test:coverage
# Type checking
npm run lint
๐ ๏ธ Development
Prerequisites
- Node.js >= 18.0.0
- npm or yarn
Setup
# Clone the repository
git clone https://github.com/cmwen/mcp-dev-env-setup.git
cd mcp-dev-env-setup
# Install dependencies
npm install
# Build the project
npm run build
# Run in development mode
npm run dev
Adding New Tools
- Add tool configuration to
src/core/tool-config.ts:
export const TOOL_CONFIGS: Record<string, ToolConfig> = {
mytool: {
name: 'mytool',
displayName: 'My Tool',
category: ToolCategory.LANGUAGE,
description: 'Description of my tool',
commandToCheck: 'mytool',
versionFlag: '--version',
installMethods: {
homebrew: {
packageManager: PackageManager.HOMEBREW,
packageName: 'mytool',
},
apt: {
packageManager: PackageManager.APT,
packageName: 'mytool',
},
// Add more package managers...
},
},
};
- Add tests in
src/__tests__/ - Update documentation
๐ค Contributing
Contributions are welcome! Please see CONTRIBUTING.md for guidelines.
Development Guidelines
- Follow TypeScript best practices
- Write tests for new features
- Update documentation
- Keep functions focused and single-purpose
- Use meaningful variable names
๐ License
MIT License - see LICENSE file for details.
๐ Links
๐ก Examples
Check System Status
import { getSystemStatus } from './validators/environment-validator';
const status = await getSystemStatus();
console.log(`OS: ${status.os}`);
console.log(`Package Manager: ${status.packageManager?.name}`);
console.log(`Installed tools: ${status.tools.filter(t => t.installed).length}`);
Install Multiple Tools
import { installMultipleTools } from './installers/unified-installer';
const results = await installMultipleTools(['python', 'nodejs', 'git']);
for (const [tool, result] of Object.entries(results)) {
console.log(`${tool}: ${result.success ? 'โ' : 'โ'}`);
}
Validate Environment
import { isSystemReady } from './validators/environment-validator';
const { ready, missing } = await isSystemReady(['python', 'nodejs']);
if (!ready) {
console.log('Please install:', missing.join(', '));
}
๐ Acknowledgments
- Built with the Model Context Protocol SDK
- TypeScript and Node.js ecosystem
๐ Support
- Open an issue for bugs or feature requests
- Check documentation for API reference
- See AGENTS.md for AI agent integration guide
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.