Forum: Haus & Smart Home Shelly TRV rpc Schnittstelle


Announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
von Stefan A. (king-crash)


Angehängte Dateien:

Lesenswert?

Hallo,

ich habe hier einen Shelly TRV Thermostat mit Gateway Gen3. Diesen 
möchte ich gerne über die rpc Webschnittstelle, die auch das Webfrontend 
verwendet ansteuern. Was der Browser darüber sendet sind allerdings nur 
Binärdaten die nicht sehr aufschlussreich sind, das Gateway antwortet 
aber mit JSON.
Das erste gesendete Byte jedes Blocks ist immer 0x81, dann kommt ein mir 
nicht zuzuordnendes Byte und dann zwei Byte Längenangabe der darauf 
folgenden Daten.
Gibt es für dieses Protokoll eine Dokumentation?

Im Anhang ein Auszug des Mitschnitts. Der erste Block wurde vom Browser 
gesendet, der zweite ist die Antwort des Shelly Gateways.

Grüße

von Michi S. (mista_s)


Lesenswert?

Stefan A. schrieb:
> über die rpc Webschnittstelle

Stefan A. schrieb:
> Gibt es für dieses Protokoll eine Dokumentation?

Die Doku für die Shelly RPC Schnittstelle gibts hier:
https://shelly-api-docs.shelly.cloud/gen2/General/RPCProtocol

Da fällt mir auf den ersten Blick allerdings nichts zu reinen 
Binär-Frames auf; eventuell verwendet die Verbindung ja 
Datenkompression?

von Εrnst B. (ernst)


Lesenswert?

Schaut aus wie Websocket-Kommunikation.
0x81 = "One-Frame Text Message"
0xEC = Masked frame mit 108 Bytes
dann Masking key (vier Bytes)
Dann Payload Data geXOR'ed mit dem Masking-Key.

https://datatracker.ietf.org/doc/html/rfc6455
1
      0                   1                   2                   3
2
      0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
3
     +-+-+-+-+-------+-+-------------+-------------------------------+
4
     |F|R|R|R| opcode|M| Payload len |    Extended payload length    |
5
     |I|S|S|S|  (4)  |A|     (7)     |             (16/64)           |
6
     |N|V|V|V|       |S|             |   (if payload len==126/127)   |
7
     | |1|2|3|       |K|             |                               |
8
     +-+-+-+-+-------+-+-------------+ - - - - - - - - - - - - - - - +
9
     |     Extended payload length continued, if payload len == 127  |
10
     + - - - - - - - - - - - - - - - +-------------------------------+
11
     |                               |Masking-key, if MASK set to 1  |
12
     +-------------------------------+-------------------------------+
13
     | Masking-key (continued)       |          Payload Data         |
14
     +-------------------------------- - - - - - - - - - - - - - - - +
15
     :                     Payload Data continued ...                :
16
     + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
17
     |                     Payload Data continued ...                |
18
     +---------------------------------------------------------------+

Du tust dir viel leichter, wenn du dir die Kommunikation mit den 
Browser-Entwicklertools, Netzwerk-Tab, anschaust.
Da wird das Websocket-Protokol dekodiert angezeigt.

von Stefan A. (king-crash)


Lesenswert?

Danke für die Infos.
Ich hatte zuerst einfach geschaut, was der Browser kommuniziert. Aber es 
geht scheinbar deutlich einfacher.

https://shelly-api-docs.shelly.cloud/gen2/Devices/Gen3/ShellyBluGwG3/
Hier gibt es sogar fertige CURL Kommandos.

Grüße

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.