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

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Bose Soundtouch steuern

    This topic has been deleted. Only users with topic management privileges can see it.
    • 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
                                    • SwedishChef
                                      SwedishChef last edited by

                                      Und da wären auch schon meine ersten Probleme:

                                      auf https://github.com/SwedishChef1/iobroker.bosesoundtouch ist eine erste Version, die allerdings beim schon beim Installieren folgenden Fehler meldet:

                                      module.js:529

                                      throw err;

                                      ^

                                      Error: Cannot find module 'string-format'

                                      Ich hab die notwendigen Pakete in package.json eingetragen:

                                      …

                                      "dependencies": {

                                      "request": "^2.83.0",

                                      "es6-promise": "^4.1.1",

                                      "xml2js": "^0.4.19",

                                      "ws": "^3.2.0",

                                      "string-format": "^0.5.0"

                                      },

                                      diese werden aber offensichtlich nicht automatisch installiert. Was mache ich falsch bzw. was fehlt hier noch? In meiner Debug-Umgebung hab ich diese Pakete natürlich händisch installiert, hätte aber angenommen, dass das durch die Auflistung in package.json automatisch geschieht.

                                      Somit kann ich auch schwer testen, ob der Rest halbwegs funktioniert.

                                      Bitte um eure Hilfe - Danke.

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

                                        Hey,

                                        also ich kann den Adapter installieren vom Github … also das klappt.

                                        Danach geht nur nix weil "/lib/utils.js" fehlt. Das muss noch rein, sonst findet der Adapter den js-controller nicht.

                                        Und am besten anstelle "setObject" immer "setObjectNotExists" nehmen ...

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

                                          Fast vergessen: die fehlende Datei und auch einige andere kleine Verbesserung sind längst auf GitHub verfügbar.

                                          Inzwischen funktioniert auch meine Debug-Umgebung fast reibungsfrei.

                                          Wie sehen eure ersten Erfahrungen mit diesem Adapter aus?

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

                                            Cool, teste später mal. Hab die Korrekturen nicht mitbekommen 😉

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            916
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            36
                                            286
                                            65252
                                            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