RFD-FHEM/SIGNALduino_TOOL

Malformed MC Data in SD_Device_ProtocolList.json

sidey79 opened this issue · 4 comments

In der SD_Device_ProtocolList.json sind fehlerhafte MC Daten, die aus irgendeiner Debug Firmware stammen.

Diese werden nicht mehr verarbeitet, wenn Parse_MC auf valide Datensätze z.B. if ($rmsg !~ /^M[cC];LL=-\d+;LH=\d+;SL=-\d+;SH=\d+;D=[0-9A-F]+;C=\d+;L=\d+;(?:R=\d+;)?$/){ prüft .

"rmsg":"MC;LL=-997;LH=967;SL=-506;SH=460;D=AAAAAAAA66959A6555655AA55556A9955565A5566AA56A96;C=488;L=192;s1;b1;"

"rmsg":"MC;LL=-1002;LH=952;SL=-489;SH=475;D=000000A0EBDDC4FBFBF13EF5B6;C=486;L=104;s48;b1;"

"rmsg":"MC;LL=-2486;LH=3348;SL=-1024;SH=1889;D=8FFF7F0F;C=1457;L=32;R=65;s26;b26;"

"rmsg":"MC;LL=-482;LH=511;SL=-230;SH=264;D=AA999559959A695996A65A9566;C=247;L=104;s17;b17;"

SD_Device_ProtocolList.json unterstützt aktuell keine fehlerhaften Daten. Um fehlerhafte Daten erkenne zu können müsste ein Flag eingebaut werden oder z.B. ein vorhandenes "dispatch_repeats":"-1" gesetzt werden.

Waren die Fehler, welche du hier mitbekommen hast für mich sichtbar oder hast du sie nur mitbekommen weil du „extern“ dies irgendwo getestet hast?

Ich überlege schon die ganze Zeit / nach einer Variante um die Daten stets plausibel zu halten ohne immer jede ID manuell zu dispatchen.

Das mit dem dispatch_repeats -1 habe ich nicht verstanden aber ich schau auch gerade nur mit dem Handy nach. Das muss ich mir am PC mal genau ansehen.

Die Daten werden durch das UnitTest Modul bei jedem push getestet:

https://github.com/RFD-FHEM/RFFHEM/runs/1623409933?check_suite_focus=true#step:12:4279

Ich sollte es geschwind in die neuere FHEM Testumgebung migrieren, dann liefert prove das Ergebnis samt möglicher Warnings.

Der angepasste Code liegt hier, wollte es halt mal probieren ob das so klappt:

https://github.com/RFD-FHEM/RFFHEM/tree/feature_parse-Optimize

Ich habe mir soeben die Fehler angesehen und auch korrigiert. Grund, es war nicht deine FW von welcher die Nachricht stammte.
Nun sollte die Richtigkeit gegeben sein @sidey79.

Test läuft damit nun durch. 👍
Das bedeutet aber auch, dass diese Firmware Versionen nicht kompatibel wären mit der Anpassung