Read the statement by Michael Teeuw here.
MMM-FlightTracker - Real time plane tracker using ADS-B systems
-
I love the idea of having a flight tracker on my magicmirror, but I already have a flight tracker on my network. Its a raspberry pi runnng PiAware flight tracker. Any way you could have this plugin support a remote flight tracker over the network rather than directly connected?
-
@jrsphoto said in MMM-FlightTracker - Real time plane tracker using ADS-B systems:
I love the idea of having a flight tracker on my magicmirror, but I already have a flight tracker on my network. Its a raspberry pi runnng PiAware flight tracker. Any way you could have this plugin support a remote flight tracker over the network rather than directly connected?
Hi @jrsphoto. The idea behind the module was to use the hardware directly rather than using an API like flightaware/flightradar24/etc, because this mean that everybody needs to have either:
- an paid account there
- another PI along side the one for the mirror + ADS-B receiver
This incur more cost hence why I went for the direct connection to the hardware.
However, I looked at PiAware and from what I can see from https://github.com/flightaware/piaware, there is no API available to get the data out of this from the LAN. But at that point, that would be irrelevant as you could target directly the public API.
Maybe I’ll do another module in the future for flightaware or flightradar24 if I got my hands on another ADS-B device.
-
Hi @tbouron
PiAware tracker (based on dump1090) makes its local data available in several JSON data dumps accessible under /data/ URL:
- http://(host):(port)/data/aircraft.json - list of visible aircrafts
- http://(host):(port)/data/stats.json - receiver statistics - number of messages, signal quality, etc.
- http://(host):(port)/data/receiver.json - receiver status, particularily refresh rate (how often aircraft.json is refreshed) and history length
- http://(host):(port)/data/history_(number).json - copy of earlier states of aircraft.json with number going from 0 to history length. History files are a ring buffer so you need to load them all to figure out the most recent one.
Other homebrew solutions based on dump1090 can have similar set of results enabled.
Complete description is here dump1090 README-json.md
But at that point, that would be irrelevant as you could target directly the public API.
It’s still relevant :). I live next to a military airbase and on my feed I see both military and government aircrafts that are censored from sites like flightaware/flightradar. I feed to Flightaware, so I know this for sure :).
-
Hum if we can get the data out of this then yes, I can look into this :)
I’ll look at dump1090 and see what I can do. Wanted to go back to the output design anyway so might be a nice feature to add.
I’ll let you know.
-
HI @ytmytm.
So I looked at this over the past week and it turns out to be more complicated than expected.
dump1090 does expose a raw stream of data but I could not use it as the data there is serialised from a C struct, which cannot be reconstructed from nodejs. I then looked at the SBS1 (BaseStation) stream to get the parsed data directly. This is a bit fiddly to make it work with the current codebase, and requires changes into npn dependencies I’m using.
However, this is the best alternative I could find so I’ll continue in that direction. Bear in mind that as I have to modify dependencies so this will take a bit of time before I can release something that works ok. -
Alright @ytmytm got something working with the data exposed by dump1090.
This is available on the branchfeature/network
where also updated theREADME.md
regarding the configuration: https://github.com/tbouron/MMM-FlightTracker/tree/feature/network. You will need to update the dependencies:git fetch && git pull feature/network && npm i
I’m running this locally and seems to work quite well. However, can I ask you to test it and report back with any issues, or a thumbs up? I’ll push this “officially” when I’m sure it works for you :)
-
@tbouron This is working great:
After
npm i
I had to do some more.I realized that
librtlsdr
is required also when using network mode, so this had to be installed first, with library headers:sudo apt install librtlsdr-dev
Next I got messages about missing symbols from
rtl-sdr.node
module:node: symbol lookup error: /home/pi/MagicMirror/modules/MMM-FlightTracker/node_modules/rtl-sdr/build/Release/rtlsdr.node: undefined symbol: _ZN2v816FunctionTemplate3NewEPNS_7IsolateEPFvRKNS_20FunctionCallbackInfoINS_5ValueEEEENS_5LocalIS4_EENSA_INS_9SignatureEEEiNS_19ConstructorBehaviorE
So it had to be rebuilt against my
librtlsdr
:npm rebuild rtl-sdr --build-from-source
Thumbs up! Thanks!
-
@ytmytm Cool, glad it works fine! I actually just realised that my last commit is not quite right regarding the connection retry if the TCP stream is closed. I’ll fix that for the merge in
master
.Regarding the dependency issue, you are right, I missed the
librtlsdr-dev
dependency in the prerequisites list, I’ll add that (FYI, this is needed only for thertlsdr
mode). And I think you had to rebuild the module because it was missing when you executednpm i
(It is certainly not something I had to do on my Pi)I’ll clean this up and push to
master
, probably tomorrow though.Finally, I’m also working on a new UI with better UX (I think), I’ll post screenshots when I can.
-
@tbouron said in MMM-FlightTracker - Real time plane tracker using ADS-B systems:
And I think you had to rebuild the module because it was missing when you executed npm i (It is certainly not something I had to do on my Pi)
That’s correct. I cleared everything and tried again. The rebuild step is not necessary because the module is actually built during
npm install
step. -
@ytmytm Thanks for confirming this. I’ll take that into account when I’ll update the
README.md