Azure MCP (Model Context Protocol) for Claude Desktop
A Model Context Protocol (MCP) implementation that enables Claude Desktop to interact with Azure services. This integration allows Claude to query and manage Azure resources directly through natural language conversations.
Features
- Azure Resource Management: Interface with Azure Resource Management client
- Subscription Management: List and manage Azure subscriptions
- Tenant Management: List and select Azure tenants
- Automatic Authentication: Leverages DefaultAzureCredential for flexible authentication methods
- Error Handling: Robust error handling with retries for transient failures
- Clean Response Formatting: Properly formatted responses compatible with Claude Desktop
Prerequisites
- Node.js (v18 or higher)
- Claude Desktop Application
- Azure Account with appropriate permissions
- Azure CLI (optional, for CLI-based authentication)
Installation
Manual Installation
- Clone the repository:
- Install dependencies:
- Configure Claude Desktop:
- Open
claude_desktop_config.json
- Add the following MCP configuration:
- Open
Authentication
The server supports multiple authentication methods through DefaultAzureCredential:
- Environment Variables
- Managed Identity
- Azure CLI
- Visual Studio Code
- Interactive Browser
The server will automatically try these methods in sequence until one succeeds.
Usage
- Close Claude Desktop if it's running (check Task Manager)
- Start Claude Desktop
- In the chat, you can now ask Azure-related questions like:
- "Can you get all the available Azure accounts and subscriptions?"
- "List all resource groups in my subscription"
- "Show me all virtual machines in a specific resource group"
Example Conversation
Development
Project Structure
Key Components
- AzureMCPServer: Main server class implementing the MCP protocol
- HandleCallTool: Processes incoming tool requests
- ExecuteWithRetry: Implements retry logic for resilient operations
Troubleshooting
- Authentication Issues:
- Ensure you're logged in via Azure CLI (
az login
) - Check environment variables if using service principal
- Verify your Azure account has necessary permissions
- Ensure you're logged in via Azure CLI (
- Connection Issues:
- Verify Claude Desktop configuration
- Check paths in config file match your installation
- Ensure no other instances are running
- Common Errors:
NO_TENANT
: Select a tenant using the 'select-tenant' toolNO_CLIENTS
: Ensure proper initialization and authenticationCODE_EXECUTION_FAILED
: Check Azure permissions and connection
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Contributors
- @calclavia - Integration with smithery.ai
Acknowledgments
- Claude Desktop team for the MCP implementation
- Azure SDK team for the comprehensive SDK
- Model Context Protocol for enabling AI-service integration
Security Note
This implementation follows Azure security best practices:
- No hardcoded credentials
- Secure credential chain implementation
- Proper error handling and sanitization
For security concerns or vulnerabilities, please create an issue.
You must be authenticated.
local-only server
The server can only run on the client's local machine because it depends on local resources.
Enables natural language interaction with Azure services through Claude Desktop, supporting resource management, subscription handling, and tenant selection with secure authentication.
- Features
- Prerequisites
- Installation
- Authentication
- Usage
- Development
- Troubleshooting
- Contributing
- Contributors
- Acknowledgments
- Security Note
Related Resources
Related MCP Servers
- -securityAlicense-qualityLets you use Claude Desktop, or any MCP Client, to use natural language to accomplish things on your Cloudflare account.Last updated -9341,390TypeScriptApache 2.0
- AsecurityAlicenseAqualityThis server provides a convenient API for interacting with Azure DevOps services, enabling AI assistants and other tools to manage work items, code repositories, boards, sprints, and more. Built with the Model Context Protocol, it provides a standardized interface for communicating with Azure DevOpsLast updated -9610TypeScriptMIT License
- -securityAlicense-qualityA server that enables LLMs like Claude to interact with Azure Cosmos DB databases through natural language queries, acting as a translator between AI assistants and database systems.Last updated -JavaScriptMIT License
- AsecurityAlicenseAqualityA server that enables LLMs (like Claude and VSCode Copilot) to interact with Azure Cosmos DB data through natural language queries, acting as a translator between AI assistants and your database.Last updated -3JavaScriptMIT License