SmartThings MCP
Samsung Smartthings Model Context Protocol Server
Lango SmartThings MCP Server
A Model Context Protocol (MCP) server that exposes Samsung SmartThings Public API as LLM-friendly tools, resources and real-time events.
Features
- Lazy Loading: Tools are discoverable without authentication - only validates API keys when tools are invoked
- Wraps common SmartThings operations as MCP Tools
- Devices:
list_devices,get_device,get_device_status,list_device_capabilities,send_device_command - Locations & Rooms:
list_locations,list_rooms,create_room,delete_room - Scenes & Rules:
list_scenes,execute_scene,list_rules - Hubs:
list_hubs,get_hub_health - Subscriptions:
list_subscriptions,create_subscription,delete_subscription - Schedules:
list_schedules,create_schedule,delete_schedule - History:
get_device_history - Capabilities:
get_capability
- Devices:
- Exposes device / status / location data as MCP Resources with read-through cache
- Supports all official MCP-Go transports
- Stdio (CLI / local), StreamableHTTP, Server-Sent Events (SSE)
- Periodic poller publishes live device status to SSE clients
- Zero external dependencies apart from
mcp-goandzaplogger
Requirements
- Go ≥ 1.23
- A valid SmartThings PAT (Personal Access Token)
Getting a Personal Access Token (PAT)
- Go to SmartThings Personal Access Tokens.
- Log in with your Samsung Account.
- Click Generate new token.
- Enter a name for your token and select the authorized scopes (e.g.,
devices,locations,scenes,rules,schedules). - Click Generate token.
- Copy and save the token immediately (it won't be shown again).
Environment Variables
| Name | Default | Description |
|---|---|---|
smartThingsToken, SMARTTHINGS_TOKEN | – | Bearer token for SmartThings API. Required for SmartThings operations, but server will start without it for tool discovery |
stBaseUrl, ST_BASE_URL | https://api.smartthings.com | Override for testing / mock servers |
MCP_LOG_LEVEL | info | debug |
Installation
Installing via Smithery
To install smartthings-mcp for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @langowarny/smartthings-mcp --client claude
Manual Installation
git clone https://github.com/langowarny/smartthings-mcp.git
cd smartthings-mcp
go mod download
Running
Stdio
SMARTTHINGS_TOKEN=123ab456-xxx... go run ./cmd/server -transport stdio
StreamableHTTP
SMARTTHINGS_TOKEN=123ab456-xxx... \
go run ./cmd/server -transport stream -host 0.0.0.0 -port 8081
Test request:
curl -X POST http://localhost:8081/mcp/tools/call \
-H 'Content-Type: application/json' \
-d '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"list_devices"}}'
SSE
SMARTTHINGS_TOKEN=123ab456-xxx... \
go run ./cmd/server -transport sse -host 0.0.0.0 -port 8081
# Open event stream
echo -e 'GET /mcp/sse HTTP/1.1\nHost: localhost:8081\n\n' | nc localhost 8081
The server emits smartthings/device_status notifications every 30 seconds.
Tool Catalogue
| Tool | Params | Description |
|---|---|---|
list_devices | location_id? | List user devices |
get_device | device_id | Device metadata |
get_device_status | device_id | Live status |
list_device_capabilities | device_id | Supported capabilities |
send_device_command | device_id, component, capability, command, arguments?[] | Issue command |
list_locations | – | List locations |
list_rooms | location_id | List rooms in a location |
create_room | location_id, name | Create a new room |
delete_room | location_id, room_id | Delete a room |
list_scenes | – | List all scenes |
execute_scene | scene_id | Trigger scene |
list_rules | – | List automation rules |
list_hubs | – | List hubs |
get_hub_health | hub_id | Get hub health status |
list_subscriptions | installed_app_id | List subscriptions |
create_subscription | installed_app_id, device_id, ... | Subscribe to device events |
delete_subscription | installed_app_id, subscription_id | Delete subscription |
list_schedules | installed_app_id | List schedules |
create_schedule | installed_app_id, name, cron | Create cron schedule |
delete_schedule | installed_app_id, schedule_id | Delete schedule |
get_device_history | device_id | Get recent device events |
get_capability | capability_id, version | Get capability definition |
Resource Patterns
| URI Template | Description | MIME |
|---|---|---|
st://devices/{device_id} | Device metadata | application/json |
st://devices/{device_id}/status | Live status | application/json |
st://locations/{location_id} | Location metadata | application/json |
Development
go vet ./...
go test ./...
go run ./cmd/server -transport stream
Logs are emitted via Uber Zap; adjust MCP_LOG_LEVEL for verbosity.
License
MIT © 2025 Lango Warny
相關伺服器
Nomad Stays
The world's platform for finding and booking digital nomad friend accommodation
drain-mcp
Open marketplace for AI services — LLMs, image/video generation, web scraping, model hosting, data extraction, and more. Agents pay per use with USDC micropayments on Polygon.
BlazeMeter MCP Server
MCP Server for AI-driven BlazeMeter performance testing
KSeF
MCP server for Poland's national e-invoicing system KSeF (Krajowy System e-Faktur). Provides 12 tools for complete KSeF API integration including session management, invoice querying/submission, export generation, and system monitoring. Built with Rust for reliability and performance. Perfect for Polish businesses automating e-invoicing processes and developers building KSeF compliance tools.
Fast Mobile MCP
High-performance mobile automation architecture with a thin MCP gateway and dedicated Go workers for Android and iOS.
MB's Personal MCP Server
A personal server for MB Crosier providing biography, contact information, and social links.
CryptoAPIs MCP Market Data
MCP server for cryptocurrency asset prices, exchange rates, and market metadata via Crypto APIs
MCP-HA-Connect
A production-ready Model Context Protocol (MCP) server for Home Assistant integration with AI assistants like Claude.
OilPriceAPI
Real-time oil, gas, and commodity prices. 40+ energy commodities with natural language queries, price subscriptions, and analyst prompts.
MCP Hub
A lightweight MCP Hub to centralize your MCP servers in one place.