3 unstable releases

0.2.1 Nov 15, 2024
0.2.0 Oct 1, 2023
0.1.0 Sep 30, 2023

#643 in Web programming

Download history 4/week @ 2024-09-20 2/week @ 2024-09-27 1/week @ 2024-10-04 115/week @ 2024-11-15 6/week @ 2024-11-22 6/week @ 2024-11-29 4/week @ 2024-12-06

131 downloads per month

MIT license

36KB
865 lines

Weather Station

Program for collecting and processing weather data.

HUGE THANKS TO WEEWX FOR DECODING THE VARIOUS MESSAGES FROM THE ACURITE DISPLAY

Install program

cargo install yngvi --features standalone

Config

Name Description Default
WS_SRC determines where to pull data from. ACURITE_DISPLAY, RTL_433, or FILE DISPLAY
WS_SRC_FILE_PATH path to file with source readings
WS_DEST INFLUXDB, INFLUXDB2, STDOUT, or INMEMORY STDOUT
WS_DEST_INFLUXDB_URL influxdb url http://localhost:8086
WS_DEST_INFLUXDB_DB influxdb database weather
WS_DEST_INFLUXDB2_URL influxdb url
WS_DEST_INFLUXDB2_ORG influxdb org
WS_DEST_INFLUXDB2_BUCKET influxdb bucket
WS_DEST_INFLUXDB2_TOKEN auth token for influxdb

Create your own

Any data source can be defined as Iterator<Item = WeatherReading> and all destinations are defined with the Writer trait. WS comes with some prebuilt readers and writers but it should be straight forward to define new data sources and new destination without touching any of the core station logic. Give it a try!

cargo add yngvi
use yngvi::core::{Station, StdoutWriter, FileReader};

#[tokio::main]
async fn main() {
    // create a new weather station
    let mut station = Station::new();

    // define where your source data will come from
    let reader = FileReader::new("data/source.txt");

    // define where your calculated data will be written to
    let mut writer = StdoutWriter::new();

    // start your station!
    station.start(reader, writer).await
}

Dependencies

~2–13MB
~158K SLoC