Skip to main content

Deebot client library in python 3

Project description

Client Library for Deebot devices (Vacuums)

PyPI - Downloads Buy Me A Coffee

IMPORTANT: Contribution only

This project is maintained in our spare time. Please be patient and respectful.

It's not related to Ecovacs or Deebot and we don't get any support from them.

As all is reverse engineered it might take some time to add new features and we can't guarantee that all features will be added.

Unfortunately some people think we are paid to do this and get angry if things don't work as they expect. As result of this, we decided that this project is in a contribution only mode.

This means, if you want something to be supported/added, you have to provide a fix yourself, wait for someone else to fix it or pay someone to do it. Members will still review and help on pull requests.

Installation

If you have a recent version of Python 3, you should be able to do pip install deebot-client to get the most recently released version of this.

Usage

To get started, you'll need to have already set up an EcoVacs account using your smartphone.

You are welcome to try using this as a python library for other efforts. A simple usage might go something like this:

import aiohttp
import asyncio
import logging
import time

from deebot_client.api_client import ApiClient
from deebot_client.authentication import Authenticator, create_rest_config
from deebot_client.commands.json.clean import Clean, CleanAction
from deebot_client.events import BatteryEvent
from deebot_client.mqtt_client import MqttClient, create_mqtt_config
from deebot_client.util import md5
from deebot_client.device import Device

device_id = md5(str(time.time()))
account_id = "your email or phonenumber (cn)"
password_hash = md5("yourPassword")
country = "DE"


async def main():
  async with aiohttp.ClientSession() as session:
    logging.basicConfig(level=logging.DEBUG)
    rest_config = create_rest_config(session, device_id=device_id, alpha_2_country=country)

    authenticator = Authenticator(rest_config, account_id, password_hash)
    api_client = ApiClient(authenticator)

    devices_ = await api_client.get_devices()

    bot = Device(devices_.mqtt[0], authenticator)

    mqtt_config = create_mqtt_config(device_id=device_id, country=country)
    mqtt = MqttClient(mqtt_config, authenticator)
    await bot.initialize(mqtt)

    async def on_battery(event: BatteryEvent):
      # Do stuff on battery event
      if event.value == 100:
        # Battery full
        pass

    # Subscribe for events (more events available)
    bot.events.subscribe(BatteryEvent, on_battery)

    # Execute commands
    await bot.execute_command(Clean(CleanAction.START))
    await asyncio.sleep(900)  # Wait for...
    await bot.execute_command(Charge())


if __name__ == '__main__':
  loop = asyncio.get_event_loop()
  loop.create_task(main())
  loop.run_forever()

A more advanced example can be found here.

Note for Windows users

This library cannot be used out of the box with Windows due a limitation in the requirement aiomqtt. More information and a workaround can be found here

Thanks

My heartfelt thanks to:

  • deebotozmo, After all, this is a debotozmo fork :)
  • sucks, deebotozmo was forked from it :)
  • xmpppeek, a great library for examining XMPP traffic flows ( yes, your vacuum speaks Jabber!),
  • mitmproxy, a fantastic tool for analyzing HTTPS,
  • click, a wonderfully complete and thoughtful library for making Python command-line interfaces,
  • requests, a polished Python library for HTTP requests,
  • Decompilers online, which was very helpful in figuring out what the Android app was up to,
  • Albert Louw, who was kind enough to post code from his own experiments with his device, and
  • All the users who have given useful feedback and contributed code!

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

deebot_client-18.0.0.tar.gz (214.3 kB view details)

Uploaded Source

Built Distributions

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

deebot_client-18.0.0-cp314-cp314-win_amd64.whl (1.0 MB view details)

Uploaded CPython 3.14Windows x86-64

deebot_client-18.0.0-cp314-cp314-musllinux_1_2_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.14musllinux: musl 1.2+ x86-64

deebot_client-18.0.0-cp314-cp314-musllinux_1_2_aarch64.whl (1.3 MB view details)

Uploaded CPython 3.14musllinux: musl 1.2+ ARM64

deebot_client-18.0.0-cp314-cp314-manylinux_2_34_x86_64.whl (1.2 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.34+ x86-64

deebot_client-18.0.0-cp314-cp314-manylinux_2_34_aarch64.whl (1.1 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.34+ ARM64

deebot_client-18.0.0-cp314-cp314-macosx_11_0_arm64.whl (1.0 MB view details)

Uploaded CPython 3.14macOS 11.0+ ARM64

deebot_client-18.0.0-cp314-cp314-macosx_10_12_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.14macOS 10.12+ x86-64

File details

Details for the file deebot_client-18.0.0.tar.gz.

File metadata

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

File hashes

Hashes for deebot_client-18.0.0.tar.gz
Algorithm Hash digest
SHA256 9e2f4315f75046584fb340485b5b1d541667b9791e48545162dad13c90aac843
MD5 d6aa5cd094322c0410a6788531e17a76
BLAKE2b-256 94f2eb92a6dd3ffd082c8459eff88254d0f0563c78adbd86cdf27e8413332f39

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0.tar.gz:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-win_amd64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-win_amd64.whl
Algorithm Hash digest
SHA256 899d996d945f6ed3e1aa9f8babce39e10b8966688412b584f7f9ee8cb0a36b00
MD5 313a9a3b6127be3db2784bc3f771f271
BLAKE2b-256 3baba79b00dabf3238aa0fd6bd1ec3ec5b501d863529e64b941bc9675b96aa74

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-win_amd64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-musllinux_1_2_x86_64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 ff8b18521fb43e657d6c8899249675461aed9fe6578168199a167464e7db005d
MD5 a7c98572209f9e16d868d611f734b4ac
BLAKE2b-256 91ebcb5e0ef532c3026d5b2f6b4cd0eb979e21251aca198dbc369799ce983a75

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-musllinux_1_2_x86_64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-musllinux_1_2_aarch64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 e770e6b355be940d567d57065fa67e68128cdbab3bbc727e8254289b9324a96d
MD5 c8a5cea1a5612c84623c5b22f343c5e1
BLAKE2b-256 487c62871294f2d4e4eadbfa4c59e896b4e305733d5fcdf1381831a33a830011

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-musllinux_1_2_aarch64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 a5e7314378328cc0b47771807a89dba6c7cbf5eb287d257c904c312899b945ed
MD5 e520f44df157c93cd47625aeb894ab30
BLAKE2b-256 75108e167e33ff2875655ef6983cad047f5db2b39a52582c5f6244537f346d35

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-manylinux_2_34_x86_64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 e10ced19bd5ef69b9d4fca9d06ae865c0ffe83d4929ab405354393a85dd6c776
MD5 7baa773eedebacf35d5585264ac72093
BLAKE2b-256 371793850395a4e569764456bd53299e4cf10ce55d7abb38b786fb3e0e6457bb

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-manylinux_2_34_aarch64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9b45b301a988a13884435609b266f101a8ed8032f5491a4b94117b5525eb13de
MD5 ba359b4702aece1002660da71d1edc36
BLAKE2b-256 2227d8758bf1dbddd6b8b72f79896e16ad8c2595c8b52c9ae83f2bb8bea7e53a

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-macosx_11_0_arm64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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

File details

Details for the file deebot_client-18.0.0-cp314-cp314-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for deebot_client-18.0.0-cp314-cp314-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 c6cad642fda70724f30f6233400edde495e02a6e41edfe9b9b519f1a300f9107
MD5 dc68b885e62aa1b7c7f8e3b81c8171bf
BLAKE2b-256 bced02fc04401842092ffeb120150cd4b7ed2c46d7ace304d04a4667cbfc8755

See more details on using hashes here.

Provenance

The following attestation bundles were made for deebot_client-18.0.0-cp314-cp314-macosx_10_12_x86_64.whl:

Publisher: ci.yml on DeebotUniverse/client.py

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