NEWS
Bose Soundtouch steuern
-
Das würde mich auch interessieren.
Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk
-
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.
-
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
-
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
-
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
-
-
Ich kam noch zu nichts …
-
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…
-
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
-
Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ?! Oder baust du die ganze Kommunikation gerade selbst?
-
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.
-
-
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: -
-
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
-
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
-
Super. Vielen Dank. [emoji106]
Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk
-
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
-
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.
-
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 ...
-
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?
-
Cool, teste später mal. Hab die Korrekturen nicht mitbekommen