NEWS
Bose Soundtouch steuern
-
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
-
Coooooooole Nummer!!
Es geht grundsätzlich.
Folgende Dinge:
1.) Ich habe rausgefunden das ich in "key" was schreiben muss damit ich Aktionen auslösen kann. ne Liste der Aktionen wäre cool, vllt damit die README.md starten? Google hat grob geholfen. habe das gefunden:
` > PLAY
PAUSE
STOP
PREV_TRACK
NEXT_TRACK
THUMBS_UP
THUMBS_DOWN
POWER
MUTE
VOLUME_UP
VOLUME_DOWN
PRESET_1
PRESET_2
PRESET_3
PRESET_4
PRESET_5
PRESET_6
AUX_INPUT
SHUFFLE_OFF
SHUFFLE_ON
REPEAT_OFF
REPEAT_ONE
REPEAT_ALL
PLAY_PAUSE
ADD_FAVORITE
REMOVE_FAVORITE `
Kannst ja mal überlegen was noch als buttons/switches (also Datenounkte) direkt sinn machtSchade das ich nicht meine sonstigen Quellen meiner Bose Lifestyle anwählen kann, Ich sehe nur das "LOCAL" als SOurce bedeutet das es die Lifestyle ist, aber nicht was schade
2.) Alternativ den "preset.x"-Channeln jeweils noch nen "Play-now" State verpassen als Button der dann dieses preset startet?! Dann braucht man die Liste aus 1 eigentlich nicht mehr Es sei denn es sind noch andere Keys verfügbar.
3.) Das "aktuell gespielte" wird bei mir nicht korrekt gefüllt. Es kommt laut Debug vom Gerät, wird aber alles leer geschrieben. Hier Debug:
` > 2017-11-14 21:39:18.551 - debug: bosesoundtouch.0 {"updates":{"deviceID":"A0F6FD5D0C31","nowPlayingUpdated":{"nowPlaying":{"deviceID":"A0F6FD5D0C31","source":"STORED_MUSIC","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","ContentItem":{"source":"STORED_MUSIC","location":"25$2","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Jarre-Musik"},"track":"Beautiful agony/Jean Michel Jarre","artist":"Jean Michel Jarre","album":"Téo & Téa","offset":"98","art":{"_":"http://192.168.178.23:50002/transcoder/ … ousEnabled":""}}}}
2017-11-14 21:39:18.552 - debug: bosesoundtouch.0 received [now_playing] {"deviceID":"A0F6FD5D0C31","source":"STORED_MUSIC","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","ContentItem":{"source":"STORED_MUSIC","location":"25$2","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Jarre-Musik"},"track":"Beautiful agony/Jean Michel Jarre","artist":"Jean Michel Jarre","album":"Téo & Téa","offset":"98","art":{"_":"http://192.168.178.23:50002/transcoder/ … ousEnabled":""}
2017-11-14 21:39:18.555 - debug: bosesoundtouch.0 _restartHeartBeat
2017-11-14 21:39:18.565 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.nowPlaying.source {"val":"STORED_MUSIC","ack":true,"ts":1510691958553,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691651011}
2017-11-14 21:39:18.566 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.nowPlaying.track {"val":"","ack":true,"ts":1510691958556,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691126283}
2017-11-14 21:39:18.571 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.nowPlaying.artist {"val":"","ack":true,"ts":1510691958558,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691126287}
2017-11-14 21:39:18.575 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.nowPlaying.album {"val":"","ack":true,"ts":1510691958566,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691126287}
2017-11-14 21:39:18.575 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.nowPlaying.station {"val":"","ack":true,"ts":1510691958568,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691639781}
2017-11-14 21:39:18.581 - info: bosesoundtouch.0 stateChange bosesoundtouch.0.on {"val":true,"ack":true,"ts":1510691958575,"q":0,"from":"system.adapter.bosesoundtouch.0","lc":1510691126288} `
Vllt kann man ja nich mehr der Infos die zurükkommen, also Album-Bild, Shuffle, Repeat, Zeit/Dauer des Tracks und so als Datenpunkte verfügbar machen …Und noch Debug nach Umschalte auf nen Internet-Radio-Stream (Sunshine Live):
> 2017-11-14 21:44:52.371 - debug: bosesoundtouch.0 {"updates":{"deviceID":"A0F6FD5D0C31","recentsUpdated":{"recents":{"recent":[{"deviceID":"A0F6FD5D0C31","utcTime":"1510692292","id":"0","contentItem":{"source":"INTERNET_RADIO","location":"44882","sourceAccount":"","isPresetable":"true","itemName":"Sunshine Live Classics","containerArt":"[http://item.radio456.com/007452/logo/lo … :](http://item.radio456.com/007452/logo/logo-44882.jpg%22%7D%7D,%7B%22deviceID%22:%22A0F6FD5D0C31%22,%22utcTime%22:%221510691651%22,%22id%22:%220%22,%22contentItem%22:%7B%22source%22:%22STORED_MUSIC%22,%22location%22:%2225$2%22,%22sourceAccount%22:%220011321a-bd63-0011-63bd-63bd1a321100/0%22,%22isPresetable%22:%22true%22,%22itemName%22:%22Jarre-Musik%22%7D%7D,%7B%22deviceID%22:%22A0F6FD5D0C31%22,%22utcTime%22:%221510090207%22,%22id%22:%220%22,%22contentItem%22:%7B%22source%22:%22STORED_MUSIC%22,%22location%22:%2225$1%22,%22sourceAccount%22:%220011321a-bd63-0011-63bd-63bd1a321100/0%22,%22isPresetable%22:%22true%22,%22itemName%22:%22Schiller-Musik%22%7D%7D,%7B%22deviceID%22:%22A0F6FD5D0C31%22,%22utcTime%22:%221505967552%22,%22id%22:%220%22,%22contentItem%22:%7B%22source%22:%22INTERNET_RADIO%22,%22location%22:%2262372%22,%22sourceAccount%22:%22%22,%22isPresetable%22:%22true%22,%22itemName%22:%22Sunshine) Live - 90er","containerArt":"[http://item.radio456.com/007452/logo/lo ... me](http://item.radio456.com/007452/logo/logo-62372.jpg%22%7D%7D,%7B%22deviceID%22:%22A0F6FD5D0C31%22,%22utcTime%22:%221505881612%22,%22id%22:%220%22,%22contentItem%22:%7B%22source%22:%22STORED_MUSIC%22,%22location%22:%2225$0%22,%22sourceAccount%22:%220011321a-bd63-0011-63bd-63bd1a321100/0%22,%22isPresetable%22:%22true%22,%22itemName%22:%22Musik) (ohne Hörbücher)"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1483196106","id":"0","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"28$59759","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Giraffenaffen"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1480751109","id":"0","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"23","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Sämtliche Musik"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1480180686","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"28$51746","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Dreamgirls"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1479791325","id":"0","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"26$#F$50697","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Falscher Hase"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1479099599","id":"0","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"26$#S$47938","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Schiller"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1479035326","id":"0","contentItem":{"unusedField":"0","source":"STORED_MUSIC","location":"26$#J$51822","sourceAccount":"0011321a-bd63-0011-63bd-63bd1a321100/0","isPresetable":"true","itemName":"Jean Michel Jarre"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1479032142","contentItem":{"unusedField":"0","source":"INTERNET_RADIO","location":"4194","sourceAccount":"","isPresetable":"true","itemName":"sunshine live"}},{"deviceID":"A0F6FD5D0C31","utcTime":"1478984919","contentItem":{"unusedField":"0","source":"INTERNET_RADIO","location":"27795","sourceAccount":"","isPresetable":"true","itemName":"Trancebase.FM"}}]}}}}
4.) Kann man Pause/Resume machen?
Code-technisch bekommst Du gleich nen kleinen PR von mir der ein paar DInge ausbügelt, primär aber in den .json Files.
Wenn Du Code hast der "Discovery" einer Bose macht (ich dachte da ging was per UDP oder so?) Dann schick mir den und ich baue es im Discovery Adapter ein
-
Und bau vllt noch einen "connection" Datenpunkt ein der auf true steht wenn die Connection da ist. oder fliegt der Adapter komplett weg falls das nicht gegeben ist?
-
Hallo in die Runde,
leider kann ich den Adapter nicht installieren.
Folgende Fehlermeldung:
ERR! fetch failed https://github.com/SwedishChef1/iobroke … all/master
npm WARN retry will retry, error on last attempt: Error: fetch failed with status code 404
Bezüglich der Aktionen hab ich gerade mal zwei Screenshots aus Fhem Soundtouch Modul gemacht.
Ich habe aber noch nicht versucht ob alle Befehle auch funktionieren.
Play Everywhere in Fhem funktioniert.
Vielleicht gehts es ja auch hier?
~~![](</s><URL url=)http://leenolium.de/media/bose1.jpg" />
~~![](</s><URL url=)http://leenolium.de/media/bose2.jpg" />
Gruß,
Nanouk~~~~
-
Das sind aber scheinbar alles keine "Standardkommandos" … da hat FHEM denke ich was eigenes gemacht und macht daraus dann intern die richtigen Kommandos
-
Vielleicht hilft das:
Bei Play Everywhere:
2017.11.16 07:08:25 5: BOSEST: processXml: $VAR1 = { 'zone' => { 'master' => 'DEVICE ID', 'member' => [ { 'ipaddress' => '192.168.XXX.XXX', 'content' => 'DEVICE ID' }, { 'ipaddress' => '192.168.XXX.XXX', 'content' => 'DEVICE ID' }, { 'content' => 'DEVICE ID', 'ipaddress' => '192.168.XXX.XXX' } ] } };
Kann da gerne noch mehr loggen.
Wenn ich irgendwie helfen kann, gerne.
Gruß Nanouk
-
Ja es scheint direkt per XML noch einiges mehr zu geben was man tun kann …
Ich hab die 1.0er Dokumente der API ... ich versuche mal aktuelle zu bekommen und dann kann ich die auf Anfrage per PN bereitstellen.
Ingo
-
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? `
Zuerst einmal danke an den (die?) Entwickler für den Soundtouch Adapter! Hier meine ersten Erfahrungen:
Ich habe den Adapter installiert und konnte danach sofort die erste Box steuern bzw. habe Informationen davon erhalten. Für meine zweite Box habe ich dann einen zweiten Adapter mit der IP- Adresse dieser Box konfiguriert. Somit habe ich zwei Instanzen bosesoundtouch.0 und bosesoundtouch.1 mit jeweils unterschiedlichen IP-Adressen in der Konfiguration.
Jetzt zum Problem: Bei beiden Instanzen werden die Informationen richtig ausgelesen und aktualisiert. Bei der Instanz bosesoundtouch.0 ist auch die Steuerung (z.B. Volume, On) möglich. Bei der zweiten Instanz geht dieses nicht. Ich habe auch schon die IP- Adressen in der Konfiguration der Instanzen getauscht. Die Steuerung ist immer nur über die Instanz bosesoundtouch.0 möglich.
-
Ich hab leider nur eine Soundtouch zum Testen, werde mir aber morgen das Problem gleich ansehen. Vielleicht finde ich ja den Fehler.
Danke für das Feedback.
Gesendet von meinem A0001 mit Tapatalk
-
…Bei beiden Instanzen werden die Informationen richtig ausgelesen und aktualisiert. Bei der Instanz bosesoundtouch.0 ist auch die Steuerung (z.B. Volume, On) möglich. Bei der zweiten Instanz geht dieses nicht. Ich habe auch schon die IP- Adressen in der Konfiguration der Instanzen getauscht. Die Steuerung ist immer nur über die Instanz bosesoundtouch.0 möglich. `
Bitte teste die beiden Instanzen mit der aktuellsten Version 0.0.8
Ich hoffe, diese Problem behoben zu haben.
-
Bei der Installation des Adapters über den Download- Link von GitHub wird immer noch die Version 0.07 geladen.