dbus-spy is a debug tool intended for the Venus embedded Linux platform created by Victron Energy. This is the platform running on the CCGX and venus GX units. This application provides a realtime view on all properties published to the D-Bus. It is also possible to change the values of those properties (whenever the application publishing the property allows it).
On startup dbus-spy will present a list of all victron D-Bus services on the system (the one whose name starts with com.victronenergy. Those services are considered to be compatible with the methods and signals we need). When activated, all properties within the service, will be shown together with the current value. The values will be updated in realtime. It is also possible to change the value. History properties are hidden by default and can be enabled with a command line argument.
--dbus
: dbus address (session, system, ...)-h
or--help
: Show help-i
or--introspect
: Use introspect to build a tree of the pesky services support GetValue on the root-r
or--history
: Show items whose path starts with 'History'.-v
or--version
: Show version
right-arrow
: open the selected D-Bus service and show the list of propertiesleft-arrow
: go back to the service listup/down-arrow
,page up/down
: move up/down (yes, really!)enter
: edit the value of the current propertyt
: switch between property values and textq
: quit the apllication. ctrl-c will do the same jobf
: add the current item to the list of favorites. The item will light up after it has been added. Pressf
again to remove it from the list.g
: get the item from the service (again).F
: switch to/from the favorites list.r
: refresh the screen
dbus-spy relies on several external libraries:
- Qt4 / Qt5 or Qt6
- libncursesw and libformw5
- veutil (as a submodule)
You will also need the venus SDK.
- There is an issue with some of the services that do not fully conform with the Victron standard: they will no supply a dictionary of all values when a GetValue method is called on the root element. The content if these services will not be shown.
- The application is written in C++ and uses the QT framework for D-Bus communication. However, the GUI is done using ncurses. The reason for this odd combination is that dbus-spy started as a QT+QML application running on PC linux. Someday I decided that being able to run the application on the embedded device itself would be more useful. So I rewrote the GUI and kept the D-Bus code.
- If you change a value of a property no checks are performed by the application. If the entered text string parses to a floating point value, it will be sent to the D-Bus as a 'double' value. Otherwise, it will be parsed an integer. If that does not work, the string itself will be sent. The receiving application may expect another type and may refuse to handle the value.
- Changing values on D-Bus services may be dangerous. Only do this if you know what you are doing.
- The screen will not be redrawn when the size of the terminal changes. So chose it wisely before starting the application.