Skip to content

Latest commit

 

History

History
135 lines (96 loc) · 5.81 KB

info.md

File metadata and controls

135 lines (96 loc) · 5.81 KB

bhyve-home-assistant

Orbit BHyve component for Home Assistant.

If this integration has been useful to you, please consider chipping in and buying me a coffee!

Buy Me A Coffee

Supported Entities

  • sensor for measuring battery levels of sprinkler_timer devices
  • binary_sensor for tracking rain/weather delays
  • switch for turning a zone on/off

Installation

Recommended installation is via HACS.

hacs_badge

Configuration

bhyve:
  username: !secret bhyve_username
  password: !secret bhyve_password

sensor:
  - platform: bhyve

binary_sensor:
  - platform: bhyve

switch:
  - platform: bhyve

Sensor Entities

A battery sensor entity is created for any device which has a battery level to report.

A zone state sensor entity is created for each zone. This reports the state of the zone, for example auto or off. A zone may be switched to off either manually through the BHyve app, or may be automatically set when battery levels are too low to operate the device correctly.

Binary Sensor Entities

A Rain Delay binary sensor will be created for each discovered sprinkler_timer device. This entity will be on whenever BHyve reports that a device's watering schedule will be delayed due to weather conditions.

Rain Delay Attributes

The following attributes are set on binary_sensor.rain_delay_* entities, if the sensor is on:

Attribute Type Notes
cause string Why a delay was put in place. Values seen: auto. May be empty.
delay number The number of hours the delay is in place. NB: This is hours from started_at attribute.
weather_type string The reported cause of the weather delay. Values seen: wind, rain. May be empty.
started_at string The timestamp the delay was put in place.

Rain Delay Template Sensors

It is possible to create template sensors from these attributes. Here are two examples which provide a sensor to report:

  1. When the current rain delay for a device is ending
  2. The number of hours remaining on the current rain delay
sensor:
  - platform: template
    sensors:
      rain_delay_lawn_finishing:
        friendly_name: "Rain Delay Lawn Finishing"
        availability_template: "{{ states('binary_sensor.rain_delay_lawn') != 'unavailable' }}"
        value_template: "{{(as_timestamp(state_attr('binary_sensor.rain_delay_lawn', 'started_at')) + state_attr('binary_sensor.rain_delay_lawn', 'delay') * 3600) | timestamp_local }}"

      rain_delay_lawn_remaining:
        friendly_name: "Rain Delay Lawn Remaining"
        unit_of_measurement: "h"
        availability_template: "{{ states('binary_sensor.rain_delay_lawn') != 'unavailable' }}"
        value_template: "{{((as_timestamp(state_attr('binary_sensor.rain_delay_lawn', 'started_at')) + state_attr('binary_sensor.rain_delay_lawn', 'delay') * 3600 - as_timestamp(now())) / 3600) | round(0) }}"

Switch Entities

A switch entity is created for each zones of a sprinkler_timer device. This switch enables starting/stopping irrigation of a zone.

Turning on the switch will enable watering of the zone for the amount of time configured in the BHyve app.

Switch Attributes

The following attributes are set on switch entities:

Attribute Type Notes
manual_preset_runtime number The number of seconds to run zone watering when switch is turned on.
smart_watering_enabled boolean True if the zone has a smart water schedule enabled.
sprinkler_type string The configured type of sprinker.
image_url string The url to zone image.
started_watering_station_at string The timestamp the zone started watering.
watering_program list[string] List of timestamps for future/scheduled watering times.

Switch Template Sensors

It's possible to create a sensor to extract the next watering time, for example:

sensor:
  - platform: template
    sensors:
      lawn_next_watering:
        friendly_name: "Next watering"
        availability_template: "{{ states('switch.backyard_zone') != 'unavailable' }}"
        value_template: >-
          {% set program = state_attr('switch.backyard_zone', 'watering_program') -%}
          {% if program and (program | count > 0) %}
            {{ as_timestamp(program[0]) | timestamp_local }}
          {% else %}
            unknown
          {% endif %}

Debugging

To debug this integration and provide device integration for future improvements, please enable debugging in Home Assistant's configuration.yaml

logger:
  logs:
    custom_components.bhyve: debug

bhyve:
  username: !secret bhyve_username
  password: !secret bhyve_password
  packet_dump: true # Save all websocket event data to a file
  conf_dir: "" # Storage directory for packet dump file. Usually not needed, defaults to hass_config_dir/.bhyve