Skip to main content

Python library for Huum saunas

Project description

huum - A python library for controlling Huum saunas

This library was created primarily to be used together with Home Assistant, but can be used as a stand-alone library as well. The API used by this library is sanctioned by Huum to be used by third parties. At least to the extent that they happily provided documentation for the API when asked about it.

This library has been tested against a Huum Drop sauna using the UKU Wi-Fi control unit.

No guarantees are given when using this library. You are using it at your own risk. Saunas can be dangerous if used without care or without the right security measures.

Installation

PIP

pip install huum

Poetry

poetry add huum

Quick guide

import asyncio

from huum.huum import Huum

async def turn_on_sauna():
    huum = Huum(username="foo", password="bar")

    # If you don't have an existing aiohttp session
    # then run `open_session()` after initilizing
    await huum.open_session()

    # Turn on the sauna
    await huum.turn_on(80)

asyncio.run(turn_on_the_sauna())

Usage

The huum package is fully asynchronous.

Supported Python versions:

Python Supported
<= 3.8
3.9 🤷
3.10 🤷
3.11
3.12
3.13

Authentication

Authentication uses username + password. The same credentials that you use for logging into the Huum application.

Passing credentials to constructor

huum = Huum(username=<username>, password=<password>)

Sessions

You can use the library either with an already existing session or create one yourself. This design decision was created mainly to support Home Assistants (HA) existing sessions and complying with their guidelines. In most cases you will want to create your own session if you are using this outside of HA.

If you already have an existing session you can pass it to the constructor using the session argument.

huum = Huum(session=<session>)

If you want the library to create a new session, run open_session() after creating a Huum instance. You must do this before running any commands. You can close the session using close_session().

huum = Huum()
huum.open_session()
...
huum.close_session()

Controlling the sauna

Getting sauna status

The Huum API exposes a status endpoint for getting the current status of the sauna.

huum.status()

Turning on and setting temperature

The Huum API does not have a specific endpoint for turning on a setting the temperature. The same endpoint does both. This library has two functions for turning on and settings the temperature, mainly for exposing a nicer interface to the developer.

# Turns on the sauna and sets its temperature to 80
huum.turn_on(temperature=80)

# Identical the the above
huum.set_temperature(temperature=80)
Security concerns

Huums API does not check if the sauna door is open or not when turning it on. It will happily turn on the sauna while the door is open. The sauna itself will most likely still not heat as it has a security guard in the sauna, but it will turn it on and will start heating if the door is closed. The Huum mobile application however checks if the sauna door is open or closed before turning on the sauna.

To mimic the security guards of the mobile application the library, by default, checks the status of the sauna before it turns it on. If you do not want to have this check, then you can pass the argument safety_override=True to either turn_on() or set_temperature.

huum.set_temperature(temperature=80, safety_override=True)

Turning off the sauna

The sauna can be turned off by calling turn_off().

huum.turn_off()

Response objects

This library uses Pydantic schemas for all method responses. I recommend checking the /huum/schemas.py for checking responses.

Handling exceptions

This library implements custom exceptions for most of its calls. You can find them in the exceptions.py file. But in short these are the exceptions triggered:

HTTP Status Exception
400 BadRequest
401 NotAuthenticated
403 Forbidden
Any other over 400 RequestError

All of exceptions triggered by the library inherit from HuumError.

If the door is open and the sauna is turned on, and the client is not told to explicitly bypass security measures (see "Security concerns" above), then huum.exceptions.SafetyException will be raised.

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

huum-0.8.2.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

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

huum-0.8.2-py3-none-any.whl (7.2 kB view details)

Uploaded Python 3

File details

Details for the file huum-0.8.2.tar.gz.

File metadata

  • Download URL: huum-0.8.2.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.12.12 Darwin/25.3.0

File hashes

Hashes for huum-0.8.2.tar.gz
Algorithm Hash digest
SHA256 44d19a7f5d50ed0d700dbe156454dbc4e4cde53fd6b925b6a8cf65445078b430
MD5 e0c186eb5b45e2e4bec2c04d5f574de2
BLAKE2b-256 69f895f2a0d0e31315862dc0f465dcda3ff4c888d78f1ee8052177e055dbf953

See more details on using hashes here.

File details

Details for the file huum-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: huum-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 7.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.12.12 Darwin/25.3.0

File hashes

Hashes for huum-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 88283ac930198c14b79ccda5bcb8ec72e880266f2c8d3f5140adea920f6a21bc
MD5 b60f8b0673dc478caec1b473ea1db33a
BLAKE2b-256 b8d03ec5eb16cf910130e2247fe5cdae4571a704e19315f307cf8812c5d341f5

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