The basic aim of the piaware package is to forward data read from an ADS-B receiver to FlightAware.
It does this using a program, piaware, aided by some support programs.
- piaware - establishes an encrypted session to FlightAware and forwards data
- piaware-config - used to configure piaware like with a FlightAware username and password
- piaware-status - used to check the status of piaware
- faup1090 - run by piaware to connect to dump1090 or some other program producing beast-style ADS-B data and translate between its format and FlightAware's
- fa-mlat-client - run by piaware to gather data for multilateration
This repo is the basis of the piaware Debian install package available from https://flightaware.com/adsb/piaware/
This repository provides only part of the overall piaware package. You must also build fa-mlat-client and faup1090 and put them in the right places.
Please use piaware_builder to build the piaware package; this is a mostly automated build that knows how to assemble and build the different parts of the piaware pacakge. It is used to build the Raspbian piaware release packages that FlightAware provides. It should also work on other Debian-based systems.
The piaware program establishes a compressed, encrypted TLS connection to FlightAware and authenticates either by MAC address, or by a registered FlightAware username (or email address) and password.
It then starts faup1090 to translate ADS-B data from a raw Beast-format feed on port 30005 to a filtered ADS-B format. The filtered data is uploaded to FlightAware over the previously established TLS connection.
Every five minutes piaware also sends a message containing basic health information about the local machine such as system clock, CPU temperature, CPU load, basic filesystem capacity and system uptime.
Piaware will start the multilateration client fa-mlat-adept on request. fa-mlat-client extracts raw messages from port 30005 and selectively forwards them by UDP to the FlightAware servers. UDP is used as this message forwarding is time-sensitive, but it's not too important if some messages get dropped. Multilateration control messages are sent over the main piaware TCP connection.
Piaware uses several techniques to keep the connection established and disconnect and reconnect if something goes wrong.
piaware-config provides a way for you to configure piaware's settings to control authentication, updates, and multilateration.
The configuration is read once when piaware starts. If you change piaware's configuration, you should then restart piaware by:
$ sudo service piaware restart
To configure the user that piaware logs in as, use:
$ sudo piaware-config -user username -password
This will set the user to "username" and prompt for the password.
Note that as of PiAware 1.13 it is no longer necessary to set a username and password, although if you do it will still work. If PiAware is not pre-configured then the server will generally be able to associate the PiAware host with your FlightAware account automatically by looking at your FlightAware web session and the IP address your pi is coming from. If it can't then there's a process for claiming a PiAware receiver as belonging to you. For more information please check out PiAware build instructions at FlightAware.
To configure whether piaware will accept requests for automatic (requested by FlightAware) or manual (requested by you via the FlightAware website control panel) updates and restarts:
# disable auto updates:
$ sudo piaware-config -autoUpdate 0
# disable manual updates:
$ sudo piaware-config -manualUpdate 0
Updates default to enabled for Piaware sdcard images, and disabled for package installs.
Multilateration data is sent to FlightAware by default. To disable it:
# disable multilateration:
$ sudo piaware-config -mlat 0
By default, multilateration positions resulting from the data that you feed to FlightAware are returned to you by sending them to the local dump1090 process on port 30104; dump1090 will then include them on the web map it generates.
There are two controls for this. There is an overall enable/disable control that can be used to entirely disable returning results if they are not needed:
$ sudo piaware-config -mlatResults 0
If you want to send the results elsewhere, you can modify where they are sent and the format used:
# Connect to localhost:30104 and send multilateration results in Beast format.
# Listen on port 310003 and provide multilateration results in Basestation format to anyone who connects
$ sudo piaware-config -mlatResultsFormat "beast,connect,localhost:30104 basestation,listen,31003"
The default configuration now connects to port 30104, not 30004. The default FlightAware dump1090 configuration has been updated to match this. This change is to avoid accidentally feeding mlat results to an older dump1090 that is not mlat-aware and might end up feeding the results to places you don't want to feed them to. If you really do want to feed to port 30004, and you know that's not going to cause problems with mlat results going where they shouldn't, you can return to the older behaviour by:
$ sudo piaware-config -mlatResultsFormat "beast,connect,localhost:30004"
piaware-status will examine your system and try to figure out what's going on. It will report on whether dump1090, faup1090 and piaware are running or not and it will identify what program, if any, is producing data on port 30005 and whether or not piaware is connected to FlightAware.
piaware logs to the file /tmp/piaware.out. At the end of each GMT day that file is renamed to /tmp/piaware.out.yesterday and a new piaware.out is started.
The fa_adept_client package provides a class library for being a FlightAware aviation data exchange protocol (ADEPT) client.
The fa_adept_config package provides functions for reading and writing the piaware config file.
The piaware package provides functions used by various of the piaware programs.
The piaware control script gets installed into /etc/init.d and piaware can be started and stopped with
/etc/init.d/piaware start
/etc/init.d/piaware stop
/etc/init.d/piaware restart
The piaware install package does the needful to make piaware stop and start automatically as Linux goes to and from multiuser operation.
This can probably be done for people installing piaware from this repo by doing a
update-rc.d piaware defaults
and removed by doing a
update-rc.d piaware remove