Skip to content

Code added to get weewx to talk to direwolf APRS client using kiss

Notifications You must be signed in to change notification settings

adamgriffiths77/weewx_direwolf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 

Repository files navigation

weewx_direwolf

Code added to get weewx to talk to direwolf APRS client using kiss to send weather reports via APRS using RF as the interface

This directory contains the files used on my raspberry pi (ws-2) for APRS weatherstations.

Hardware/Software Configuration

  • Raspberry pi 4
  • RTL-SDR dongle to pull weatherstations via the use of RTL_433 decoder
  • weewx weatherstation software (starts rtl_433 and is filtered for my external WS-1080 weatherstation)
  • WS-1080 based weatherstation (cheap but works) https://www.jaycar.com.au/mini-lcd-display-weather-station/p/XC0400
  • direwolf software TNC configured to automatically start via a cronjob refering the dw-start.sh script
  • cheap USB audio dongle with custom cable to my radio
  • Wouxun KG-UV6D 2m/70cm handheld radio, running off a battery eliminator, with squelch turned off to assist with receiving other APRS messages.
  • direwolf uses a Wouxon 2m Amateur handheld radio as the RF interfaace, using a usb audio dongle and a relay connected to GPIO to trigger the PTT.
  • Diamond X30N 2m/70cm antenna mounted at the ridge line of my house.
  • 12V to USB 3A converter to power the pi
  • a RAMP-25 Military grade 20/40W (20V off 12v) 30-512Mhz RF Amplifier
  • 3 Relay Raspberry PI hat (https://core-electronics.com.au/3-channel-relay-module-shield-smart-home-for-raspberry-pi-3.html)
  • All of this is now mounted in a nice small Pelican Hardcase with two antenna ports (one for recieving 433Mhz data and one for transmitting the APRS messages) and a military grade power connector connected to a 12V power supply.

Weatherstation Operation

  1. Weather station data is received using the RTL-SDR dongle using the rtl_433 application, and is configured to filter for my weather station id (433Mhz ISM band is used for a large number of devices) and export the data in JSON format.
  2. weewx is configured to obtain data for the WS-1080 weather station using the RTLSDR option and consumes the JSON output of above. This is a lot cleaner and more reliable that using the indoor weather station received, which has an un-reliable USB implementation that usually hangs a couple of times a week.
  3. weex outputs the weather data in APRS format to a text file every 30 mins. This is a modified version of the APRS client, using learning from the CWOP and YAAC code
  4. KissTNC is configured to watch the output directory of the text file and converts any file in that directory to a properly formatted TNC data string and passes it on to direwolf TNC
  5. Direwolf transmits the APRS message via the 2M hand-held radio
  6. APRS message received by any iGate within radio range.
  7. As Direwolf is also configured as an (receive only) iGate, it also uploads this message, and any other received radio APRS messages to aprs.fi

Output can be seen on the aprs.fi website for my callsign https://aprs.fi/info/a/VK3AGD-9 (weatherstation) https://aprs.fi/info/a/VK3AGD-5 (iGate)

modifications from out-of-the-box weewx and direwolf

direwolf

  • direwolf: the only modification is the cron script to add starting kisstnc.
  • direwolf is started with the following cron "* * * * * /root/dw-start.sh >/dev/null 2>&1"
  • using the file in the direwolf directory (currently runs at root, although this is a bad idea
  • others can read the file and figure out where callsign data and PTT GPIO are used and how to wire up a radio so I'm not going to describe that part here (unless I have to rebuild the whole thing and figure out out again...I haven't done the physical part for good 10 years).
  • direwolf is also configured as an iGate and sending data to aprs.fi. Using the code generated from my callsign at http://apps.magicbug.co.uk/passcode/

KissUtil

  • configured to start automatically via the dw-start.sh script
  • is configured to read the /root/send directory for messages to send out
  • is configured to write to the /root/recieve directory for messages decoded by direwolf.

weewx

This directory contains the files that are modified for Weewx to correctly obtain data from the weatherstation using RTL_433 and also export the data into the listed text files.

Weewx.conf

  • see the section of the configuration file under SDR for the RTL_433 configuration and mapping of sensors. note the sensor name (22). I found that I could pick up quite a few devices transmitting data via 433Mhz so sometimes you'll need to run RTL_433 seperately to identify the specific weatherstation that you need data from. NOTE: this doesn't seem the change once the weatherstation is turned on but I do check this every time I change the batteries just to make sure
  • see the section at the bottom of the configuration file for the APRS configuration which specifies the output directory and comments which is appended to the APRS packet for station description (helps people if they need to contact me if my station is doing something weird)

/user/aprs.py

This is a modified version of the aprs driver that is provided with weewx. The included driver assumes that the APRS message is being sent to a full external TNC (which provides the callsign and path data) hence this driver is modified to including the callsign, destination and path info. It is also modified (at the bottom) to output the completed APRS packet to the output file specified in weewx.conf rather than a serial port. This is the file which is then picked up by direwolf to transmit the packet. NOTE: I have noticed that there's a couple of hardcoded variables (ie callsign and path), which I should move to a variable when I get a chance. 5 min job but not important give it works pretty much perfectly.

Next Steps/improvements

  1. figure out why the Pi sometimes complains of low power. I think my relay setup is pulling too much off the 5V rail...
  2. Fix the hardcoded variables in Weewx and move them to configurable options.

About

Code added to get weewx to talk to direwolf APRS client using kiss

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published