* [airgradient] Initial contribution AirGradient are open source and open hardware air quality sensors that you can read values from through a cloud API or directly from the device. Signed-off-by: Jørgen Austvik <jaustvik@acm.org>
6.2 KiB
AirGradient Binding
AirGradient provides open source and open hardware air quality monitors.
This binding reads air quality data from the AirGradient (https://www.airgradient.com/) API.
This API is documented at https://api.airgradient.com/public/docs/api/v1/
Supported Things
This binding supports all the different AirGradient sensors, providing most of the sensor data.
bridge
: Connection to the APIlocation
: Location in the API to read values for
Discovery
Autodiscovery of locations is implemented. Start by adding an AirGradient API thing. When that is added and online, run a scan for new things in the AirGradient binding.
Thing Configuration
This binding supports reading data both directly from AirGradient sensors and from the AirGradient API. If you don't specify any path on the server, the binding will behave as if the hostname is the hostname of the AirGradient API server, and append paths and tokens for it.
The binding will adapt to the content type of the returned content to support different formats for getting data both from local and cloud installations.
Name | Hostname | Content-Type | Parser |
---|---|---|---|
API | Hostnames without any path (e.g., https://api.airgradient.com/) | application/json | JSON parser for the AirGradient API, correct paths will be appended to the calls |
Local OpenMetrics | Hostnames with path (e.g., http://192.168.x.x/metrics) | application/openmetrics-text | OpenMetrics parser |
Local Web | Hostnames with path (e.g., http://192.168.x.x/measures/current) | application/json | JSON parser for the AirGradient API, as if you returned the value of sendToServer() payload |
Local Prometheus | Hostnames with path (e.g., http://192.168.x.x/measures) | text/plain | Prometheus parser for Prometheus format |
AirGradient API
The connection to the API needs setup and configuration
- Log in to the AirGradient Dashboard: https://app.airgradient.com/dashboard
- Navigate to Place->Connectivity Settings from the upper left hamburger menu.
- Enable API access, and take a copy of the Token, which will be used in the token setting to configure the connection to the API.
To add a location, you need to know the location ID. To get the location ID, you
- Log in to the AirGradient Dashboard: https://app.airgradient.com/dashboard
- Navigate to Locations from the upper left hamburger menu.
- Here you will find a list of all of your sensors, with a location ID in the left column. Use that id when you add new Location things.
API
Thing Configuration
Name | Type | Description | Default | Required | Advanced |
---|---|---|---|---|---|
token | text | Token to access the device | N/A | yes | no |
hostname | text | Hostname or IP address of the API | https://api.airgradient.com/ | no | yes |
refreshInterval | integer | Interval the device is polled in sec. | 600 | no | yes |
Location
Thing Configuration
Name | Type | Description | Default | Required | Advanced |
---|---|---|---|---|---|
location | text | A number identifying the location id in the AirGradient Dashboard | N/A | yes | no |
Channels
For more information about the data in the channels, please refer to the models in https://api.airgradient.com/public/docs/api/v1/
Channel | Type | Read/Write | Description |
---|---|---|---|
pm01 | Number:Density | Read | Particulate Matter 1 (0.001mm) |
pm02 | Number:Density | Read | Particulate Matter 2 (0.002mm) |
pm10 | Number:Density | Read | Particulate Matter 10 (0.01mm) |
pm003-count | Switch | Read | The number of particles with a diameter beyond 0.3 microns in 1 deciliter of air |
rco2 | Number:Density | Read | Carbon dioxide PPM |
tvoc | Number:Density | Read | Total Volatile Organic Compounds |
atmp | Number:Temperature | Read | Ambient Temperature |
rhum | Number:Dimensionless | Read | Relative Humidity Percentage |
wifi | Number | Read | Received signal strength indicator |
boot | Number:Dimensionless | Read | Number of measure uploads since last reboot (boot) |
Full Example
Thing Configuration
Bridge airgradient:airgradient-api:home "My Home" [ token="abc123...." ] {
Thing location "654321" "Outside" [ location="654321" ]
}
Item Configuration
Number:Density AirGradient_Location_PM2 "%.0f kg/m³" <density> {channel="airgradient:location:654321:pm2"}"
Number:Temperature AirGradient_Location_PM2 "Temperature [%.1f °C]" <temperature> {channel="airgradient:location:654321:atmp"}"