Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Praktische Anwendungen (Showcase)
  4. Alexa in Node Red ohne contrib-alexa-home oder Ähnliches

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    209

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    7.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

Alexa in Node Red ohne contrib-alexa-home oder Ähnliches

Alexa in Node Red ohne contrib-alexa-home oder Ähnliches

Scheduled Pinned Locked Moved Praktische Anwendungen (Showcase)
alexanode redalexa ohne cloudalexa skill
82 Posts 14 Posters 12.1k Views 25 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Z zzippo

    @jrudolph Dann hoffe ich, das morgen alles klappt. wenn es erstmal läuft, dann macht es richtig Freude. Ich wäre dann auch motiviert, weiter an der Sache zu entwickeln, obwohl im Moment schon alle meine Bedürfnisse gedeckt sind.
    Wenn ich nicht so ein blutiger Anfänger in JS wäre, würde ich auch einen Adapter bauen. Ich werde mir in den nächsten Tagen mal ein paar Youtube Videos zu Gemüte führen, evtl. hilft das ja.

    J Offline
    J Offline
    Ju5t1n
    wrote on last edited by
    #38

    @zzippo Juchuu 😁
    Kaum stimmt das Passwort, dann klappts auch.
    Vielen Dank für deine bisherigen Bemühungen. Ist ein ganz tolles Projekt.

    1 Reply Last reply
    0
    • Z zzippo

      @jrudolph Dann hoffe ich, das morgen alles klappt. wenn es erstmal läuft, dann macht es richtig Freude. Ich wäre dann auch motiviert, weiter an der Sache zu entwickeln, obwohl im Moment schon alle meine Bedürfnisse gedeckt sind.
      Wenn ich nicht so ein blutiger Anfänger in JS wäre, würde ich auch einen Adapter bauen. Ich werde mir in den nächsten Tagen mal ein paar Youtube Videos zu Gemüte führen, evtl. hilft das ja.

      J Offline
      J Offline
      Ju5t1n
      wrote on last edited by
      #39

      @zzippo Könntest du mal zeigen, wie du die Rolladensteuerung eingerichtet hast. Geht das auch über den Mode Regler?
      Ich habe das folgendermaßen versucht zu lösen:
      9a82173c-93c0-464a-9cb6-eacf74b277b5-image.png
      4d9faca1-940c-4ffb-8206-1e54e5919e81-image.png
      Das Gerät wird von Alexa auch gefunden, allerdings kommt als Antwort: "Ich weiß nicht, wie ich diese Einstellung für Laden Test machen kann."
      Bei den friendly Names hinter den Supported Modes habe ich Laden Test hoch bzw. runter eingegeben.

      Z 1 Reply Last reply
      0
      • J Ju5t1n

        @zzippo Könntest du mal zeigen, wie du die Rolladensteuerung eingerichtet hast. Geht das auch über den Mode Regler?
        Ich habe das folgendermaßen versucht zu lösen:
        9a82173c-93c0-464a-9cb6-eacf74b277b5-image.png
        4d9faca1-940c-4ffb-8206-1e54e5919e81-image.png
        Das Gerät wird von Alexa auch gefunden, allerdings kommt als Antwort: "Ich weiß nicht, wie ich diese Einstellung für Laden Test machen kann."
        Bei den friendly Names hinter den Supported Modes habe ich Laden Test hoch bzw. runter eingegeben.

        Z Offline
        Z Offline
        zzippo
        wrote on last edited by zzippo
        #40

        @Ju5t1n said in Alexa in Node Red ohne contrib-alexa-home oder Ähnliches:

        @zzippo Könntest du mal zeigen, wie du die Rolladensteuerung eingerichtet hast. Geht das auch über den Mode Regler?
        Ich habe das folgendermaßen versucht zu lösen:

        Hallo Ju5t1n,
        Toll das es klappt.
        Ich habe die Rolläden auch über mode angebunden, bin aber gerade dabei das umzustellen, weil die neuen Tasmota Versionen Rolläden speziell unterstützen.
        ich habe es so gemacht:
        Rollo.png
        RolloDB.png

        und kann dann mit dem Befehl 'Alexa, Küche Rolladen runter' arbeiten.

        1 Reply Last reply
        0
        • Z zzippo

          @jrudolph Dann hoffe ich, das morgen alles klappt. wenn es erstmal läuft, dann macht es richtig Freude. Ich wäre dann auch motiviert, weiter an der Sache zu entwickeln, obwohl im Moment schon alle meine Bedürfnisse gedeckt sind.
          Wenn ich nicht so ein blutiger Anfänger in JS wäre, würde ich auch einen Adapter bauen. Ich werde mir in den nächsten Tagen mal ein paar Youtube Videos zu Gemüte führen, evtl. hilft das ja.

          J Offline
          J Offline
          jrudolph
          wrote on last edited by
          #41

          @zzippo Ich kann bestätigen dass nun neue Geräte gefunden werden. Erst gab es noch Probleme mit der Verbindung zwischen Proxy und PC. Im PC mußte ich noch eine Firewall Regel für den Port 41101 einrichten. Das als Hinweis für andere bei denen es evtl. auch an dieser Stelle klemmt.

          Z 1 Reply Last reply
          0
          • J jrudolph

            @zzippo Ich kann bestätigen dass nun neue Geräte gefunden werden. Erst gab es noch Probleme mit der Verbindung zwischen Proxy und PC. Im PC mußte ich noch eine Firewall Regel für den Port 41101 einrichten. Das als Hinweis für andere bei denen es evtl. auch an dieser Stelle klemmt.

            Z Offline
            Z Offline
            zzippo
            wrote on last edited by
            #42

            @jrudolph, danke für den Hinweis. Wundert mich aber, weil ich die Firewall Regel per Software setzte, hattest Du das Programm mit Administrator Rechten gestartet?

            J 1 Reply Last reply
            0
            • Z zzippo

              @jrudolph, danke für den Hinweis. Wundert mich aber, weil ich die Firewall Regel per Software setzte, hattest Du das Programm mit Administrator Rechten gestartet?

              J Offline
              J Offline
              jrudolph
              wrote on last edited by
              #43

              @zzippo Tja, hat mich auch gewundert. Ich sehe die Regel für den AlexaDeviceGenerator (für alle Ports) in den Windows Defender Firewall Regeln. Habe mal probehalber wieder meine 41101 Regel deaktiviert --> geht wieder nicht. Regel 41101 aktiviert --> alles OK.
              Ja, läuft unter Admin.
              Jedenfalls funktioniert es jetzt.

              1 Reply Last reply
              0
              • Z zzippo

                Vorab, was wird benötigt:

                • Eine Dyndns Adresse, damit wir unser Smart Home aus dem Internet erreichen können.
                • Einen Rechner der als Reverse-Proxy dient, in meinem Fall ein Raspi.
                • Eine Portfreigabe im Router auf den Reverse-Proxy (port80 und port 443)
                • IOBroker mit NodeRed
                • Windows Rechner um neue Geräte zu konfigurieren.

                Für Teil 1 brauchen wir noch nichts.

                Teil 1: Erstellen eines eigenen Alexa Smarthome skills

                Bevor wir anfangen müssen wir uns als Developer bei Amazon anmelden, außerdem brauchen wir einen AWS account, da wir eine Lambda Funktion schreiben müssen. AWS ist ein kostenpflichtiger Dienst von Amazon, aber keine Angst, das monatliche Frei-Volumen ist so riesig, das man damit hunderte Smarthomes versorgen kann. (Als Beispiel: jeden Monat eine Million Lambda Aufrufe frei, was in unserem Fall einem Kommando unseres Skills an Alexa entspricht.)

                Wie man sich irgendwo anmeldet brauche ich ja wohl nicht erklären.
                Amazon Developer Seite: https://developer.amazon.com/de/
                Amazon AWS Seite: https://aws.amazon.com/de/

                Haben wir die Anmelde-Formalitäten hinter uns, brauchen wir ständig mehrere Tabs im Browser um Daten hin und her zu kopieren. Wir fangen an auf der Alexa Skill Developer Seite unter: https://developer.amazon.com/alexa/console/ask?
                Nach dem einloggen klicken wir auf den blauen Knopf „Create skill“
                Dann können wir aussuchen welchen Typ Skill wir erstellen wollen.
                bild1.png
                Wir geben unserem skill einen Namen, und wählen Smart Home, danach klicken wir auf Create skill. In einem weiteren Tab öffnen wir AWS-Lambda unter:
                https://eu-west-1.console.aws.amazon.com/lambda/home?region=eu-west-1#/functions
                Die Lambda Funktion ist sozusagen das Interface zwischem dem Skill und unserem Smart Home, normalerweise würde hier der Hersteller Deines Smart Home Devices, seine Routinen zur Verwaltung der Benutzer und Geräte implementieren.

                Wir klicken auf ‚Funktion erstellen‘, und es erscheint diese Seite:
                bild2.png
                Wir geben unserer Funktion einen beliebigen Namen und wählen Node.js 12x als Laufzeit aus. Danach unten auf Funktion erstellen. Dann sollten wir folgendes sehen:
                bild3.png
                Jetzt kopieren wir die oben rechts erschienene ARN, wechseln auf den Alexa skill Tab und tragen Sie im Alexa Skill unter: ‚default endpoint‘ ein. Danach kopieren wir im Alexa skill die „Your skill ID“, und klicken ‚Save‘.
                bild4.png
                jetzt wechseln wir wieder auf den Lambda tab. Hier klicken wir jetzt auf Auslöser hinzufügen, es erscheint folgendes:
                bild5.png
                Wir wählen als Auslöser Alexa Smart Home, und unter Anwendungs-ID die eben kopierte Adresse. Danach klicken wir Hinzufügen. Damit haben wir den Alexa Skill und die Lambda Funktion schon einmal miteinander ‚verheiratet‘.
                Wenn ein neuer Benutzer, in diesem Fall ja Ihr selbst, den Skill aktivieren möchte, so muss er sich authentifizieren. Amazon Benutzt hier das AuthO verfahren, dieses müssen wir jetzt noch kurz einrichten. Wir benutzen den Amazon Account um uns zu identifizieren. Öffne in einem neuen Tab die Amazon Developer Seite mit:
                https://developer.amazon.com/de/
                Klicke oben auf Developer Consolebild6.png
                Danach auf Login mit Amazon
                bild7.png
                Jetzt auf Erstellen eines neuen Sicherheitsprofils
                bild8.png
                Nun geben wir wieder einen beliebigen Namen ein, sowie eine Beschreibung. Außerdem brauchen wir noch eine Web Adresse mit den Datenschutzhinweisen, Hier sollte eine Sinnvolle Adresse stehen,
                damit auch alles funktioniert. Bei mir ist es eine leere Webseite. Danach könnt ihr auf speichern drücken.
                bild9.png
                Nach dem Speichern klicken wir auf „Client-ID und Client-Geheimnis anzeigen“. Wir kopieren jetzt die client-ID und wechseln auf unseren Alexa Skill tab. Hier wählen wir auf der linken Seite die Schaltfläche ‚ACCOUNT LINKING‘ und fügen unter: ‚Your Client ID‘ die kopierte ID ein. Das gleiche machen wir mit ‚Client Geheimnis‘ welches unter Your Secret eingetragen wird.
                Im Feld ‚Your Web Autorization URI‘ geben wir https://www.amazon.com/ap/oa
                ein. Im Feld Access Token URI geben wir: https://api.amazon.com/auth/o2/token
                ein. Jetzt klicken wir auf ‚Add scope‘, und geben im Eingabefeld ‚profile‘ ein.
                Jetzt drücken wir wieder den Save button oben
                bild10.png
                Danach müssen wir noch die 3 unten stehenden ‚Alexa Redirect URL’s‘ in die Zulässigen Rückleitungs URL’s des Authentifizierungsdienstes eingeben. Dafür klicken wir im Tab ‚Login with Amazon‘ auf das Zahnrad neben unserem erstellten Login, und wählen Webeinstellung
                bild11.png
                Jetzt kopieren wir nacheinander die 3 Adressen und drücken natürlich speichern.
                bild12.png
                Jetzt wechseln wir noch einmal in den Alexa Skill tab und wählen links Permission, und schalten den Schalter ‚Send Alexa events‘ auf ein, danach wieder Save.
                bild13.png
                Jetzt fehlt nur noch der Code für die Lambda Funktion, wir wechseln also in den Lambda Tab. Ist der Funktionscode nicht zu sehen dann klickt auf die Lambda Funktion. Darunter erscheint dann ein code Fenster.
                bild14.png
                Jetzt löschen wir alles was im code Fenster ist und kopieren den folgenden code hinein:
                index.js
                danach klicken wir auf deploy.
                Die Zeilen 9 und 10 müssen wir später noch ändern, hier kommt dann eure Adresse und das codierte Passwort rein.

                Jetzt sollte alles Startklar sein, und wir können die Alexa App, am Besten im Browser starten.
                unter: https://alexa.amazon.de
                wir gehen jetzt links auf Skills und dann oben rechts auf Ihre Skills.
                bild16.png
                jetzt wählen wir oben Entwicklerskills an.
                Wenn ich in meiner Anleitung nicht vergessen habe sollte jetzt der Skill auftauchen, und ihr könnt ihn installieren.

                Gerne Feedback, ob bis hierhin alles verständlich war, und ob es funktioniert hat.

                Teil 2 wird dann wesendlich einfacher, ich mache ein Skript, welches alles automatisch auf einem frischen Raspi installiert.
                inkl. Apache Webserver, LetsEncrypt Zertifikat, Einrichtung des Reverse Proxy mit Fernzugriff auf Node Red.

                P.S. Bitte keine Kommentare wenn das js Skript nicht optimal ist. Ich habe mir das innerhalb von einer Woche selbst beibringen müssen, da ich sonst nie etwas damit zu tun hatte.

                L Offline
                L Offline
                lito
                wrote on last edited by lito
                #44

                @zzippo Hi, besten Dank. Ich bin bei Teil 1 bis zum letzten Schritt gekommen. Leider wird bei mir in Alexa unter Skills der Button "Entwicklerskills" überhaupt nicht angezeigt. Muss ich da noch etwas zusätzlich aktivieren, damit ich das bekomme?alexa.jpg

                EDIT: hat sich erledigt. Irgendwie hatte ich einen Amazon Developer Account unter der gleichen Email, aber mit anderem Passwort als mein 'normaler' Amazon Account, der auch meine Echos drin hat. Daher war mein Alexa Developer und mein Alexa nicht miteinander verbunden.

                1 Reply Last reply
                0
                • M Offline
                  M Offline
                  Marsx79
                  wrote on last edited by Marsx79
                  #45

                  @zzippo

                  Sehr interessantes Projekt. Lob an zzippo! Teil 1 hat super funktioniert!

                  Leider habe ich noch einige Schwierigkeiten mit Teil 2.

                  Die Ports 80 und 443 müssen auf diesen vor der Installation durchgeschaltet sein.

                  Nur die Ports vom Raspberry auf dem Router (in meinem Fall eine Fritzbox), oder noch woanders?

                  Danach die IP Adresse auf der NodeRed bzw. der IOBroker läuft.

                  Nur die IP? Kein Port oder weiteres?

                  Dann Die IP des Rechners, welcher die Discovery Response von Alexa beantwortet.

                  Was ist Discovery Response? Wird irgendwie nie vorher drüber gesprochen. Oder habe ich was überlesen?

                  Zu guter letzt Dein Userlogin und Passwort für die Authentifizierung wenn Du auf Deine Geräte vom Internet zugreifen willst.

                  Das sind dann wohl die Zugangsdaten vom DynDNS?

                  Ich frage das alles weil das Script nur mit sehr vielen Fehlern durchläuft. Auch bei der Installtion von Letzencrypt scheint was nicht zu funktionieren. Ich komme nach der Installation auch nicht über den DynDNS auf die Apache Startseite.

                  Z 1 Reply Last reply
                  0
                  • M Marsx79

                    @zzippo

                    Sehr interessantes Projekt. Lob an zzippo! Teil 1 hat super funktioniert!

                    Leider habe ich noch einige Schwierigkeiten mit Teil 2.

                    Die Ports 80 und 443 müssen auf diesen vor der Installation durchgeschaltet sein.

                    Nur die Ports vom Raspberry auf dem Router (in meinem Fall eine Fritzbox), oder noch woanders?

                    Danach die IP Adresse auf der NodeRed bzw. der IOBroker läuft.

                    Nur die IP? Kein Port oder weiteres?

                    Dann Die IP des Rechners, welcher die Discovery Response von Alexa beantwortet.

                    Was ist Discovery Response? Wird irgendwie nie vorher drüber gesprochen. Oder habe ich was überlesen?

                    Zu guter letzt Dein Userlogin und Passwort für die Authentifizierung wenn Du auf Deine Geräte vom Internet zugreifen willst.

                    Das sind dann wohl die Zugangsdaten vom DynDNS?

                    Ich frage das alles weil das Script nur mit sehr vielen Fehlern durchläuft. Auch bei der Installtion von Letzencrypt scheint was nicht zu funktionieren. Ich komme nach der Installation auch nicht über den DynDNS auf die Apache Startseite.

                    Z Offline
                    Z Offline
                    zzippo
                    wrote on last edited by
                    #46

                    Hallo Marsx79,

                    Nur die Ports vom Raspberry auf dem Router (in meinem Fall eine Fritzbox), oder noch woanders?

                    Ja, In der Fritzbox müssen die Ports 443 und 80 auf den Reverse-Procy umgeleitet werden.
                    Portfreigabe.png

                    Danach die IP Adresse auf der NodeRed bzw. der IOBroker läuft.

                    Nur die IP? Kein Port oder weiteres?

                    Ja, nur die IP Adresse, der NodeRed Port (1880) wird mit dem Script in die Datei <DeineDynDNS>.config automatisch eingetragen.

                    Dann Die IP des Rechners, welcher die Discovery Response von Alexa beantwortet.

                    Was ist Discovery Response? Wird irgendwie nie vorher drüber gesprochen. Oder habe ich was überlesen?

                    Nein, das hatte ich nicht erklärt. Amazon nennt die Gerätesuche 'Discovery', Discovery Response ist dann die Antwort auf die Gerätesuche.

                    Zu guter letzt Dein Userlogin und Passwort für die Authentifizierung wenn Du auf Deine Geräte vom Internet zugreifen willst.

                    Das sind dann wohl die Zugangsdaten vom DynDNS?

                    Nein, das sind die Login Daten für den Apache Server, Alle Adressen die Du über den Reverse Proxy erreichen möchtest, fordern Dich dann auf, Deine Daten einzugeben. Du möchtest ja sicher nicht, das jemand anderes Dein NodeRed aus der Ferne bedient.
                    Die DynDNS diehnt ja nur dazu, (falls du eine Dynamische IP hast) Deine Fritzbox mit einem immer gleichen Namen aus dem Internet zu erreichen.

                    Ich frage das alles weil das Script nur mit sehr vielen Fehlern durchläuft. Auch bei der Installtion von Letzencrypt scheint was nicht zu funktionieren. Ich komme nach der Installation auch nicht über den DynDNS auf die Apache Startseite.

                    Hier wäre interessant welche Fehler auftreten, LetzEncrypt lässt sich nur installieren wenn die Portfreigabe funktioniert.

                    1 Reply Last reply
                    0
                    • M Offline
                      M Offline
                      Marsx79
                      wrote on last edited by
                      #47

                      @zzippo said in Alexa in Node Red ohne contrib-alexa-home oder Ähnliches:

                      Nein, das hatte ich nicht erklärt. Amazon nennt die Gerätesuche 'Discovery', Discovery Response ist dann die Antwort auf die Gerätesuche.

                      Aber welche IP soll ich denn da angeben?

                      Z 1 Reply Last reply
                      0
                      • M Marsx79

                        @zzippo said in Alexa in Node Red ohne contrib-alexa-home oder Ähnliches:

                        Nein, das hatte ich nicht erklärt. Amazon nennt die Gerätesuche 'Discovery', Discovery Response ist dann die Antwort auf die Gerätesuche.

                        Aber welche IP soll ich denn da angeben?

                        Z Offline
                        Z Offline
                        zzippo
                        wrote on last edited by
                        #48

                        @Marsx79 said in Alexa in Node Red ohne contrib-alexa-home oder Ähnliches:

                        Aber welche IP soll ich denn da angeben?

                        Für die Geräte-Suche ist das Windows-Programm. Du brauchst also einen Rechner mit Windows. Dessen IP gibst Du hier ein, damit der Reverse Proxy Gerätesuchen zu diesem weiterleiten kann.
                        Wichtig ist, das dieser immer die gleiche IP von Deinem Router zugewiesen bekommt.

                        1 Reply Last reply
                        0
                        • M Offline
                          M Offline
                          Marsx79
                          wrote on last edited by
                          #49

                          @zzippo

                          Vielen Dank erstmal für die Hilfe und die Erklärungen. Soweit hat jetzt alles mit dem Einrichten funktioniert.

                          In der Alexa App findet er jetzt auch die neuen Geräte. Allerdings lassen diese sich nicht schalten. Kann ich irgendwie prüfen ob der Zugriff von NodeRed auf die sql Datenbank funktioniert?

                          Wolltest du noch einen 4. Teil machen über die Datenbank usw.?

                          Z 1 Reply Last reply
                          0
                          • M Marsx79

                            @zzippo

                            Vielen Dank erstmal für die Hilfe und die Erklärungen. Soweit hat jetzt alles mit dem Einrichten funktioniert.

                            In der Alexa App findet er jetzt auch die neuen Geräte. Allerdings lassen diese sich nicht schalten. Kann ich irgendwie prüfen ob der Zugriff von NodeRed auf die sql Datenbank funktioniert?

                            Wolltest du noch einen 4. Teil machen über die Datenbank usw.?

                            Z Offline
                            Z Offline
                            zzippo
                            wrote on last edited by zzippo
                            #50

                            @Marsx79
                            Natürlich kannst Du das prüfen. Am besten erst einmal Debug Nodes in NodeRed anlegen, z.B. wie hier:
                            NodeRedDebug.png
                            Die debug nodes sollten so konfiguriert sein, das sie immer das gesammte Telegramm anzeigen:
                            NodeRedDebug2.png
                            Wenn Du es deploy'st und dann Alexa einen Schaltbefehl gibst solltest Du in etwa folgenden Output im Debug Tab sehen:
                            NodeRedDebug3.png
                            Hier wird eine Steckdose geschatltet, welche keiner speziellen Alexa zugeordnet ist.
                            Wenn z.B. kein Output im Debug erscheint, dann kommt auch der HTTP request nicht bei NodeRed an.

                            M 1 Reply Last reply
                            0
                            • Z zzippo

                              @Marsx79
                              Natürlich kannst Du das prüfen. Am besten erst einmal Debug Nodes in NodeRed anlegen, z.B. wie hier:
                              NodeRedDebug.png
                              Die debug nodes sollten so konfiguriert sein, das sie immer das gesammte Telegramm anzeigen:
                              NodeRedDebug2.png
                              Wenn Du es deploy'st und dann Alexa einen Schaltbefehl gibst solltest Du in etwa folgenden Output im Debug Tab sehen:
                              NodeRedDebug3.png
                              Hier wird eine Steckdose geschatltet, welche keiner speziellen Alexa zugeordnet ist.
                              Wenn z.B. kein Output im Debug erscheint, dann kommt auch der HTTP request nicht bei NodeRed an.

                              M Offline
                              M Offline
                              Marsx79
                              wrote on last edited by
                              #51

                              @zzippo
                              NodeRed.jpg

                              Bei mir sieht das so aus.

                              Z 1 Reply Last reply
                              0
                              • M Marsx79

                                @zzippo
                                NodeRed.jpg

                                Bei mir sieht das so aus.

                                Z Offline
                                Z Offline
                                zzippo
                                wrote on last edited by zzippo
                                #52

                                @Marsx79
                                Dann liegt es am Eintrag in der Datenbank, ich nehme nicht an das Du dort 'test' falsch geschrieben hast. Eher ist das Feld 'WelcheAlexa' nicht NULL sondert 'Leer'.
                                Zeig mal einen Screenshot.

                                M 1 Reply Last reply
                                0
                                • Z zzippo

                                  @Marsx79
                                  Dann liegt es am Eintrag in der Datenbank, ich nehme nicht an das Du dort 'test' falsch geschrieben hast. Eher ist das Feld 'WelcheAlexa' nicht NULL sondert 'Leer'.
                                  Zeig mal einen Screenshot.

                                  M Offline
                                  M Offline
                                  Marsx79
                                  wrote on last edited by
                                  #53

                                  @zzippo

                                  sql.jpg

                                  Dürfen die Felder nicht leer sein? Muss ich dort "Null" eintragen? Mir ist auch noch nicht ganz klar für was die einzelnen Felder sind.

                                  Z 1 Reply Last reply
                                  0
                                  • M Marsx79

                                    @zzippo

                                    sql.jpg

                                    Dürfen die Felder nicht leer sein? Muss ich dort "Null" eintragen? Mir ist auch noch nicht ganz klar für was die einzelnen Felder sind.

                                    Z Offline
                                    Z Offline
                                    zzippo
                                    wrote on last edited by zzippo
                                    #54

                                    @Marsx79 OK, dann erkläre ich das mal.
                                    Also bei einfügen einer neuen Zeile sind erst einmal alle Felder auf NULL. Wobei das kein Text ist, sondern heisst, das es keinen Eintrag gibt.
                                    Da Du den DB-Browser benutzt, passiert es schnell das ein NULL Eintrag überschrieben wird. z.B. wenn Du mit Tab durch die Felder läufst.

                                    • Lösungsmöglichkeit 1:
                                      Du setzt das Feld wieder auf NULL (rechte Maustaste auf dem Feld, und 'Auf NULL setzten' anwählen)

                                    • Lösungsmöglichkeit 2:
                                      Das Script im Node-Red in der Node:'SQL for any Alexa' so ändern, das nicht nur auf NULL sondern auch auf Leerstring abgefragt wird. (siehe Zeile 14)

                                    var instance = '';
                                    if (typeof msg.FromSkill.payload.directive.header.instance !== 'undefined')
                                    { instance = "' AND instance = '" + msg.FromSkill.payload.directive.header.instance;}
                                    
                                    
                                    var mode = '';
                                    if (typeof msg.FromSkill.payload.directive.payload.mode !== 'undefined')
                                    { mode = "' AND mode = '" + msg.FromSkill.payload.directive.payload.mode;}
                                    
                                    msg.topic =    "SELECT topic,value,AlexaSpeakOn,AlexaSpeakOff FROM AlexaEndpoints WHERE endpointId = '"  + 
                                                    msg.FromSkill.payload.directive.endpoint.endpointId + 
                                                    instance + 
                                                    mode + 
                                                    "' AND (WelcheAlexa IS NULL OR WelcheAlexa = '');";
                                    return msg;
                                    

                                    Zu den Einzelnen Feldern der Datenbank:

                                    • EndpointID: Das ist die ID des Gerätes, diese hast Du beim Anlegen im Device generator definiert.
                                      Sie wird von der Alexa App übertragen, damit Du weisst welches Gerät angesprochen wird.
                                    • Controller: ist nur für Dich als Info welche Art controller es ist, wird sonst (noch) nirgends benutzt.
                                    • comment: Nur ein Kommentar für Dich, wird sonst nicht benutzt.
                                    • instance: Dies ist für Mode Controller, da eine Endpoint ID mehrere Mode-Controller haben kann. ist sozusagen auch eine ID. Z.B. hast Du einen Enpoint Kueche, dieser hat einen Mode-Controller für Rollos und einen für ein farbiges Licht.
                                      Du könntest dann Deine instancen z.B. 'kueche.rollo' und 'kueche.farbe' nennen.
                                      Hier trägst Du also den Namen ein welchen Du im Device Generator vergeben hast.
                                      Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                    • mode: Das ist der mode für die instance, z.B. hast du die Instance 'kueche.rollo' und dann jeweils einen mode für 'auf' und 'ab', wieder Die ID eintagen welche Du im Device Generator vergeben hast.Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                    • topic: Das ist die IO-Broker Variable, welche Du schalten möchtest. Bitte immer darauf achten welchen Typen die Variable haben will. Aus dem Power-Controller kommt standardmässig immer true/false
                                    • value: Bei Power-Controller wird automatisch true/false übertragen, Bei Percentage und anderen der gesprochene Wert. In diesen Fällen kann also der Wert freigelassen werden. Bei Mode-Controllern kannst Du hier den Wert eintragen der an die topic variable gesendet werden soll.
                                    • WelcheAlexa: Du kannst zum Beispiel im Device-Generator ein Gerät anlegen, welches Stehlampe heißt, Du hast aber 3 Stehlampen im Haus, über die Angabe der Alexa kannst Du dann steuern welche Stehlampe geschaltet wird.
                                      Du machst also 3 Zeilen in der Datenbank mit jeweils dem gleichen Endpoint, aber mit unterschiedlichen Alexas.
                                    • AlexaSpeakOn: Für Powercontroller, Antwort von Alexa bei 'Ein', für Alle anderen Contoller: Antwort von Alexa,
                                      -AlexaSpeakOff: Nur für Powercontroller, Antwort von Alexa bei 'Aus'

                                    Ausserdem kannst Du mehrere Geräte gleichzeitig schalten, indem du einfach in mehreren Zeilen die gleiche Enpoint-ID, mit unterschiedlichen topics benutzt.
                                    z.B habe ich ein Kommando 'alles Aus' welches diverse Lampen und Steckdosen ausschaltet.

                                    Ich hoffe das hilft ersteinmal weiter.

                                    M M 2 Replies Last reply
                                    0
                                    • Z zzippo

                                      @Marsx79 OK, dann erkläre ich das mal.
                                      Also bei einfügen einer neuen Zeile sind erst einmal alle Felder auf NULL. Wobei das kein Text ist, sondern heisst, das es keinen Eintrag gibt.
                                      Da Du den DB-Browser benutzt, passiert es schnell das ein NULL Eintrag überschrieben wird. z.B. wenn Du mit Tab durch die Felder läufst.

                                      • Lösungsmöglichkeit 1:
                                        Du setzt das Feld wieder auf NULL (rechte Maustaste auf dem Feld, und 'Auf NULL setzten' anwählen)

                                      • Lösungsmöglichkeit 2:
                                        Das Script im Node-Red in der Node:'SQL for any Alexa' so ändern, das nicht nur auf NULL sondern auch auf Leerstring abgefragt wird. (siehe Zeile 14)

                                      var instance = '';
                                      if (typeof msg.FromSkill.payload.directive.header.instance !== 'undefined')
                                      { instance = "' AND instance = '" + msg.FromSkill.payload.directive.header.instance;}
                                      
                                      
                                      var mode = '';
                                      if (typeof msg.FromSkill.payload.directive.payload.mode !== 'undefined')
                                      { mode = "' AND mode = '" + msg.FromSkill.payload.directive.payload.mode;}
                                      
                                      msg.topic =    "SELECT topic,value,AlexaSpeakOn,AlexaSpeakOff FROM AlexaEndpoints WHERE endpointId = '"  + 
                                                      msg.FromSkill.payload.directive.endpoint.endpointId + 
                                                      instance + 
                                                      mode + 
                                                      "' AND (WelcheAlexa IS NULL OR WelcheAlexa = '');";
                                      return msg;
                                      

                                      Zu den Einzelnen Feldern der Datenbank:

                                      • EndpointID: Das ist die ID des Gerätes, diese hast Du beim Anlegen im Device generator definiert.
                                        Sie wird von der Alexa App übertragen, damit Du weisst welches Gerät angesprochen wird.
                                      • Controller: ist nur für Dich als Info welche Art controller es ist, wird sonst (noch) nirgends benutzt.
                                      • comment: Nur ein Kommentar für Dich, wird sonst nicht benutzt.
                                      • instance: Dies ist für Mode Controller, da eine Endpoint ID mehrere Mode-Controller haben kann. ist sozusagen auch eine ID. Z.B. hast Du einen Enpoint Kueche, dieser hat einen Mode-Controller für Rollos und einen für ein farbiges Licht.
                                        Du könntest dann Deine instancen z.B. 'kueche.rollo' und 'kueche.farbe' nennen.
                                        Hier trägst Du also den Namen ein welchen Du im Device Generator vergeben hast.
                                        Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                      • mode: Das ist der mode für die instance, z.B. hast du die Instance 'kueche.rollo' und dann jeweils einen mode für 'auf' und 'ab', wieder Die ID eintagen welche Du im Device Generator vergeben hast.Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                      • topic: Das ist die IO-Broker Variable, welche Du schalten möchtest. Bitte immer darauf achten welchen Typen die Variable haben will. Aus dem Power-Controller kommt standardmässig immer true/false
                                      • value: Bei Power-Controller wird automatisch true/false übertragen, Bei Percentage und anderen der gesprochene Wert. In diesen Fällen kann also der Wert freigelassen werden. Bei Mode-Controllern kannst Du hier den Wert eintragen der an die topic variable gesendet werden soll.
                                      • WelcheAlexa: Du kannst zum Beispiel im Device-Generator ein Gerät anlegen, welches Stehlampe heißt, Du hast aber 3 Stehlampen im Haus, über die Angabe der Alexa kannst Du dann steuern welche Stehlampe geschaltet wird.
                                        Du machst also 3 Zeilen in der Datenbank mit jeweils dem gleichen Endpoint, aber mit unterschiedlichen Alexas.
                                      • AlexaSpeakOn: Für Powercontroller, Antwort von Alexa bei 'Ein', für Alle anderen Contoller: Antwort von Alexa,
                                        -AlexaSpeakOff: Nur für Powercontroller, Antwort von Alexa bei 'Aus'

                                      Ausserdem kannst Du mehrere Geräte gleichzeitig schalten, indem du einfach in mehreren Zeilen die gleiche Enpoint-ID, mit unterschiedlichen topics benutzt.
                                      z.B habe ich ein Kommando 'alles Aus' welches diverse Lampen und Steckdosen ausschaltet.

                                      Ich hoffe das hilft ersteinmal weiter.

                                      M Offline
                                      M Offline
                                      mech
                                      wrote on last edited by
                                      #55

                                      @zzippo danke für diese tolle Möglichkeit. Ich komme leider aktuell nicht zum ausprobieren, freue mich aber darauf hier weiter zu lesen.

                                      Weiter so!

                                      Gruß

                                      1 Reply Last reply
                                      0
                                      • Z zzippo

                                        @Marsx79 OK, dann erkläre ich das mal.
                                        Also bei einfügen einer neuen Zeile sind erst einmal alle Felder auf NULL. Wobei das kein Text ist, sondern heisst, das es keinen Eintrag gibt.
                                        Da Du den DB-Browser benutzt, passiert es schnell das ein NULL Eintrag überschrieben wird. z.B. wenn Du mit Tab durch die Felder läufst.

                                        • Lösungsmöglichkeit 1:
                                          Du setzt das Feld wieder auf NULL (rechte Maustaste auf dem Feld, und 'Auf NULL setzten' anwählen)

                                        • Lösungsmöglichkeit 2:
                                          Das Script im Node-Red in der Node:'SQL for any Alexa' so ändern, das nicht nur auf NULL sondern auch auf Leerstring abgefragt wird. (siehe Zeile 14)

                                        var instance = '';
                                        if (typeof msg.FromSkill.payload.directive.header.instance !== 'undefined')
                                        { instance = "' AND instance = '" + msg.FromSkill.payload.directive.header.instance;}
                                        
                                        
                                        var mode = '';
                                        if (typeof msg.FromSkill.payload.directive.payload.mode !== 'undefined')
                                        { mode = "' AND mode = '" + msg.FromSkill.payload.directive.payload.mode;}
                                        
                                        msg.topic =    "SELECT topic,value,AlexaSpeakOn,AlexaSpeakOff FROM AlexaEndpoints WHERE endpointId = '"  + 
                                                        msg.FromSkill.payload.directive.endpoint.endpointId + 
                                                        instance + 
                                                        mode + 
                                                        "' AND (WelcheAlexa IS NULL OR WelcheAlexa = '');";
                                        return msg;
                                        

                                        Zu den Einzelnen Feldern der Datenbank:

                                        • EndpointID: Das ist die ID des Gerätes, diese hast Du beim Anlegen im Device generator definiert.
                                          Sie wird von der Alexa App übertragen, damit Du weisst welches Gerät angesprochen wird.
                                        • Controller: ist nur für Dich als Info welche Art controller es ist, wird sonst (noch) nirgends benutzt.
                                        • comment: Nur ein Kommentar für Dich, wird sonst nicht benutzt.
                                        • instance: Dies ist für Mode Controller, da eine Endpoint ID mehrere Mode-Controller haben kann. ist sozusagen auch eine ID. Z.B. hast Du einen Enpoint Kueche, dieser hat einen Mode-Controller für Rollos und einen für ein farbiges Licht.
                                          Du könntest dann Deine instancen z.B. 'kueche.rollo' und 'kueche.farbe' nennen.
                                          Hier trägst Du also den Namen ein welchen Du im Device Generator vergeben hast.
                                          Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                        • mode: Das ist der mode für die instance, z.B. hast du die Instance 'kueche.rollo' und dann jeweils einen mode für 'auf' und 'ab', wieder Die ID eintagen welche Du im Device Generator vergeben hast.Bei nicht Mode-Controllern einfach das Feld leer lassen.
                                        • topic: Das ist die IO-Broker Variable, welche Du schalten möchtest. Bitte immer darauf achten welchen Typen die Variable haben will. Aus dem Power-Controller kommt standardmässig immer true/false
                                        • value: Bei Power-Controller wird automatisch true/false übertragen, Bei Percentage und anderen der gesprochene Wert. In diesen Fällen kann also der Wert freigelassen werden. Bei Mode-Controllern kannst Du hier den Wert eintragen der an die topic variable gesendet werden soll.
                                        • WelcheAlexa: Du kannst zum Beispiel im Device-Generator ein Gerät anlegen, welches Stehlampe heißt, Du hast aber 3 Stehlampen im Haus, über die Angabe der Alexa kannst Du dann steuern welche Stehlampe geschaltet wird.
                                          Du machst also 3 Zeilen in der Datenbank mit jeweils dem gleichen Endpoint, aber mit unterschiedlichen Alexas.
                                        • AlexaSpeakOn: Für Powercontroller, Antwort von Alexa bei 'Ein', für Alle anderen Contoller: Antwort von Alexa,
                                          -AlexaSpeakOff: Nur für Powercontroller, Antwort von Alexa bei 'Aus'

                                        Ausserdem kannst Du mehrere Geräte gleichzeitig schalten, indem du einfach in mehreren Zeilen die gleiche Enpoint-ID, mit unterschiedlichen topics benutzt.
                                        z.B habe ich ein Kommando 'alles Aus' welches diverse Lampen und Steckdosen ausschaltet.

                                        Ich hoffe das hilft ersteinmal weiter.

                                        M Offline
                                        M Offline
                                        Marsx79
                                        wrote on last edited by Marsx79
                                        #56

                                        @zzippo

                                        Super es funktioniert! Danke für die tolle Erklärung!

                                        1 Reply Last reply
                                        0
                                        • M Offline
                                          M Offline
                                          Marsx79
                                          wrote on last edited by Marsx79
                                          #57

                                          Ich hätte da aber noch zwei weitere Fragen:

                                          1. Hat schon jemand "Thermostat Regler" probiert? Die Alexa App findet zwar das Gerät aber wenn ich dann da drauf gehe sagt diese nur "Warte auf Verbindung..." und dann geht es nicht weiter.

                                          2. Wenn ich eine dimmbare Lampe habe die keinen Datenpunkt für "an und aus" (also true und false) hat, sondern nur einen Datenpunkt für 0 - 99 (wobei 0 aus und 99 an ist) hat. Wie kann ich das machen? "Helligkeits Regler" funktioniert zwar für die Prozentangabe aber nicht für an/aus.

                                          Z 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          104

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe