A Python library to interact with the API behind the myVAILLANT app
Project description
myPyllant
A Python library to interact with the API behind the myVAILLANT app ((and branded versions of it, such as the MiGo app from Saunier Duval). Needs at least Python 3.10.
[!WARNING]
If you're using sensoAPP or the multiMATIC app, this library won't work for you. Try the pymultiMATIC library instead and check Vaillant's website for more information.This integration is not affiliated with Vaillant, the developers take no responsibility for anything that happens to your devices because of this library.
Install and Test
[!WARNING]
You need at least Python 3.10
pip install myPyllant
# Only on Windows, and other systems without a timezone database:
pip install tzdata
..or use Docker, if you just want to use it as a CLI tool:
docker run -ti ghcr.io/signalkraft/mypyllant:latest uv run -m myPyllant.export user password brand --country country
Usage
Exporting Data about your System
python3 -m myPyllant.export user password brand --country country
# See python3 -m myPyllant.export -h for more options and a list of countries
The --data argument exports historical data of the devices in your system.
Without this keyword, information about your system will be exported as JSON.
Exporting Energy Reports
python3 -m myPyllant.report user password brand --country country
# Wrote 2023 report to energy_data_2023_ArothermPlus_XYZ.csv
# Wrote 2023 report to energy_data_2023_HydraulicStation_XYZ.csv
Writes a report for each heat generator, by default for the current year. You can provide --year to select
a different year.
Using the API in Python
#!/usr/bin/env python3
import argparse
import asyncio
import logging
from datetime import datetime, timedelta
from myPyllant.api import MyPyllantAPI
from myPyllant.const import ALL_COUNTRIES, BRANDS, DEFAULT_BRAND
parser = argparse.ArgumentParser(description="Export data from myVaillant API .")
parser.add_argument("user", help="Username (email address) for the myVaillant app")
parser.add_argument("password", help="Password for the myVaillant app")
parser.add_argument(
"brand",
help="Brand your account is registered in, i.e. 'vaillant'",
default=DEFAULT_BRAND,
choices=BRANDS.keys(),
)
parser.add_argument(
"--country",
help="Country your account is registered in, i.e. 'germany'",
choices=ALL_COUNTRIES.keys(),
required=False,
)
parser.add_argument(
"-v", "--verbose", help="increase output verbosity", action="store_true"
)
async def main(user, password, brand, country):
async with MyPyllantAPI(user, password, brand, country) as api:
async for system in api.get_systems():
print(await api.set_set_back_temperature(system.zones[0], 18))
print(await api.quick_veto_zone_temperature(system.zones[0], 21, 5))
print(await api.cancel_quick_veto_zone_temperature(system.zones[0]))
setpoint = 10.0 if system.control_identifier.is_vrc700 else None
print(
await api.set_holiday(
system,
datetime.now(system.timezone),
datetime.now(system.timezone) + timedelta(days=7),
setpoint, # Setpoint is only required for VRC700 systems
)
)
print(await api.cancel_holiday(system))
if system.domestic_hot_water:
print(await api.boost_domestic_hot_water(system.domestic_hot_water[0]))
print(await api.cancel_hot_water_boost(system.domestic_hot_water[0]))
print(
await api.set_domestic_hot_water_temperature(
system.domestic_hot_water[0], 46
)
)
if __name__ == "__main__":
args = parser.parse_args()
if args.verbose:
logging.basicConfig(level=logging.DEBUG)
asyncio.run(main(args.user, args.password, args.brand, args.country))
Tested Configurations
See https://github.com/signalkraft/mypyllant-component/blob/main/README.md#tested-setups
Contributing
[!WARNING]
You need at least Python 3.10 and uv installed
I'm happy to accept PRs, if you run the pre-commit checks and test your changes:
git clone https://github.com/signalkraft/myPyllant.git
cd myPyllant
uv tool install pre-commit --with pre-commit-uv
pre-commit install
uv run pytest
Supporting new Countries
The myVAILLANT app uses Keycloak and OIDC for authentication, with a realm for each country and brand. There is a script to check which countries are supported:
uv run -m myPyllant.tests.find_countries
Copy the resulting dictionary into src/myPyllant/const.py
Contributing Test Data
Because the myVAILLANT API isn't documented, you can help the development of this library by contributing test data:
uv run -m myPyllant.tests.generate_test_data -h
uv run -m myPyllant.tests.generate_test_data username password brand --country country
..or use Docker:
docker run -v $(pwd)/test_data:/build/src/myPyllant/tests/json -ti ghcr.io/signalkraft/mypyllant:latest uv run -m myPyllant.tests.generate_test_data username password brand --country country
With docker, the results will be put into test_data/.
You can then either create a PR with the created folder, or zip it and attach it to an issue.
Acknowledgements
- Auth is loosely based on ioBroker.vaillant
- Most API endpoints are reverse-engineered from the myVaillant app, using mitmproxy
- Logo based on Hase Icons erstellt von Freepik - Flaticon & Ouroboros Icons erstellt von Freepik - Flaticon.
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 mypyllant-0.9.9.tar.gz.
File metadata
- Download URL: mypyllant-0.9.9.tar.gz
- Upload date:
- Size: 225.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8483e9a8f72e8a14e5358cb546690f7591f890ee21b9e85bb20ec0201acc7b88
|
|
| MD5 |
370b24507252a451b90567fa2fcff36c
|
|
| BLAKE2b-256 |
0642fa7d40590afba37c856f0392e2d160b6f677c5cfebdc4f19bd27399cd639
|
Provenance
The following attestation bundles were made for mypyllant-0.9.9.tar.gz:
Publisher:
build-test.yaml on signalkraft/myPyllant
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mypyllant-0.9.9.tar.gz -
Subject digest:
8483e9a8f72e8a14e5358cb546690f7591f890ee21b9e85bb20ec0201acc7b88 - Sigstore transparency entry: 832834145
- Sigstore integration time:
-
Permalink:
signalkraft/myPyllant@b69b53fb27a68b5c1a7d9199aa0edf1d916d20eb -
Branch / Tag:
refs/tags/v0.9.9 - Owner: https://github.com/signalkraft
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-test.yaml@b69b53fb27a68b5c1a7d9199aa0edf1d916d20eb -
Trigger Event:
push
-
Statement type:
File details
Details for the file mypyllant-0.9.9-py3-none-any.whl.
File metadata
- Download URL: mypyllant-0.9.9-py3-none-any.whl
- Upload date:
- Size: 153.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fa9445fe883b14ea3c76b1e0381d0b601091de4f372698067e02cdca55d0a1fb
|
|
| MD5 |
f7a362da7894eeb9dcc04f795a59f42d
|
|
| BLAKE2b-256 |
fff8e0ced645a36a5f926110ed5d69af20a46136652312512ded689d904dc690
|
Provenance
The following attestation bundles were made for mypyllant-0.9.9-py3-none-any.whl:
Publisher:
build-test.yaml on signalkraft/myPyllant
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mypyllant-0.9.9-py3-none-any.whl -
Subject digest:
fa9445fe883b14ea3c76b1e0381d0b601091de4f372698067e02cdca55d0a1fb - Sigstore transparency entry: 832834146
- Sigstore integration time:
-
Permalink:
signalkraft/myPyllant@b69b53fb27a68b5c1a7d9199aa0edf1d916d20eb -
Branch / Tag:
refs/tags/v0.9.9 - Owner: https://github.com/signalkraft
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-test.yaml@b69b53fb27a68b5c1a7d9199aa0edf1d916d20eb -
Trigger Event:
push
-
Statement type: