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

PyPI - Status PyPI PyPI - Python Version PyPI - License PyPI - Downloads
Control your Haier 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

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
========== Waschmaschine ==========
commands:
  pauseProgram: pauseProgram command
  resumeProgram: resumeProgram command
  startProgram: startProgram command
  stopProgram: stopProgram command
data:
  actualWeight: 0
  airWashTempLevel: 0
  airWashTime: 0
  antiAllergyStatus: 0
...

The claim is, to see everything what you can see in your hOn app and to execute everything you can execute there.

Python-API

List devices

import asyncio
from pyhon import HonConnection

async def devices_example():
    async with HonConnection(USER, PASSWORD) as hon:
        for device in hon.devices:
            print(device.nick_name)

asyncio.run(devices_example())

Execute a command

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

Set command parameter

Use device.settings to get all variable parameters.
Use device.parmeters to get also fixed parameters.

async with HonConnection(USER, PASSWORD) as hon:
    washing_machine = hon.devices[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

Tested devices

  • Haier Washing Machine HW90

Unfortunately I don't have any more Haier appliances...

Usage example

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

Project details


Release history Release notifications | RSS feed

This version

0.2.2

Download files

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

Source Distribution

pyhOn-0.2.2.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

pyhOn-0.2.2-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file pyhOn-0.2.2.tar.gz.

File metadata

  • Download URL: pyhOn-0.2.2.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for pyhOn-0.2.2.tar.gz
Algorithm Hash digest
SHA256 f72aa3fc60da61c30579a36c8290bdfc67ecb2e2eba89365cc8ca0d2945d4950
MD5 9ccfe19ad3b3d4d5c2661fd68a9e73a3
BLAKE2b-256 8e8f55dafb98cd2fa09696124da972e15b0fcbe4d7eb3e3d66cd9520c58a5b54

See more details on using hashes here.

File details

Details for the file pyhOn-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: pyhOn-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 11.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for pyhOn-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9a539feeddf9a34acef858faef97886f91eabeddcc4a1b62007a04c5390dfb42
MD5 a04efbcf61610c8e8bc0aa719b0f536a
BLAKE2b-256 448cb5e9d9884099682e72b868792103e91c4d876777b77a4d86e60e2bd70435

See more details on using hashes here.

Supported by

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