Skip to main content

A package to control Roborock vacuums.

Project description

Roborock

PyPI Version Supported Python versions License Code Coverage

Roborock library for online and offline control of your vacuums.

Installation

Install this via pip (or your favourite package manager):

pip install python-roborock

Example Usage

See examples/example.py for a more full featured example, or the API documentation for more details.

Here is a basic example:

import asyncio

from roborock.web_api import RoborockApiClient
from roborock.devices.device_manager import create_device_manager, UserParams


async def main():
    email_address = "youremailhere@example.com"
    web_api = RoborockApiClient(username=email_address)
    # Send a login code to the above email address
    await web_api.request_code()
    # Prompt the user to enter the code
    code = input("What is the code?")
    user_data = await web_api.code_login(code)

    # Create a device manager that can discover devices.
    user_params = UserParams(username=email_address, user_data=user_data)
    device_manager = await create_device_manager(user_params)
    devices = await device_manager.get_devices()

    # Get all vacuum devices. Each device generation has different capabilities
    # and APIs available so to find vacuums we filter by the v1 PropertiesApi.
    for device in devices:
        if not device.v1_properties:
            continue

        # The PropertiesAPI has traits different device commands such as getting
        # status, sending clean commands, etc. For this example we send a
        # command to refresh the current device status.
        status_trait = device.v1_properties.status
        await status_trait.refresh()
        print(status_trait)

asyncio.run(main())

Functionality

The library interacts with devices through specific API properties based on the device protocol:

  • Standard Vacuums (V1 Protocol): Most robot vacuums use this. Interaction is done through device.v1_properties, which contains traits like status, consumables, and maps. Use the command trait for actions like starting or stopping cleaning.
  • Wet/Dry Vacuums & Washing Machines (A01 Protocol): Devices like the Dyad and Zeo use this. Interaction is done through device.a01_properties using query_values() and set_value().

You can find detailed documentation for Devices and Traits.

Supported devices

You can find what devices are supported here. Please note this may not immediately contain the latest devices.

Acknowledgements

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python_roborock-5.7.1.tar.gz (140.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_roborock-5.7.1-py3-none-any.whl (183.1 kB view details)

Uploaded Python 3

File details

Details for the file python_roborock-5.7.1.tar.gz.

File metadata

  • Download URL: python_roborock-5.7.1.tar.gz
  • Upload date:
  • Size: 140.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for python_roborock-5.7.1.tar.gz
Algorithm Hash digest
SHA256 2d395ccf06ad9eb2fa8765d7491ef8f2f2f95f4ce4734ddc2a60a7504378ddbd
MD5 d1e9a674cf4d5cf50d7dd44c2d3e0f76
BLAKE2b-256 bf00d51de50052f1cdc22d54e7675a3088c6b0a9aaee58abf84707227b9c9e76

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_roborock-5.7.1.tar.gz:

Publisher: ci.yml on Python-roborock/python-roborock

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file python_roborock-5.7.1-py3-none-any.whl.

File metadata

  • Download URL: python_roborock-5.7.1-py3-none-any.whl
  • Upload date:
  • Size: 183.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for python_roborock-5.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a9923a015344361230ba69cf5e26ec2e378ff12eb16545aee87f074da9c6880a
MD5 58755aedb35657a502bb796a82205b9a
BLAKE2b-256 bb2623d8a5ebb5b5b4255fd96094b05c21bb9cdb76e07172a79b4102761a134a

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_roborock-5.7.1-py3-none-any.whl:

Publisher: ci.yml on Python-roborock/python-roborock

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page