Celem niniejszego artykułu jest zaprezentowanie przykładu integracji systemu mulitroom Sonos z Systemem Grenton Smart Home z wykorzystaniem Gate Http
data:image/s3,"s3://crabby-images/06d38/06d38a6d69670a6aa14aeab5ff41ff32d6bf2d98" alt=""
Urządzenie, które zostało zastosowane w tym przykładzie to SONOS ONE
Integracja ta pozwala nam na:
- sterowaniem nagłośnieniem
- Play, Pause, Next, Previous
- odczyt aktualnego utworu/albumu
Do zrealizowania poniższego przykładu potrzebujemy:
- CLU Z-Wave
- Gate HTTP
- Inteligentny głośnik SONOS
Przygotowanie
- W pierwszym kroku należy skonfigurować głośnik Sonos i połączyć go z lokalną siecią, w której znajduje się CLU i Gate Http.
- Następnie należy przygotować dwa obiekty wirtualne HttpRequest. (GET i POST)
data:image/s3,"s3://crabby-images/0b13b/0b13b1f90ca0b1fb349ec0eaded2633c30eea098" alt=""
- Obiekt HttpRequest o przykładowej nazwie "HttpRequest_post" uzupełniam jak poniżej:
data:image/s3,"s3://crabby-images/047af/047af192500968d00d6683222c78ec4e9fe1d2f6" alt=""
Host: 192.168.7.175:1400 (adres IP SONOS)
Path:/MediaRenderer/AVTransport/Control
Method: POST
RequestType: XML
ResponseType: XML
- Obiekt HttpRequest o przykładowej nazwie "HttpRequest_get_volume" uzupełniam jak poniżej:
data:image/s3,"s3://crabby-images/bbef9/bbef91dd909716473a5c796b22ee5a4072adba4f" alt=""
Host: 192.168.7.175:1400 (adres IP SONOS)
Path:/MediaRenderer/RenderingControl/Control
Method: GET
RequestType: XML
ResponseType: XML
Sterowanie nagłośnieniem
Do płynnego sterowania nagłośnieniem będzie potrzebna informacja o obecnej wartości głośności. W tym celu należy przygotować skrypt, który zrealizuje zapytanie o tą wartość i przekaże ją do cechy użytkownika. Poniżej opis jak należy to wykonać:
- W pierwszym kroku należy utworzyć cechę użytkownika w module Gate Http o przykładowej nazwie "SONOS_volume"
data:image/s3,"s3://crabby-images/64c9e/64c9e25a68b4c5b905b1c034026d5a12aa937c83" alt=""
- Następnie skrypt o nazwie "Sonos_volume_get", który wyśle zapytanie:
local body, header, user
user = {xmlTag = 's:Body',{xmlTag = 'u:GetVolume',['xmlns:u'] = 'urn:schemas-upnp-org:service:RenderingControl:1',{xmlTag = 'InstanceID',0 },{xmlTag = 'Channel','Master'}}}
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:RenderingControl:1#GetVolume",}
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_get_volume->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_get_volume->SetRequestBody(body)
Gate_HTTP->HttpRequest_get_volume->SendRequest()
- Oraz kolejny skrypt "Sonos_resp_volume", który pobierze wartość z cechy ResponseBody i przekaże jej wartość do cechy użytkownika "SONOS_volume"
local resp
resp = Gate_HTTP->HttpRequest_get_volume->ResponseBody
Gate_HTTP->SONOS_volume = tonumber(resp[1][1][1][1])
Skrypt ten należy wywołać przez zdarzenie OnResponse obiekcie wirtualnym HttpRequest "HttpRequest_get_volume"
data:image/s3,"s3://crabby-images/30367/303670cd19d2d084be9c27393c8f29951f37cb53" alt=""
Po wysłaniu konfiguracji i uruchomieniu skryptu "Sonos_volume_get", cecha StatusCode przyjmie wartość 200
data:image/s3,"s3://crabby-images/98ef6/98ef6e048187b57a7602f946026f80bc2e7d2f7c" alt=""
a wartość cechy użytkownika "SONOS_volume" zostanie zaktualizowana:
data:image/s3,"s3://crabby-images/e76bb/e76bb6ea1eaa8fa237c0854f71aa1bde3f96dfd3" alt=""
Gdy już znamy wartość nagłośnienia, możemy wykonać sterowanie głośnością. W tym celu musimy przygotować skrypty, które zrealizują inkrementację, dekrementację lub wyzerują wartości Volume. Poniżej opis jak można to wykonać:
- Tworzymy skrypty "sonos_volume_up" realizujący inkrementację
local header,body,user,vol,path
Gate_HTTP->Sonos_volume_get()
SYSTEM.Wait(100)
vol = Gate_HTTP->SONOS_volume
vol = vol + 1
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:RenderingControl:1#SetVolume",}
user = {xmlTag = 's:Body',{xmlTag = 'u:SetVolume',['xmlns:u'] = 'urn:schemas-upnp-org:service:RenderingControl:1',{xmlTag = 'InstanceID',0 },
{xmlTag = 'Channel','Master'},{xmlTag = 'DesiredVolume',vol}}}
path = "/MediaRenderer/RenderingControl/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->Sonos_volume_get()
- Następnie skrypt "sonos_volume_down" realizujący dekrementację
local header,body,user,vol,path
Gate_HTTP->Sonos_volume_get()
SYSTEM.Wait(100)
vol = Gate_HTTP->SONOS_volume
vol = vol - 1
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:RenderingControl:1#SetVolume",}
user = {xmlTag = 's:Body',{xmlTag = 'u:SetVolume',['xmlns:u'] = 'urn:schemas-upnp-org:service:RenderingControl:1',{xmlTag = 'InstanceID',0 },
{xmlTag = 'Channel','Master'},{xmlTag = 'DesiredVolume',vol}}}
path = "/MediaRenderer/RenderingControl/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->Sonos_volume_get()
- Oraz skrypt "sonos_volume_mute", który wyciszy głośnik
local header,body,user,path,vol
vol = 0
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:RenderingControl:1#SetVolume",}
user = {xmlTag = 's:Body',{xmlTag = 'u:SetVolume',['xmlns:u'] = 'urn:schemas-upnp-org:service:RenderingControl:1',{xmlTag = 'InstanceID',0 },
{xmlTag = 'Channel','Master'},{xmlTag = 'DesiredVolume',vol}}}
path = "/MediaRenderer/RenderingControl/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->Sonos_volume_get()
Po wysłaniu konfiguracji, uruchomienie wyżej wymienionych skryptów spowoduje zmianę nagłośnienia.
Pobieranie informacji o utworze, wykonawcy, albumie
Do uzyskania informacji o obecnie odtwarzanym utworze, albumie lub wykonawcy należy wykonać poniższe kroki:
- W pierwszym kroku należy stworzyć obiekt wirtualny o nazwie "HttpRequest_get_info"
data:image/s3,"s3://crabby-images/bd46d/bd46d401cf515449732e1bd52f0d6c385f5ab3c4" alt=""
Host: 192.168.7.175:1400 (adres IP SONOS)
Path:/MediaRenderer/AVTransport/Control
Method: GET
RequestType: XML
ResponseType: XML
- W kolejnym kroku musimy utworzyć cechy użytkownika, do których zostaną przekazane informację:
data:image/s3,"s3://crabby-images/c89f0/c89f02c756577ef3faecdecaabd17370b384b12b" alt=""
Znaczenie cech użytkownika:
track - tytuł utworu
artist - wykonawca
duration - długość utworu
rel_time - czas trwania utworu
album - tytuł albumu
- Następnie należy utworzyć skrypt "sonos_info_get"
local user, body, header, path
user = { xmlTag = 's:Body', {xmlTag = 'u:GetPositionInfo', ['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1', { xmlTag = 'InstanceID',0 }}}
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:RenderingControl:1#GetPositionInfo",}
path = "/MediaRenderer/AVTransport/Control"
body = { xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_get_info->SetPath(path)
Gate_HTTP->HttpRequest_get_info->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_get_info->SetRequestBody(body)
Gate_HTTP->HttpRequest_get_info->SendRequest()
- Oraz skrypt "sonos_info_resp", który zrealizuje odczyt wysłanej odpowiedzi
local resp, did1
resp = Gate_HTTP->HttpRequest_get_info->ResponseBody
didl = xml.parse(resp[1][1][3][1])
Gate_HTTP->track = didl[1][4][1]
Gate_HTTP->artist = didl[1][6][1]
Gate_HTTP->album = didl[1][7][1]
Gate_HTTP->duration = resp[1][1][2][1]
Gate_HTTP->rel_time = resp[1][1][5][1]
Skrypt ten należy wywołać przez zdarzenie OnResponse obiekcie wirtualnym HttpRequest "HttpRequest_get_info"
data:image/s3,"s3://crabby-images/90495/904958d1a39aa01643b1c6e546145018a8c777a0" alt=""
Po wysłaniu konfiguracji i uruchomieniu skryptu "sonos_info_get" cecha StatusCode przyjmie wartość 200
data:image/s3,"s3://crabby-images/09d2c/09d2cee50cf8c590526edcc8acbfafd8d0bd6abf" alt=""
a wartości cech użytkownika zostaną zaktualizowane
data:image/s3,"s3://crabby-images/2144b/2144bc834ad7a80bf93f6d3d191352b8c6ed12be" alt=""
Sterowanie odtwarzaniem (Play, Pause, Next, Previous)
Do kontrolowania odtwarzanej muzyki (Play, Pause) musimy znać stan głośnika. W tym celu należy wykonać poniższe kroki:
- W pierwszym kroku należy utworzyć cechę użytkownika w module Gate Http o przykładowej nazwie "state"
data:image/s3,"s3://crabby-images/84032/84032c9d6ec0f9e061db2d5788745749eb6dd8c9" alt=""
- oraz obiekt wirtualny HttpRequest o nazwie "HttpRequest_get_state"
data:image/s3,"s3://crabby-images/52384/52384a97fc2096a07740dfd95475e2ed3b64999a" alt=""
Host: 192.168.7.175:1400 (adres IP SONOS)
Path:/MediaRenderer/AVTransport/Control
Method: GET
RequestType: XML
ResponseType: XML
- następnie musimy utworzyć skrypt "sonos_state_get"
local body,head,path, user
user = {xmlTag = 's:Body',{xmlTag = 'u:GetTransportInfo',['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1',{xmlTag = 'InstanceID',0}}}
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:AVTransport:1#GetTransportInfo",}
path = "/MediaRenderer/AVTransport/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_get_state->SetPath(path)
Gate_HTTP->HttpRequest_get_state->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_get_state->SetRequestBody(body)
Gate_HTTP->HttpRequest_get_state->SendRequest()
- oraz skrypt "sonos_state_get_resp", który przekaże informacje do cechy użytkownika
local resp
resp = Gate_HTTP->HttpRequest_get_state->ResponseBody
Gate_HTTP->state = resp[1][1][1][1]
- Skrypt ten należy wywołać przez zdarzenie OnResponse w obiekcie wirtualnym HttpRequest "HttpRequest_get_state"
data:image/s3,"s3://crabby-images/991a6/991a6bb50e4c6d2a826e173e579700176abcfe69" alt=""
Po wysłaniu konfiguracji i uruchomieniu skryptu "sonos_state_get", cecha StatusCode przyjmie wartość 200
data:image/s3,"s3://crabby-images/ae5dd/ae5dd1039b201ee374481e78151390ad4e9f33db" alt=""
a wartość cechy użytkownika zostanie zaktualizowana:
data:image/s3,"s3://crabby-images/7c580/7c580ed73f544b368e5ea50a34cb611ef11cc355" alt=""
Gdy już znamy stan pracy głośnika, możemy wykonać skrypty sterujące funkcjami Play, Pause, Next, Previous
- skrypt "sonos_play_pause":
local header,body,user,path
if (Gate_HTTP->state == "PAUSED_PLAYBACK" or Gate_HTTP->state == "STOPPED") then
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:AVTransport:1#Play",}
user = {xmlTag = 's:Body',{xmlTag = 'u:Play' ,['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1',{xmlTag = 'InstanceID',0 },{xmlTag = 'Speed',1 },}}
path = "/MediaRenderer/AVTransport/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
else
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:AVTransport:1#Pause",}
user = {xmlTag = 's:Body',{xmlTag = 'u:Pause' ,['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1',{xmlTag = 'InstanceID',0 },{xmlTag = 'Speed',1 },}}
path = "/MediaRenderer/AVTransport/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
end
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->sonos_state_get()
- Skrypt "sonos_next"
local header,body,user,path
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:AVTransport:1#Next",}
user = {xmlTag = 's:Body',{xmlTag = 'u:Next' ,['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1',{xmlTag = 'InstanceID',0 },{xmlTag = 'Speed',1 },}}
path = "/MediaRenderer/AVTransport/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->sonos_state_get()
- Skrypt "sonos_previous
local header,body,user,path
header = {['SOAPAction'] = "urn:schemas-upnp-org:service:AVTransport:1#Previous",}
user = {xmlTag = 's:Body',{xmlTag = 'u:Previous' ,['xmlns:u'] = 'urn:schemas-upnp-org:service:AVTransport:1',{xmlTag = 'InstanceID',0 },{xmlTag = 'Speed',1 },}}
path = "/MediaRenderer/AVTransport/Control"
body = {xmlTag = 's:Envelope',['xmlns:s'] = 'http://schemas.xmlsoap.org/soap/envelope/',['s:encodingStyle'] = 'http://schemas.xmlsoap.org/soap/encoding/',user}
Gate_HTTP->HttpRequest_post->SetPath(path)
Gate_HTTP->HttpRequest_post->SetRequestHeaders(header)
Gate_HTTP->HttpRequest_post->SetRequestBody(body)
Gate_HTTP->HttpRequest_post->SendRequest()
Gate_HTTP->sonos_state_get()
Powyższe skrypty będę potrzebne do zbudowania interfejsu w myGrenton, na którym zobaczyć można informację o aktualnie odtwarzanym utworze, uruchomić odtwarzanie, zatrzymać, przełączyć utwór.
data:image/s3,"s3://crabby-images/abba5/abba55166e5c55e62131774c6fbeaba27740db84" alt=""
Widżety Value konfigurujemy by pokazywały wskazana Cechę Wbudowaną
data:image/s3,"s3://crabby-images/fca16/fca16b87252f96c67f4799d38b513af6aeace78e" alt=""
Widżet sceny podwójnej do zmiany odtwarzanego utworu wywołuje skrypt, który realizuje daną komendę.
data:image/s3,"s3://crabby-images/f6f78/f6f78945f68b3c214c6cafcccfb065b5028628ef" alt=""
Widżet Value konfigurujemy aby pokazał wartość nagłośnienia
data:image/s3,"s3://crabby-images/91843/9184327f198ffb7afe54ecdcd1efd3eadfd7356a" alt=""
data:image/s3,"s3://crabby-images/0b8d1/0b8d17bf7e654cd3141892881a671bcd74caf119" alt=""