openhab-addons/bundles/org.openhab.binding.dwdunwetter/README_de.md
Kai Kreuzer 6df6783b60 added migrated 2.x add-ons
Signed-off-by: Kai Kreuzer <kai@openhab.org>
2020-09-21 03:37:19 +02:00

7.4 KiB

DwdUnwetter Binding

Binding zur Abfrage von aktuellen Unwetterwarnungen des Deutschen Wetterdienstes via DWD Geoserver

Unterstütztes Thing

Das Binding unterstützt genau ein Thing - Unwetterwarnungen. Ein Thing stellt dabei eine oder mehrere Warnungen für eine Gemeinde bereit.

Thing Konfiguration

Property Default Required Description
cellId - Yes ID der abzufragenden Zelle. Siehe cap_warncellids_csv.csv Es kann auch mittels % eine Gesamtmenge abgefragt werden, z.B. 8111% alle Gemeinden die mit 8111 anfangen
refresh 30 No Abfrageintervall in Minuten. Minimum 15 Minuten.
warningCount 1 No Anzahl der Warnungen, die als Channels bereitgestellt werden sollen
Wählt man die Cell-ID mittels des %-Operators zu groß, so kann es passieren, das gar keine Warnungen kommen.
Das ist immer Fall, wenn die zurückgelieferte XML-Datei des DWD zu groß ist, dass sie nicht intern gebuffered werden kann.
Dies ist bei ca. 300+ Warnungen der Fall.

Channels

Für jede bereitgestellte Warnung werden mehrere Channels bereitgestellt. Die Channels sind jeweils durchnummeriert, Channels die mit 1 enden sind für die erste Warnung, Channels die mit 2 enden für die zweite Warnung usw. Die vom DWD gelieferten Warnungen werden dabei nach Severity (Warnstufe) sortiert und innerhalb der Warnstufe nach Beginndatum. Dadurch ist sichergestellt, dass in den Channels für die erste Warnung (...1) immer die Warnung mit der höchsten Warnstufe steht. Werden mehr Warnungen vom DWD geliefert, als an Channels konfiguriert ist, werden dadurch die Warnungen mit der niedrigsten Warnstufe verworfen.

Channel Type Beschreibung
warningN Switch Schalter, der auf ON steht, wenn eine Warnung vorliegt, OFF sonst.
UpdatedN Trigger Channel Sendet das Event "NEW", wenn diese Warnung das erste mal gesendet wird.
severityN String Warnstufe, von niedrig nach hoch: Minor, Moderate, Severe, Extreme.
headlineN String Überschrift der Warnung, z.B. Amtliche WARNUNG vor STURMBÖEN
descriptionN String Klartext Beschreibung der Warnung.
eventN String Art der Warnung, z.B. STURMBÖEN
effectiveN DateTime Zeitpunkt, an dem die Warnung ausgegeben wurde.
onsetN DateTime Zeitpunkt, von dem an die Warnung gilt.
effectiveN DateTime Zeitpunkt, bis zu dem die Warnung gilt.
altitudeN Number:Length Höhe über dem Meerespiegel, ab dem die Warnung gilt.
ceilingN Number:Length Höhe über dem Meerespiegel, bis zu dem die Warnung gilt.
urgencyN String Zeitrahmen der Meldung, Mögliche Werte sind Future (Vorabinformation) und Immediate (Konkrete Warnung)
instructionN String Zusatztext zur Warnung (Instruktionen und Sicherheitshinweise)

Sämtliche Channels sind ReadOnly!

Der Channel warningN dient hauptsächlich dazu, um z.B. in Sitemaps dynamisch Warnungen ein- oder auszublenden, bzw. um in Regeln zu prüfen, ob überhaupt eine Warnung vorliegt. Er ist nicht geeignet um auf das Erscheinen einer Warnung zu prüfen. Denn wenn eine Warnung durch eine neue Warnung ersetzt wird, bleibt der Zustand ON, es gibt keinen Zustandswechsel. Um auf das erscheinen einer Warnung zu prüfen, sollte der Trigger-Channel updatedN genutzt werden. Der feuert immer dann, wenn eine Warnung das erste mal gesendet wird. Das heißt, der feuert auch dann, wenn eine Warnung durch eine neue Warnung ersetzt wird.

Weitere Erläuterungen der Bedeutungen finden sich in der Dokumentation des DWDs unter CAP DWD Profile 1.2

Vollständiges Beispiel

demo.things:

dwdunwetter:dwdwarnings:koeln "Warnungen Köln" [ cellId="105315000", refresh=15, warningCount=1 ]

demo.items:

Switch WarnungKoeln "Warnung vorhanden" { channel="dwdunwetter:dwdwarnings:koeln:warning1" }
String WarnungKoelnServerity "Warnstufe [%s]" { channel="dwdunwetter:dwdwarnings:koeln:severity1" }
String WarnungKoelnBeschreibung "[%s]" { channel="dwdunwetter:dwdwarnings:koeln:description1" }
String WarnungKoelnAusgabedatum "Ausgeben am [%s]" { channel="dwdunwetter:dwdwarnings:koeln:effective1" }
String WarnungKoelnGueltigAb "Warnung gültig ab [%s]" { channel="dwdunwetter:dwdwarnings:koeln:onset1" }
String WarnungKoelnGueltigBis "Warnung gültig bis [%s]" { channel="dwdunwetter:dwdwarnings:koeln:expires1" }
String WarnungKoelnTyp "Warnungstyp [%s]" { channel="dwdunwetter:dwdwarnings:koeln:event1" }
String WarnungKoelnTitel "[%s]" { channel="dwdunwetter:dwdwarnings:koeln:headline1" }
String WarnungKoelnHoeheAb "Höhe ab [%d m]" { channel="dwdunwetter:dwdwarnings:koeln:altitude1" }
String WarnungKoelnHoeheBis "Höhe bis [%d m]" { channel="dwdunwetter:dwdwarnings:koeln:ceiling1" }
String WarningCologneUrgency "[%s]" { channel="dwdunwetter:dwdwarnings:cologne:urgency1" }
String WarningCologneInstruction "Zusatzinformationen: [%s]" { channel="dwdunwetter:dwdwarnings:cologne:instruction1" }

demo.sitemap:

sitemap demo label="Main Menu"
{
    Frame {
        Text item=WarnungKoelnTitel visibility=[WarnungKoeln==ON]
        Text item=WarnungKoelnBeschreibung visibility=[WarnungKoeln==ON]
    }
}

demo.rules

rule "Neue Warnung"
when
     Channel 'dwdunwetter:dwdwarnings:koeln:updated1' triggered NEW
then
   // Neue Warnung, Informiere alle Bewohner
end