Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Neuer Adapter für Roborock-Staubsauger

    NEWS

    • Amazon Alexa - ioBroker Skill läuft aus ?

    • Monatsrückblick – September 2025

    • Neues Video "KI im Smart Home" - ioBroker plus n8n

    Neuer Adapter für Roborock-Staubsauger

    This topic has been deleted. Only users with topic management privileges can see it.
    • copystring
      copystring @andibr last edited by

      @andibr said in Neuer Adapter für Roborock-Staubsauger:

      @copystring

      Ich gehe davon aus, dass euch für MQTT die Tools schon bekannt sind:
      Linux (Debian) == mqttx
      Windows == mqtt.fx

      Damit könnt ih den gesamten Trafic vom MQTT-Broker Abonieren, und dann mal schauen und immer weiter eingrenzen.

      Aber vermutlich schreibe ich da Dinge die ihr schon längst kennt. Etwas änliches gibt es glaub auch für Modbus TCP/RTU, aber mir fällt der Namen nicht gerade ein.
      Beim Linux gibt es noch irgendwie eine Möglichkeit, den Trafic über einen Port mit zuschneiden und in ein File zu paken. Aber auch da gibt es garantiert Personen die das besser wissen und können.

      Andi

      Nein. Das geht nicht mehr, seitdem ich da herumgespielt habe. Roborock hat das mitbekommen. Man kann nur noch über mitimproxy den Traffic mitschneiden. Vorher konnte man ganz einfach den Topic für das Senden der Befehle abonnieren. Das wurde gesperrt. Daher muss mitgeschnitten werden.
      Der gesamte Datenverkehr ist mit SSL und speziellen Keys doppelt verschlüsselt und kodiert. Der Adapter dekodiert und entschlüsselt alles, wenn die Nachrichten mit mitmproxy und meinen python addon an den Adapter geschickt wird.

      A 1 Reply Last reply Reply Quote 0
      • A
        andibr @copystring last edited by

        @copystring
        Ok, dass ist aber doof. Wieder eine Firma die nicht will das man sich vor der chinesischen Überwachung verstecken kann.
        Da könnte es ja auch sein, dass mit eine Firmeware Update alle eure super Arbeit zu nichte gemacht wird?

        Andi

        copystring 1 Reply Last reply Reply Quote 0
        • copystring
          copystring @andibr last edited by

          @andibr said in Neuer Adapter für Roborock-Staubsauger:

          @copystring
          Ok, dass ist aber doof. Wieder eine Firma die nicht will das man sich vor der chinesischen Überwachung verstecken kann.
          Da könnte es ja auch sein, dass mit eine Firmeware Update alle eure super Arbeit zu nichte gemacht wird?

          Andi

          Unwahrscheinlich. Mitschneiden von Traffic kann man nicht verhindern. Änderungen könnte man schnell einbauen, indem man einfach den Traffic neu mitschneidet.

          1 Reply Last reply Reply Quote 0
          • jahnbes
            jahnbes @SpacerX last edited by

            @spacerx
            Danke! Ich werde mich am Wochenende darum kümmern und das Wiki ergänzen.

            Kannst Du mir / uns das "Kleines Blockly zum loggen der Datenpunkte vom Sauger geschrieben." zukommen lassen?

            Gruß Bert.

            S 2 Replies Last reply Reply Quote 0
            • S
              SpacerX @jahnbes last edited by SpacerX

              @jahnbes sagte in Neuer Adapter für Roborock-Staubsauger:

              Kannst Du mir / uns das "Kleines Blockly zum loggen der Datenpunkte vom Sauger geschrieben." zukommen lassen?

              Kann ich.

              Ich habe noch etwas dran herum gestrickt damit es einfach so läuft ohne Anpassungen.

              Zu beachten ist das nur vom Adapter bereitgestellte Datenpunkte erfasst werden und immer die Verzögerung eintritt die beim Aktualisierungsintervall im Adapter angegeben ist.

              SchnipSchnap.PNG

              <xml xmlns="https://developers.google.com/blockly/xml">
                <variables>
                  <variable id="Dp(TEdvXq|dD(9XLkW!D">text</variable>
                  <variable id=":UNV]Z$?%Qg963*a]Bn@">id</variable>
                  <variable id="y]eb]G~;C._1Kg*RZ*)b">robiDevice</variable>
                  <variable id="+r1nueMYBS=AZLN+pK0^">datenpunkt</variable>
                  <variable id="k6-Q,C$hI=dp+9Lz9*Ih">beschreibung</variable>
                </variables>
                <block type="procedures_defcustomnoreturn" id="qIp]hmVn|SQ~VcN{33kg" x="38" y="-213">
                  <mutation statements="false">
                    <arg name="text" varid="Dp(TEdvXq|dD(9XLkW!D"></arg>
                  </mutation>
                  <field name="NAME">RobiLog</field>
                  <field name="SCRIPT">Y29uc29sZS5sb2coKCcjIFJvYmkgLT4gJyArIFN0cmluZyh0ZXh0KSkpOw==</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="procedures_defcustomreturn" id="CP?Cyo9e2)ey}0dh;^ke" x="37" y="-162">
                  <mutation statements="false"></mutation>
                  <field name="NAME">GetRobiStateText</field>
                  <field name="SCRIPT">dmFyIHN0YXRlSUQgPSAicm9ib3JvY2suMC5EZXZpY2VzLiIgKyByb2JpRGV2aWNlICsgIi5kZXZpY2VTdGF0dXMuc3RhdGUiDQpyZXR1cm4gZ2V0T2JqZWN0KHN0YXRlSUQpLmNvbW1vbi5zdGF0ZXNbZ2V0U3RhdGUoc3RhdGVJRCkudmFsXQ==</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="procedures_defcustomreturn" id="oX1{x8TY@`NKcBbs^kq`" x="38" y="-113">
                  <mutation statements="false">
                    <arg name="id" varid=":UNV]Z$?%Qg963*a]Bn@"></arg>
                  </mutation>
                  <field name="NAME">GetName</field>
                  <field name="SCRIPT">cmV0dXJuIGdldE9iamVjdChpZCkuY29tbW9uLm5hbWU7</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="procedures_defcustomreturn" id="O-zZjZP:-@/s|8_l-`wX" x="38" y="-62">
                  <mutation statements="false"></mutation>
                  <field name="NAME">GetDevice</field>
                  <field name="SCRIPT">dmFyIGRldmljZSA9IEFycmF5LnByb3RvdHlwZS5zbGljZS5hcHBseSgkKCJyb2Jvcm9jay4wLkRldmljZXMuKiIpKVswXS5zcGxpdCgnLicpWzNdOw0KY29uc29sZS5sb2coKFsnICMgUm9iaSAtPiBTdGFydCBsb2dnaW5nIFJvYm9yb2NrIEluc3RhbnogMCAtIERldmljZTogIicsZGV2aWNlLCciJ10uam9pbignJykpKTsNCnJldHVybiBkZXZpY2U7</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="procedures_defcustomreturn" id="b#cVo{O:Xr%.:G~wk%BH" x="38" y="-12">
                  <mutation statements="false">
                    <arg name="id" varid=":UNV]Z$?%Qg963*a]Bn@"></arg>
                  </mutation>
                  <field name="NAME">GetDatenpunkt</field>
                  <field name="SCRIPT">dG1wTGlzdGUgPSBpZC5zcGxpdCgnLicpOw0KdG1wTGlzdGUgPSB0bXBMaXN0ZS5zbGljZSh0bXBMaXN0ZS5sZW5ndGggLSAyLCB0bXBMaXN0ZS5sZW5ndGgpOw0KcmV0dXJuIHRtcExpc3RlLmpvaW4oJy4nKTs=</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="procedures_defcustomreturn" id="N%zy{o^r_)pj@)iW{[?^" x="38" y="38">
                  <mutation statements="false">
                    <arg name="id" varid=":UNV]Z$?%Qg963*a]Bn@"></arg>
                  </mutation>
                  <field name="NAME">GetSektion</field>
                  <field name="SCRIPT">dG1wTGlzdGUgPSBpZC5zcGxpdCgnLicpOw0KcmV0dXJuIHRtcExpc3RlLnNsaWNlKC0yKVswXQ==</field>
                  <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                </block>
                <block type="comment" id="?!:f=F9o%1h~eQ+b=~1H" x="37" y="88">
                  <field name="COMMENT">Roborock DP`s loggen</field>
                  <next>
                    <block type="variables_set" id="*IkFS7Tt#d$=Zm3kGZ@u">
                      <field name="VAR" id="y]eb]G~;C._1Kg*RZ*)b">robiDevice</field>
                      <value name="VALUE">
                        <block type="procedures_callcustomreturn" id="K-7wFf;`p!Dsqw69}$fO">
                          <mutation name="GetDevice"></mutation>
                        </block>
                      </value>
                      <next>
                        <block type="on_ext" id="}Cjj:guHosL3tZ9AS7!F">
                          <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation>
                          <field name="CONDITION">ne</field>
                          <field name="ACK_CONDITION"></field>
                          <value name="OID0">
                            <shadow type="field_oid" id="_1~8-Qi)XQQfbpzHscaH">
                              <field name="oid">default</field>
                            </shadow>
                            <block type="selector" id="%nM33D%sk`5v*|1MAb4k">
                              <field name="TEXT">roborock.0.Devices." + robiDevice + ".*</field>
                            </block>
                          </value>
                          <statement name="STATEMENT">
                            <block type="variables_set" id="Y5uR438l0`7hHKOW4aqP">
                              <field name="VAR" id="+r1nueMYBS=AZLN+pK0^">datenpunkt</field>
                              <value name="VALUE">
                                <block type="procedures_callcustomreturn" id="3CX:;{,RAM%~o.w6B-gn" inline="true">
                                  <mutation name="GetDatenpunkt">
                                    <arg name="id"></arg>
                                  </mutation>
                                  <value name="ARG0">
                                    <block type="on_source" id="d-*Fm*J|4{(1#,-UGfb,">
                                      <field name="ATTR">id</field>
                                    </block>
                                  </value>
                                </block>
                              </value>
                              <next>
                                <block type="controls_if" id="s9!Kr3|Fy|vPX`(aBW|^">
                                  <mutation elseif="2" else="1"></mutation>
                                  <value name="IF0">
                                    <block type="logic_compare" id="~wZ4EwlpPJ]w[VS:1{qA">
                                      <field name="OP">EQ</field>
                                      <value name="A">
                                        <block type="variables_get" id="+dbMgijJ12zIg1zv*?bh">
                                          <field name="VAR" id="+r1nueMYBS=AZLN+pK0^">datenpunkt</field>
                                        </block>
                                      </value>
                                      <value name="B">
                                        <block type="text" id="8FXGeXyr?zpfFei$1618">
                                          <field name="TEXT">deviceStatus.msg_seq</field>
                                        </block>
                                      </value>
                                    </block>
                                  </value>
                                  <statement name="DO0">
                                    <block type="comment" id="2b{#DDDt4KmkFVzUfvPT">
                                      <field name="COMMENT">ausschließen</field>
                                    </block>
                                  </statement>
                                  <value name="IF1">
                                    <block type="logic_compare" id="0!^^HpJ.J08-{eY*ODa3">
                                      <field name="OP">EQ</field>
                                      <value name="A">
                                        <block type="variables_get" id=")|yoBHjnvqqN@kOxF3le">
                                          <field name="VAR" id="+r1nueMYBS=AZLN+pK0^">datenpunkt</field>
                                        </block>
                                      </value>
                                      <value name="B">
                                        <block type="text" id="Z;6E8hFG!WL:oZSGB0Tm">
                                          <field name="TEXT">networkInfo.rssi</field>
                                        </block>
                                      </value>
                                    </block>
                                  </value>
                                  <statement name="DO1">
                                    <block type="comment" id="qnCQIoA)9[ijQMLQF6no">
                                      <field name="COMMENT">ausschließen</field>
                                    </block>
                                  </statement>
                                  <value name="IF2">
                                    <block type="logic_compare" id="R!z=Y/lV^q|3{z#*MX?n">
                                      <field name="OP">EQ</field>
                                      <value name="A">
                                        <block type="procedures_callcustomreturn" id="lBk9kQU1UfL35p1}`X%/" inline="true">
                                          <mutation name="GetSektion">
                                            <arg name="id"></arg>
                                          </mutation>
                                          <value name="ARG0">
                                            <block type="on_source" id="inf$mhhpto.(Z#qor)gM">
                                              <field name="ATTR">id</field>
                                            </block>
                                          </value>
                                        </block>
                                      </value>
                                      <value name="B">
                                        <block type="text" id="P[^^zTEfaL)=-BV:atZ[">
                                          <field name="TEXT">map</field>
                                        </block>
                                      </value>
                                    </block>
                                  </value>
                                  <statement name="DO2">
                                    <block type="comment" id="IrLaMx.fY]vHKd=GC|]m">
                                      <field name="COMMENT">ausschließen</field>
                                    </block>
                                  </statement>
                                  <statement name="ELSE">
                                    <block type="variables_set" id="5wr|$lnk==:5JTX)rDfk">
                                      <field name="VAR" id="k6-Q,C$hI=dp+9Lz9*Ih">beschreibung</field>
                                      <value name="VALUE">
                                        <block type="text" id="Z(s%7um*A*H;~t9eiq#c">
                                          <field name="TEXT"></field>
                                        </block>
                                      </value>
                                      <next>
                                        <block type="controls_if" id="g}5r)k5v#*y|]xH[lpE$">
                                          <value name="IF0">
                                            <block type="logic_compare" id="]:,Uu/R%/+22NQ-m]x:_">
                                              <field name="OP">EQ</field>
                                              <value name="A">
                                                <block type="variables_get" id="#=HegdOuoxuWaVjhrB8u">
                                                  <field name="VAR" id="+r1nueMYBS=AZLN+pK0^">datenpunkt</field>
                                                </block>
                                              </value>
                                              <value name="B">
                                                <block type="text" id="_{#]pq]9a+2R;eM!wt5:">
                                                  <field name="TEXT">deviceStatus.state</field>
                                                </block>
                                              </value>
                                            </block>
                                          </value>
                                          <statement name="DO0">
                                            <block type="variables_set" id="fD)M(aoA*^`D@`fLBYW3" disabled="true">
                                              <field name="VAR" id="k6-Q,C$hI=dp+9Lz9*Ih">beschreibung</field>
                                              <value name="VALUE">
                                                <block type="text_join" id="bh:KAYP%BS8VW6=XC]8C" inline="true">
                                                  <mutation items="3"></mutation>
                                                  <value name="ADD0">
                                                    <block type="text" id="hb[3Y**=`bfao{[D^e2c">
                                                      <field name="TEXT"> (</field>
                                                    </block>
                                                  </value>
                                                  <value name="ADD1">
                                                    <block type="field_oid" id="(eK!JWI[O-3X@y_%jST/">
                                                      <field name="oid">alias.0.Kueche.Roborock.Status.Zustand</field>
                                                    </block>
                                                  </value>
                                                  <value name="ADD2">
                                                    <block type="text" id="P:j.NT!lnmMvX`/KvVlk">
                                                      <field name="TEXT">)</field>
                                                    </block>
                                                  </value>
                                                </block>
                                              </value>
                                              <next>
                                                <block type="variables_set" id="|tzt{0w;V0obfXU}$pk-">
                                                  <field name="VAR" id="k6-Q,C$hI=dp+9Lz9*Ih">beschreibung</field>
                                                  <value name="VALUE">
                                                    <block type="text_join" id=":PATIg.X0t##Du:,wU#`" inline="true">
                                                      <mutation items="3"></mutation>
                                                      <value name="ADD0">
                                                        <block type="text" id="?X:DfH.Zm-_r$K5O][fp">
                                                          <field name="TEXT"> (</field>
                                                        </block>
                                                      </value>
                                                      <value name="ADD1">
                                                        <block type="procedures_callcustomreturn" id="cDL1Mb$AAM$)z,[yj9^V" inline="true">
                                                          <mutation name="GetRobiStateText"></mutation>
                                                        </block>
                                                      </value>
                                                      <value name="ADD2">
                                                        <block type="text" id=",3_,#[I$6[:,f:M|cT_k">
                                                          <field name="TEXT">)</field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </value>
                                                </block>
                                              </next>
                                            </block>
                                          </statement>
                                          <next>
                                            <block type="procedures_callcustomnoreturn" id="0]vAqu2g7aQrTv|hf%W+" inline="true">
                                              <mutation name="RobiLog">
                                                <arg name="text"></arg>
                                              </mutation>
                                              <value name="ARG0">
                                                <block type="text_join" id="FkCwEa@T*cREvAt;iV*#">
                                                  <mutation items="4"></mutation>
                                                  <value name="ADD0">
                                                    <block type="procedures_callcustomreturn" id="ba5]2zs,;pKK9P/sfH-?" inline="true">
                                                      <mutation name="GetName">
                                                        <arg name="id"></arg>
                                                      </mutation>
                                                      <value name="ARG0">
                                                        <block type="on_source" id="L$IUp=sJxALkb[!h=,l7">
                                                          <field name="ATTR">id</field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </value>
                                                  <value name="ADD1">
                                                    <block type="text_join" id="S].PLij5PRyzH^RY+b48" inline="true">
                                                      <mutation items="3"></mutation>
                                                      <value name="ADD0">
                                                        <block type="text" id="a),`F*[,hxB}KrSOk3r`">
                                                          <field name="TEXT"> [</field>
                                                        </block>
                                                      </value>
                                                      <value name="ADD1">
                                                        <block type="variables_get" id=".{KppZkN-dBxc!zEjCSZ">
                                                          <field name="VAR" id="+r1nueMYBS=AZLN+pK0^">datenpunkt</field>
                                                        </block>
                                                      </value>
                                                      <value name="ADD2">
                                                        <block type="text" id="M*9=yoSfjY[z)(qCZ|+/">
                                                          <field name="TEXT">] =  </field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </value>
                                                  <value name="ADD2">
                                                    <block type="text_join" id="Q%QO01tRqYTTg)HJLpuW" inline="true">
                                                      <mutation items="3"></mutation>
                                                      <value name="ADD0">
                                                        <block type="on_source" id="8X.KdeqQu]=!sw.iN~fA">
                                                          <field name="ATTR">oldState.val</field>
                                                        </block>
                                                      </value>
                                                      <value name="ADD1">
                                                        <block type="text" id="T=TB(;Oo=zS.sJf#}c3$">
                                                          <field name="TEXT"> -&gt; </field>
                                                        </block>
                                                      </value>
                                                      <value name="ADD2">
                                                        <block type="on_source" id="H=Uvd4SX;)7L3|Y_(F!!">
                                                          <field name="ATTR">state.val</field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </value>
                                                  <value name="ADD3">
                                                    <block type="variables_get" id="i+fzc8kY=V}R`Lv%V/UW">
                                                      <field name="VAR" id="k6-Q,C$hI=dp+9Lz9*Ih">beschreibung</field>
                                                    </block>
                                                  </value>
                                                </block>
                                              </value>
                                            </block>
                                          </next>
                                        </block>
                                      </next>
                                    </block>
                                  </statement>
                                </block>
                              </next>
                            </block>
                          </statement>
                        </block>
                      </next>
                    </block>
                  </next>
                </block>
              </xml>
              


              Mit den 3 "falls mache" werden drei Datenpunkte ausgeschlossen die das log sehr unübersichtlich machen. Wer diese mit haben will, einfach den Block hinter falls ausblenden.
              Wer noch weitere Ausschließen will, dann ein "falls mache" hinzufügen.

              Dann viel Spaß beim Loggen der Adapterdatenpunkte.

              MfG Ralf

              jahnbes M 2 Replies Last reply Reply Quote 0
              • jahnbes
                jahnbes @SpacerX last edited by

                @spacerx
                Es ist mir etwas peinlich, aber nachdem ich mir fast den iobroker zerschossen habe, wie bekomme ich Dein Skript bei mir in den iobroker?
                Das Blockly ist nur ein Ausschnitt und der Code bringt bei mir nur Fehler. Finden wir einen Weg. Wie machst Du das bei Dir, also Dein Weg vom Code zum Blockly?
                Gruß Bert.

                S 1 Reply Last reply Reply Quote 0
                • S
                  SpacerX @jahnbes last edited by

                  @jahnbes auf der Seite JavaScript ein neues Blockly erstellen. Das dann öffnen und oben rechts im Editor Block einfügen wählen. Dort kopierst du den Code aus dem Spoiler rein. Dann Skript speichern und starten.
                  das war es.

                  jahnbes 1 Reply Last reply Reply Quote 0
                  • jahnbes
                    jahnbes @SpacerX last edited by jahnbes

                    @spacerx
                    Danke, der Weg funktionierte leider nicht. Ich habe inzwischen auch gefunden, warum, in Deinem Blockly-Skript oben fehlt die erste Zeile

                    <xml xmlns="https://developers.google.com/blockly/xml">

                    Steht die am Beginn des Blockly-Skriptes, dann wird blockly ohne Fehler erkannt und angezeigt.
                    Mehr noch nicht, ich bin am forschen.
                    Gruß Bert.

                    S 1 Reply Last reply Reply Quote 0
                    • S
                      SpacerX @jahnbes last edited by

                      @jahnbes Sorry.

                      Ich hatte es schon komplett kopiert und im Code Tag war auch alles enthalten.
                      Nur Stand der Code Tag in der gleichen Zeile wie der Beginn des Codes so das diese von HTML verschluckt wurde.

                      Ich hab das in meinem Beitrag oben korrigiert und auch den Import sowie dann die Funktion getestet.

                      Nun ist alles Richtig und es sollte funktionieren.

                      jahnbes 1 Reply Last reply Reply Quote 0
                      • jahnbes
                        jahnbes @SpacerX last edited by

                        @spacerx
                        Da sind noch ein paar private (?) Funktionen enthalten, die nicht mit rübergekommen sind, oder denke ich da falsch? Von "RobiLog" nach unten bis "GetSektion".
                        Siehe im Bild links
                        roblog_1.jpg
                        Sind das private Funktionen oder allen zugängliche und ich habe sie nur noch nicht gefunden?
                        Gruß Bert.

                        S 1 Reply Last reply Reply Quote 0
                        • S
                          SpacerX @jahnbes last edited by SpacerX

                          @jahnbes das sind kleine Javascripts wenn du bei der Funktion auf (...) klickst siehst du diese.
                          Das Blockly sollte so funktionieren. Einfach Starten und im Log sollte was von:
                          "Start logging Roborock Instanz 0 - Device: "deindevice"

                          Ich schrub ja schon das ich den Code im oben im Spoiler korrigiert habe.

                          Ich hab das in meinem Beitrag oben korrigiert und auch den Import sowie dann die Funktion getestet.

                          Nun ist alles Richtig und es sollte funktionieren.

                          jahnbes 1 Reply Last reply Reply Quote 0
                          • jahnbes
                            jahnbes @SpacerX last edited by

                            @spacerx
                            Klasse, jetzt sehe ich den log auch, vielen Dank und ein schönes Wochenende!
                            Gruß Bert.

                            1 Reply Last reply Reply Quote 0
                            • S
                              SpacerX @copystring last edited by

                              @copystring
                              Ich hab mich mal am Sniffing Versuch.
                              So einfach wie es in der Wiki steht ist ja doch nicht.
                              Dazu hab ich mir auch mal ioBroker auf Windows installiert mit nur Roborock Adapter.
                              Erst mal den ganzen Kram nach Python zu installieren hat schon fast den ganzen Nachmittag aufgefressen.
                              Der Proxy auf dem Windows Rechner läuft und WireGuard auf dem IPhone auch.
                              Das Zertifikat hab ich abgerufen und im Iphone installiert.
                              Ich bekomme einfach keine Verbindung Zustande. Es kommen Fehler von TCL Version auf Client.

                              Könntest du mir da etwas unter die Arme greifen. Gern auch in einem Beitrag um das hier nicht so zuzumüllen,

                              copystring 1 Reply Last reply Reply Quote 0
                              • copystring
                                copystring @SpacerX last edited by

                                @spacerx said in Neuer Adapter für Roborock-Staubsauger:

                                Es kommen Fehler von TCL Version auf Client.

                                In der Roborock App?

                                S 1 Reply Last reply Reply Quote 0
                                • S
                                  SpacerX @copystring last edited by SpacerX

                                  @copystring Nein im Cmd von mitmproxy.

                                  Der Start.

                                  mit Bash Script

                                  C:\Users\SpacerX\.local\pipx\venvs\mitmproxy\Scripts\mitmweb.exe --listen-port 9090 --web-port 9091  --set tls_version_client_min=TLS1_3 --mode wireguard -s C:\ioBroker\node_modules\iobroker.roborock\lib\sniffing\mitmproxy_roborock.py
                                  Pause
                                  
                                  [23:47:57.984] Loading script C:\ioBroker\node_modules\iobroker.roborock\lib\sniffing\mitmproxy_roborock.py
                                  [23:47:58.017] Initializing WireGuard server ...
                                  [23:47:58.017] WireGuard server listening for UDP connections on 0.0.0.0:9090 and [::]:9090 ...
                                  [23:47:58.017] WireGuard server successfully initialized.
                                  [23:47:58.017] ------------------------------------------------------------
                                  [Interface]
                                  PrivateKey = 
                                  Address = 10.0.0.1/32
                                  DNS = 10.0.0.53
                                  
                                  [Peer]
                                  PublicKey = 
                                  AllowedIPs = 0.0.0.0/0
                                  Endpoint = 10.0.0.3:9090
                                  ------------------------------------------------------------
                                  [23:47:58.034] WireGuard server listening at *:9090.
                                  [23:47:58.034] Web server listening at http://127.0.0.1:9091/
                                  [23:48:08.804][10.0.0.1:57020] client connect
                                  [23:48:08.804][10.0.0.1:62599] client connect
                                  [23:48:08.804][10.0.0.1:61335] client connect
                                  [23:48:08.804][10.0.0.1:64527] client connect
                                  [23:48:08.804][10.0.0.1:49858] client connect
                                  [23:48:08.830][10.0.0.1:60201] client connect
                                  [23:48:08.864][10.0.0.1:64843] client connect
                                  [23:48:08.881][10.0.0.1:64843] server connect 17.248.209.64:443
                                  [23:48:09.695][10.0.0.1:64843] Client TLS handshake failed. Client and mitmproxy cannot agree on a TLS version to use. You may need to adjust mitmproxy's tls_version_client_min option.
                                  [23:48:09.695][10.0.0.1:64843] client disconnect
                                  

                                  dann fortlaufen.

                                  [23:49:21.680][10.0.0.1:52312] client disconnect
                                  [23:49:22.146][10.0.0.1:49597] client connect
                                  [23:49:22.284][10.0.0.1:63804] client connect
                                  [23:49:22.304][10.0.0.1:63804] server connect 216.58.212.174:443
                                  [23:49:22.323][10.0.0.1:63805] client connect
                                  [23:49:22.354][10.0.0.1:63805] server connect 17.248.209.64:443
                                  [23:49:22.361][10.0.0.1:63804] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for clients3.google.com, this may indicate that the client does not trust the proxy's certificate.
                                  [23:49:22.364][10.0.0.1:63804] client disconnect
                                  [23:49:22.365][10.0.0.1:63804] server disconnect 216.58.212.174:443
                                  [23:49:22.365][10.0.0.1:52816] client connect
                                  [23:49:22.384][10.0.0.1:63805] Client TLS handshake failed. Client and mitmproxy cannot agree on a TLS version to use. You may need to adjust mitmproxy's tls_version_client_min option.
                                  [23:49:22.387][10.0.0.1:63805] client disconnect
                                  [23:49:22.389][10.0.0.1:63805] server disconnect 17.248.209.64:443
                                  [23:49:22.519][10.0.0.1:63806] client connect
                                  [23:49:22.541][10.0.0.1:63806] server connect 216.58.212.174:443
                                  [23:49:22.603][10.0.0.1:63806] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for clients3.google.com, this may indicate that the client does not trust the proxy's certificate.
                                  [23:49:22.605][10.0.0.1:63806] client disconnect
                                  [23:49:22.605][10.0.0.1:63806] server disconnect 216.58.212.174:443
                                  [23:49:22.611][10.0.0.1:55374] client connect
                                  [23:49:22.738][10.0.0.1:63807] client connect
                                  [23:49:22.757][10.0.0.1:63807] server connect 216.58.212.174:443
                                  [23:49:22.821][10.0.0.1:63807] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for clients3.google.com, this may indicate that the client does not trust the proxy's certificate.
                                  [23:49:22.821][10.0.0.1:63807] client disconnect
                                  [23:49:22.821][10.0.0.1:63807] server disconnect 216.58.212.174:443
                                  [23:49:24.700][10.0.0.1:63808] client connect
                                  [23:49:24.728][10.0.0.1:63808] server connect 17.248.209.64:443
                                  [23:49:24.754][10.0.0.1:63808] Client TLS handshake failed. Client and mitmproxy cannot agree on a TLS version to use. You may need to adjust mitmproxy's tls_version_client_min option.
                                  [23:49:24.754][10.0.0.1:63808] client disconnect
                                  [23:49:24.754][10.0.0.1:63808] server disconnect 17.248.209.64:443
                                  [23:49:26.493][10.0.0.1:60191] Closing connection due to inactivity: Client(10.0.0.1:60191, state=open)
                                  
                                  copystring 1 Reply Last reply Reply Quote 0
                                  • copystring
                                    copystring @SpacerX last edited by

                                    @spacerx warum hast du --set tls_version_client_min=TLS1_3 hinzugefügt?

                                    S 1 Reply Last reply Reply Quote 0
                                    • S
                                      SpacerX @copystring last edited by

                                      @copystring im log stand auch ohne diese Option

                                      [23:48:09.695][10.0.0.1:64843] Client TLS handshake failed. Client and mitmproxy cannot agree on a TLS version to use. You may need to adjust mitmproxy's tls_version_client_min option.
                                      

                                      Das war mein Versuch, nachdem ich nach dem Fehler im i-Net gegoggelt hatte und dies als Möglichkeit fand.
                                      Habe, von TLS1_1 über TLS1_2 bis SSL3 alles ausprobiert.

                                      copystring 1 Reply Last reply Reply Quote 0
                                      • copystring
                                        copystring @SpacerX last edited by

                                        @spacerx welchen Browser nimmst du? Bei lief es mit Chrome

                                        S 1 Reply Last reply Reply Quote 0
                                        • S
                                          SpacerX @copystring last edited by

                                          @copystring im Moment Edge. Der ist eigentlich Chrome basierend.

                                          S 1 Reply Last reply Reply Quote 0
                                          • S
                                            SpacerX @SpacerX last edited by

                                            Ich habe nun mal Chrome installiert. Das ändert leider Garnichts.

                                            Noch mal eine Ausgabe dazu.

                                            [11:01:04.438][10.0.0.1:54441] server connect 142.250.184.206:443
                                            [11:01:04.485][10.0.0.1:54441] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for clients3.google.com, this may indicate that the client does not trust the proxy's certificate.
                                            [11:01:04.485][10.0.0.1:54441] client disconnect
                                            [11:01:04.485][10.0.0.1:54441] server disconnect 142.250.184.206:443
                                            [11:01:04.500][10.0.0.1:49611] client connect
                                            [11:01:04.610][10.0.0.1:54442] client connect
                                            [11:01:04.625][10.0.0.1:54442] server connect 142.250.184.206:443
                                            [11:01:04.672][10.0.0.1:54442] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for clients3.google.com, this may indicate that the client does not trust the proxy's certificate.
                                            [11:01:04.672][10.0.0.1:54442] client disconnect
                                            [11:01:04.672][10.0.0.1:54442] server disconnect 142.250.184.206:443
                                            [11:01:07.218][10.0.0.1:54381] client connect
                                            [11:01:07.250][10.0.0.1:54381] server connect 52.29.91.104:8883
                                            [11:01:07.359][10.0.0.1:54381] client disconnect
                                            [11:01:07.359][10.0.0.1:54381] server disconnect 52.29.91.104:8883
                                            [11:01:09.109][10.0.0.1:54443] client connect
                                            [11:01:09.124][10.0.0.1:54444] client connect
                                            [11:01:09.140][10.0.0.1:54443] server connect 18.195.207.39:443
                                            [11:01:09.155][10.0.0.1:54444] server connect 52.29.136.229:443
                                            [11:01:09.218][10.0.0.1:54443] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for api-eu.roborock.com, this may indicate that the client does not trust the proxy's certificate.
                                            [11:01:09.218][10.0.0.1:54443] client disconnect
                                            [11:01:09.218][10.0.0.1:54443] server disconnect 18.195.207.39:443
                                            [11:01:09.218][10.0.0.1:54444] Client TLS handshake failed. The client disconnected during the handshake. If this happens consistently for awsde0.fds.api.xiaomi.com, this may indicate that the client does not trust the proxy's certificate.
                                            

                                            Die Verbindung zum iPhone mit WireGuard scheint zu Funktionieren nur vom Proxy zu Roborock usw. klappt anscheinend nicht weil was mit dem Zertifikat nicht hin haut.

                                            Ehrlich gesagt ist so langsam meine Frustschwelle erreicht.

                                            <frust = on>
                                            Wer sich den ganzen Müll mit den Zertifikaten ausgedacht hat gehört geteert und gefedert.
                                            <frust = off>

                                            Vielleicht war mein Vorgehen bei der ganzen Installation auch falsch.

                                            • Python installiert
                                            • pip installiert [python -m pip install --user pipx]
                                            • Dann die Installationen zu mitmproxy
                                              • py -m pipx install mitmproxy --force
                                              • py -m pipx inject mitmproxy websocket
                                              • py -m pipx inject mitmproxy websocket-client

                                            Noch jemand eine Idee wie man das Prob gelöst bekommt?

                                            @copystring
                                            Geht der Installationskram auch anders. In der Wiki ist von Python als Voraussetzung nicht die Rede. Ich nehme mal an durch die Programmiererei hast du den Kram eh auf dem Rechner. Deshalb klappts bei dir ohne Prob. Ich hab's nur nicht so mit den Zertifikaten und hab immer versucht dem aus dem Weg zu gehen.

                                            copystring 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            1.1k
                                            Online

                                            32.3k
                                            Users

                                            81.1k
                                            Topics

                                            1.3m
                                            Posts

                                            133
                                            916
                                            307878
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo