tapo 0.8.5

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) and sensors (KE100, T100, T110, T300, T310, T315).
Documentation
# Tapo


[![License][license_badge]][license]
[![Crates][crates_badge]][crates]
[![Documentation][crates_documentation_badge]][crates_documentation]
[![Crates.io][crates_downloads_badge]][crates]
[![PyPI][pypi_badge]][pypi]
[![Python][pypi_versions_badge]][pypi]
[![PyPI][pypi_downloads_badge]][pypi]\
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) and sensors (KE100, T100, T110, T300, T310, T315).

[license_badge]: https://img.shields.io/crates/l/tapo.svg
[license]: https://github.com/mihai-dinculescu/tapo/blob/main/LICENSE
[crates_badge]: https://img.shields.io/crates/v/tapo.svg?logo=rust&color=F75101
[crates]: https://crates.io/crates/tapo
[crates_documentation_badge]: https://img.shields.io/docsrs/tapo.svg?logo=rust&color=F75101
[crates_documentation]: https://docs.rs/tapo
[crates_downloads_badge]: https://img.shields.io/crates/d/tapo?logo=rust&label=downloads&color=F75101

[pypi_badge]: https://img.shields.io/pypi/v/tapo.svg?logo=pypi&color=00ADD4
[pypi]: https://pypi.org/project/tapo
[pypi_versions_badge]: https://img.shields.io/pypi/pyversions/tapo.svg?logo=python&color=00ADD4
[pypi_downloads_badge]: https://img.shields.io/pypi/dm/tapo?logo=python&color=00ADD4

## Device support

✓ - Rust only\
✅ - Rust and Python

| Feature<br/><br/><br/>               | GenericDevice<br/><br/><br/> | L510<br/>L520<br/>L610<br/> | L530<br/>L535<br/>L630<br/> | L900<br/><br/><br/> | L920<br/>L930<br/><br/> | P100<br/>P105<br/><br/> | P110<br/>P110M<br/>P115<br/> | P300<br/>P306<br/><br/> | P304M<br/>P316M<br/><br/> | H100<br/><br/><br/> |
| ------------------------------------ | :--------------------------- | :-------------------------- | :-------------------------- | :------------------ | :---------------------- | :---------------------- | :--------------------------- | :---------------------- | :------------------------ | :------------------ |
| device_reset                         |                              | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     |                         |                           |                     |
| get_child_device_component_list_json |                              |                             |                             |                     |                         |                         |                              | &#x2705;                | &#x2705;                  | &#x2705;            |
| get_child_device_list                |                              |                             |                             |                     |                         |                         |                              | &#x2705;                | &#x2705;                  | &#x2705;            |
| get_child_device_list_json           |                              |                             |                             |                     |                         |                         |                              | &#x2705;                | &#x2705;                  | &#x2705;            |
| get_current_power                    |                              |                             |                             |                     |                         |                         | &#x2705;                     |                         |                           |                     |
| get_device_info                      | &#x2705;                     | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     | &#x2705;                | &#x2705;                  | &#x2705;            |
| get_device_info_json                 | &#x2705;                     | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     | &#x2705;                | &#x2705;                  | &#x2705;            |
| get_device_usage                     |                              | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     |                         |                           |                     |
| get_energy_data                      |                              |                             |                             |                     |                         |                         | &#x2705;                     |                         |                           |                     |
| get_energy_usage                     |                              |                             |                             |                     |                         |                         | &#x2705;                     |                         |                           |                     |
| get_supported_ringtone_list          |                              |                             |                             |                     |                         |                         |                              |                         |                           | &#x2705;            |
| off                                  | &#x2705;                     | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     |                         |                           |                     |
| on                                   | &#x2705;                     | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     |                         |                           |                     |
| play_alarm                           |                              |                             |                             |                     |                         |                         |                              |                         |                           | &#x2705;            |
| refresh_session                      | &#x2705;                     | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                | &#x2705;                | &#x2705;                     | &#x2705;                | &#x2705;                  | &#x2705;            |
| set_brightness                       |                              | &#x2705;                    | &#x2705;                    | &#x2705;            | &#x2705;                |                         |                              |                         |                           |                     |
| set_color                            |                              |                             | &#x2705;                    | &#x2705;            | &#x2705;                |                         |                              |                         |                           |                     |
| set_color_temperature                |                              |                             | &#x2705;                    | &#x2705;            | &#x2705;                |                         |                              |                         |                           |                     |
| set_hue_saturation                   |                              |                             | &#x2705;                    | &#x2705;            | &#x2705;                |                         |                              |                         |                           |                     |
| set_lighting_effect                  |                              |                             |                             |                     | &#x2705;                |                         |                              |                         |                           |                     |
| set() API \*                         |                              |                             | &#x2705;                    | &#x2705;            | &#x2705;                |                         |                              |                         |                           |                     |
| stop_alarm                           |                              |                             |                             |                     |                         |                         |                              |                         |                           | &#x2705;            |


\* The `set()` API allows multiple properties to be set in a single request.

## Hub (H100) Child Devices Support

&check; - Rust only\
&#x2705; - Rust and Python

| Feature<br/><br/>                | KE100<br/><br/> | S200B<br/><br/> | T100<br/><br/> | T110<br/><br/> | T300<br/><br/> | T310<br/>T315 |
| -------------------------------- | :-------------- | :-------------- | :------------- | :------------- | :------------- | :------------ |
| get_device_info \*               | &#x2705;        | &#x2705;        | &#x2705;       | &#x2705;       | &#x2705;       | &#x2705;      |
| get_device_info_json             | &#x2705;        | &#x2705;        | &#x2705;       | &#x2705;       | &#x2705;       | &#x2705;      |
| get_temperature_humidity_records |                 |                 |                |                |                | &#x2705;      |
| get_trigger_logs                 |                 | &#x2705;        | &#x2705;       | &#x2705;       | &#x2705;       |               |
| set_child_protection             | &#x2705;        |                 |                |                |                |               |
| set_frost_protection             | &#x2705;        |                 |                |                |                |               |
| set_max_control_temperature      | &#x2705;        |                 |                |                |                |               |
| set_min_control_temperature      | &#x2705;        |                 |                |                |                |               |
| set_target_temperature           | &#x2705;        |                 |                |                |                |               |
| set_temperature_offset           | &#x2705;        |                 |                |                |                |               |

\* Obtained by calling `get_child_device_list` on the hub device or `get_device_info` on a child device handler.


## Rust

### Usage

> Cargo.toml
```toml
[dependencies]
tapo = "0.8"
```

> main.rs
```rust
let device = ApiClient::new("<tapo-username>", "tapo-password")
    .p110("<device ip address>")
    .await?;

device.on().await?;
```

### Examples

```bash
export TAPO_USERNAME=
export TAPO_PASSWORD=
export IP_ADDRESS=

cargo run --example tapo_l530
```

See all examples in [/tapo/examples][examples].

### Wrapper REST API
[tapo-rest][tapo_rest] is a REST wrapper of this library that can be deployed as a service or serve as an advanced example.

## Python

### Usage

```bash
pip install tapo
```

```python
client = ApiClient("<tapo-username>", "tapo-password")
device = await client.p110("<device ip address>")

await device.on()
```

### Examples

```bash
cd tapo-py
poetry install # On the initial run
poetry shell
maturin develop # On the initial run and whenever the Rust code is modified

export TAPO_USERNAME=
export TAPO_PASSWORD=
export IP_ADDRESS=
```

```bash
python examples/tapo_p110.py
```

See all examples in [/tapo-py/examples][examples-py].

## Contributing

Contributions are welcome and encouraged! See [/CONTRIBUTING.md][contributing].

## Credits

Inspired by [petretiandrea/plugp100][inspired_by].

[examples]: https://github.com/mihai-dinculescu/tapo/tree/main/tapo/examples
[examples-py]: https://github.com/mihai-dinculescu/tapo/tree/main/tapo-py/examples
[tapo_rest]: https://github.com/ClementNerma/tapo-rest
[contributing]: https://github.com/mihai-dinculescu/tapo/blob/main/CONTRIBUTING.md
[inspired_by]: https://github.com/petretiandrea/plugp100