Wetterdaten in openHAB integrieren

Für weitere Regeln und Automatisierungen wollte ich die aktuellen Wetterdaten in openHAB integrieren. Im ersten Schritt wollte ich das ohne eigene Wetterstation umsetzen und die externen Daten etwas aggregieren und testen welche Daten ich überhaupt benötige.

Alle Artikel die ich gefunden habe, referenzieren aktuell auf das WeatherUnderground Binding. Leider gibt es dafür keine kostenlosen API-Keys zur privaten Nutzung mehr. Als Alternative habe ich jetzt das Weather1 Binding mit Daten von OpenWetherMap verwendet.

Die Grundlagen für den Artikel habe ich bei Wenzlaff.de gefunden.

Installation

Die Installation wird wie gewohnt in openHAB in der Paper UI durchgeführt:

openHAB – Paper UI – Add-ons – Bindings – Weather Binding – INSTALL

Bitte achtet darauf, dass die Legacy-Bindings für ein Version 1 Binding in den Einstellungen aktiviert sind.

OpenWeatherMap

Für die Verwendung von externen Wetterdaten benötigt man bei OpenWeatherMap einen API-Key. Der Account wird hier erstellt und danach per E-Mail verschickt.

Services

Die Anpassung der Services wird in der Datei services/weather.cfg vorgenommen.

apikey.OpenWeatherMap=xxx

# Location – Altomünster – OpenWeatherMap

weather:location.Altomuenster-OWM.latitude=48.3859

weather:location.Altomuenster-OWM.longitude=11.2535

weather:location.Altomuenster-OWM.provider=OpenWeatherMap

weather:location.Altomuenster-OWM.language=de

weather:location.Altomuenster-OWM.updateInterval=30

Der apiKey muss durch den vorher generierten Schlüssel ersetzt werden. Die location kann an die eigenen Bedürfnisse angepasst werden. Den Aktualisierungsintervall habe ich auf 30 Minuten gesetzt.

Um die GPS-Koordinaten (latitude, longitude) für Altomünster herauszufinden, habe ich den Service von gpskoordniaten.de genutzt.

Items

Als erste Test-Items kann man den Satz an Daten verwenden:

// OpenWeatherMap Daten
Number   owmHumidity                              "Feuchte [%d %%]"                                                        {weather="locationId=Altomuenster-OWM, type=atmosphere, property=humidity"}
Number   owmTemperature                           "Temperatur [%.2f °C]"                                                   {weather="locationId=Altomuenster-OWM, type=temperature, property=current"}
Number   owmPressure                            "Luftdruck [%.2f hPa]"                                                   {weather="locationId=Altomuenster-OWM, type=atmosphere, property=pressure"}
String   owmPressureTrend                    "Luftdruck Trend [%s]"                                                   {weather="locationId=Altomuenster-OWM, type=atmosphere, property=pressureTrend"}
Number   owmWindSpeed               "Windgeschwindigkeit [%.2f km/h]"                            {weather="locationId=Altomuenster-OWM, type=wind, property=speed"}
String   owmWindDirection           "Windrichtung [%s]"                                                      {weather="locationId=Altomuenster-OWM, type=wind, property=direction"}
Number   owmWindDegree                            "Windrichtung in Grad [%.0f °]"                                   {weather="locationId=Altomuenster-OWM, type=wind, property=degree"}
Number   owmClouds                                   "Bewölkung [%.0f %%]"                                                          {weather="locationId=Altomuenster-OWM, type=clouds, property=percent"}
Number   owmRain                                  "Regen der letzten 3 Stunden [%.2f mm/h]"           {weather="locationId=Altomuenster-OWM, type=precipitation, property=rain"}
Number   owmSnow                                  "Schnee der letzten 3 Stunden [%.2f mm/h]"      {weather="locationId=Altomuenster-OWM, type=precipitation, property=snow"}

// Forecast +1 ist der nächste Tag
// ACHTUNG: Funktioniert aktuell nicht mit OpenWeatherMap, 25.08.2018
Number   ownForecastTempMin         "Temperatur min. [%.2f °C]"                      {weather="locationId=Altomuenster-OWM, forecast=1, type=temperature, property=min"}
Number   ownForecastTempMax         "Temperatur max. [%.2f °C]"                      {weather="locationId=Altomuenster-OWM, forecast=1, type=temperature, property=max"}

Sitemap

Danach habe ich die Sitemap zur Visualisierung an meine Anforderungen angepasst:

Text label="Wetter" icon="temperature" {
Frame label="Altomünster (Open Weather Map)" {           
Frame label="Heutiger Tag" {           
Text item=owmTemperature icon="selfTemperature"
Text item=owmHumidity icon="selfWater"
Text item=owmPressure
Text item=owmPressureTrend
Text item=owmWindSpeed icon="wind"
Text item=owmWindDirection icon="wind"
Text item=owmWindDegree icon="wind"
Text item=owmClouds
Text item=owmRain icon="rain"
Text item=owmSnow
}

Frame label="Morgiger Tag" {           
Text item=ownForecastTempMin
Text item=ownForecastTempMax
}
}        
}

Fazit

Mit dem Weather1 Binding sind schnell und unkompliziert „grobe“ Wetterdaten in openHAB integriert.

Was ich leider erst im Nachgang gesehen habe ist das von OpenWeatherMap mit den kostenlosen Accounts momentan nur aktuelle Tagesdaten und keine Wettervorschau für die nächsten Tage verwendet werden kann (obwohl das in der Dokumentation anders beschrieben steht).  Das Problem wird in diesem Ticket im Detail beschrieben.

Wie habt Ihr eure Wetterdaten zur Hausautomatisierung verwendet? Soll ich doch besser gleich auf eine „richtige“ Wetterstation für die Daten umsteigen?

Anbindung Amazon Alexa an openHAB

Nachdem Update auf openHAB 2.3 steht mir nun auch das Amazon Echo Control Binding zur Verfügung. Bis jetzt konnte ich unsere Echo-Geräte (also „Alexa“) nur zur Steuerung der Hausautomatisierung per Sprachbefehlen verwenden. Mit dem neuen Binding ist es jetzt auch möglich die Echo-Geräte direkt in openHAB zu integrieren und damit eine Steuerung zu ermöglichen.

Es ist zum Beispiel damit möglich beim Betätigen eines KNX-Lichtschalters einen bestimmten Sender / Playlist auf allen Echo-Geräten abzuspielen. Auch können die Echo-Geräte für die Ausgabe von bestimmten Befehlen der Hausautomatisierung benutzt werden. Mir fallen da so einige Einsatzgebiete für die Zukunft ein 🙂

Aber im ersten Schritt muss erst einmal alles in openHAB eingebunden werden

Installation

Als erstes muss das Binding unter „Paper UI – Add-ons – Bindings – Amazon Echo Control Binding“ installiert werden.

Die ersten Schritte zu Konfiguration werden hier beschrieben.

Beispiel

Das komplette Beispiel auf der openHAB-Seite findet Ihr hier. Ich habe einige Anpassungen vorgenommen, aber der Ablauf sollte auch an meiner Konfiguration erkennbar sein.

Things

Nach der Installation muss ein Thing für den Amazon Account und die zugehörigen Geräte erstellt werden.

In meiner Konfiguration sieht das wie folgt aus (2 Echo’s, 1 Echo Dot, eine Multi-Room-Gruppe und zwei Flash Briefings):

Bridge amazonechocontrol:account:account1 "Amazon Account" @ "Alexa" [amazonSite="amazon.de", email="xxx", password="xxx", pollingIntervalInSeconds=60]
{
    // Echo Geräte
    Thing echo                 echodot1            "Alexa (Kinderzimmer)" @ "Alexa" [serialNumber="xxx"]
    Thing echo                 echo1               "Alexa (Wohnbereich)" @ "Alexa" [serialNumber="xxx"]
    Thing echo                 echo2               "Alexa (Büro)" @ "Alexa" [serialNumber="xxx"]

    // Musikgruppen
    Thing wha                  wha1                "Multi-Room: Erdgeschoss" @ "Alexa" [serialNumber="xxx"] 

    // Flash Briefings
    Thing flashbriefingprofile flashbriefing1      "Flash Briefing Technical" @ "Alexa"
    Thing flashbriefingprofile flashbriefing2      "Flash Briefing Life Style" @ "Alexa"
}

Beim Account muss noch email und password entsprechend angepasst werden. In den Geräten muss man die serialNumber an seine entsprechenden Devices anpassen.

Danach ist der Account in openHAB über http://IP:PORT/amazonechocontrol/account1 erreichbar. Von dort können auch alle notwendigen Seriennummern ausgelesen werden.

Items

Eine Konfiguration der Items sieht wie folgt aus (hier ist ein Echo konfiguriert):

Group Alexa_Living_Room <player>

// Player control
Player Echo_Living_Room_Player                "Player"                                (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:player"}
Dimmer Echo_Living_Room_Volume                "Volume [%.0f %%]" <soundvolume>        (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:volume"}
Switch Echo_Living_Room_Shuffle               "Shuffle"                               (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:shuffle"}

// Player Information
String Echo_Living_Room_ImageUrl              "Image URL"                             (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:imageUrl"}
String Echo_Living_Room_Title                 "Title"                                 (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:title"}
String Echo_Living_Room_Subtitle1             "Subtitle 1"                            (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:subtitle1"}
String Echo_Living_Room_Subtitle2             "Subtitle 2"                            (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:subtitle2"}
String Echo_Living_Room_ProviderDisplayName   "Provider"                              (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:providerDisplayName"}

// Music provider and start command
String Echo_Living_Room_MusicProviderId       "Music Provider Id"                     (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:musicProviderId"}
String Echo_Living_Room_PlayMusicCommand      "Play music voice command (Write Only)" (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:playMusicVoiceCommand"}
String Echo_Living_Room_StartCommand          "Start Information"                     (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:startCommand"}

// TuneIn Radio
String Echo_Living_Room_RadioStationId        "TuneIn Radio Station Id"               (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:radioStationId"}
Switch Echo_Living_Room_Radio                 "TuneIn Radio"                          (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:radio"}

// Amazon Music
String Echo_Living_Room_AmazonMusicTrackId    "Amazon Music Track Id"                 (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:amazonMusicTrackId"}
String Echo_Living_Room_AmazonMusicPlayListId "Amazon Music Playlist Id"              (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:amazonMusicPlayListId"}
Switch Echo_Living_Room_AmazonMusic           "Amazon Music"                          (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:amazonMusic"}

// Bluetooth
String Echo_Living_Room_BluetoothMAC          "Bluetooth MAC Address" <bluetooth>     (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:bluetoothMAC"}
Switch Echo_Living_Room_Bluetooth             "Bluetooth"             <bluetooth>     (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:bluetooth"}
String Echo_Living_Room_BluetoothDeviceName   "Bluetooth Device"      <bluetooth>     (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:bluetoothDeviceName"}

// Commands
String Echo_Living_Room_TTS                   "Text to Speech"                        (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:textToSpeech"}
String Echo_Living_Room_Remind                "Remind"                                (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:remind"}
String Echo_Living_Room_PlayAlarmSound        "Play Alarm Sound"                      (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:playAlarmSound"}
String Echo_Living_Room_StartRoutine          "Start Routine"                         (Alexa_Living_Room) {channel="amazonechocontrol:echo:account1:echo1:startRoutine"}

Sitemap

In der Visualisierung habe ich dann ein Gerät wie folgt integriert (damit kann man dann sehr viel schon einmal in der Basic UI darstellen):

Text label="Wohnbereich" icon="recorder" {
Frame label="Wohnbereich" icon="recorder" {
Default   item=Echo_Living_Room_Player
Slider    item=Echo_Living_Room_Volume
Switch    item=Echo_Living_Room_Shuffle
Image     item=Echo_Living_Room_ImageUrl      label=""
Text      item=Echo_Living_Room_Title
Text      item=Echo_Living_Room_Subtitle1
Text      item=Echo_Living_Room_Subtitle2
Text      item=Echo_Living_Room_ProviderDisplayName

// The listed providers are only samples, you could have more
Selection item=Echo_Living_Room_MusicProviderId mappings=[ 'TUNEIN'='Radio', 'SPOTIFY'='Spotify', 'AMAZON_MUSIC'='Amazon Music', 'CLOUDPLAYER'='Amazon']
Text    item=Echo_Living_Room_MusicProviderId

// To start one of your flashbriefings use Flashbriefing.<YOUR FLASHBRIEFING THING ID>
Selection item=Echo_Living_Room_StartCommand mappings=[ 'Weather'='Weather', 'Traffic'='Traffic', 'GoodMorning'='Good Morning', 'SingASong'='Song', 'TellStory'='Story', 'FlashBriefing'='Flash Briefing', 'FlashBriefing.flashbriefing1'='Technical', 'FlashBriefing.flashbriefing2'='Life Style' ]

Selection item=Echo_Living_Room_RadioStationId mappings=[ ''='Off', 's97458'='TOP FM', 's25217'='ROCK ANTENNE' ]
Text    item=Echo_Living_Room_RadioStationId
Switch  item=Echo_Living_Room_Radio

Text    item=Echo_Living_Room_AmazonMusicTrackId
Text    item=Echo_Living_Room_AmazonMusicPlayListId
Switch  item=Echo_Living_Room_AmazonMusic

Text    item=Echo_Living_Room_BluetoothMAC
// Change the <YOUR_DEVICE_MAC> Place holder with the MAC address shown, if alexa is connected to the device
Selection item=Echo_Living_Room_BluetoothMAC mappings=[ ''='Disconnected', '<YOUR_DEVICE_MAC>'='Bluetooth Device 1', '<YOUR_DEVICE_MAC>'='Bluetooth Device 2']

// These are only view of the possible options. Enable ShowIDsInGUI in the binding configuration and look in drop-down-box of this channel in the Paper UI Control section
Selection item=Echo_Living_Room_PlayAlarmSound mappings=[ ''='None', 'ECHO:system_alerts_soothing_01'='Adrift', 'ECHO:system_alerts_atonal_02'='Clangy']

Switch  item=Echo_Living_Room_Bluetooth
Text    item=Echo_Living_Room_BluetoothDeviceName
     }
}

Rules

Eine mögliche Regel für die Automatisierung habe ich wie folgt umgesetzt (damit kann sobald der Lichtschalter im Büro betätigt wird per TTS eine Sprachausgabe erfolgen und auf einen Amazon Music Sender geschalten werden):

rule "ALEXA_TEST"
when
Item Licht_EG_Buero received update ON
then

Echo_Living_Room_TTS.sendCommand('Hello World')

Echo_Living_MusicProviderId.sendCommand('AMAZON_MUSIC')
Echo_Living_PlayMusicCommand.sendCommand('Heavy Metal')
end

Fazit

Im Großen und Ganzen war die Umsetzung für die Integration in openHAB aller Amazon-Devices bei mir recht schnell erledigt. Jetzt kommt dann die Anpassung an die Szenarien (was erfahrungsgemäß mehr Spaß macht).

Folgende Punkte haben mich etwas Zeit gekostet (hier könntet Ihr etwas aufpassen):

  • die ID’s der Sender in TuneIn findet man am einfachsten über die URL auf der Seite https://tunein.com heraus
  • Sender / Playlists in Amazon Music konnte ich bis jetzt nicht in Paper UI einbinden, sondern nur über Regeln selektieren (hier habe ich noch keine weitere Idee)
  • Wenn Ihr mehrere Geräte in „Gruppen“ zusammengefasst habt, müsst Ihr diese wha-Gruppe in den Things und im Channel der Items entsprechend anpassen (die Anpassung in den Channels habe ich übersehen)

Habt Ihr das neue Amazon Echo Control bei euch auch schon verwendet? Welche Szenarien bildet Ihr damit ab?

Visual Studio als Code-Editor für openHAB

Mit dem Update 2.2.0 von openHAB ist es jetzt auch möglich Visual Studio anstatt dem Eclipse SmartHome Designer zu verwenden.

Es muss mindestens openHAB 2.2.0 (Build #1065) verwendet werden, da mit dieser Version erst das Language Server Protocol (LSP) implementiert wurde. Aus meiner Sicht der wichtigste Vorteil ist jetzt ein besserer Syntax-Check des generierten Codes.

Bei onesmarthome.de habe ich dazu eine gute Einführung gefunden.

Installation und Basis-Konfiguration

  • Installation von Microsoft direkt starten (64 Bit User Installer verwendet)
  • Die Installation wird mit den Standard-Parametern durchgeführt
  • Visual Studio Code wird gestartet
  • Danach kann man direkt im Willkommens-Bildschirm noch das Deutsche Sprachpaket aktivieren
  • Nun wird die openHAB Extension installiert:
    • Extensions – openHAB eingeben und mit Install bestätigen
  • VS neu starten
  • Über „Open Folder“ wird der Pfad zum conf-Verzeichnis angegeben
  • IP-Adresse des openHAB-Rechners anpassen:
    • Zahnrad – Einstellungen – openHAB Configuration – openhab.host anpassen (wenn Ihr eine andere IP / Namen habt)

Fazit

Nun könnt Ihr anstatt dem Eclipse SmartHome Designer auch Visual Studio Code für die Anpassungen in openHAB verwenden. Momentan habe ich keine größeren „Customizings“ – ich werde dann im Laufe der Zeit dazu etwas schreiben.

Anpassungen nach Aktualisierung auf openHAB 2.3

Nachdem der erste Funktionscheck nach dem openHAB 2.3 Update durchgeführt wurde, musste noch alle Änderungen in den jeweiligen Release Notes (2.1.0, 2.2.0, 2.3.0) kontrolliert werden.

Folgende Anpassungen wurden vorgenommen:

  • In der PaperUI under Add-ons / Bindings das KNX Binding 2.x deinstallieren (ich nutze das KNX 1.x weiter, bis ich etwas Zeit für die Migration finde – beide dürfen nicht parallel installiert sein)
  • Aus dem Update 2.1.0 müssen die Group-Items von „Group MyLights“ auf „Group:Switch MyLights“ angepasst werden
  • Außerdem muss beim Update 2.1.0 das „Astro Binding“ ggf. angepasst werden (altitude wandert jetzt als Parameter in die geolocation)
  • Sprachsteuerung per Alexa war nicht funktionsfähig (im Update 2.2.0 müssen die Geräte gelöscht und neu in der Alexa-App gesucht werden)
  • Außerdem mußten beim Update 2.2.0 die Regeln und das Inbox auto-approval kontrolliert werden
  • Im Update 2.3.0 war nur eine Aktualisierung der Charts und des AVM Fritz Bindings für Powerline notwendig (diese beiden Komponenten habe ich nicht verwendet)

Nach den Anpassungen und weiteren Funktionstests läuft die Installation wieder „rund“ und es kann nun mit der Einrichtung der neuen Funktionen begonnen werden.

Aktualisierung openHAB 2.0 auf 2.3

Die Datensicherung vor der Aktualisierung unserer Haussteuerung openHAB habe ich im vorherigen Artikel schon einmal kurz beschrieben. Eine Aktualisierung von Version 2.0 auf 2.3 sollte eigentlich ganz einfach sein (leider hat in meinem Fall die Ausnahme wieder die Regel bestätigt).

Versionshistorie

Ablauf Update

Diese Aktualisierung sollte direkt von Version 2.0 auf 2.3 aktualisieren:

  • wget -qO – ‚https://bintray.com/user/downloadSubjectPublicKey?username=openhab‘ | sudo apt-key add –
  • sudo apt-get install apt-transport-https
  • sudo vi /etc/apt/sources.list.d/openhab2.list | echo ‚deb https://dl.bintray.com/openhab/apt-repo2 stable main‘
  • sudo apt-get update
  • sudo apt-get upgrade

Leider war nach dem Update (das lief ca. 30 Minuten) die Software noch auf dem Stand 2.0.

Nach ein paar Recherchen habe ich gesehen, dass ich ursprünglich das Paket „openhab2-offline“ installiert hatte (das war die damalige Empfehlung). Dieses Paket gibt es aber aktuell nicht mehr.

Ich habe damit die Installation noch einmal wie folgt gestartet:

  • sudo apt-get install openhab2

Damit wird das vorhandene Paket „openhab2-offline“ deinstalliert und durch das neue Paket ersetzt.

Am Ende habe ich noch einen Neustart mit „sudo shutdown -r now“ vorgenommen und die Log-Dateien auf Fehler kontrolliert.

 

Backup einer openHAB 2.x Installation erstellen

Meine Haussteuerung basiert momentan auf openHAB 2.0.0 und wurde schon seit Anfang 2017 nicht mehr aktualisiert. Für ein Update war dann im Urlaub doch etwas Zeit da. Ich beschreibe das Update nach meiner Installation. Wenn Ihr Fragen habt, könnt Ihr euch auch gerne bei mir melden!

Es gibt bei openHAB bereits drei neue Major-Releases. Aber wie vor jedem Update soll erst einmal ein Backup erstellt werden. Auf dieser Seite findet Ihr Informationen wie Ihr am besten einen RaspberyPi sichert.

Ich habe das Vorgehen für mich wie folgt umgesetzt:

  • Win32 Disk Imager auf einem Windows 10 PC installiert
  • Raspberry Pi per „sudo shutdown -h now“ herunterfahren
  • Stromzufuhr entfernen
  • SD-Karte aus dem RaspberryPi in den Rechner mit Kartenleser einlegen
  • Win32 Disk Imager öffnen und den Speicherort der img-Datei auswählen
  • Mit „Lesen“ den Sicherungsvorgang starten (hat bei 16 GB ca. 5 Minuten benötigt)

Damit hatte ich schon einmal eine komplette Sicherung der SD-Karte.

Danach habe ich noch das conf- und das userdata-Verzeichnis manuell einmal gesichert (damit ich auch eine lesbare Kopie meiner Konfigurationsdateien habe).

Damit habe ich für die folgenden Updates schon einmal ein besseres Gefühl …

Weitere HomeMatic-Lichtschalter in unserem Haus – jetzt kommt die Präsenzmeldung :-)

Ich habe heute den letzten „konventionellen“ Lichtschalter bei uns im Haus (in der Speis) getauscht (ich glaube den Austausch im Keller stelle ich erst einmal wegen zu geringer Mehrwerte zurück). Langsam kommt in den Tausch der Lichtschalter etwas Routine rein. Ich hatte ja hier schon einmal das allgemeine Vorgehen beschrieben 🙂

Die Integration in OpenHAB und in die Alexa-Sprachsteuerung klappt mittlerweile sehr gut und schnell (wobei für mich immer der „handwerkliche“ Aufwand beim Austausch des Schalters der größere Aufwand ist).

Da jetzt alle Steckdosen und Lichtschalter per Regeln und App geschalten werden können, kann jetzt der nächste Schritt angegangen werden.

Ich möchte jetzt abhängig von der Präsenz von Personen im Haus alle Verbraucher deaktivieren können. Mein erster Ansatz war über die Mac-Adresse / IP-Adresse der Smartphones im WLAN die Präsenz im Haus zu steuern d.h. wenn keines der drei Smartphones (damit Bewohner) im WLAN ist, können automatisch alle Lichter im Haus per Regel deaktiviert werden.

Wie regelt Ihr bei euch die Präsenzmeldung? Meint Ihr die Steuerung über die Smartphones reicht aus?

Heise Developer Podcast zur Softwarearichtektur von OpenHAB und Eclipse SmartHome

Wenn jemand Interesse an ein paar Details zur Softwarearchitektur, der Historie und der Zukunft von OpenHAB hat, dann sollte er sich diesen ct-Webcast anhören (dauert ca. 1 Stunde).

Planung Update OpenHAB 2.0 auf den aktuellen Stand

Für die Haussteuerung verwende ich bei uns das OpenSource-System OpenHAB.

Momentan verwende ich die Version 2.0.0 (das ist ein schon etwas älterer Stand vom Januar 2017).

Im Juni 2017 ist dann die Version 2.1.0 erschienen. Und im Dezember 2017 wurde die Version 2.2.0 veröffentlicht.

Da ein Update des Systems doch immer etwas Testaufwand nach sich zieht und das System ja immer verfügbar sein muss (nein, ich habe hier privat keine Testumgebung) habe ich das Update noch nicht durchgeführt.

Ich würde das Update in zwei Schritten installieren und testen. Bei Version 2.1 waren größere Änderungen in den Group-Items und bei 2.2 könnte sich ggf. etwas an den Regeln geändert haben.

Habt Ihr schon ein Update von einer 2.0 auf eine 2.2 durchgeführt? Was sind eure Erfahrungen? Rechtfertigen die neuen Funktionen und Vereinfachungen ein Update (oder lieber doch noch etwas abwarten)?

Integration HomeMatic-Lichtschalter in openHAB

Im vorherigen Artikel habe ich schon einmal kurz meine Idee für den Austausch von ein paar konventionellen Lichtschaltern gegen HomeMatic-Schalter beschrieben.

Jetzt haben ein Bekannter und ich den ersten Schalter bei uns im Haus getauscht. Der N-Leiter war da, damit war der technische Tausch kein Problem.

Ich hatte für den ersten Test einen HomeMatic (HM-LC-Sw1PBU-FM) und die zugehörigen Jung-Adapterset gekauft. Das Adapterset ist abhängig von den Schaltern indem das HomeMatic-Gerät integriert werden soll.

Das Ergebnis sieht wie folgt aus und war sehr schnell umgesetzt:

Verkabelung

Wie der Schalter verkabelt wird kann man sehr gut in der Anleitung erkennen.

Zwei Punkte waren hier wichtig:

  • Wir mussten den Eingang 2 verwenden (ansonsten war der Status An / Aus vertauscht) – das war so in der Anleitung nicht ersichtlich
  • Ich habe den Schalter „auf Kopf“ eingebaut, damit man beim Drücken nach Unten einschalten und beim Drücken nach Oben ausschaltet

HomeMatic

In die HomeMatic-Bridge (CCU2) ist der Schalter wie bei allen Endgeräten recht schnell integriert.

Man wechselt auf die Weboberfläche und wechselt dort auf „Geräte anlernen“ und wählt dann „HM Geräte anlernen“ aus. Damit ist der Anlernmodus aktiv. Danach muss man den Config-Modus am Schalter mit einem spitzen Gegenstand aktivieren. Kurz danach hat man den gewünschten Schalter im Posteingang der CCU2.

Jetzt noch einen kurzen Funktionstest durchführen und optional gewünschte Einstellungen vornehmen. Bei mir sind das die folgenden Parameter:

  • „Protokolliert“ für das Gerät aktivieren
  • Benennung des Schalters und des Schaltaktors entsprechend der gewünschten Konventionen anpassen
  • Seriennummer des Endgeräts notieren

OpenHAB

Für die Integration in meine zentrale Haussteuerung muss man in der OpenHAB-Weboberfläche das PaperUI auswählen.

Danach bekommt man in der Inbox auch schon das neue HomeMatic-Item angezeigt und muss es nur bestätigen (Add as thing).

Da ich die manuelle Konfiguration aktiviert habe, muss ich nun in meiner Item-Datei folgende Konfiguration einfügen:

Switch hmLicht_EG_WC_LOWBAT "Licht EG - WC (HM-LC-Sw1PBU-FM) - Low Battery" (gEG_WC) {channel="homematic:HM-LC-Sw1PBU-FM:ccu:SERIENNUMMER:0#LOWBAT"}
Switch hmLicht_EG_WC_SIGNAL "Licht EG - WC (HM-LC-Sw1PBU-FM) - Signal Strength" (gEG_WC) {channel="homematic:HM-LC-Sw1PBU-FM:ccu:SERIENNUMMER:0#RSSI_DEVICE"}
Switch hmLicht_EG_WC_STATE "Licht WC" (gEG_WC, gLicht, gLicht_EG) [ "Lighting" ] {channel="homematic:HM-LC-Sw1PBU-FM:ccu:SERIENNUMMER:1#STATE"}

Die SERIENNUMMER im Beispiel muss gegen die richtige Nummer ersetzt werden. Der Switch muss dann noch an die eigenen Bedürfnisse angepasst werden.

Danach kann über die BasicUI ein Funktionstest durchgeführt werden. Als letzter Schritt kann man dann noch das neue Gerät in seine Sitemap zur besseren Visualisierung aufnehmen (danach empfiehlt sich ein Neustart des OpenHAB-Dienstes).

Nun ist im Web-Client und der Smartphone-App die Funktion komplett verfügbar.

Alexa

Natürlich soll das Gerät auch per Sprachsteuerung durch Amazon Alexa bedient werden können.

Dazu muss man einfach kurz die Alexa-App starten und unter „Smart Home“ die neuen „Geräte hinzufügen“. Nach ein paar Sekunden ist dann auch die Sprachsteuerung aktiviert.

Fazit

Mit den HomeMatic-Schaltern ist es sehr schnell möglich einen konventionellen Schalter gegen einen „intelligenten“ Schalter auszutauschen. Der Zeitaufwand hält sich in Grenzen und die Integration in OpenHAB oder Amazon Alexa sind nur optional notwendig.

Wichtig war nur bei der Verkabelung die „2“ zu verwenden, damit der Status richtig visualisiert wird und der richtige Einbau des Schalters.