Argo is a Signal K compliant server written in Go. The goal of Argo is to consume as many different sources of data as possible and convert them to Signal K on as many different transports as possible.
It currently supports WebSockets, ZeroMQ and MQTT transports and ingestion of NMEA 2000 data using an Actisense NGT-1 NMEA 2000 to USB converter or a Lawicel CAN-USB adapter. It can also read CANboat JSON from a file.
If you don't have go, you'll need to install it first. See the golang Getting
Started guide for information. On Debian/Ubuntu
apt-get install golang may be sufficient.
After that, you can install argo. Go has some opinions on how you should manage your source code workspaces, so use the commands below to get the paths right.
$ sudo apt-get install libzmq-dev $ cd $GOPATH/src $ git clone email@example.com:timmathews/argo github.com/timmathews/argo $ cd github.com/timmathews/argo $ ./build.sh $ sudo ./build.sh --install
If you're not interested in hacking on Argo, you can install the libzmq-dev
library as above and then
go get github.com/timmathews/argo. Which will
install argo in into $GOPATH/bin.
By default, argo will try to use /dev/ttyUSB0 for the Actisense NGT-1, but you
can change this by calling argo with a specific device like
There are utility scripts in the
actisense folders which will
install udev rules for those devices. You probably won't need these, but if for
some reason your distro doesn't recognize the vendor IDs for those devices,
these scripts can help.
- Daemonize argo and write an upstart script for it
- Better Signal K support
- Simplify commandline arguments and move more settings into the config file
- Set the default path for the config file to /etc
- Add support for reading raw CAN packet captures in Actisense and CANUSB formats (maybe others)
- Add SocketCAN support
- Web GUI for configuration
- CLI for configuration