Metadata-Version: 2.1
Name: pysaleryd
Version: 3.0.3
Summary: Python library for controlling Saleryd HRV system
Home-page: https://github.com/bj00rn/pysaleryd/
Author: Björn Dalfors
Author-email: bj00rn@users.noreply.github.com
License: MIT
Project-URL: Documentation, https://bj00rn.github.io/pysaleryd/
Platform: Mac
Platform: Linux
Classifier: Development Status :: 4 - Beta
Classifier: Programming Language :: Python
Requires-Python: >=3.10
Description-Content-Type: text/x-rst; charset=UTF-8
Provides-Extra: testing
License-File: LICENSE.txt


.. image:: https://img.shields.io/pypi/v/pysaleryd.svg
    :alt: PyPI-Server
    :target: https://pypi.org/project/pysaleryd/
.. image:: https://pepy.tech/badge/pysaleryd/month
    :alt: Monthly Downloads
    :target: https://pepy.tech/project/pysaleryd

.. image:: https://img.shields.io/badge/-PyScaffold-005CA0?logo=pyscaffold
    :alt: Project generated with PyScaffold
    :target: https://pyscaffold.org/

|

=========
pysaleryd
=========


    Python library for controlling Saleryd HRV system


Python library for controlling Saleryd HRV system using the built in websocket server used by Saleryd HRV Homeassistant integration https://github.com/bj00rn/ha-saleryd-ftx


Supported devices
==================

LOKE1/Loke Basic/LS-01 using control system 4.1.1

Usage with asyncio as library
=============================


Read data
---------

.. code-block:: python3

    import asyncio

    from pysaleryd.client import Client

    async with Client(WEBSOCKET_URL, WEBSOCKET_PORT) as hrv_client:
        await asyncio.sleep(2) # wait a bit for some data
        print(client.data)

Read data using callback
------------------------

.. code-block:: python3

    import asyncio

    from pysaleryd.client import Client

    def handle_messge(raw_message: str):
        print(msg)

    async with Client(WEBSOCKET_URL, WEBSOCKET_PORT) as hrv_client:
        hrv_client.add_handler(handle_message)
        await asyncio.sleep(3) # wait around a bit for data

Send control command
--------------------
Command syntax can be found by dissecting websocket messages in the built in web ui

.. code-block:: python3

    import asyncio

    from pysaleryd.client import Client

    async with Client(WEBSOCKET_URL, WEBSOCKET_PORT) as hrv_client:
        await hrv_client.send_command("MF", 0) # send command to set fan mode

CLI usage
=========

List command line usage

.. code-block:: shell

    $ pysaleryd -h 


Connect to system and capture websocket data to stdout

.. code-block:: shell

    $ pysaleryd --host WEBSOCKET_URL --port WEBSOCKET_PORT [-t TIMEOUT] 

Send command to system

.. code-block:: shell

    $ pysaleryd --host 192.168.1.151 --port 3001 --send --key MF --data 0

Troubleshooting
===============
* Confirm system is connected and UI is reachable on the local network. Follow steps in the manual.
* Confirm websocket port by connecting to the UI using a browser and take note of websocket port using debug console in browser. 3001 is probably default
* The system HRV system can only handle a few connected clients. Shut down any additional clients/browsers and try again


Disclaimer
==========

Use at own risk.

This project is in no way affiliated with the manufacturer. 

All product names, logos, and brands are property of their respective owners. All company, product and service names used are for identification purposes only. Use of these names, logos, and brands does not imply endorsement.

.. _pyscaffold-notes:

Note
====

This project has been set up using PyScaffold 4.4. For details and usage
information on PyScaffold see https://pyscaffold.org/.
