Skip to main content

No project description provided

Project description

bluebattery.py

Software for interacting with the BlueBattery line of battery computers for RVs.

Features:

  • Reading of periodically sent measurements
  • Publishes value to an MQTT broker
  • Auto-discovery of BB devices
  • Access to stored logs
  • Homeassistant support
  • Modification of device settings
  • Firmware update

Changelog

2026-01-05: Support for Homeassistant 2023-01-14: Moved to bleak library. This should make the software much more reliable. Multiple devices are now supported and the MQTT topic has changed to include the device address.

Installation

To install the latest published version:

sudo apt-get install python3-pip
# log out and in again to apply new environment variables 
pip3 install bluebattery-py

To install the latest version from this git repository:

sudo apt-get install python3-pip
# log out and in again to apply new environment variables 
pip3 install git+https://github.com/danielfett/bluebattery.py.git

Setting up a Systemd Service

See the systemd service file for details.

Reading values from the command line

$ bb_cli log

If you want to see more details of what is going on, use the debug flag:

$ bb_cli --log-level DEBUG log

Publishing values to an MQTT server

If you want to use the MQTT features, start the MQTT publisher using

$ bb_cli mqtt

Append --help to see the configuration options.

This is an example of the values published to the MQTT broker:

service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/max_solar_current_day_A 0.0
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/max_solar_watt_day_W 0.0
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/solar_charge_day_Ah 0.0
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/solar_energy_day_Wh 0
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/solar_charger_status 1
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/solar_module_voltage_V 0.0
service/bluebattery/FC:45:C3:CA:FF:EE/live/solar_charger_ext/relay_status RelayStatus()
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/battery_charge_Ah 158.48
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/state_of_charge_percent 83.4
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/max_battery_current_day_A 0.0
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/min_battery_current_day_A -1.1
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/max_battery_charge_day_Ah 16.16
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/min_battery_charge_day_Ah 15.84
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/max_battery_voltage_day_V 12.54
service/bluebattery/FC:45:C3:CA:FF:EE/live/battery_comp_1/min_battery_voltage_day_V 12.5
service/bluebattery/FC:45:C3:CA:FF:EE/live/info/battery_voltage_V 12.61
service/bluebattery/FC:45:C3:CA:FF:EE/live/info/starter_battery_voltage_V 12.43

Use --prefix BBX to pass a specific device name. In this example, BBX.

For using the bb_mqtt as daemon see here.

Troubleshooting

Depending on your environment, you may need to enable BLE first or to set up your linux user to allow using BLE:

Enabling Bluetooth LE

If the above command does not work out-of-the-box, you might have to enable Bluetooth Low-Energy.

On Ubuntu, add the following two lines at the bottom of /etc/bluetooth/main.conf:

EnableLE=true
AttributeServer=true

Then restart bluetooth: sudo service bluetooth restart

On the Raspberry Pi

This software works on a Raspberry Pi and was tested with the built-in bluetooth device. To use the software as the user pi (recommended!), you need to make the dbus policy changes described here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bluebattery_py-1.2.0.tar.gz (13.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bluebattery_py-1.2.0-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file bluebattery_py-1.2.0.tar.gz.

File metadata

  • Download URL: bluebattery_py-1.2.0.tar.gz
  • Upload date:
  • Size: 13.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bluebattery_py-1.2.0.tar.gz
Algorithm Hash digest
SHA256 dc089fee3108fdc8bf4e4e5fc82cd8d8e1f4a207d85bfde91614a44312995ef9
MD5 08d60e5470b615c5be99ac38a33b601a
BLAKE2b-256 87c2d6d1e6f47fcfb28d5d76035f94ae8cd2527acd264dc1fa52ad9ed4a14a84

See more details on using hashes here.

Provenance

The following attestation bundles were made for bluebattery_py-1.2.0.tar.gz:

Publisher: python-publish.yml on danielfett/bluebattery.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bluebattery_py-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: bluebattery_py-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bluebattery_py-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3b88300fa08d6ad7d00002e35320a0fd8fe56b2ff0899194b6cdee71955e03e6
MD5 de74a610a66967f45698e5b156f4dd0b
BLAKE2b-256 7d919256384f2c4e7fe2bb09ceb2123e89e695f3215ccbf4e9f019dfb33d0366

See more details on using hashes here.

Provenance

The following attestation bundles were made for bluebattery_py-1.2.0-py3-none-any.whl:

Publisher: python-publish.yml on danielfett/bluebattery.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page