Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bolausson/SensorPush
Use the SensorPush API to save temperature, humidity, dewpoint, barometric pressure, altitude and VPD data to a local InfluxDB database
https://github.com/bolausson/SensorPush
g1-wifi-gateway humidity influxdb sensorpush temperature
Last synced: 3 months ago
JSON representation
Use the SensorPush API to save temperature, humidity, dewpoint, barometric pressure, altitude and VPD data to a local InfluxDB database
- Host: GitHub
- URL: https://github.com/bolausson/SensorPush
- Owner: bolausson
- License: gpl-3.0
- Created: 2019-08-10T18:00:43.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-02-11T09:51:01.000Z (11 months ago)
- Last Synced: 2024-02-14T21:38:23.125Z (11 months ago)
- Topics: g1-wifi-gateway, humidity, influxdb, sensorpush, temperature
- Language: Python
- Homepage:
- Size: 6.41 MB
- Stars: 15
- Watchers: 3
- Forks: 9
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SensorPush
[SensorPush](http://www.sensorpush.com/) recently introduced a [API](http://www.sensorpush.com/api/docs) to query the temperature and humidity samples recorded by their smart sensors via G1 WIFI GATEWAY - As long as the API is in beta stage, you have to contact support to get access!This Python 3 tool can query the API and save the temperature and humidity time series to InfluxDB so it can easily be plotted with Grafana.
If you don't have an G1 WIFI Gateway and still want to plot your temperature, you can us another little tool I wrote to feed the CSV file which you can export via the Android App to InfluxDB.
![Grafana](https://github.com/bolausson/SensorPush/blob/master/SensorPush-Grafana-InfluxDB.png?raw=true)
## API query
```
# sensorpush.py --help
usage: sensorpush.py [-h] [-s STARTTIME] [-p STOPTIME] [-b BACKLOG]
[-t TIMESTEP] [-q QLIMIT] [-d DELAY] [-l] [-g]
[-i SENSORLIST [SENSORLIST ...]] [-n] [-x]Queries SensorPus API and stores the temp and humidity readings in InfluxDB
optional arguments:
-h, --help show this help message and exit
-s STARTTIME, --start STARTTIME
start query at time (e.g. "2019-07-25T00:10:41+0200")
-p STOPTIME, --stop STOPTIME
Stop query at time (e.g. "2019-07-26T00:10:41+0200")
-b BACKLOG, --backlog BACKLOG
Historical data to fetch (default 1 day) - time can be
specified in the format [m|h|d|w|M|Y]. E.g.:
10 Minutes = 10m, 1 day = 1d, 1 month = 1M
-t TIMESTEP, --timestep TIMESTEP
Time slice per query (in minutes) to fetch (default
720 minutes [12 h])
-q QLIMIT, --querylimit QLIMIT
Number of samples to return per sensor (default unset
= API default limimt [10])
-d DELAY, --delay DELAY
Delay in seconds between queries
-l, --listsensors Show a list of sensors and exit
-g, --listgateways Show a list of gateways and exit
-i SENSORLIST [SENSORLIST ...], --sensorlist SENSORLIST [SENSORLIST ...]
List of sensor IDs to query
-n, --noconvert Do not convert °F to °C, inHG to mBar, kPa to mBar and feet
to meters
-x, --dryrun Do not write anything to the database, just print what
would have been written
```## CSV import
```
# sensorpush_csv-import.py --help
usage: sensorpush_csv-import.py [-h] [-f CSVFILE] [-s SENSORNAME]
[-i SENSORID] [-d] [-c CHUNKS]Reads a CSV file exported from the SensorPush Android App and stores the temp
and humidity readings in InfluxDBoptional arguments:
-h, --help show this help message and exit
-f CSVFILE, --csvfile CSVFILE
CSV file exported from the SensorPush Android App
-s SENSORNAME, --sensorname SENSORNAME
Sensor name
-i SENSORID, --sensorid SENSORID
Sensor id
-d, --dryrun Do not write anything to InfluxDB - just print what
would have been written
-c CHUNKS, --chunks CHUNKS
Write data in chunks to InfluxDB to not overload e.g.
a RaspberryPi
```