Alexa-Fhem: Unterschied zwischen den Versionen

Aus FHEMWiki
Keine Bearbeitungszusammenfassung
Zeile 26: Zeile 26:
# Mit <source lang="bash" style="width:50%;">npm install</source> alle Abhängigkeiten installieren
# Mit <source lang="bash" style="width:50%;">npm install</source> alle Abhängigkeiten installieren
# SSL Zertifikat erzeugen durch Aufruf von <source lang="bash" style="width:50%;">./createKey.sh</source>. Hierbei beachten, dass ein Kennwort vergeben werden soll, das mindestens aus 4 Zeichen besteht.
# SSL Zertifikat erzeugen durch Aufruf von <source lang="bash" style="width:50%;">./createKey.sh</source>. Hierbei beachten, dass ein Kennwort vergeben werden soll, das mindestens aus 4 Zeichen besteht.
# Die Datei ''config-sample.json'' nach ''~/.alexa/config.json'' kopieren und die Werte auf die eigene Umgebung hin anpassen. Der Filter funktioniert hierbei wie bei [http://www.fhemwiki.de/wiki/Homebridge_einrichten#Einstellungen_f.C3.BCr_homebridge homebridge-fhem], "oauthClientID": -> ''Client Id'' aus Punkt 1. '''Login with Amazon'''
# Die Datei ''config-sample.json'' nach ''~/.alexa/config.json'' kopieren und die Werte auf die eigene Umgebung hin anpassen. Der Filter funktioniert hierbei wie bei [http://www.fhemwiki.de/wiki/Homebridge_einrichten#Einstellungen_f.C3.BCr_homebridge homebridge-fhem],die folgenden Zeilen sind anzupassen oder zu löschen:<br>"nat-pmp": -> wenn nat-pmp verwendet werden soll: die ip des eigenen routers,<br>"nat-upnp": -> wenn nat-upnp verwendet werden soll: ''true'',<br>"applicationId": -> noch nicht verwendet,<br>"oauthClientID": -> ''Client Id'' aus Punkt 1. '''Login with Amazon'''
# Durch Aufruf von <source lang="bash" style="width:50%;">./bin/alexa</source> den Dienst starten
# Durch Aufruf von <source lang="bash" style="width:50%;">./bin/alexa</source> den Dienst starten



Version vom 24. November 2016, 10:23 Uhr

Alexa-Fhem ist eine in JavaScript und auf NodeJS basierende Software, welche es ermöglicht, der digitalen Amazon Assistentin Alexa zusätzliche Skills für die Heimautomatisierung via FHEM beizubringen. Eine erste funktionierende Version wurde von justme1968 im Forum veröffentlicht. Das ist eine erste Version der Dokumentation zur Installation und Einrichtung, eine Erweiterung wird sicherlich in nächster Zeit noch folgen.

Alexa-Fhem
Zweck / Funktion
Anbindung von FHEM an Amazon Assistent Alexa
Allgemein
Typ Inoffiziell
Details
Dokumentation siehe Forum
Support (Forum) Sonstige Systeme
Modulname
Ersteller justme1968
Wichtig: sofern vorhanden, gilt im Zweifel immer die (englische) Beschreibung in der commandref!


Installation

Grundvoraussetzung für alle folgenden Schritte ist, dass ein Amazon-Account vorhanden ist. Es wird davon ausgegangen, dass bereits für alle folgenden Amazon-Dienste vorab das Konto jeweils eingerichtet wurde, die Einrichtung dieser ist nicht Bestandteil dieser Anleitungen.

Voraussetzungen

Folgende grundlegende Voraussetzungen sollten erfüllt sein, bevor du mit der Einrichtung beginnst:

  • Amazon Echo oder Amazon Dot
  • node.js (vermutlich ab Version 0.12, getestet mit 4.2.6. Kann in Debian z.B. mit
    apt-get install nodejs-legacy
    
    installiert werden)
  • Weiterleitung von Port 3000 vom Router aus auf den Rechner, auf dem Alexa-Fhem läuft

Alexa-Fhem installieren

  1. Die tgz-Datei entpacken (Quelle: https://forum.fhem.de/index.php/topic,60244.0.html)
  2. Verzeichnis package in alexa-fhem umbenennen
  3. Durch
    cd alexa-fhem
    
    in das Verzeichnis wechseln
  4. Mit
    npm install
    
    alle Abhängigkeiten installieren
  5. SSL Zertifikat erzeugen durch Aufruf von
    ./createKey.sh
    
    . Hierbei beachten, dass ein Kennwort vergeben werden soll, das mindestens aus 4 Zeichen besteht.
  6. Die Datei config-sample.json nach ~/.alexa/config.json kopieren und die Werte auf die eigene Umgebung hin anpassen. Der Filter funktioniert hierbei wie bei homebridge-fhem,die folgenden Zeilen sind anzupassen oder zu löschen:
    "nat-pmp": -> wenn nat-pmp verwendet werden soll: die ip des eigenen routers,
    "nat-upnp": -> wenn nat-upnp verwendet werden soll: true,
    "applicationId": -> noch nicht verwendet,
    "oauthClientID": -> Client Id aus Punkt 1. Login with Amazon
  7. Durch Aufruf von
    ./bin/alexa
    
    den Dienst starten

Alexa Smart Home Skill anlegen

Für folgende Schritte muss man unter der Adresse http://developer.amazon.com angemeldet sein

  1. Anmeldung auswählen
    Developer.amazon.com-01-login2.png
  2. Anmeldedaten eingeben
    Developer.amazon.com-02-userpass2.png

Apps & Services

  1. Klicke nach der Anmeldung auf APPS & SERVICES
    Developer.amazon.com-03-apps and services.png
  2. Klicke anschließend auf Security Profiles
    Developer.amazon.com-05-apps and services - security profiles.png
  3. Wähle anschließend Create a New Security Profile aus
    Developer.amazon.com-06-apps and services - create a new security profile.png
  4. Gebe dann ein Namen und eine Beschreibung für das Profil ein und bestätige die Eingaben durch anklicken von Save
    Developer.amazon.com-07-apps and services - security profile management.png

Login with Amazon

Info green.pngHier wird beschrieben, wo Client Id und Client Secret zu finden ist
  1. Nachdem du die vorherigen Schritte befolgt hast, siehst du im Browser das Profil dass du angelegt hast. Klicke jetzt oben rechts auf Login with Amazon
    Developer.amazon.com-08-login with amazon.png
  2. Auf der neu geladenen Seite klickst du dann auf Sign up
    Developer.amazon.com-09-login with amazon - sign up.png
  3. Wähle anschließend im Dropdown Menü das vorher angelegte Profil aus und bestätige das anschließend mit Confirm
    Developer.amazon.com-10-login with amazon - create new profile.png Developer.amazon.com-11-login with amazon - create new profile2.png
  4. Im folgenden Fenster gibst du dann die Adresse https://www.amazon.com/gp/help/customer/display.html?nodeId=468496 ein und bestätigst die Eingabe mit Save
    Developer.amazon.com-12-login with amazon - enter consent screen information.png
  5. Klicke dann bei dem neu angelegten Eintrag auf der rechten Seite auf das Zahnrad und wähle Web Settings aus
    Developer.amazon.com-13-login with amazon - web settings.png
  6. Im neu geladenen Fenster klickst du dann auf Edit
    Developer.amazon.com-14-login with amazon - edit.png
  7. Füge zuletzt dann bei Allowed Return URLs die Adresse https://layla.amazon.co.uk/api/skill/link/xxx, https://pitangui.amazon.com/api/skill/link/xxx, und https://layla.amazon.com/api/skill/link/xxx hinzu. xxx muss hierbei durch den Wert ersetzt werden, der bei Punkt 6 Skill Kit einrichten unter Redirect Urls am Ende der URLs angezeigt wird.
    Developer.amazon.com-15-login with amazon - allowed return urls.png

Skill Kit einrichten

  1. Wähle im Menü den Punkt Alexa aus
    Developer.amazon.com-03-apps and services.png
  2. Klicke dann Get started beim Punkt Alexa Skills Kit an
    Developer.amazon.com-17-alexa - alex skills kit - get started.png
  3. Wähle dann auf der neu geladenen Seite oben rechts Add a New Skill aus
    Developer.amazon.com-18-alexa - alex skills kit - add a new skill.png
  4. Auf der folgenden Seite wählst du Smart Home Skill API sowie German als Sprache aus und gibst ein Name für den Skill ein was du dann mit Next bestätigst.
    Developer.amazon.com-19-alexa - alex skills kit - skill information.png
  5. Die folgende Seite klickst du mit Next dann weiter
    Developer.amazon.com-20-alexa - alex skills kit - interaction model.png
  6. Auf der Seite Configuration gibst du dann unter Authorization URL die Adresse https://www.amazon.com/ap/oa an, bei Scope profile:user_id und bei Access Token URI https://api.amazon.com/auth/o2/token sowie bei Privacy Policy URL die Adresse https://www.amazon.com/gp/help/customer/display.html?nodeId=468496

    Folgende Felder müssen individuell ausgefüllt werden:
    * Service Endpoint Type -> Europe auswählen und im Textfeld den Wert aus Punkt 12 AWS Lambda Funktion anlegen eintragen
    * Client Id -> Client Id aus Punkt 1. Login with Amazon
    * Client Secret -> Client Secret aus Punkt 1. Login with Amazon


    Developer.amazon.com-21-alexa - alex skills kit - configuration.png

  7. Developer.amazon.com-22-alexa - alex skills kit - test.png
Info green.pngHier wird beschrieben, wo die Alexa Skill Id zu finden ist

Zur späteren Verwendung unter Punkt 7 AWS Lambda Funktion anlegen wird noch die Application Id benötigt. An diese kommt man wie folgt:

  1. Wähle im Menü den Punkt Alexa aus
    Developer.amazon.com-03-apps and services.png
  2. Klicke dann Get started beim Punkt Alexa Skills Kit an
    Developer.amazon.com-17-alexa - alex skills kit - get started.png
  3. Beim vorher angelegten Eintrag auf Edit klicken
    Developer.amazon.com-23-alexa - alex skills kit - overview.png
  4. Die Id, die nun oben angezeigt wird, ist die gesuchte
    Aws.amazon.com-06-configure triggers2.png

AWS Lambda Funktion anlegen

Für folgende Schritte muss man unter der Adresse http://aws.amazon.com angemeldet sein

  1. Anmeldung auswählen
    Aws.amazon.com-01-site.png
  2. Anmeldedaten eingeben
    Aws.amazon.com-02-login.png
  3. Den Punkt Lambda links auf der Startseite auswählen
    Aws.amazon.com-03-lambda.png
  4. Anschließend den Punkt Get Started Now auswählen
    Aws.amazon.com-04-get started now.png
  5. Den Blueprint Blank function auswählen
    Aws.amazon.com-05-select blueprint.png
  6. Im neuen Fenster dann auf den gestrichelten Kasten klicken und Alexa Smart Home auswählen und mit Next bestätigen
    Aws.amazon.com-06-configure triggers1.png
    Achtung! Es ist möglich, dass ihr hier Alexa Smart Home überhaupt nicht auswählen könnt. Dann solltet ihr ganz rechts oben in der Ecke mal schauen, welche Region bzw. welches Land ausgewählt ist. Ich empfehle hier Ireland auszuwählen. Dann erscheint bei den Funktionen auch Alexa Smart Home.
  7. Bei Application Id den Wert eintragen, dessen Ermittlung unter Skill Kit einrichten in der zusätzlichen Beschreibung beschrieben wird, den Haken bei Enable trigger setzen und mit Next bestätigen
    Aws.amazon.com-06-configure triggers3.png
  8. Auf der Konfigurationsseite bei Name den Wert FHEM eingeben, bei Runtime Node.js 4.3. Bei Role den Wert Choose an existing role wählen und bei Existing role dann x wählen. Der Quellcode der Datei lambda.js aus dem Quellpaket wird dann an die Stelle des großen Textfeldes vollständig eingefügt. Dann noch den Hostname im Quellcode an den eigenen anpassen. Anschließend alles mit Next bestätigen.
    Aws.amazon.com-07-configure function.png
  9. Auf der Übersichtsseite dann Create function anklicken
    Aws.amazon.com-08-review.png
  10. Klicke dann auf der Übersichtsseite oben links auf Function
    Aws.amazon.com-09-go overview.png
  11. Wähle dann die angelegte Funktion aus und klicke dann im Menü Action auf den Punkt Show ARN
    Aws.amazon.com-10-1-show arn.png
  12. Es wird nun eine ARN Adresse angezeigt, die für den Punkt 6 bei Skill Kit einrichten benötigt wird
    Aws.amazon.com-10-2-arn.png

Alexa Skill einrichten

  1. Auf http://alexa.amazon.de anmelden
  2. Auf Skills klicken
    Alexa.amazon.de-01-startseite.png
  3. Oben rechts Meine Skills auswählen
    Alexa.amazon.de-03-meine skills.png
  4. In der Liste der Skills sollte das angelegte FHEM Skill angezeigt werden. Dieses anklicken
    Alexa.amazon.de-02-liste skills.png
  5. Oben Rechts in den Details des Skills auf Skill aktivieren klicken
    Alexa.amazon.de-04-skill details.png
  6. In dem neu geöffneten Fenster die Authorisierung bestätigen
    Alexa.amazon.de-05-amazon auth.png
  7. Anschließend sollte die Verbindung erfolgreich aufgebaut worden sein
    Alexa.amazon.de-06-success.png

Geräteeinrichtung

  1. Auf http://alexa.amazon.de anmelden
  2. Auf Smart Home klicken
    Alexa.amazon.de-01-startseite.png
  3. Anschließend den Punkt Geräte suchen anklicken
    Alexa.amazon.de-07-Gerätesuche.png
  4. Wurde soweit alles korrekt eingerichtet, werden nun die gefundenen Geräte angezeigt.

Tip: Es macht Sinn, unter Meine Gruppen Gruppen benannt nach den Räumen einzurichten. Hierdurch kann Alexa die Geräte besser auseinander halten, vor allem wenn die den gleichen Alias (z.B. "Licht") haben.

Nutzung

Sprachkommandos

Nach erfolgreicher Einrichtung sollte Alexa mit den Befehlen

“alexa, schalte <gerät/raum> ein”
“alexa, schalte <gerät/raum> aus”
“alexa, stelle <gerät/raum> auf <wert> prozent”
“alexa, stelle <gerät/raum> auf <anzahl> grad”
“alexa, erhöhe <gerät/raum> um <anzahl> prozent”
“alexa, reduziere <gerät/raum> um <anzahl> prozent”
“alexa, erhöhe <gerät/raum> um <anzahl> grad”
“alexa, reduziere <gerät/raum> um <anzahl> grad”

nutzbar sein

Optimierung

Normalerweise wird von Alexa-Fhem der Wert im Feld NAME verwendet, mit dem ein Gerät angesprochen werden kann via Alexa. Ist ein anderer "Rufname" gewünscht, kann das Feld Alias gesetzt werden. Der hier gesetzte Wert wird dann als alternativer Name verwendet.

Troubleshooting

Allgemeiner Hinweis

Besonders wichtig ist, dass man sich sehr genau an diese Anleitung hält. Ein häufiger Fehler ist, dass die einfachen Anführungszeichen in der Anleitung unter AWS Lambda Funktion anlegen Punkt 8 einfach weggelassen werden. Diese sind zwingend notwendig. Es darf auch nur der reine Hostname eingetragen werden. Also kein http:// davor. Entweder eine feste IP Adresse oder den Hostnamen, um den Rechner zu erreichen, den ihr über den Port 3000 freigegeben habt. Das sollte dann so aussehen:

const PORT=3000;
const HOST='mein.host.name';

Freigabe von Port 3000

X mark.svgDerzeit müsst ihr über einen echten IPv4 Anschluss verfügen, damit der Amazon Lambda-Server euch erreichen kann. DS-Lite Anschlüsse wie die von UnityMedia z.B. funktionieren derzeit leider nicht. Eine möglicher "Workaround" wird hier beschrieben: https://forum.fhem.de/index.php/topic,60244.msg518276.html#msg518276


Auf dem Router muss der Port 3000 Protokoll TCP freigegeben werden. D.h. von außen muss man wenn man den Port 3000 aufruft, auf dem intern laufenden node.js Alexa-Dienst zugreifen können. Je nach Router gestaltet sich das Portforwarding bzw. die Portumleitung etwas schwieriger.

Bei einem Speedport Router der Telekom beispielsweise, muss der Router komplett neu gestartet werden, wenn die Portfreigabe eingerichtet wurde.

Bei der Fritz!Box ist das nicht nötig, bei dieser finden die Freigabe unter Internet -> Freigaben -> Portfreigaben statt. Dort wählt man dann den Rechner aus und richtet eine neue Freigabe ein. Wichtig hierbei ist, dass man Portfreigabe auswählt und nicht MyFRITZ!-Freigabe. Bei Port von bis trägt man 3000 ein, bei Port extern ebenfalls.

Um die Portweiterleitung zu testen, solltet ihr euch auch nicht im gleichen Netz befinden. Viele Router blockieren den Netzaufruf aus dem gleichen Netz. Am besten testet ihr es, wenn ihr an eurem Mobiltelefon W-LAN deaktiviert und im Browser folgende Seite aufruft: https://mein.hostname:3000. Wenn ihr im Browser dann einen Quellcode von Alexa seht, funktioniert die Portumleitung.

Wenn bis hier alles funktioniert und es läuft dennoch nicht rund, liegt das Problem woanders. Kommt z.B. bei der Gerätesuche kein Request rein (sichtbar auf dem Bildschirm, wenn bin/alexa gestartet wurden), kann evtl. der Lambda-Dienst falsch konfiguriert sein.

Probleme mit node.js - npm install

Falls eine Fehlermeldung auftritt, dass "npm" nicht gefunden werden kann, bitte NodeJS entsprechend der Anleitung im Homebridge-Artikel vorgehen: NodeJS installieren sowie Python, g++, MDNS installieren, siehe auch folgenden Abschnitt.

Es kommen diverse Fehlermeldungen beim Starten von alexa-fhem und es beendet sich

Wenn man auf der Konsole angemeldet ist, den Befehl

node -v

eingeben. Ist die Version niedriger als die geforderte 0.12, muss eine neuere installiert werden. Hier darf man dann im Wiki unter http://www.fhemwiki.de/wiki/Homebridge_einrichten#NodeJS_installieren nachschauen. NodeJS V4 sollte hierbei schon ausreichen. Solange die node.js Version nicht passt, gar nicht groß rum experimentieren! Bitte beachtet, dass alle Voraussetzungen unter http://www.fhemwiki.de/wiki/Alexa-Fhem#Voraussetzungen erfüllt sind! Keine Experimente mit Versionen die darunter liegen.

Fehlermeldung NAT-PMP failed: Error: timeout Fehler angezeigt beim Start von alexa-fhem

Wenn ihr dann alexa-fhem über die Konsole startet und bekommt folgenden Fehler: NAT-PMP failed: Error: timeout, lasst euch davon nicht irritieren. Das bedeutet lediglich, dass der Port nicht automatich freigegeben wurde über uPNP. Alternativ prüft, ob die Funktion der Portfreigabe via uPNP auf eurem Router aktiviert ist.

Was ist zu tun, wenn alexa-fhem keine Geräte findet?

Zunächst müssen die Geräte, die angesprochen werden wollen, unter FHEM ein neues Attribut zugewiesen bekommen. Dazu das Gerät in FHEM öffnen und das Attribut genericDeviceType switch hinzufügen, wenn es ein Schalter mit der Funktiona AN/AUS sein soll. Wenn man will, kann man dem Gerät jetzt noch über das Attribut alias eine besseren Namen geben, mit dem Alexa das Gerät dann auch finden kann. Anschließend muss alexa-fhem neu gestartet werden und die definierten Geräte sollten nun gefunden werden.

Was ist zu tun, wenn Alexa zwar Geräte findet, diese aber nicht angesprochen werden können?

Zunächst sollte man sich unter http://aws.amazon.com das Logfile seiner erstellten Funktion anschauen. Ist überhaupt ein Logfile vorhanden? Falls nicht, liegt es vermutlich am Trigger. Den solltet ihr überprüfen. Scheinbar kommt es hin und wieder vor, dass dieser nicht gesetzt ist. Dazu einfach auf Triggers klicken und mit Add trigger erneut einen anlegen. Hier muss, wie in der Anleitung unter AWS Lambda Funktion anlegen Punkt 7, die Application Id stehen und der Haken bei Enable trigger gesetzt sein. Dann alexa-fhem neu starten. Wenn ihr Änderugen gemacht habt und den alexa-fhem Dienst noch nicht neu gestartet habt, wäre jetzt der richtige Zeitpunkt.