@signalk/vedirect-serial-usb

Signal K Node.js server plugin to read VE.Direct data via serial USB

Usage no npm install needed!

<script type="module">
  import signalkVedirectSerialUsb from 'https://cdn.skypack.dev/@signalk/vedirect-serial-usb';
</script>

README

Build Status Greenkeeper badge

vedirect-serial-usb

This code is a Signal K Node Server plugin. It reads and parses Victron VE.Direct data.

The common way to connect to a Victron product is with the Victron VE.Direct to USB interface cable. Alternatively, this plugin also supports receiving the data via UDP and on a TCP socket.

Compatible Victron products:

  • BMV-700 series of Battery Monitors
  • SmartShunt series of Battery Monitors
  • SmartSolar Chargers
  • BlueSolar Chargers
  • Phoenix Inverters, including the Smarts, having a VE.Direct comms port

Note that above list may not be complete.

The TCP and UDP connection methods are to allow connecting to a Victron product too far away to run a serial cable. Ie. using a bridge to LAN/Wi-Fi that takes the serial data and makes it available on a TCP socket or sends it out as UDP packets. There are many of such devices available, as well as example DIY projects. A good example on how to make it yourself is explained here: https://pysselilivet.blogspot.com/2021/02/victron-vedirect-with-raspberry.html.

Lastly, note that when having a Victron GX Device, you won't be needing this plugin. Details for that here.

Installation

Use the Signal K app store or install via NPM in the Signal K server root directory: npm install @signalk/vedirect-serial-usb

Usage

Set up the appropiate device on the settings page of this plugin in the Signal K server admin UI, for instance to /dev/ttyUSB0 and enable the plugin. Your VE.Direct data will be available in Signal K format via various clients and apps.

Connections

Select device

  • Serial, UDP or TCP

Connection details

  • Serial: Enter device path e.g /dev/ttyUSB0
  • UDP: ignored
  • TCP: Enter host IP address

Port

  • Serial: ignored
  • UDP/TCP: port

Ignore Checksum

  • If you want to ignore checksum, use this option. Default ON

SK Paths

  • Give each device unique SK paths

License

Copyright 2018 Joachim Bakke <github@heiamoss.com>, Fabian Tollenaar <fabian@decipher.industries> and 
Karl-Erik Gustafsson <ke.gustafsson@gmail.com>

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.