Unofficial Tapo API Client. Works with TP-Link Tapo smart devices. Tested with light bulbs (L510, L520, L530, L535, L610, L630), light strips (L900, L920, L930), plugs (P100, P105, P110, P110M, P115), power strips (P300, P304M, P306, P316M), hubs (H100), switches (S200B, S200D) and sensors (KE100, T100, T110, T300, T310, T315).
See /SUPPORTED_DEVICES.md for the supported devices and feature matrix.
Cargo.toml
[dependencies]
tapo = "0.8"main.rs
let device = ApiClient::new("<tapo-username>", "tapo-password")
.p110("<device ip address>")
.await?;
device.on().await?;export TAPO_USERNAME=
export TAPO_PASSWORD=
export IP_ADDRESS=
cargo run --example tapo_l530See all examples in /tapo/examples.
pip install tapoclient = ApiClient("<tapo-username>", "tapo-password")
device = await client.p110("<device ip address>")
await device.on()cd tapo-py
uv venv # On the initial run only
uv sync --group dev --locked
uv run maturin develop # On the initial run and whenever the Rust code is modified
export TAPO_USERNAME=
export TAPO_PASSWORD=
export IP_ADDRESS=python examples/tapo_p110.pySee all examples in /tapo-py/examples.
An MCP server that exposes Tapo devices as AI-callable tools and resources via the Model Context Protocol. See /tapo-mcp/README.md for setup and usage.
- tapo-rest — a REST wrapper of this library that can be deployed as a service or serve as an advanced example.
Contributions are welcome and encouraged! See /CONTRIBUTING.md.
Inspired by petretiandrea/plugp100.