Unofficial async Python client for SEKO Pooldosing systems. SEKO is a manufacturer of various monitoring and control devices for pools and spas. Some devices from VÁGNER POOL are compatible as well.
This client uses an undocumented local HTTP API. It provides live readings for pool sensors such as temperature, pH, ORP/Redox, as well as status information and control over the dosing logic.
Disclaimer: Use at your own risk. No liability for damages or malfunctions.
- Async/await support for non-blocking operations
- Dynamic sensor discovery based on device model and firmware
- Dictionary-style access to instant values
- Structured data API with type-based organization
- Device analyzer for discovering unsupported device capabilities
- PEP-561 compliant with full type hints for Home Assistant integrations
- Command-line interface for direct device interaction and testing
- Secure by default - WiFi passwords excluded unless explicitly requested
- Comprehensive error handling with detailed logging
- SSL/HTTPS support for secure communication
- Install and set-up the PoolDose devices according to the user manual.
- In particular, connect the device to your WiFi network.
- Identify the IP address or hostname of the device.
- Browse to the IP address or hostname (default port: 80).
- Try to log in to the web interface with the default password (0000).
- Check availability of data in the web interface.
- Optionally: Block the device from internet access to ensure cloudless-only operation.
pip install python-pooldoseimport asyncio
from pooldose.client import PooldoseClient
from pooldose.request_status import RequestStatus
async def main():
client = PooldoseClient(host="192.168.1.100")
status = await client.connect()
if status != RequestStatus.SUCCESS:
print(f"Connection failed: {status}")
return
# Dictionary-style access
status, values = await client.instant_values()
if status == RequestStatus.SUCCESS and values:
print(f"Temperature: {values['temperature']}")
print(f"pH: {values.get('ph', 'N/A')}")
# Structured data (grouped by type)
status, data = await client.instant_values_structured()
if status == RequestStatus.SUCCESS:
for sensor, info in data.get("sensor", {}).items():
print(f"{sensor}: {info['value']} {info.get('unit', '')}")
asyncio.run(main())# Connect to device
pooldose --host 192.168.1.100
# With HTTPS
pooldose --host 192.168.1.100 --ssl
# Analyze device capabilities
pooldose --host 192.168.1.100 --analyze
# Mock mode (testing without hardware)
pooldose --mock path/to/data.json
# Show help / version
pooldose --help
pooldose --versionSee docs/cli.md for full CLI documentation and device analysis details.
| Device | PRODUCT_CODE | FW Code | Notes |
|---|---|---|---|
| SEKO PoolDose Double | PDPR1H1HAW100 | 539187 | |
| SEKO PoolDose Double Spa | PDPR1H04AW100 | 539292 | |
| SEKO POOLDOSE pH+ORP CF Group Wi-Fi | PDPR1H1HAW102 | 539187 | Alias for PDPR1H1HAW100 mapping |
| SEKO PoolDose pH | PDPH1H1HAW100 | 539176 | pH-only device |
| VÁGNER POOL VA DOS BASIC | PDHC1H1HAR1V0 | 539224 | |
| VÁGNER POOL VA DOS EXACT | PDHC1H1HAR1V1 | 539224 | Alias for PDPR1H1HAR1V0 mapping |
Other models may work but are untested. See docs/device-support.md for how to request support for new devices.
| Topic | Description |
|---|---|
| API Reference | Constructor, methods, properties, data formats |
| CLI & Device Analysis | Command line usage and device analyzer |
| Examples | Basic and advanced usage examples |
| Mock Client | Testing without hardware using JSON files |
| SSL/HTTPS | SSL configuration and migration guide |
| Security | Data classification and sensitive data handling |
| Type Hints & HA | PEP-561 compliance and Home Assistant integration |
For detailed release notes and version history, please see CHANGELOG.md.