Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Bose Soundtouch steuern

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Bose Soundtouch steuern

    This topic has been deleted. Only users with topic management privileges can see it.
    • htrecksler
      htrecksler Forum Testing last edited by

      Mit diesen beiden Befehlen sollte es funktionieren.

      '<key state="press" sender="Gabbo">POWER</key>'
      
      
      '<key state="release" sender="Gabbo">POWER</key>'
      
      

      Im Prinzip sagt man damit der Soundtouch:

      1. Drücke den Power Button

      2. Lasse ihn wieder los.

      Ich komme heute leider nicht dazu den kompletten Code zu testen, falls du damit so nicht klar kommst gib mir eine kurze Info, dann mache ich morgen ein komplettes Beispiel….

      Gruss Hermann

      1 Reply Last reply Reply Quote 0
      • G
        gogohome last edited by

        Hi

        habe folgenden Code geschrieben.

        Kann das Objekt auch in iobroker vis sehen und benutzen.

        Leider geht die Soundtouch Anlage nicht an.

        Ist der Code eigentlich OK.

        createState('Bose_Power', {type: 'boolean'});
        
        function PowerSetzen() {
            var BodyString = '<key state="press" sender="Gabbo">POWER</key>';
            var request = require('request');
            request.post({
                url:     'http://192.168.178.43:8090/key',
                body:    BodyString
            }, function(error, response, body) {
                if (error) log(error, 'error');
            });
        }
        function PowerClear() {
            var BodyString = '<key state="release" sender="Gabbo">POWER</key>';
            var request = require('request');
            request.post({
                url:     'http://192.168.178.43:8090/key',
                body:    BodyString
            }, function(error, response, body) {
                if (error) log(error, 'error');
            });
        }
        
        on ({id: "javascript.0.Bose_Power", val: true}, function () {
            PowerSetzen;
            PowerClear;
            setState("javascript.0.Bose_Power", false);
        });
        
        1 Reply Last reply Reply Quote 0
        • P
          Phantomio last edited by

          Hallo,

          das steuern der Soundtouch bekomme ich schon hin.

          Hat es einer von euch schon geschafft auch etwas auszulesen:

          z.B. was wird gerade gestream

          oder ob die Soundtouch gerade an oder aus ist.

          Ich habe in einem neuem Thema auch noch mal die Frage gestellt, ob eine Sprachausgabe wie bei Sonos möglich ist http://forum.iobroker.net/viewtopic.php … hilit=Bose

          Evtl. hat ja einer von euch eine Idee.

          Mann könnte sich zwar auch Sonos kaufen, aber die Preset Tasten von Bose sind schon cool 8-)

          Gruß

          Phantomio

          1 Reply Last reply Reply Quote 0
          • S
            stoepselinho last edited by

            gibt es schon einen fertigen Adapter für Bose?

            1 Reply Last reply Reply Quote 0
            • M
              Master77 last edited by

              Das würde mich auch interessieren.

              Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

              1 Reply Last reply Reply Quote 0
              • L
                lubeda last edited by

                @Master77:

                Das würde mich auch interessieren. `

                Mich auch 😄 , ich habe eigentlich FHEM nur noch wegen diesem Adapter laufen.

                Ich mache alle Sprachausgaben von ioBroker über FHEM. Das FHEM dazu einen Minidlna Server benötigt gefällt mir auch nicht wirklich.

                Aber bei der Programierung bin ich raus, da kann ich nicht helfen.

                1 Reply Last reply Reply Quote 0
                • apollon77
                  apollon77 last edited by

                  So ein Adapter steht auf meiner Todo-Liste … aber anderes steht vorher da 🙂

                  Um einen "Mini-DLNA-Server" (auch wenn er wenn dann in ioBroker läuft) kommt man wohl auch nicht drum rum 😞

                  1 Reply Last reply Reply Quote 0
                  • N
                    Nanouk last edited by

                    Wie würde denn der Teil für Power aussehen?

                    Also quasi das Skript so erweitert das man bei VIS einen Power On/Off Widget hätte?

                    Könnte man auch beim Einschalten / Preset schalten alle Soundtouch Lautsprecher verbinden?

                    Grüße

                    Oliver

                    1 Reply Last reply Reply Quote 0
                    • N
                      Nanouk last edited by

                      Also den Power Button habe ich jetzt auch hinbekommen.

                      createState('BoseVolume', 10);
                      createState('Bose_Power',   {type: 'boolean'});
                      createState('Bose_Preset_1', {type: 'boolean'});
                      createState('Bose_Preset_2', {type: 'boolean'});
                      createState('Bose_Preset_3', {type: 'boolean'});
                      createState('Bose_Preset_4', {type: 'boolean'});
                      createState('Bose_Preset_5', {type: 'boolean'});
                      createState('Bose_Preset_6', {type: 'boolean'});
                      
                      function PowerSetzen() {
                          var BodyString = '<key state="press" sender="Gabbo">POWER</key>';
                          var request = require('request');
                          request.post({
                              url:     'http://Bose IP:8090/key',
                              body:    BodyString
                          }, function(error, response, body) {
                              if (error) log(error, 'error');
                          });
                      }
                      function PowerClear() {
                          var BodyString = '<key state="release" sender="Gabbo">POWER</key>';
                          var request = require('request');
                          request.post({
                              url:     'http://Bose IP:8090/key',
                              body:    BodyString
                          }, function(error, response, body) {
                              if (error) log(error, 'error');
                          });
                      }
                      
                      function PresetSetzen(pWert) {
                          var BodyString = '<key state="release" sender="Gabbo">' + pWert + '</key>';
                          var request = require('request');
                          request.post({
                              url:     'http://Bose IP:8090/key',
                              //body:    '<volume>20</volume>'
                              body:    BodyString
                          }, function(error, response, body) {
                              if (error) log(error, 'error');
                          });
                      }
                      
                      function VolumeSetzen(pWert) {
                          var BodyString = '<volume>' + pWert + '</volume>';
                          var request = require('request');
                          request.post({
                              url:     'http://Bose IP:8090/volume',
                              //body:    '<volume>20</volume>'
                              body:    BodyString
                          }, function(error, response, body) {
                              if (error) log(error, 'error');
                          });
                      }
                      
                      on ({id: "javascript.0.Bose_Power", val: true}, function () {
                          PowerSetzen('Power');
                          setState("javascript.0.Bose_Power", false);
                      });
                      
                      on ({id: "javascript.0.BoseVolume", change: "ne"}, function () {
                          lVolume = getState("javascript.0.BoseVolume");
                          VolumeSetzen(lVolume.val);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_1", val: true}, function () {
                          PresetSetzen('PRESET_1');
                          setState("javascript.0.Bose_Preset_1", false);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_2", val: true}, function () {
                          PresetSetzen('PRESET_2');
                          setState("javascript.0.Bose_Preset_2", false);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_3", val: true}, function () {
                          PresetSetzen('PRESET_3');
                          setState("javascript.0.Bose_Preset_3", false);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_4", val: true}, function () {
                          PresetSetzen('PRESET_4');
                          setState("javascript.0.Bose_Preset_4", false);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_5", val: true}, function () {
                          PresetSetzen('PRESET_5');
                          setState("javascript.0.Bose_Preset_5", false);
                      });
                      
                      on ({id: "javascript.0.Bose_Preset_6", val: true}, function () {
                          PresetSetzen('PRESET_6');
                          setState("javascript.0.Bose_Preset_6", false);
                      });
                      
                      

                      Leider kenne ich mich mit Javascript nicht aus und die Implementierung von /set_Zone überfordert mich. 🙂

                      Vielleicht hat das schon jemand erfolgreich laufen?

                      Gruß Oliver

                      1 Reply Last reply Reply Quote 0
                      • N
                        Nanouk last edited by

                        Hallo,

                        @apollon77: gibts schon was neues zu dem Soundtouch Adapter?

                        Viele Grüße

                        Oliver

                        1 Reply Last reply Reply Quote 0
                        • apollon77
                          apollon77 last edited by

                          Ich kam noch zu nichts …

                          1 Reply Last reply Reply Quote 0
                          • SwedishChef
                            SwedishChef last edited by

                            Hallo Leute,

                            ich bin seit ein paar Tagen dran, für die Bose SoundTouch einen Adapter zu basteln. Per JavaScript hab ich schon den code soweit beisammen, dass ich keys (z.B. 'POWER') per HTTP-push senden kann.

                            Statusabfragen per HTTP-get (z.B. http://bosesoundtouch-ip:8090/volume) funktionieren auch und auch ein websocket, der Statusänderungen der soundbar mitbekommt und entsprechend parsed (aktuell volume, now_playing und presets) läuft.

                            Jetzt starte ich, das ganze zu einem Adapter umzubauen, werke gerade am Aufbau einer debug-Umgebung mit VS Code. Mehr als ein leeres Adapter-Template von GitHub hab ich aber noch nicht am Laufen. Wird also noch eine Weile dauern.

                            JavaScript hab ich erst mit diesem Projekt 'erlernt', war bisher rein auf C/C++/C# unterwegs. Brauche also für alles entsprechend Einarbeitungszeit.

                            bis bald…

                            1 Reply Last reply Reply Quote 0
                            • M
                              Master77 last edited by

                              Super, und danke für die Zwischeninfo. Würde dir gern dabei helfen aber ich kenne mich leider null damit aus. Danke das du dich der Sache annimmst.

                              Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

                              1 Reply Last reply Reply Quote 0
                              • apollon77
                                apollon77 last edited by

                                Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ?! Oder baust du die ganze Kommunikation gerade selbst?

                                1 Reply Last reply Reply Quote 0
                                • SwedishChef
                                  SwedishChef last edited by

                                  @apollon77:

                                  Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ? ` Welche npm-Projekte gäbe es da?

                                  Das Grundgerüst für meinen Code stammt von https://github.com/ChrisScheffler/node-soundtouch. Ich musste hier aber einige Änderungen vornehmen, hauptsächlich beim Parsen der empfangenen Pakete. Hier dürfte sich an der API von Bose inzwischen einiges geändert haben.

                                  Ich verwende folgende npm-pakete:

                                  • request - sendet auf Port 8090 Befehle (push - Lautstärke setzen, POWER-key…) und Statusanforderungen (get - aktuelle Lautstärke, Now playing...)

                                  • ws - WebSocket, der auf port 8080 auf Updates der SoundTouch hört (Lautstärkeänderungen, Now playing…)

                                  • xml2js - parsen der empfangenen Daten

                                  • es6-promise - hab ich einfach so übernommen

                                  Hab gestern noch den ioBroker samt meinem Adapter-Template und VS-Code debug Umgebung auf meinem Windows PC grob zum Laufen gebracht. Jetzt muss ich noch meinen Script-code einpflegen. Sobald ich in den nächsten Tagen eine erste Version am Laufen hab, kann ich ihn zu Testzwecken bereitstellen. Auch hier muss ich mich erst Schlau machen, wie man da vorgeht.

                                  Bis demnächst.

                                  1 Reply Last reply Reply Quote 0
                                  • Bluefox
                                    Bluefox last edited by

                                    @SwedishChef:

                                    @apollon77:

                                    Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ? ` Welche npm-Projekte gäbe es da?

                                    Das Grundgerüst für meinen Code stammt von https://github.com/ChrisScheffler/node-soundtouch. Ich musste hier aber einige Änderungen vornehmen, hauptsächlich beim Parsen der empfangenen Pakete. Hier dürfte sich an der API von Bose inzwischen einiges geändert haben.

                                    Ich verwende folgende npm-pakete:

                                    • request - sendet auf Port 8090 Befehle (push - Lautstärke setzen, POWER-key…) und Statusanforderungen (get - aktuelle Lautstärke, Now playing...)

                                    • ws - WebSocket, der auf port 8080 auf Updates der SoundTouch hört (Lautstärkeänderungen, Now playing…)

                                    • xml2js - parsen der empfangenen Daten

                                    • es6-promise - hab ich einfach so übernommen

                                    Hab gestern noch den ioBroker samt meinem Adapter-Template und VS-Code debug Umgebung auf meinem Windows PC grob zum Laufen gebracht. Jetzt muss ich noch meinen Script-code einpflegen. Sobald ich in den nächsten Tagen eine erste Version am Laufen hab, kann ich ihn zu Testzwecken bereitstellen. Auch hier muss ich mich erst Schlau machen, wie man da vorgeht.

                                    Bis demnächst. `
                                    Interessant währe auch noch discovery zu implementieren:

                                    https://github.com/CONNCTED/SoundTouch- … scovery.js

                                    1 Reply Last reply Reply Quote 0
                                    • apollon77
                                      apollon77 last edited by

                                      @SwedishChef:

                                      @apollon77:

                                      Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ? Welche npm-Projekte gäbe es da?

                                      Erst einmal willkommen unter den Adapter-Entwicklern 🙂

                                      Im Trello unter https://trello.com/c/BBntjcUq gibts auch schon eine Karte dafür.

                                      Wäre cool wenn Du dich zu Trello anmeldest (und mir deinen Namen schickst, dann schalte ich dich frei). Dann kannst Du die Karte übernehmen.

                                      Dort hatte ich auch mal Links gesammelt. Zusätzlich noch aus meiner privaten Sammlung:

                                      https://github.com/CONNCTED/SoundTouch-NodeJS

                                      https://github.com/CONNCTED/homebridge- … r/index.js

                                      https://www.npmjs.com/package/homebridge-soundtouch

                                      http://www.nikolaus-lueneburg.de/2017/0 ... ay-teil-2/

                                      Wenn natürlich node-Libs vom npm nicht mehr aktualisiert werden ist das blöd. Neben einem Fork ginge aber mit dem Entwickler zu schreiben ob der es nicht auch aktualisieren will oder Pull-Requests einzureichen ... hilft dann allen 🙂

                                      Wenn Du Fragen hast bitte Bescheid geben

                                      1 Reply Last reply Reply Quote 0
                                      • SwedishChef
                                        SwedishChef last edited by

                                        Eine erste Version werde ich voraussichtlich am Mittwoch zur Verfügung stellen können.

                                        Bin aktuell unterwegs und muss mich dann noch schlau machen, wie so ein pre-release funktioniert. GitHub?

                                        Gesendet von meinem A0001 mit Tapatalk

                                        1 Reply Last reply Reply Quote 0
                                        • M
                                          Master77 last edited by

                                          Super. Vielen Dank. [emoji106]

                                          Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

                                          1 Reply Last reply Reply Quote 0
                                          • apollon77
                                            apollon77 last edited by

                                            Vllt hilft das: http://forum.iobroker.net/viewtopic.php?f=24&t=6383 🙂

                                            Ansonsten kurz: Ja, ab auf GitHub damit und dann können die Forum Leute mit dem Link das ganze installieren … später dann npm wenn es mal stable ist

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            903
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            36
                                            286
                                            61949
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo