Skip to content

A gecko client to publich Gecko in.touch data on a broker

Notifications You must be signed in to change notification settings

kalinrow/geckoclient

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GeckoClient

A client for Gecko SPA system using in.touch. It used the GeckoLib from gazoodle to connect to your SPA and publishes the most relevant information on a broker. From there your home automation system can retrieve the values again.

So far the heater, water care, filter, the pumps and lights status as well as the reminders are published. The lights can also be controlled.

Requirements

The script has been written and tested only on a Linux machine. No idea, if it also works on a Windows host. For sure the service installation needs to be adapted.

You need to have Python 3.8 or later installed with the libraries geckolib and asyncio-paho.

sudo apt install python3-pip       # if not already installed
sudo pip3 install geckolib==0.4.8
sudo pip3 install asyncio-paho

Installation

The installation is quiet simple by coping the files to a dedicated folder and configuring the client to run as a service. If you update from an older version, please stop the service before coping the files.

  1. Create a folder, e.g. /opt/geckoclient
  2. Copy all python file into the folder
    cp src/*.py /opt/geckoclient
    
  3. Copy the config template to config.py
    cp src/config.py_template /opt/geckoclient/config.py
    

Configuration

In order to connect to your SPA and broker, you need to configure the connection parameters below. You can use the in.touch APP to retrieve the SPA_NAME and SPA_IDENTIFIER. The identifier should be the MAC address with SPA as prefix. If the spa is not detected you can add the IP address. That can help to fix the issue. See example below.

Please use the UUID generator to create an unique ID for your client. That is important for have a good communication. See also comments from the developer of the geckolib on this topic under https://github.com/gazoodle/geckolib

# SPA values
SPA_NAME = "My Spa"
SPA_IDENTIFIER = "SPAxx:xx:xx:xx:x:xx"   # Please use lowercase characters
SPA_IP_ADDRESS = "DHCP"   # either the IP address or DHCP in case of dynamic assignment


# Replace with your own UUID, see https://www.uuidgenerator.net/>
CLIENT_ID = "123"

# BROKER values
BROKER_ADDRESS = "192.168.1.100"
BROKER_PORT = 1883
BROKER_USERNAME = "username"
BROKER_PASSWORD = "password"
BROKER_ID = "geckoclient"

# Topic
TOPIC = "whirlpool"

# Log file
LOGFILE = "/var/log/geckoclient.log"

# Debug settings
# level # can be one of the following strings
#   'CRITICAL','FATAL', 'ERROR', 'WARN', 'INFO', 'DEBUG', 'NOTSET'
DEBUG_LEVEL = 'DEBUG'
GECKOLIB_DEBUG_LEVEL = 'WARN'
# number of log files to keep
BACKUP_COUNT=5

Configure as service

  1. Update the path in gecko.service (only if geckoclient has not been installed in /opt/geckoclient)
  2. Copy service/gecko.service into /etc/systemd/system
    cp service/gecko.service /etc/systemd/system
    
  3. Enable the service
    sudo systemctl enable gecko.service
    

Start/Stop the service

To start the service use

sudo systemctl start gecko.service

To stop the service use

sudo systemctl stop gecko.service

To check the status of the service use

sudo systemctl status gecko.service

SPA controllers

Since version 0.6.x the SPA is controlled by only one control topic %prefix%/control. The message has been transferred into a JSON string. The different items can be controlled as following

Item JSON String Comment
Lights {"lights":"off|on"}
Temperature {"temp":TEMP} TEMP is in steps of 0.5
Pumps {"pump":"off|low|high","number":PUMPNUMBER} Not all SPA support 'low' value
Blower {"blower":"off|high"}
Watercare {"watercare":"MODE"} See below for possible MODE values
Refresh All {"refresh":"all"}

Watercare mode is one of the values below (you can use either the integer or the string value):

  • 0 = "Away From Home"
  • 1 = "Standard"
  • 2 = "Energy Saving"
  • 3 = "Super Energy Saving"
  • 4 = "Weekender"

Known Issues

Version 0.6.0 is a breaking change

The control topic and messages have been changed from version 0.6.0. From this version only one command topic %prefix%\control is used to control the SPA. And the message has been switched to JSON.

Long waiting time for receiving value change notification

Without manipulating the geckolib, receiving changed values might take up to 2 minutes. I was not able to figure out why.

If you need quicker, e.g because you want to measure runtime of pumps, etc. you need to change the file async_facade.py. To do so, first find the file (in a standard Debian 11 with python3.9 is might be under /usr/local/lib/python3.9/dist-packages/geckolib/automation). Then add after line 78 the block (take care to use tabs or spaces depending on what the exiting file already uses):

    if self._ready:
        active_mode = True

It should now look like:

76  for device in self.all_config_change_devices:
77      if device.is_on:  # type: ignore
78          active_mode = True
79  if self._ready:
80      active_mode = True
81  set_config_mode(active_mode)

Now changes are reported immediately. Still there is a 2 minuted gap after the startup of the service.

High CPU usage

If you suffer from high CPU usage you can change the yield value for asyncio sleep time. That will dramatically reduce the CPU usage.

To do so, change the value ASYNCIO_SLEEP_TIMEOUT_FOR_YIELD in geckolib const.py in geckolib main folder (see above) from 0.001 to 0.02. The latter value works well for me.

    CONNECTION_STEP_PAUSE_IN_SECONDS = 0  # Time between connection steps
    MAX_RF_ERRORS_BEFORE_HALT = 50
    ASYNCIO_SLEEP_TIMEOUT_FOR_YIELD = 0.02 # Changed from 0.001

Acknowledgements

License

Licensed under the EUPL-1.2-or-later.

https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12

Improvement ideas

  • (DONE) Switch command topic values to json format
  • Error handling not able to find/connect to a spa

History

v0.6.1

  • Support for fahrenheit temperature unit
  • Usage of temperature min. and max. values from geckolib

v0.6.0

  • Breaking change
  • Switch to one command topic and change value to json format
  • Update to use geckolib v0.4.8

v0.5.4

  • Fix bug that water care mode could not be set
  • Fix error describing setting of water care mode in README.md

v0.5.3

  • Forced decimal separator to point
  • Added a check, if facade is ready. Log the error and exit gracefully.
  • Improved unexpected disconnection handling
  • Added publishing filter status

v0.5.2

  • BugFix #3: Spa check interval configured as string instead of integer in const.py
  • Added missing configuration values in config.py-template
  • Adding refresh_all command to re-publish all values

v0.5.1

  • Adding log level option for geckolib in config.py
  • Adding exception handling with default values for missing SPA_IP_ADDRESS (DHCP) and BACKUP_COUNT (WARN) values in config.py

v0.5

  • Breaking changes in config.py:
    • SPA_IP_ADDRESS address parameter needs to be provided
    • BACKUP_COUNT needs to be provided
  • Fixing publishing filter values
  • Adding smart winter and ozone mode values
  • Adding setting of first blower and water care mode (thanks to Marcus)
  • Add BACKUP_COUNT option in config.py

v0.4

  • Adapting to geckolib 0.4.7
  • No manipulation of the GeckoLib is needed anymore to get the reminders.
  • Switching to Asynchronous I/O (asyncio) Paho MQTT client to be able to use the async part of the geckoclient

v0.3

  • Adding states for blowers

v0.2

  • fix for reading pumps correctly

v0.1

  • first working version

About

A gecko client to publich Gecko in.touch data on a broker

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages