Skip to main content

Control hOn devices with python

Project description

This python package is unofficial and is not related in any way to Haier. It was developed by reversed engineered requests and can stop working at anytime!

pyhon-revived

PyPI - Status PyPI PyPI - Python Version PyPI - License PyPI - Downloads

Control your Haier, Candy and Hoover appliances with python! The idea behind this library is, to make the use of all available commands as simple as possible.

Installation

pip install pyhon-revived

Quick overview

To get an idea of what is possible, use the commandline-tool pyhon. This command requests all available options of connected appliances from the hOn api of your Haier Account.

$ pyhon --user example@mail.com --password pass123
========== WM - Waschmaschine ==========
data:
  attributes:
    parameters:
      ...
      texture: 1
      totalElectricityUsed: 28.71
      totalWashCycle: 35
      totalWaterUsed: 2494
      transMode: 0
      ...
settings:
  startProgram:
    rinseIterations:
      max: 5
      min: 3
      step: 1
    spinSpeed:
      - 0
      - 400
      - 600
      - 800
      ...

Python-API

List devices

import asyncio
from pyhon import Hon

async def devices_example():
    async with Hon(USER, PASSWORD) as hon:
        for appliance in hon.appliances:
            print(appliance.nick_name)

asyncio.run(devices_example())

Execute a command

async with Hon(USER, PASSWORD) as hon:
    washing_machine = hon.appliances[0]
    pause_command = washing_machine.commands["pauseProgram"]
    await pause_command.send()

Set command parameter

async with Hon(USER, PASSWORD) as hon:
    washing_machine = hon.appliances[0]
    start_command = washing_machine.commands["startProgram"]
    for name, setting in start_command.settings:
        print("Setting", name)
        print("Current value", setting.value)
        if setting.typology == "enum":
            print("Available values", setting.values)
            setting.value = setting.values[0]
        elif setting.typology == "range":
            print("Min value", setting.min)
            print("Max value", setting.max)
            print("Step value", setting.step)
            setting.value = setting.min + setting.step

Translation

To get the translation of some keys like programs, you can use the translation command to see all of hOn's available translations

$ pyhon translate es
AC:
  APPLIANCE_RENAME:
    CONTENT_CHOOSE_NAME: Antes de continuar, debes elegir un nombre...
    DEFAULT_NAME: Aire acondicionado
    TITLE_CHOOSE_NAME: ¡Elije un nombre para tu aire acondicionado!
    TITLE_SAVE_NAME: Para cambiar el nombre de tu aparato:
...

This generates a huge output. It is recommended to pipe this into a file

$ pyhon translate fr > hon_fr.yaml
$ pyhon translate en --json > hon_en.json

Usage example

This library is used for the custom HomeAssistant Integration "Haier hOn".

Contribution

Any kind of contribution is welcome!

Please add your appliances data to our hon-test-data collection.
This helps us to develop new features and not to break compatibility in newer versions.

Project details


Download files

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

Source Distribution

pyhon_revived-0.18.3.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

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

pyhon_revived-0.18.3-py3-none-any.whl (41.4 kB view details)

Uploaded Python 3

File details

Details for the file pyhon_revived-0.18.3.tar.gz.

File metadata

  • Download URL: pyhon_revived-0.18.3.tar.gz
  • Upload date:
  • Size: 30.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for pyhon_revived-0.18.3.tar.gz
Algorithm Hash digest
SHA256 6709d7c29dbbe666dba7d4c48f0c563d725184efc1e8884e24a5a6c57c73ae4e
MD5 6949c328b6ae0cb9cbc6a1511b802a82
BLAKE2b-256 7fccfa83f5559a78e89519d219e8ad023abc3465143c5add207e70d582217dd8

See more details on using hashes here.

File details

Details for the file pyhon_revived-0.18.3-py3-none-any.whl.

File metadata

  • Download URL: pyhon_revived-0.18.3-py3-none-any.whl
  • Upload date:
  • Size: 41.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for pyhon_revived-0.18.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8169b1ad7a26ff7fd26ac38dbbb05aeaecfab9d7a0ef0fd934c9d7ea40fbae13
MD5 bef89554cb02a3a21a5abebf8d14457a
BLAKE2b-256 92b0a48cbe2f74a3871db3d6fcd2003b0f58e5d98e25993515aff4cb10da03f2

See more details on using hashes here.

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