/victron

Victron bluetooth and serial communication at a python script. With MQTT and HomeAssistant support.

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

VictronConnect Bluetooth & Serial

This repository is in no way approved by or affiliated with the official Victron Energy repository. I am not responsible for any problems or damages with your devices or this code

Only run this script if you are sure you know what you are doing!

This repository is based on https://github.com/vvvrrooomm/victron.

I use this repository to have a running version with mqtt for my camping car. If you want more information about the development and a wireshark dissector, refer to vvvrrooomm's repository.

New version for the new bluetooth gatt api used in the beta firmware of the SmartShunt

See https://community.victronenergy.com/questions/93919/victron-bluetooth-ble-protocol-publication.html for more information about how to activate the new gatt protocol with the beta firmware.

The Bluetooth-BLE (new gatt protocol) and the serial protocol works quiet stable. The normal bluetooth protocol is the hardest to implement. Many values are still missing.

More features will be added soon.

Ability of this repository

The script is tested with python > 3.7

Supported/tested devices:

Bluetooth BLE:

  • Smart Shunt

Bluetooth:

  • Smart Shunt
  • Smart Solar 100/30
  • Orion Smart 12/12-30

Serial:

  • Phoenix Inverter 12 800VA 230V
  • Smart Shunt
  • Smart Solar 100/30

Outputs

  • mqtt
  • syslog
  • print

Autostart scripts (systemd)

These scripts are written for my specific config file. If you have your devices in different order, you may need to adjust them.

Howto use


NOTE

If you want the serial communication with the Phoenix Inverter, you must install this library:

There are some more commandline arguments, you can view them with python3 victron.py --help


  1. You need to install some requirements: pip3 install -r requirements.txt
  2. Add your devices to the configuration file. See "Configuration in detail" section for examples.
  3. If you are using bluetooth or bluetooth ble you must be pairing your devices via bluetoothctl
# Open bluetoothctl from commandline
bluetoothctl

# Enable scanning
scan on
  
# Get the mac address of your device
# pair device and enter pin
pair MAC

  1. Start the script for your desired device: python3 victron.py -d 0
  2. For autostart tweak systemd files to your need, link them to /etc/systemd/system/, then start and/or enable systemd file
ln -s /opt/victron/systemd/victron-shunt.service /etc/systemd/system/victron-shunt.service

systemctl enable victron-shunt.service
systemctl start victron-shunt.service

FAQ

No output shown with following log message "merror: Not connected"

Please check if you paired the victron device correctly via bluetooth using bluetoothctl. If you changed the pin of the vicron device, delete and repair the device.

Configuration in detail

Device section

Mandatory: Name, Type, Protocol and (MAC or serialport) depending of the type. bluetooth and bluetooth-ble need to have the bluetooth mac adress of the victron device specified.
Name: Choose yourself
Type: phoenix, smartshunt, smartsolar, orionsmart
Protocol: serial, bluetooth, bluetooth-ble

    - name: Phoenix1
      type: phoenix
      protocol: serial
      port: /dev/victron-phoenix

or

    - name: Shunt1
      type: smartshunt
      protocol: bluetooth-ble
      mac: fd:d4:50:0f:6c:1b

or

    - name: Solar1
      type: smartsolar
      protocol: bluetooth
      mac: F9:8E:1C:EC:9C:72

Optional:

Output section

You can choose between:

logger: mqtt

or

logger: syslog

or

logger: print

MQTT section

Choose host, port, base_topic and if you want to use HomeAssistant Discovery (Yet only supported on serial devices). SSL and authentication will be added later.

mqtt:
    host: 192.168.3.2
    port: 1883
    base_topic: victron
    hass: True

Collections section

You can specify if you want the values get summarized into one json output statement. Otherwise it will send out every value as soon as it is collected from victron device. See configfile for more information!

Known issues

  • The devices with bluetooth protocol are currently auto disconnecting after 30 seconds. This may prevent some values from being gathered.
  • Orion Smart must be more reverse engineered to get some more interesting values
  • Bluetooth: From smart solar you can't get the history values. The protocol itself is decoded (and working) for this part, but the smart solar doesn't send the data. I guess we need to send another init sequence. I didn't figure out the corrent sequence yet!
  • Serial: Smart Solar history currently not gathered

Feel free to help improving this repository.

Future plans:

  • Choose via config file which values should be printed
  • Choose how often values should be printed (especially bluettooth with notifications)
  • CMD Parameter instead of config (easier testing of new devices)
  • SmartSolar history values
  • Get device settings via serial and bluetooth
  • Add a config checker to avoid invalid config parameter