Asynchronous Python client for Hot Spring Connected Spa Kit 2.
Project description
Asynchronous Python client for Hot Spring Connected Spa Kit 2.
[!WARNING] This library is currently in heavy development. Not all features might work perfectly, and some features may not be fully tested as they depend on the physical hardware available for testing.
About
This package allows you to control and monitor a Hot Spring spa equipped with the Connected Spa Kit 2 programmatically via its local HTTP API. It communicates with the Home Network Adapter (HNA), which bridges your home network to the spa's control board over LoRA radio.
It is primarily designed to be used as the communication layer for an official Home Assistant integration.
Supported Features
- Temperature monitoring & control — Read current/target water temperature, set target temperature, change heating modes
- Jets & blower — Control jet speeds (off, low, high) across all jet pumps
- Multi-zone lighting — Set colors and brightness for up to 4 light zones plus the logo light
- Water care — Monitor FreshWater IQ salt system metrics (pH, chlorine, ORP, sensor life)
- Diagnostics — Read voltage, power consumption, and failure states
- Connection monitoring — Check LoRA bridge and cloud connectivity status
- Energy saving schedules — View configured energy saving time windows
- Clean cycle — Start or stop the 10-minute clean cycle
Compatible Spas
This library works with any Hot Spring, Caldera, or Freeflow spa that supports the Connected Spa Kit 2 (compatible with spas from 2014 onwards that use the IQ2020/Eagle control board).
[!NOTE] This library has been primarily tested on a Hotspring Hot Spot Relay 2025. Compatibility with other specific models and configurations may vary.
Installation
pip install python-hotspring
Usage
import asyncio
from hotspring import HotSpring
async def main() -> None:
"""Show example of controlling your Hot Spring spa."""
async with HotSpring("192.168.1.100") as spa_client:
# Get full spa status
spa = await spa_client.update()
print(f"Water temperature: {spa.heater.current_temperature}°F")
print(f"Heater: {'on' if spa.heater.is_on else 'off'}")
print(f"Heating mode: {spa.heater.heating_mode.name}")
# Control the spa
await spa_client.set_temperature(102)
await spa_client.set_jet(1, "highSpeed")
await spa_client.set_light_color(1, "Blue")
await spa_client.set_clean_cycle(enabled=True)
if __name__ == "__main__":
asyncio.run(main())
Demos
Several demonstration scripts are available in the demo/ directory to help you get started with the library and verify connectivity with your spa.
Architecture
The Hot Spring Connected Spa Kit 2 uses a two-part system:
- HNA (Home Network Adapter) — Located inside the home, connects to WiFi/Internet and runs the local HTTP API that this library communicates with
- SNA (Spa Network Adapter) — Located inside the spa, wired to the IQ2020 control board via RS485, communicates with the HNA via LoRA radio
All API calls go through the HNA, which relays commands to the spa over LoRA. Commands typically take 2–5 seconds to process.
Changelog & Releases
This repository keeps a change log using GitHub's releases functionality.
Releases are based on Semantic Versioning, and use the format
of MAJOR.MINOR.PATCH. In a nutshell, the version will be incremented
based on the following:
MAJOR: Incompatible or major changes.MINOR: Backwards-compatible new features and enhancements.PATCH: Backwards-compatible bugfixes and package updates.
Contributing
This is an active open-source project. We are always open to people who want to use the code or contribute to it.
Thank you for being involved! :heart_eyes:
Setting up development environment
This Python project is fully managed using the Poetry dependency manager.
You need at least:
- Python 3.12+
- Poetry
To install all packages, including all development requirements:
poetry install
As this repository uses the prek framework, all changes are linted and tested with each commit. You can run all checks and tests manually, using the following command:
poetry run prek run --all-files
To run just the Python tests:
poetry run pytest
Authors & contributors
The original setup of this repository is by @Moustachauve.
The structure of this library is inspired by python-wled from @frenck and pytechnove from @Moustachauve.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file python_hotspring-1.0.0.tar.gz.
File metadata
- Download URL: python_hotspring-1.0.0.tar.gz
- Upload date:
- Size: 17.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
81bad7a6607745b323ee0fd6afb18a9a4517324e10c1d285bb61df37217cec34
|
|
| MD5 |
0e8a9c1c59d19e9721bd720333d0a2ea
|
|
| BLAKE2b-256 |
a1372a9856caa9e85ced1aca43985641602ade01069acda1d27a195cba18b2be
|
Provenance
The following attestation bundles were made for python_hotspring-1.0.0.tar.gz:
Publisher:
release.yaml on Moustachauve/python-hotspring
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_hotspring-1.0.0.tar.gz -
Subject digest:
81bad7a6607745b323ee0fd6afb18a9a4517324e10c1d285bb61df37217cec34 - Sigstore transparency entry: 1446045153
- Sigstore integration time:
-
Permalink:
Moustachauve/python-hotspring@9e90b9e1de6fa6916e5feb9ac60480e32d72b5f8 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/Moustachauve
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@9e90b9e1de6fa6916e5feb9ac60480e32d72b5f8 -
Trigger Event:
release
-
Statement type:
File details
Details for the file python_hotspring-1.0.0-py3-none-any.whl.
File metadata
- Download URL: python_hotspring-1.0.0-py3-none-any.whl
- Upload date:
- Size: 16.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
289f12953e3089b0916ce1952db71811a213d4bd9078c40a01ce22f65e168ee1
|
|
| MD5 |
a620fe16890e9f48a4014a1bb224e753
|
|
| BLAKE2b-256 |
4cd145b2aa96a58a5f34835f3d1a394254d10be8e18f1d0933cb8ca653af11f3
|
Provenance
The following attestation bundles were made for python_hotspring-1.0.0-py3-none-any.whl:
Publisher:
release.yaml on Moustachauve/python-hotspring
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_hotspring-1.0.0-py3-none-any.whl -
Subject digest:
289f12953e3089b0916ce1952db71811a213d4bd9078c40a01ce22f65e168ee1 - Sigstore transparency entry: 1446045364
- Sigstore integration time:
-
Permalink:
Moustachauve/python-hotspring@9e90b9e1de6fa6916e5feb9ac60480e32d72b5f8 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/Moustachauve
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@9e90b9e1de6fa6916e5feb9ac60480e32d72b5f8 -
Trigger Event:
release
-
Statement type: