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 (reported to work also on the BMV-600)
- 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.
Use the Signal K app store or install via NPM in the Signal K server root directory: npm install @signalk/vedirect-serial-usb
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.
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
It's possible to use this plugin as a library, in other Node.js code. This feature simply wraps the plugin in an easy-to-consume manner, so functionality is identical. Example:
const VEDirect = require('@signalk/vedirect-serial-usb/standalone')
const consumer = new VEDirect({
device: '/dev/ttyUSB0',
ignoreChecksum: true,
mainBatt: 'House',
auxBatt: 'Starter',
solar: 'Main',
})
consumer.on('delta', (delta) => console.log('[onDelta]', delta))
consumer.stop() // stop the plugin, destruct the connections
consumer.start() // (re-)start the plugin
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.