Skip to content

Home Assistant custom component to interface with Astra Pool Halo pool chlorinators

License

Notifications You must be signed in to change notification settings

phrak/astralpool_halo_chlorinator

 
 

Repository files navigation

Astral Pool Halo Chlorinator

No Affiliation with Astral Pools or Fluidra

GitHub Release GitHub Activity License

pre-commit Black

hacs Project Maintenance

Community Forum

BuyMeCoffee

Please also support https://github.com/pbutterworth/astralpool_chlorinator for his initial work with the Astral Viron EQ Chlorinator.

**This component will set up the following platforms.**

Platform Description
binary_sensor Show something True or False.
sensor Show info from Astral Pool Halo Chlorinator API.
select Control the chlorinator mode (off/auto/manual)

Pre-Requisites

Astral Halo Minimum Firmware Version 2.2

Hardware

  1. Obtain an ESP32 dev board. The M5Stack Atom Lite is a great choice for first timers. If you are handy with a soldering iron, and you want a professional PoE powered BLE Proxy. Obtain a GL.iNet GL-S10, and follow the Instructions at blakadder.com on how to converting it to a ESPHome Bluetooth Proxy. The GL-S10 has a external antenna which will provide better range than a typical esp32 dev board
  2. Connect your ESP32 to your computer with a USB Data Cable. Double-check it actually IS actually a data cable and not just a charge cable.

Install a Bluetooth Proxy to the ESP board

  1. Visit https://esphome.io/projects/?type=bluetooth.
  2. Select "Bluetooth Proxy" and your device type.
  3. Flash your device.
  4. Join it to your WiFi network.
  5. Add it to Home Assistant as an ESPHome device. You do not need the ESPHome server running, just the ESPHome device discovered.
  6. Ping your device IP to confirm it's online.
  7. Mount your ESP32 device close (recommend within ~1 meter for best performance) to your Halo Chlorinator and within WiFi network range.

Installation

Best experience is to install with HACS.

Open your Home Assistant instance and open a repository inside the Home Assistant Community Store.

Installation via HACS

  1. Open the HACS page on your Home Assistant Dashboard.
  2. Select "Integrations".
  3. From the 3 dots menu, select "Custom Repositories".
  4. Add the URL of this GitHub (https://github.com/DanielNagy/astralpool_halo_chlorinator). Select "Integration" as the Category.
  5. Select "Astral Pool Halo Chlorinator". Download/install the latest version.
  6. Restart HomeAssistant when instructed.

Manual Installation

  1. Using the tool of choice open the directory (folder) for your HA configuration (where you find configuration.yaml).
  2. If you do not have a custom_components directory (folder) there, you need to create it.
  3. In the custom_components directory (folder) create a new folder called astralpool_halo_chlorinator.
  4. Download all the files from the custom_components/astralpool_halo_chlorinator/ directory (folder) in this repository.
  5. Place the files you downloaded in the new directory (folder) you created.
  6. Using your HA configuration directory (folder) as a starting point you should now also have this:
custom_components/astralpool_halo_chlorinator/translations/en.json
custom_components/astralpool_halo_chlorinator/translations/fr.json
custom_components/astralpool_halo_chlorinator/translations/nb.json
custom_components/astralpool_halo_chlorinator/translations/sensor.en.json
custom_components/astralpool_halo_chlorinator/translations/sensor.fr.json
custom_components/astralpool_halo_chlorinator/translations/sensor.nb.json
custom_components/astralpool_halo_chlorinator/translations/sensor.nb.json
custom_components/astralpool_halo_chlorinator/__init__.py
custom_components/astralpool_halo_chlorinator/api.py
custom_components/astralpool_halo_chlorinator/binary_sensor.py
custom_components/astralpool_halo_chlorinator/config_flow.py
custom_components/astralpool_halo_chlorinator/const.py
custom_components/astralpool_halo_chlorinator/manifest.json
custom_components/astralpool_halo_chlorinator/sensor.py
custom_components/astralpool_halo_chlorinator/switch.py
  1. Restart Home Assistant when instructed.

Configuration

Configuration is done in the Home Assistant UI

  1. Visit your HomeAssistant Integrations Dashboard

Open your Home Assistant Integrations Dashboard.

  1. Wait patiently for your chlorinator to be discovered (should only be a few seconds once HA has started up)
  2. When the Halo device is detected in Home Assistant, you will see a new HCHLOR integration card with button for 'Configure'.
  3. Go to your physical Halo Control Panel (the one near your pool) to start the pairing process.
  • Take a mobile device or laptop with you so you can control Home Assistant and the Chlorinator from the same place.

Pair Your HALO

  1. Open your Home Assistant Integrations page
  2. Click the 'Configure' button on the newly discovered HCHLOR device.
  3. Press submit to confirm 'add device'.
  4. Home Assistant will start polling for new pairing connections.
  5. On Halo Control Panel: Put your HALO into pairing mode.
  6. On Home Assistant: Once discovered, Home Assistant will ask you what HA Area the Halo is located. Select your area as desired.
  7. Your Halo should now be added to HA as 1 new device with ~19 entities.

Troubleshooting:

  1. The HA pairing discovery may either error or the circle might just spin forever.
  2. If it errors, hit config / add / confirm again (whilst the Halo is still in pairing mode).
  3. If it is spinning, just wait approx 30 seconds, then cancel it, and hit configure again.
  4. Repeat as needed until the pairing is successful.

Note

Halo only supports one concurrent Bluetooth or Cloud connection at any point in time.
While Home Assistant is polling your Halo, you will not be able to use your mobile app to connect to the Halo either via Bluetooth or Cloud.
Likewise, while your mobile is connected, Home Assistant will not be able to poll the Halo.

If you need to access Halo from your mobile while Home Assistant is connected, you will have to wait for the poll to finish and then open your mobile connection.

  • Open your mobile app and look for a 'blue dot' next to your chlorinator.
  • If it is NOT there, HA is currently polling for data (takes 20 seconds to complete).
  • As soon as the blue dot appears, you will be able to connect to it from your mobile.

Other interesting links

Hidden Menu

Halo has a hidden system menu that allows you to display the actual ORP value on the Halo screen and also on the app screen. Here is a video on how to access the menu. https://www.youtube.com/watch?v=zaRFVSt8Hc4

Pool Monitor Card

https://github.com/wilsto/pool-monitor-card The "Pool Monitor Card" is a home assistant plugin that display information of 12 pre-defined sensors of your swimming pool : temperature, pH, ORP levels and TDS but also if you need them : salinity, CYA, calcium, phosphate, alkalinity, free chlorine, total chlorine, filter pressure

Credits

This project was forked from @pbutterworth's' AstralPool Chlorinator with a future goal to merge both Halo and EQ together.

This project was generated from @oncleben31's Home Assistant Custom Component Cookiecutter template.

Code template was mainly taken from @Ludeeus's integration_blueprint template


About

Home Assistant custom component to interface with Astra Pool Halo pool chlorinators

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%