Nest Protect MCP Server
Integrates with Google's Smart Device Management API to monitor and control Nest Protect smoke and carbon monoxide detectors.
Uses Google Cloud project for OAuth 2.0 authentication and access to the Smart Device Management API.
Manages Nest Protect devices that are added to a Google Home or Nest account, enabling device discovery and control.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Nest Protect MCP ServerCheck the battery levels of all my Nest Protects."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Nest Protect MCP Server
📖 Installation Guide — quick start, manual setup, and troubleshooting
Quick Start
git clone https://github.com/sandraschi/nest-protect-mcp
cd nest-protect-mcp
justThis opens an interactive dashboard showing all available commands. Run just bootstrap to install dependencies, then just serve or just dev to start.
Manual Setup
If you don't have just installed:
Overview
The Nest Protect MCP Server is a production-ready FastMCP 3.2.0 compatible server that provides seamless integration between Google Nest Protect devices and the Model Context Protocol (MCP). It offers comprehensive monitoring and control capabilities for your Nest Protect smoke and carbon monoxide detectors through Claude Desktop and other MCP clients.
Current Status: FULLY OPERATIONAL - SOTA UPGRADE COMPLETE
20 Production Tools - Complete device management suite
Real API Integration - No mocks, authentic Google Smart Device Management API v1
FastMCP 3.2.0 - Sampling, agentic workflows, prompts (skills)
MCPB Packaging - Claude Desktop optimized deployment
Python 3.10+ - Modern baseline requirements
OAuth 2.0 Security - Complete authentication flow with token management
Comprehensive Assets - 22KB prompt templates and documentation
Ruff Linted - 100% code quality compliance
Key Components
MCP Server: Implements the Model Context Protocol (MCP) v2.13.0 standard with MCPB packaging
Nest API Integration: Handles OAuth 2.0 authentication and communication with Google's Smart Device Management API v1
Device Management: Provides 20 production-ready tools to discover, monitor, and control Nest Protect devices
MCPB Assets: Comprehensive prompt templates (22KB) and documentation for Claude Desktop integration
Architecture
graph LR
A[MCP Client<br/>(Claude Desktop)] <--> B[Nest Protect MCP Server]
B <--> C[Google Nest<br/>Cloud Services]
D[Web Interface] <--> B
E[Container Runtime] <--> B
F[CI/CD Pipeline] --> B
style A fill:#f9f,stroke:#333
style B fill:#bbf,stroke:#333
style C fill:#bfb,stroke:#333
style D fill:#fbf,stroke:#333
style E fill:#fbf,stroke:#333
style F fill:#bbf,stroke:#333Features
Core Capabilities
FastMCP 3.2.0 Compliance: Sampling, agentic workflows, prompts (skills)
Real Nest API Integration: Authentic Google Smart Device Management API v1 calls with OAuth 2.0
20 Production Tools: Complete device management and control suite
MCPB Packaging: Claude Desktop optimized deployment with comprehensive assets
State-of-the-Art Security: OAuth 2.0 authentication with automatic token refresh
Nest Protect Integration
Device Discovery: List all Nest Protect devices in your home
Real-time Status: Monitor battery, connectivity, and alarm states
Device Control: Hush alarms, run safety checks, adjust settings
Alarm Testing: Sound alarms for testing purposes
Event History: Access device events and activity logs
Technical Features
OAuth 2.0 Authentication: Secure Google API integration
State Management: Persistent device state and configuration
Error Handling: Comprehensive error reporting and recovery
Pydantic V2 Models: Modern data validation and serialization
Async/Await: Full asynchronous operation for optimal performance
Quick Start
Prerequisites
Python 3.10 or later
Google Cloud Project with Smart Device Management API enabled
Nest Protect devices added to your Google Home/Nest account
Authentication Setup
Before using the Nest Protect MCP server, you need to set up authentication with Google's API:
Create a Google Cloud Project (if you don't have one):
Go to Google Cloud Console
Create a new project
Enable the Smart Device Management API
Configure OAuth consent screen (select "External" user type)
Create OAuth 2.0 credentials (Desktop app type)
Download the credentials as
client_secret_*.json
Set up environment variables in a
.envfile:# Copy the example .env file cp .env.example .env # Edit the .env file with your credentials NEST_CLIENT_ID=your_client_id NEST_CLIENT_SECRET=your_client_secret NEST_PROJECT_ID=your_project_id
Installation
Prerequisites
uv installed (RECOMMENDED)
Python 3.12+
Quick Start
Run immediately via uvx:
uvx nest-protect-mcpClaude Desktop Integration
Add to your claude_desktop_config.json:
"mcpServers": {
"nest-protect-mcp": {
"command": "uv",
"args": ["--directory", "D:/Dev/repos/nest-protect-mcp", "run", "nest-protect-mcp"]
}
}Option 1: Claude Desktop (MCPB) - Recommended
Download the
.mcpbpackage from GitHub ReleasesDrag the
.mcpbfile into Claude Desktop settingsInstall Python dependencies (run in terminal):
pip install FastMCP 3.2.0 pydantic>=2.0.0 aiohttp>=3.8.0 httpx>=0.24.0 websockets>=11.0.0 python-dotenv>=1.0.0 tomli>=0.10.2 python-dateutil>=2.8.2 anyio>=4.5.0 structlog>=23.1.0Configure Google Nest API credentials in Claude Desktop settings:
nest_client_id: Your Google OAuth Client IDnest_client_secret: Your Google OAuth Client Secretnest_project_id: Your Google Cloud Project IDnest_refresh_token: Your OAuth refresh token
Start using - Claude will automatically connect to your Nest Protect devices
Installation
Prerequisites
uv installed (RECOMMENDED)
Python 3.12+
Quick Start
Run immediately via uvx:
uvx nest-protect-mcpClaude Desktop Integration
Add to your claude_desktop_config.json:
"mcpServers": {
"nest-protect-mcp": {
"command": "uv",
"args": ["--directory", "D:/Dev/repos/nest-protect-mcp", "run", "nest-protect-mcp"]
}
}Running the Server
MCP Mode (Recommended for IDE Integration)
# Start the server in MCP mode
python -m nest_protect_mcpHTTP Mode (For Web Interfaces)
# Start the HTTP server on port 8000
python -m nest_protect_mcp --httpDevelopment Mode (With Auto-Reload)
# Start in development mode with auto-reload
python -m nest_protect_mcp --reloadDocker Mode
# Run with Docker
docker run -d \
--name nest-protect-mcp \
-p 8080:8080 \
-v $(pwd)/config:/app/config \
-v $(pwd)/data:/app/data \
sandraschi/nest-protect-mcp:latestAvailable MCP Tools
The server provides 20 production-ready tools organized into categories:
Device Status Tools
get_devices- Get a list of all Nest Protect devicesget_device- Get detailed information about a specific deviceget_alarm_state- Get current alarm states and battery health
Device Control Tools
silence_alarm- Hush active alarms on devicesrun_test- Execute device tests and diagnostics
System Status Tools
Enhanced logging - Comprehensive debugging and monitoring
State management - Persistent configuration and device state
MCPB Package
MCPB Deployment - State of the Art
The Nest Protect MCP server includes a production-ready MCPB package optimized for Claude Desktop and modern MCP environments:
# Download from GitHub Releases:
# nest-protect-mcp-1.0.0.mcpbMCPB Features:
20 Production Tools - Complete device management suite
22KB Comprehensive Assets - Extensive prompt templates and documentation
FastMCP 3.2.0 - Latest MCP specification compliance
OAuth 2.0 Security - Secure authentication with automatic token refresh
Claude Desktop Optimized - Seamless drag-and-drop installation
MCPB Assets Included
The MCPB package includes comprehensive prompt templates and documentation:
Prompt Templates (22KB total)
system.md(8.2KB) - Comprehensive Claude Desktop integration guideuser.md(6.3KB) - Interactive usage examples and templatesexamples.json(9.9KB) - Structured usage examples with 12 detailed scenarios
Visual Assets
icon.png- Professional branding and recognitionscreenshots/- Usage documentation screenshotsdashboard.png- Main interface overviewconfiguration.png- Setup and configuration guideusage.png- Tool usage examples
Tool Categories (20 Tools)
Device Status (3 tools): list_devices, get_device_status, get_device_events
Device Control (5 tools): hush_alarm, run_safety_check, set_led_brightness, sound_alarm, arm_disarm_security
System Status (3 tools): get_system_status, get_process_status, get_api_status
Authentication (3 tools): initiate_oauth_flow, handle_oauth_callback, refresh_access_token
Configuration (5 tools): get_config, update_config, reset_config, export_config, import_config
Help & About (5 tools): list_available_tools, get_tool_help, search_tools, about_server, get_supported_devices
CI/CD Pipeline
Automated Workflows
The repository includes a comprehensive CI/CD pipeline with modern practices:
Quality Assurance
Multi-OS testing (Ubuntu, Windows, macOS)
Multi-Python support (3.10-3.13)
Security scanning (vulnerability checks)
Code quality analysis (mypy, bandit, radon)
Performance benchmarking
Automated Deployment
Semantic versioning with automated releases
PyPI publishing for stable releases
GitHub releases with changelog generation
Docker container builds (multi-architecture)
Documentation deployment (GitHub Pages)
Maintenance & Monitoring
Dependency updates (automated security patches)
Repository cleanup (workflow run management)
Notification system (Slack/Discord integration)
Performance tracking (benchmarking)
Modern Development Practices
Version Management
# .bumpversion.toml
[bumpversion]
current_version = 0.1.0
commit = True
tag = True
[bumpversion:file:pyproject.toml]
search = version = "{current_version}"
replace = version = "{new_version}"Container Definition
# Multi-stage build for optimal size
FROM python:3.11-slim as base
# ... optimized production containerPackage Configuration
{
"dependencies": ["FastMCP 3.2.0,<4.0.0"],
"configuration": {
"nest_client_id": {"type": "string", "required": true},
"nest_client_secret": {"type": "string", "required": true, "secret": true},
"nest_project_id": {"type": "string", "required": true},
"nest_refresh_token": {"type": "string", "required": true, "secret": true}
}
}Troubleshooting
Recent Fixes Applied
FastMCP 3.2.0: Sampling, agentic workflows, prompts (skills); see docs/AUTH_SETUP.md for auth.
MCPB Packaging: Claude Desktop optimized; run
scripts/get_nest_refresh_token.pyfor refresh token.Webapp: Onboarding page and Help modal with setup steps.
Common Issues & Solutions
Server Disconnects from Claude Desktop
Symptom: Server starts but disconnects after a few seconds
Solution: Check your claude_desktop_config.json - ensure no --kill arguments:
{
"mcpServers": {
"nest protect": {
"command": "py",
"args": ["-3.13", "-m", "nest_protect_mcp"],
"cwd": "D:/Dev/repos/nest-protect-mcp"
}
}
}Authentication Issues
Symptom: "No refresh token available" or authentication errors Solution:
Get a refresh token: run
python scripts/get_nest_refresh_token.py(see docs/AUTH_SETUP.md)Put
NEST_CLIENT_ID,NEST_CLIENT_SECRET,NEST_PROJECT_ID,NEST_REFRESH_TOKENin.envin the repo rootEnsure Smart Device Management API is enabled in Google Cloud Console
Tool Help Not Working
Symptom: "get tool help" has difficulties with parameters Solution: FIXED - Updated FastMCP tool registration with proper syntax
Device Not Found
Symptom: No devices appear in tool responses Solution:
Verify devices are set up in Google Home app
Check authentication permissions
Restart server after authentication
Enhanced Debugging
The server now includes comprehensive logging:
=== FASTMCP SERVER INITIALIZED ===
Tool registration complete
Authentication state loaded
Device discovery startedIf you see errors, check the detailed logs for specific failure points.
Documentation
** Complete Documentation**
For detailed documentation, please refer to the docs directory:
AUTH_SETUP - Auth and refresh token (quick reference); also in webapp Setup & auth and Help modal
Setup Guide - Full installation and configuration
Technical Architecture - System design, FastMCP 3.2.0, tools and prompts
MCP Production Checklist - Deployment readiness
Containerization Guidelines - Docker deployment
Troubleshooting - Common issues and solutions
Tools Reference - Complete tool documentation
** Quick Reference**
Installation
Prerequisites
uv installed (RECOMMENDED)
Python 3.12+
Quick Start
Run immediately via uvx:
uvx nest-protect-mcpClaude Desktop Integration
Add to your claude_desktop_config.json:
"mcpServers": {
"nest-protect-mcp": {
"command": "uv",
"args": ["--directory", "D:/Dev/repos/nest-protect-mcp", "run", "nest-protect-mcp"]
}
}Server Commands
# MCP mode (default)
python -m nest_protect_mcp
# HTTP mode
python -m nest_protect_mcp --http
# Development mode
python -m nest_protect_mcp --reload
# Help
python -m nest_protect_mcp --helpAuthentication
# Start OAuth flow
python -m nest_protect_mcp.auth
# Verify authentication
python -m nest_protect_mcp --statusREST API Reference
When running in HTTP mode, the following endpoints are available:
GET /health- Health checkGET /api/devices- List all devicesGET /api/devices/{device_id}- Get device detailsPOST /api/devices/{device_id}/command- Send command to device
Security
OAuth 2.0 Authentication - Secure Google API integration
Token Management - Automatic refresh with secure storage
HTTPS Support - Optional SSL/TLS encryption
Input Validation - Pydantic V2 model validation
Security Scanning - Automated vulnerability checks
Deployment
** MCPB Package**
# Deploy MCPB package (Claude Desktop)
# Download and drag nest-protect-mcp-1.0.0.mcpb into Claude Desktop** Docker Container**
# Run container
docker run -d \
--name nest-protect-mcp \
-p 8080:8080 \
sandraschi/nest-protect-mcp:latest** Cloud Deployment**
Railway - One-click deployment available
Heroku - Container-based deployment
AWS/GCP - Container orchestration support
Contributing
Contributions are welcome! Please read our Contributing Guide for details.
Development Setup
# Clone repository
git clone https://github.com/sandraschi/nest-protect-mcp.git
cd nest-protect-mcp
# Install development dependencies
uv pip install -e .[dev]
# Run tests
pytest
# Run linting
pre-commit run --all-filesPerformance
Multi-threaded API calls for optimal performance
Connection pooling for efficient HTTP requests
State caching for reduced API calls
Async/await patterns for non-blocking operations
Memory efficient device state management
Updates & Maintenance
The repository includes automated maintenance workflows:
Weekly dependency updates for security patches
Automated testing across multiple environments
Performance monitoring and benchmarking
Documentation updates with each release
Changelog
See CHANGELOG.md for detailed version history.
Support
For support, please:
Check the troubleshooting guide
Search existing issues
Open a new issue with detailed information
🛡️ Industrial Quality Stack
This project adheres to SOTA 14.1 industrial standards for high-fidelity agentic orchestration:
Python (Core): Ruff for linting and formatting. Zero-tolerance for
printstatements in core handlers (T201).Webapp (UI): Biome for sub-millisecond linting. Strict
noConsoleLogenforcement.Protocol Compliance: Hardened
stdout/stderrisolation to ensure crash-resistant JSON-RPC communication.Automation: Justfile recipes for all fleet operations (
just lint,just fix,just dev).Security: Automated audits via
banditandsafety.
License
MIT License - see LICENSE file for details.
Made with for the smart home community
This server cannot be installed
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/sandraschi/nest-protect-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server