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
    12
    2
    247

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

  • 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

    @zzippo Ich frage mich wie ich das damals gemacht habe, der richtige Befehl für die Ausgabe des Passwortes wäre:
    echo -n $username:$pass | base64.
    Ich ändere gleich das script, und beseitige auch den Ausgabefehler in Zeile 65.

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

    @zzippo wie fast immer, sitzt das Problem zwischen Stuhl und Monitor. 😠
    kann mich wirklich ärgern über diesen Fehler. Entschuldige bitte, das ich Dir diese Sucherei eingebrockt habe.

    J 1 Reply Last reply
    0
    • Z zzippo

      @zzippo wie fast immer, sitzt das Problem zwischen Stuhl und Monitor. 😠
      kann mich wirklich ärgern über diesen Fehler. Entschuldige bitte, das ich Dir diese Sucherei eingebrockt habe.

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

      @zzippo Danke! Das probiere ich morgen gleich mal aus (habe gerade einen Termin). Hat mir aber Spaß gemacht mich mit dem Thema mal näher zu befassen.

      Schönen Abend noch!

      Z 1 Reply Last reply
      0
      • J jrudolph

        @zzippo Danke! Das probiere ich morgen gleich mal aus (habe gerade einen Termin). Hat mir aber Spaß gemacht mich mit dem Thema mal näher zu befassen.

        Schönen Abend noch!

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

        @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 J 3 Replies 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
          #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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          83

                                          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