lifx-mcp-server
A Model Context Protocol server for controlling LIFX smart lights, enabling AI assistants to manage power, color, brightness, effects, and scenes.
README
LIFX MCP Server
A comprehensive Model Context Protocol (MCP) server for controlling LIFX smart lights, built with TypeScript and Bun. This server provides seamless integration between AI assistants and LIFX lighting systems.
Features
š” LIFX Control Tools
- List Lights: Discover and list all LIFX lights with detailed information
- Set State: Control light power, color, brightness, and transitions
- Toggle Power: Smart power toggling based on current state
- Effects: Apply breathe, pulse, and other lighting effects
- Scenes: List and activate LIFX scenes
- Color Validation: Validate and convert color formats
š LIFX Resources
- Server Information: Runtime information and LIFX API status
- Color Examples: Comprehensive guide to LIFX color formats
- Selector Examples: Examples of LIFX light selector syntax
š¬ Smart Prompts
- Lighting Scenes: Generate custom lighting setups for moods and activities
- Troubleshooting: Diagnose and fix LIFX lighting issues
- Color Recommendations: Get scientifically-backed color suggestions
š Transport Support
- Stdio Transport: For Claude Desktop and command-line integration
- HTTP Transport: For web-based clients with session management
Installation
Prerequisites
- Bun installed on your system
- Node.js v18+ (for compatibility)
- LIFX API token from LIFX Cloud
Setup
# Clone or create the project
cd lifx-mcp-server
# Install dependencies
bun install
# Configure your LIFX API token
cp .env.example .env
# Edit .env and add your LIFX_API_TOKEN
Get Your LIFX API Token
- Go to LIFX Cloud Settings
- Generate a new personal access token
- Copy the token to your
.envfile or pass it as a command line argument
Usage
Stdio Mode (for Claude Desktop, etc.)
# Start with token from environment
bun run start:stdio
# Or pass token directly
bun run src/index.ts --token=YOUR_LIFX_TOKEN
# Development mode with auto-reload
bun run dev
HTTP Mode (for web clients)
# Start HTTP server (requires token in .env)
bun run start:http
# The server will be available at:
# http://localhost:3000
Configuration for Claude Desktop
Add this to your Claude Desktop configuration:
{
"mcpServers": {
"lifx-mcp-server": {
"command": "bun",
"args": ["run", "src/index.ts", "--token=YOUR_LIFX_TOKEN"],
"cwd": "/path/to/your/lifx-mcp-server"
}
}
}
LIFX Tools Reference
list-lights
Discover and list LIFX lights with detailed information.
Parameters:
selector: string (default: "all") - Light selector (e.g., "all", "label:Kitchen", "group:Living Room")
Example:
{
"name": "list-lights",
"arguments": {
"selector": "group:Living Room"
}
}
set-state
Control light properties including power, color, brightness.
Parameters:
selector: string (default: "all") - Light selectorpower: "on" | "off" (optional) - Power statecolor: string (optional) - Color (e.g., "red", "#ff0000", "kelvin:3500")brightness: number (optional) - Brightness (0.0 to 1.0)duration: number (optional) - Transition duration in secondsfast: boolean (optional) - Use fast mode for quicker response
Example:
{
"name": "set-state",
"arguments": {
"selector": "label:Bedroom",
"power": "on",
"color": "blue saturation:0.5",
"brightness": 0.7,
"duration": 2
}
}
toggle-power
Smart power toggle - turns off if any lights are on, turns on if all are off.
Parameters:
selector: string (default: "all") - Light selectorduration: number (optional) - Transition duration in seconds
breathe-effect
Apply a breathing effect to lights.
Parameters:
selector: string (default: "all") - Light selectorcolor: string - Effect colorfromColor: string (optional) - Starting colorperiod: number (default: 1.0) - Period in secondscycles: number (default: 1.0) - Number of cyclespersist: boolean (default: false) - Keep final colorpowerOn: boolean (default: true) - Turn on lights if offpeak: number (default: 1.0) - Brightness peak (0.0 to 1.0)
pulse-effect
Apply a pulsing effect to lights.
Parameters:
selector: string (default: "all") - Light selectorcolor: string - Effect colorfromColor: string (optional) - Starting colorperiod: number (default: 1.0) - Period in secondscycles: number (default: 1.0) - Number of cyclespersist: boolean (default: false) - Keep final colorpowerOn: boolean (default: true) - Turn on lights if off
list-scenes
List all available LIFX scenes in your account.
activate-scene
Activate a LIFX scene by UUID.
Parameters:
sceneUuid: string - Scene UUIDduration: number (optional) - Transition durationignore: string[] (optional) - Device IDs to ignoreoverrides: object (optional) - State overrides
validate-color
Validate a color string and get its HSBK representation.
Parameters:
color: string - Color to validate
Color Format Guide
LIFX supports various color formats:
Named Colors
- Basic: "red", "blue", "green", "yellow", "orange", "purple", "pink", "cyan", "white"
- Extended: "gold", "coral", "lime", "navy", etc.
Hex Colors
- Standard: "#ff0000", "#00ff00", "#0000ff"
- Short: "#f00", "#0f0", "#00f"
HSL Format
- "hue:120 saturation:1.0"
- "hue:240 saturation:0.5 brightness:0.8"
Kelvin Temperature
- "kelvin:2700" (warm white)
- "kelvin:6500" (cool white)
- "kelvin:9000" (very cool)
Combined Formats
- "red brightness:0.3"
- "blue saturation:0.5"
- "kelvin:3500 brightness:0.8"
Light Selectors
LIFX uses powerful selectors to target specific lights:
Basic Selectors
all- All lightsid:d3b2f1d97452- Specific light by ID
Label Selectors
label:Kitchen- Single light by labellabel:Kitchen,Bedroom- Multiple lights by label
Group Selectors
group:Living Room- All lights in a groupgroup:Living Room,Kitchen- Multiple groups
Location Selectors
location:Home- All lights at a locationlocation:Home,Office- Multiple locations
Combined Selectors
group:Living Room label:Lamp- Intersectionlocation:Home group:Bedroom- Complex targeting
Example Usage Scenarios
1. Morning Routine
// Gradually turn on bedroom lights
{
"name": "set-state",
"arguments": {
"selector": "group:Bedroom",
"power": "on",
"color": "kelvin:2700",
"brightness": 0.3,
"duration": 10
}
}
2. Work Focus Setup
// Set office lights to cool white, high brightness
{
"name": "set-state",
"arguments": {
"selector": "location:Office",
"power": "on",
"color": "kelvin:6500",
"brightness": 0.9,
"duration": 3
}
}
3. Party Mode
// Apply colorful pulse effect
{
"name": "pulse-effect",
"arguments": {
"selector": "all",
"color": "hue:300 saturation:1.0",
"period": 0.5,
"cycles": 10,
"persist": false
}
}
4. Relaxation Scene
// Dim warm lights with breathing effect
{
"name": "breathe-effect",
"arguments": {
"selector": "group:Living Room",
"color": "kelvin:2200 brightness:0.2",
"period": 4,
"cycles": 5,
"persist": true
}
}
Development
Project Structure
src/
āāā index.ts # Main LIFX MCP server implementation
āāā server-http.ts # HTTP transport server
āāā test-client.ts # Test client for development
package.json # Dependencies and scripts
tsconfig.json # TypeScript configuration
.env # Environment configuration
README.md # This file
Testing
# Run the test client
bun run test:manual
# Build for production
bun run build
# Format code
bun run format
# Lint code
bun run lint
Security & Best Practices
- Store your LIFX API token securely
- Use environment variables instead of hardcoding tokens
- Be mindful of rate limits when making frequent API calls
- Test selectors to ensure they target the correct lights
- Use
fast=truemode sparingly for better reliability
Troubleshooting
Common Issues
- API Token Invalid: Check your token at LIFX Cloud Settings
- No Lights Found: Verify lights are online and connected to WiFi
- Selector Not Working: Check light labels and group names in LIFX app
- Rate Limit Errors: Reduce frequency of API calls
- Effects Not Working: Ensure lights support the requested effect type
Debug Mode
Set DEBUG=true in your .env file for detailed API request/response logging.
License
MIT License - see LICENSE file for details.
Resources
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.