openhab-addons/bundles/org.openhab.binding.sensebox
Wouter Born 8672ed0208
Start license headers with `/*` instead of `/**` (#18061)
Prevents JavaDoc tooling issues because these tools check comments starting with `/**`.

Signed-off-by: Wouter Born <github@maindrain.net>
2025-01-07 22:33:03 +01:00
..
src/main Start license headers with `/*` instead of `/**` (#18061) 2025-01-07 22:33:03 +01:00
NOTICE added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
README.md [Documentation] Markdown improvements n to s (#13948) 2022-12-14 16:52:43 +01:00
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00

README.md

senseBox Binding

The senseBox binding integrates environment data from the senseBox Citizen Science Toolkit.

Prerequisites

The API server uses Letsencrypt certificates. Therefore, one needs to either import the Letsencrypt root certificates into the local keystore (see the description in the Netatmo Binding). Another way would be to simply update the JDK to at least JDK 1.8.0_111

Supported Things

This binding supports a generic "senseBox" API endpoint which is a representation of the physical box.

Discovery

This binding provides no discovery. The desired senseBox must be configured manually or via a things file.

Binding configuration

The binding has no configuration options itself, all configuration is done at 'Things' level.

Thing configuration

The senseBox thing requires the box Id (which can be obtained on the map) and an interval in seconds for the API polling. The senseBox support team wrote in an email that polling even every five minutes is still o.k., therefore the minimum is hardcoded to be 300 seconds.

Thing sensebox:box:home [ senseBoxId = "foothesmurfingbar", refreshInterval = 600 ]

Channels

In the table is shown more detailed information about each Channel type. The binding introduces the following channels:

Channel ID Channel Description Supported item type Advanced
descriptors#location Location of the box Point False
measurements#uvIntensity Intensity of Ultraviolet radiation Number:Intensity False
measurements#illuminance Illuminance Number:Illuminance False
measurements#pressure Air pressure Number:Pressure False
measurements#humidity Humidity Number:Dimensionless False
measurements#temperature Temperature Number:Temperature False
measurements#particulateMatter2dot5 Particulate Matter 2.5 µm in diameter Number:Density False
measurements#particulateMatter10 Temperature Matter 10 µm in diameter Number:Density False
lastReported#uvIntensityLastReported The timestamp when uv radiation intensity was last reported DateTime True
lastReported#illuminanceLastReported The timestamp when illuminance was last reported DateTime True
lastReported#pressureLastReported The timestamp when pressure was last reported DateTime True
lastReported#humidityLastReported The timestamp when humidity was last reported DateTime True
lastReported#temperatureLastReported The timestamp when temperature was last reported DateTime True
lastReported#particulateMatter2dot5LastReported The timestamp when particulate matter 2.5 was last reported DateTime True
lastReported#particulateMatter10LastReported The timestamp when particulate matter 10 was last reported DateTime True

Channels starting with "descriptors" are defined on the API server.

Example

The Temperature and Pressure items are defined two times, one with the native unit and one with a localized unit. This is to show an example of using Units of Measurements to display data without explicit recalculation is rules.

sensebox.things:

Thing sensebox:box:davos [ senseBoxId = "5b94a2c97c51910019097f14", refreshInterval = 900 ]

sensebox.items:

Location             Davos_Location      "Davos Location"                                       { channel = "sensebox:box:davos:descriptors#location" }

Number:Intensity     Davos_UVIntensity   "Davos UvIntensity [%.2f %unit%]"      <light>         { channel = "sensebox:box:davos:measurements#uvIntensity" }
Number:Illuminance   Davos_Illuminance   "Davos Light Level [%.2f %unit%]"      <light>         { channel = "sensebox:box:davos:measurements#illuminance" }
Number:Pressure      Davos_Pressure      "Davos Pressure [%.2f %unit%]"         <pressure>      { channel = "sensebox:box:davos:measurements#pressure" }
Number:Dimensionless Davos_Humidity      "Davos Humidity [%.2f %%]"             <humidity>      { channel = "sensebox:box:davos:measurements#humidity" }
Number:Temperature   Davos_Temperature   "Davos Temperature [%.2f %unit%]"      <temperature>   { channel = "sensebox:box:davos:measurements#temperature" }
Number:Density       Davos_PM2dot5       "Davos PM2.5 [%.2f %unit%]"                            { channel = "sensebox:box:davos:measurements#particulateMatter2dot5" }
Number:Density       Davos_PM10          "Davos PM10 [%.2f %unit%]"                             { channel = "sensebox:box:davos:measurements#particulateMatter10" }

sensebox.sitemap:

sitemap sensebox label="SenseBox Davos" {
    Text item=Davos_Temperature
    Text item=Davos_Pressure
    Text item=Davos_Humidity
    Text item=Davos_Luminance
    Text item=Davos_UVIntensity
    Text item=Davos_PM2dot5
    Text item=Davos_PM10
    Mapview item=Davos_Location height=10
}

senseBox API