Snap package for python-velbustcp.
The snap is published through the official Canonical snap store. To install, simply open a terminal on any snapd-supported Linux distribution and type:
snap install velbus-tcp
To allow the snap to access your Velbus USB interface, connect it to the raw-usb plug using:
snap connect velbus-tcp:raw-usb :raw-usb
Alternatively, if you are running on a gadget which exposes a serial-port slot, use:
snap connect velbus-tcp:serial-port :serial-port
A complete list of configuration options is listed below. The current configuration can be retrieved with:
snap get velbus-tcp -d
By default, the application will connect to the first Velbus USB interface it can find and use (based on VID and PID). If you want to change this behaviour or use a serial port, you can manually set the port using:
snap set velbus-tcp serial.autodiscover=false
snap set velbus-tcp serial.port=/dev/ttyAMA0
By default, the application will bind on 27015 and accept all hosts, using TLS/SSL and authorization.
You can enable/disable authorization to restrict unauthorized access to your Velbus installation by using:
snap set velbus-tcp tcp.auth=true
By default, an authorization key is generated during installation, to get this key use:
snap get velbus-tcp tcp.authkey
To set your own authorization key, use:
snap set velbus-tcp tcp.authkey=YOUR_KEY_HERE
The authorization key is a key that needs to be sent after establishing a connection. No data will be exchanged until the key verified.
You can enable TLS/SSL to encrypt the connection between you and the application:
snap set velbus-tcp tcp.ssl=true
The used certificate can be found at /var/snap/velbus-tcp/common/
.
You can set up multiple bind points by using comma-seperated values. You'll need to supply all values for a second bind point, for example;
snap set velbus-tcp \
tcp.host=0.0.0.0,127.0.0.1 \
tcp.port=27015,54934 \
tcp.relay=true,true \
tcp.ssl=true,true \
tcp.auth=true,false \
tcp.authkey=MY_AUTH_KEY,
Which would set up two bind points;
One which binds on 27015 and accepts all hosts (0.0.0.0), which has TCP relay and SSL and uses auth with MY_AUTH_KEY One which binds on 54934 and only accepts 127.0.0.1, which has relay and SSL and doesn't have auth
The application can broadcast the system time on the bus, this is option disabled by default.
You can enable NTP with:
snap set velbus-tcp ntp.enabled=true
When enabled, it will broadcast the time at startup, after that;
If ntp.synctime is not set or is set to empty, it will do so at every hour transition and at DST transitions, whichever is closer.
If ntp.synctime is set, it will broadcast at the specified time and at DST transitions, whichever is closer.
To change the the sync time use
snap set velbus-tcp ntp.synctime='03:00'
The application logs can be obtained using:
snap logs velbus-tcp -f
To set the verbosity level (info, debug) of the logging:
snap set velbus-tcp logging.level=debug
Having troubles getting the snap up and running?
Ensure the plug is connected, otherwise USB/serial communication will not work.
Try to disect the logging for possible errors.
Try installing the core22 snap with:
snap install core22