APRS API in Python.
Go to file
2023-04-16 21:04:26 -05:00
.gitignore Add .gitignore. 2023-04-06 20:46:10 -05:00
api_app.py Add basic API call to select by "from" station. 2023-04-16 21:04:26 -05:00
api_waitress.py Update waitress IP to make it work on production. 2023-04-15 16:37:31 -05:00
config.ini Add kiss stuff to config. 2023-04-16 16:45:22 -05:00
init_db.py Snapshot. 2023-04-13 20:46:28 -05:00
kiss_and_db.py At /packets, return 10 records by default and add n=x to return x packets. 2023-04-16 18:50:39 -05:00
README.md At /packets, return 10 records by default and add n=x to return x packets. 2023-04-16 18:50:39 -05:00
requirements.txt Try to get working on production. 2023-04-15 14:20:07 -05:00
schema.sql Add kiss stuff to config. 2023-04-16 16:45:22 -05:00
start-aprs_api.sh Try to get working on production. 2023-04-15 14:20:07 -05:00
tcp_kiss_send_recv.py Store frames in database, remove frames older than chosen age. 2023-04-14 22:06:48 -05:00

README

I got tired of APRS-IS websites not showing me all the paths that packets take, only the shortest path to IS. So this is a Python 3 tool that turns direwolf logs into a REST API in JSON format.

Setup

  1. Run direwolf with logging to CSV on by using -l. (-L not yet implemented).
  2. Install requirements using pip install -r requirements.txt.
  3. Set up database file with python init_db.py.
  4. Run app.py with either a Python call or a real WSGI server. You can use screen to detach the session.
    • Default URL is http://127.0.0.1:5000
    • Example waitress and screen scripts are included, see
      • api_waitress.py and
      • start-aprs_api.sh
  5. Access the API from whatever other system you want.

Endpoints:

-/packets - gives the most recent packets, sorted descending by time received. - argument n will return a specific number of packets, default 10. E.g., https://digi.w1cdn.net/aprs_api/packets?n=1 returns one packet.

Example of an object packet sent by W1CDN-1 and digipeated by K0UND-2:

{
      "id": 1,
      "addresse": null,
      "alive": null,
      "altitude": null,
      "comment": "Leave a message to say hi!",
      "course": null,
      "created": "2023-04-16 15:04:03",
      "format": "uncompressed",
      "frame": null,
      "from": "W1CDN-2",
      "gpsfixstatus": null,
      "latitude": 47.94133333333333,
      "longitude": -97.02683333333333,
      "mbits": null,
      "messagecapable": 1,
      "message_text": null,
      "mtype": null,
      "object_format": null,
      "object_name": null,
      "path": "['K0UND-2', 'WIDE2-2']",
      "phg": null,
      "phg_dir": null,
      "phg_gain": null,
      "phg_height": null,
      "phg_power": null,
      "phg_range": null,
      "posambiguity": 0,
      "raw": "W1CDN-2>APQTH1,K0UND-2,WIDE2-2:@150321h4756.48N/09701.61W-Leave a message to say hi!",
      "raw_timestamp": "150321h",
      "speed": null,
      "station_call": "W1CDN-1",
      "station_lat": 47.9415,
      "station_lon": -97.027,
      "status": null,
      "symbol": "-",
      "symbol_table": "/",
      "telemetry": null,
      "timestamp": 1681657401,
      "to": "APQTH1",
      "tEQNS": null,
      "tPARM": null,
      "tUNIT": null,
      "via": "",
      "weather": null,
      "wx_raw_timestamp": null
    }

Contributing

If you want to contribute, please get in touch with me on Mastodon at https://mastodon.radio/@W1CDN.