openhab-addons/bundles/org.openhab.binding.openuv
J-N-K 31a20dc249
Apply spotless and fix itests (#10000)
* apply spotless
* fix itests

Signed-off-by: Jan N. Klug <jan.n.klug@rub.de>
2021-01-31 20:31:41 +01:00
..
src/main Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo 2020-09-20 23:52:13 +02:00
.classpath Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo 2020-09-20 23:52:13 +02:00
.project Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo 2020-09-20 23:52:13 +02:00
NOTICE Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo 2020-09-20 23:52:13 +02:00
pom.xml Apply spotless and fix itests (#10000) 2021-01-31 20:31:41 +01:00
README.md Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo 2020-09-20 23:52:13 +02:00

OpenUV Binding

This binding uses the OpenUV Index API service for providing UV Index information for any location worldwide.

To use this binding, you first need to register and get your API token.

Binding Installation

This binding can be installed via the Add-ons section of the Paper UI.

Go to Bindings and search for OpenUV. Click on install.

Discovery

Once a bridge with the api Key has been created, Local UV Index informations can be autodiscovered based on system location.

Binding Configuration

The binding has no configuration options, all configuration is done at Bridge and Thing level.

Bridge Configuration

The bridge has only one configuration parameter :

Parameter Description
apikey Data-platform token to access the OpenUV service. Mandatory.

Will accept a Refresh command in order to reinitiate connexion (eg in case of Quota exceeded).

Thing Configuration

The thing has a few configuration parameters :

Parameter Description
location Geo coordinates to be considered by the service.
refresh Refresh interval in minutes. Optional.

For the location parameter, the following syntax is allowed (comma separated latitude, longitude and optional altitude):

37.8,-122.4
37.8255,-122.456
37.8,-122.4,177

Channels

The OpenUV Report thing that is retrieved has these channels:

Channel ID Item Type Description
UVIndex Number UV Index
UVColor Color Color associated to given UV Index.
UVMax Number Max UV Index for the day (at solar noon)
UVMaxTime DateTime Max UV Index datetime (solar noon)
Ozone Number:ArealDensity Ozone level in du (Dobson Units) from OMI data
OzoneTime DateTime Latest OMI ozone update datetime
UVTime DateTime UV Index datetime
SafeExposure Number:Time Safe exposure time for Fitzpatrick Skin Types.
elevation Number:Angle Current Sun elevation.

The elevation channel will be used as an input in order to limit API queries to OpenUV. If not used, the binding will not consider it. When value is provided queries will only be issued if the elevation is > 0°.

Examples

demo.things:

Bridge openuv:openuvapi:local "OpenUV Api" [ apikey="xxxxYYYxxxx" ] {
    Thing uvreport city1 "UV In My City" [ location="52.5200066,13.4049540", refresh=10 ]{
        Channels:
            Type SafeExposure : Parents [       
                index=3
            ]
            Type SafeExposure : Childs [
                index=2
            ]
    }
}

demo.items:

Number              UVIndex   "UV Index"  {channel="openuv:uvreport:local:city1:UVIndex" }
Number              UVMax     "UV Max"    {channel="openuv:uvreport:local:city1:UVMaxEvent" }
Number:ArealDensity Ozone     "Ozone"     {channel="openuv:uvreport:local:city1:Ozone" }

astro.items:


Number:Angle        Elevation "Elevation" {channel="astro:sun:home:position#elevation",
                                           channel="openuv:uvreport:local:city1:elevation" [profile="follow"] }