home-assistant / core

:house_with_garden: Open source home automation that puts local control and privacy first.
https://www.home-assistant.io
Apache License 2.0
71.3k stars 29.86k forks source link

Some Roborock entities not updating to match the app #109584

Closed smenzer closed 2 months ago

smenzer commented 7 months ago

The problem

There are at least a few entities that do not update. Specifically, the Water shortage and Water box attached always show as "ok", even when the water is empty or the tank is removed. The Roborock app properly shows the current status (i.e. when the water tank is low, I see the light on the base station and the app tells me it's low) even though the home assistant integration isn't updating (i.e. the status shows as Ok or Connected (respectively)).

What version of Home Assistant Core has the issue?

core-2024.1.5

What was the last working version of Home Assistant Core?

No response

What type of installation are you running?

Home Assistant OS

Integration causing the issue

Roborock

Link to integration documentation on our website

https://www.home-assistant.io/integrations/roborock

Diagnostics information

config_entry-roborock-0f57b332cc4ba310ffd96640e200f761.json.txt

Example YAML snippet

No response

Anything in the logs that might be useful for us?

Saw this in the logs:

2024-02-03 21:38:46.735 ERROR (Thread-13 (_thread_main)) [roborock.cloud_api] [Roborock S7] ('Failed to decode %s for %s', b'n6qWb90e\x00\x00\x00\x00\x00\x00\x00\x01\xfaX\x00\x00\x00\x00\x00\x00\x96\x96\xc9W\x05\r\xb2\xb9r)L6\xfa@\x15\xca\x9eT\xc9\x8d\x16K\x7f\xf5\xa6\x8a\xe7{\xb7\xab\xa5\xcc\xa5\xa3t\xa8\xa2\x99\x01\x99O\xc4w/\xfai\xa2\x034\x8f9\x1b\xc0\xae\x84\x9f\xe7:\xe6\xe8\xe1Q\xb7mOY\xac1#v;\x1f\xc5\xc1\xc8S\x0c\x9fHO\xfc\xb5\xf4\x00\xb9\xa7\xa3\xfc\xa3a\xff\xfe0\x87Gq\x97P]\xb3\xe0\xd2Bn\x98\x01\x04\xdf\xb1\x0c\xef\x0eE\xbdn\xf9\x0f\x0c\xcd:\x8a\xd2\xb5\x19N\xa5\x1b*\x18a\xedJfg\xa2\xc6\x964ms\xfe\x97\x86\x0b\x08\xc5R\x16mz\x1a]4\x83\xea\xabf\xc3\x89\xa3\rp\xf8oZK\xa8\xa1\xfd\xcer\x1e]w\xdb\x10w\xd8\xe4\nd\x0f^\xaf\'\x0e\x9d$\xcb`J\xb1\t\xea!un\xee\xc9\x11\xa5\xbc 2\xc5\xc5\xa8\xb6@\xefo\xeco\xd5W\x12)\x94\xd0\xc3\x93i?\x85\xf6\xf1:\xe5\xb0,\xdbaX\r\xf4\xeb\xd1\x0b\x83\x10j\x00\ri\xd7mM\xa7\xb5\xa2\x12\xe2\xb7\x08\xf7O\x134\xb1C\x16\xb4\x89\xc7lu\xc3t\xff\xf7\x8at\xb4LRV@\xf1CV\x84\xd6\xc3\xea\xea\xe5\xa2\x0e\x16\xd3\x14\x0f\x07\x19\xcc\xf9>"\x13\xa6Zo\x18lb\x10\xd5\xbf\xabL> J\xeb\x1d"\xe1\x8euk6\xcc\x13\xde3\xea\x9e\x99\x868^\xee\xa6\xa1\xd0~\xe6\xd9\xbf%\xf1}\xb7\xc9\x97\x9bF\xb7\xb7H%\x95\xeb\xfd\x16 \x9f\xf4\xd8\xf7\xed\xc6%\xc2w\xca\x90N\xb9\xfa6\xfaL\x9b\x11\xc7\'j38\x85\x1b?s0\r\xba<\xd8m\x05&\x9a\xc2/\x81rS\x15\xb7+\xc9\r\x01L\x15\xe8\xfd\xc7\x10/\x7f\x1c\x9c0\xf9\xc6d\xb6\x92*\x9fk\x02\x83\x97x\x96\x11\xb3\xa9\xa4\x84X\xf0^.\xd0\xa1\x91a6M8\n\x8e\xd9N\xa6\x9e\x8eLu\x17\xbb\xdc|\xd2\x1e\x10\xb3\xad}\xb3\xd5\xa20\xcc\x7f\x93J\xc5\xf8d7L\xb3\xf5o\xe4\xbc/\x0c\x10\xf7\x80O\xfa\x87\x17\xae\xb2E\xfe\xc3\xd2\x8b\x92\xe3p\x9f\x94\x8c\x12\r=\xb3nc\xc5l\x16\xacK\x9a.D\xfc\xb9\x05\x95Q\x06\xac\x1d\x0b\x9f\x88\x9cO\xa9\xc9o\x1d\x9a2\x07tu&T;F]\x82\xa4\xb8K\x96\xcd\xd0u\x16^b\x82\x98\x04\xb2\xb2\xf3\xcf\x82\xaf\xe9K[\xd5=\xf4o\xe1\xdd\xbe\xccT\xaawL\x01\x87Y\'\xf3!H&6\xd4<Q\x12\xd5_c\xc8\x91\xaa+\xa2\x19$\x98 \xec&\xa38E\x95\xeb=\x1e?\xb9\x9c\xe6\x19\x01\x01\xea\x9c\xc8\x8fI\r\x92$^\'\x97\xbbrsV\x1c\x11\xdf\xc2\xf3\xbc$\xc7\x14ob\xceM`\xe6\xf6\xf0\x02\xf3-Q>[\xd0\xbd\xbdg\xae\xb5\x1f\x89\x9dy\x83\x8d\xd6=f\x06J\xb9\x11]\xde@V\x8f\xa3\xe3\xdb\xb6\xe5\r\xba0\xa6\xda\xf1W\xe0\x0840\xef\xd4\xa0\x17H\xdb\xf9\xefV\xce\xdd\xec\xeb7"\xcfC\xcf\x9fn\x89\xc0\xdd&\xdc\xd1_\xc1\xb7\t}iC\x93\xc7@S<Sv\xb4\xb4\x1b\xd1\x80$(\x02\tY:\xccZ+\xed\x82F\xfd^\xdd\xa3L\xc9ltx\xa1\xf3\xde\x0c\xbc\xe4\xeeV[Zj\x06\x1d\x86i\xe1V\xad\x81\xc6d!\x9ek\xf2\xcc\x9ei\xf4\x86\xf7\xaeC=\x0cG\xb0\xd6\x13\xa9\xbf\x11\xf0\xe1\x9a\xaa3H\xd0R\x90~r\x9c_\xbf3\xfbJA=\xa7VdrMe\x82@\xd3\xa2\x8f\x94\x88S\x9f\x98\xf4\xc6\x15i\x8b;\xa2\t#sq# \xac\x9a\x17:h\xad\xf9cP\xe5 \xb0>\xcfu[\xef\xda6N\x0fK\xef\xff*J\xa1\xbcL\xae\xaf\x96|a\xf8\xa4\xd4\xb0\x18\xf3\x94\xe2s\xc8\x1c\x846\xf9V\x05o\xfdJ\xe9\x1f\x07\xd8\xbe\x19i\xc4\x17\xa1J\x03 \xd5\xae\x99\x10FDO\xb0\xdd\xb6\x83JX.\xd9\xff\xc0\xeb\xb4\xd4J_\xb0\x02\xcd\x81gsp\'\xcbH\n>\xb5\xb3\x0b&\x13i\x15\x84\xc9\xf2\xb0\xc0\xc7\xa7\xb3\xab\xfb4\x90\xd0\x7fu\x1e\x01H\xa6\xef`\r!\xb3!\xffK%Q\xa2P\xe4\xcb\xe6\x14\xdd\xe3C\xd4\xbb\xf0\xce\xad6\x92H\rO9\xa2\x9b}\xfbR\xa7\x10\xf2\xff\x0e\xe7n1\x9d\x9c\x16\xc5S\xdb\xb0Z\x01n,\x91i\xa6\xd1D\xadI\x8d\x90~C\x10\x1cU?\xfer\x8a\xf9\x08\xb9\x0f\xe3\x93\x1d\x9a\x17\x95\x03\xc4\xd8N\xa0\xdb\xbb5\x9a\xe0\xd4\xa4slB2d\x05\xe8\xf4\x06\xc1\xf4\xa7\x10DIH-\xd1=UzN\xc3\xb6\xfc\xf7\xea\xa4\x03(\xad\xa0\\7\xa7w\xc7N\x9c\x9d:\xd5\xa4\x1c@\xeaq}\x12\xbc\xa6M\xe3\xc0\xd4\xa9\xa8.\xca8\xa9\x0c\xe2\x84\xc59\x1b\xba\x80\x15ymG:\xe5\xebg\x92\x1c\xaf\xbbor#\xa9\xc6\x94P\xd4\xd8\'iN]\x8dM\xe5h\xec\xbb$\x98\xb5\xd1\xc1\xee\xca\x02\xdc\xe3\xb7\x92<\x10\x04H\xd4y\xb0\xcf[\x16\xf6`\xb9@g\xa5/\xf1@\x97o@2\xfb\x10$\xa6%@\xe6{\x7f:\xe0\xa2t\xc5\xab\\#\xfega\xc1{\xd3\xf4\xc4\xd7\x824\xdc.\x92u\x96O\xd1\x89-\x07\xb7l\x1fTK.\xb15N\xd3\xa0\n@\xaa\xfcR0lY\xb0\xbe\xec\xc9]\xa9\xc1\x9b\xc70:H\xdcw\xfbT\xee,2\x80\x94f\xd0\x16\xefHwn\xa6\x01\x99\x9c\x87`~a\xa7\x198\xe1\x12\x88\x1d\x81\x02\xd9\xc7\x98\x8fe\xac\xd12NE\xe2\x17\xb1\x0c\x0f\xf6\x03o_\x1eP\xaep\xd0^\x12o\xd5\xd29\xbd\xe5:\xe4\xaf6\xc4\xe1\xbc\xfak\x81\xad\xa2\xe8R\\\xbc\x83\x98\xc1\x7fw\x99\xef\xb4%\xde\xd1\xcb\x94?P\xa1\xd1\x05\xa28\xe5\x16\x92\x1bV\t\xac\x9b\x0e\xd0\x98\xe4\x9d_9\x15\x82\xb1\xf0l\x97\x10\xc3\xe9\xb3\xf9\x08\xe04\xca\x1c\xe8V6E\xcd\x83\xfb\x9e#\xeany\x01\xee\t,lTH\xe5\xa5\x0b\xe28\x1a\xf7LG\xd7i\xa1w\xac)\xc4\x18@\x9f\xb2\xc6~\xd7\xafH\xaa\x07\x14O>\x14Q\xb9\x7f\xd4\xf6\xa3 \xf5\xf8\\=-\xc2\xcf%!|\x1f\xf7/\x8aG<\xc0\xb5\x04\xbc\xda\x04\xd1nA1d\xff\xe5\xf5[\x04\x03:\xde\x8a\x00s\xa1(\x1d\xb3(\x9asX\xa7\x86\x00H\xf6\xc1\xafv\xd1\x81\x99T\x8c 0\xef\xa8{\xd0\x12 \x15n\xe7t|\x900\xf0\xeb\xb5Bj\x00\x82JG\xfa\x10\x97\xf7"\xb0\xaa\xf74\xfb\t\xa9\xed)\xd2\xa6\x94R\xc6\x86\xcf\xc6\x98td\x00\xa0\x10!P\x0b-\xd7\xac4\xd4\xf4\xe8\xe9\xdbf\xddB\xa7\x0c\x98_\xb9\xa6+\xb3\xe2\x85\x99}\xccI&s~\x80\xf7\x12\xe2|(\x10\xfb\xc2\xf8P\xa7G"\xae\xfc^\xf3\x9e\x9d\xc4\x1d\xad\xbe\xed\xfaj\xe7P\xbeL*\xfa\xf2{\xf9\x11\xab\x08\xa4\x030\xfe\xff\'!\x06\x8e`G){\xae\xd8\xe9\xc1\xd8T#Bcd\x03\x94\x9b\xc9A\xd7\xfc\xb4\x10Be\xbdzf\x86\x0f\'\xbc\x91\x14h\\\xfb;\xf8q\xbc!pu\xab$i\\\xa4\xb3\xab\x9f\xb6s\x0f\x9a>\xa3T+I\xf2\x07\x10\xcdR\x04\xec\xdf\x87"`7!m\xfa\x07\x19+4\x11\x93\xc6\x14\xae)*\xfc`.~\xc0u\xb0\xa0\xc7j\x04\xab\x07\xa9\x04z\x9e\xb2\x1f|\x87\n\xb8\\\xcd>c6i\xfb\xc1\x7f\xed\xa7\x8c\xa4\xba\xbbj\x07\xee\x9f%\xc4\xf4l\x98\x1b\xac-\xf1%\x9dv#b\xfb~\xaf\xc0\xe4!\xda\xc5;\x9c\x8e\xe3\xce\xc9\xd3v\x15IH\xf2W\r\xd2\xed\x15>\x0e\xf7\xfb\x1a\xc2l#y\xf9m\x97\x15M\x9acr\xdb\x8bX\xd4\xd7\xe0\xb5%\x93\x00\xd9\xed\xbd\x9d\x98U)I\xe2\xd9\xf9\x80\xceYcwO0\xdfK}\x84j\x88\xe5\xf4\x03(\x13\x8a\x9e\x81,h\\\xf8++\x90\r\xf1\x8f\xf8[tW\xf0\xa9\x9e\xde+S\xf5\x08\x04}B\x86\xa9\x1e\xc3\x83XY#H\xbc\xb0p\x0f{\x98\x83\n^LK*\xf7\xa2\xb3\xa1o\xcc\x7f0=\xbez\xdc\x03z<\xad\x92\xfc\x84\xf2p\x11\xd8\x07\xe7\xe6dT\xebE\xe4:\x8aq\x8b\x19j\x91\xa9bs\x185K\x08\xd0\xc8&\xd2\x02\xbfT\x9b%}\xf3@-\xae\xa2\xee\x96f\x17\xe8\xb7\xc10\xd6%\xa2\xdb\xc7,\xb9\xe73\xde\xc1\xdd\xcd\xf5\xdb\xf5\xf7\x18\x08n\xdc^\x95\xe2\xfe>\x9f!\xf5\xe9\x98r\xe6\xef\x16\xcf=\xae\xa5P\x02c}\xffrL\x88`d\xe1\xe4\xf4\xb6l]\x0cB,\xb4\x92\xad\x96.\xa8v\xe5/\x1e\x91v\xc2\xbdi\xd9\xe7\x07T\x19r\x11\xd4#\x0b\xd5\xd1Zx\xb9U\x05L\x95,\x1c\xb7\xbf\x01F\xd7<\xc7K\xbdI/\xc0\x1dkd\xc5:\x98N]B\x84\x15\x19\xe8k\xa1\x1cH\xd7\xfd@\xff\x1a\xda]OCB8\x19\x1bG4^\xf2\x86$\xa2m\xde\xda\x1f\xa1\xb1~\xdf\x9393\x10"\x14\xce"&\xf6@\xdd\xe6)W\xa0\tP\xc6\xbd\xe3\xa7D3\xff\x1c\xca\xd4\x7f\xb0\xe8K\xd5\x90\x02S0\xaa\xf9pI\xdfn\x06\xa8DJu\xc6\x81\x11\x9a\xb4\xfa\xd1\x1b\xaa\xe0\xdd\xeb\x18\'.\x92*\x9ct\xe71C\xec\x84-=\xdc\x03\xb0&\x8b\r\x98\xd3,M\xc2l\xfa\xe4&\xe2\xdf\xedXC\x19g\x10\xd3\xcdQ\x15\xa2\xa1\x16w\x96S\xdf\xa7\xf0@&\xc1HC4p+D\xe0=\xed\x19\x89\xfe\xe4\xb4c\tYC\xc2[\xd2h`\x88\\ \xc5\xd3\xe6\xfee\x9a3Sk\x07\xb4\xce\xaad\xe9\x87\xed\xc8\xde\x15n\xe8\x8fT\x82\xe2(G`&\xc8\xf9\xe3\xb5\xba\x03#/\x01jR\x19\x03\xcc\xbcQ\x93\x8d3\xeb\x98\xbe%\xa1\r\xfaJ\xf8W\xfee\xad\xa9Y\xcc\xa7\x1fVI\x12\xcdt\x99jd\x9e8G/\x02\xd1\x17\xcb\xa0\x11\xee\xf3\x08!\xec,\x12\xfa\t\x1d\x89\xf6\xf8\x04v\xa6\x7f\x91\x8b\x06\x94rY8\xc6vs \x19\xd4\x91\xb0V\x15/<\x8a\x93Xi\x0bG\\\x00i,J\xc0J\xc7\x08\xcd\x1e\x89\x8c\xd5\xc6\xd6\xc6#\x95\xf7W%\x9e`k\n\xff"5\xa2N\xc0\xb5\x90\xd5\x06\xefw\xe1\xeb\x0b\x879\x1d\xc6R\x84\xa4\xd5\x8fI\x90\xc8w\x91\xe0c\xa0\x13JP\n\xef{uy8G\x8bK\xd8I\x1e\x12\x96\x949iz/\xbe\xc1\x96\x7f\x9a\xfe\x91\xfd\xd9\x13\x89h\xb4\xc5L\x1b.6,\x15JV\x86>>\x9dzx\x97\xb4\xa6a\xc5\xd9n\xa2\xd7\xb9\x98\x14\x07\t\xd9I\xf8\x12\x99\xccF\xd9\xdaY\x16\xa0\x8dv\x9a\xe2sfF\xb5[\xed\xd1N\x8d\xe9\xc8I\x84\xffj\xc4)\x96\x93\xd6u\xf5\nz\x16\xe6xP9\xc5{\xedw\xb5*\x84!\xd6\xe2\x06;=\x9f,\x01|\xbe\x8a\xdb\x18\x1f\x18\xe4\xd5%\xe6\x07\x00n\x92\xe9\x01L\x94D-\xc6\xb5\x14E\xbf\xfc\xe7\xb7V\xad=C@)\xeb\x03\x83\'\xf1m\xdc\xdb\x92\x8a}\x13op\x8f\xe2b~|\x9b\xe2w;p;\x9a\x07_`\xbf{p\\-\x88\xd5\xf0\x02r\xeaq\x9c\xb7\x05#\xca\xf9\x9f\xbb\xaas\xfa\x01!\x9b\xb1\xbbKM\xe8\xec\x9fc\xbc\x83\xa2\x03\xc5w\xb4\x12\xfe\xd3\xd7\n\x9a\xa8_S\xe3\xe6\x9a\xae\xb9i\xf7\xc2\xe1\nO\x9d|\x15\x84\x9e,k\xe2\xb4\xf7\\p\x11\xa5\xc3\xe6\xf1T\x8c\xd3\x85\x98\xb2\'K\t\xa2\x90\xc3:\xd3\x8e\x8d\xd7\x97\x91[\xa4\xd7f\x9f\x19\xf3\xdc\x8a\xd8\xdf\xd5\ra$\xa5\x9f\xd2\x82\x00A\xe3\xfa\xd7"\xbb\x82\x1a\x94\t\x12\xce\x1d\x87^\xb0X\xf9\xf5\xe1\x88\xcdHf\xf3\x82\x13UJ\xaa\x87_\x00\xea\x9d\xab\xb2\xf915\xce\x1dE\xeb\xb7\xc38\xb2\xf7@1n\xc7!\xdf\xa0F\xc0\xf1\xec\xd2M\xf5\x8eN\xfd\xa4\xa0\xf9@\xef\xb4\xa9\xf9[0cM\x1a9\x0f4\x12u\xe2\x98\xcb\r\xd3\xfd\xdb\x90\x86\x1c6\xcbxEt\xf1X\x9a)\xbc\x93\xceCGd\xce\xc7\xf1\xf5\xef?\xba\xdb,\x9dA\x00\xfc\x8d3+\xa7\x1a\xd465\x91>2\x13\x01M\x06\x17L\x8e\x91\xaaY\xc47\xc1\xc2\x0c0A\x99\xfc\x85\x00\x16\xf4|f2\xc0<#\xa0\x87\x98\'\xd6\xf2,d\xb6\x1b\x02i*-\x9f$"N\x9aTK!\x01Q6\xf3\x81\x8cM\x1d\xd1\xce\\\xab\x02(\xf7g\xca8\xf93\xdcY\x12\x04\xa2f\x92p\x0fx^\x9avO\x17\xe98\xe7\x13\xc1?\x14\x8drq\xc3n\x85KpJ\xaa\xf3\xe0sI\xdd\xb5\x87,\x01x\x1da\x95\xf53\x99\x1dzT\xb7\xae\xbaK\x006I(6\xcc\x8c\xa6#]\xbb\x92\xac\xef\xa2\x15\xba\x02\x15\xfa\xf4\xb2\xf9\xe1\xf6"\xd6\xb0\xc2!\xad\xb25\x90\x0f\xb4\x95O\x99(=9\xd1s\x16S\x97\xef\x95lbsT\x8eP<\xff*2\x02"S\xb5\xec\x1es1(\x0cAY\x97KW&\xe0\x12\xb2\xa4\xcd\x19\x08\n\xc6\x00ZS\x19L\x9a\xbe\x0b#\x9cJL\x81\xe1\xba\x07\x1bX>n\xda\x19\x1e\xbcl\xb6\x91\xf2\xa6\x0b\xca\xb0\xa6|\xfcO7\xeeP&SD\xdc\x8d\xceT\x1c\xe5\xceySG\x0e\x18\xab\\N\xc2d\x02+\x11\xfdF\xff\xd4\xcf\x91+\xd3,\xb4!\xb8\xc6\xc65\xb0\xce{*\x9c\xcf\x8d|\xd3\xbe:\xc6\xac\xc1\x82\xa6\xeez\x82\xc2\xe9\xa6\x8a\x93\x95\xb7\xb6\x12v\x8b\x8b\x91c7\xcd|\xd8~\xbb=K\x8c\xb4\xfe\xde\x99\x11#\xaa}\xa1\x03\xc3y\xeekZ\x02xZ\xf6\xdf\xb5~\xac2\xfd\xb1V\xe8\x19OjZ\x0b\x9a\xe5\x1a\xbf!\x0b\xfcEn\xa0\xd3\xb0\xc6\xa5\x8a\r%\xbe(\x94\xc8\xe5\x86<J(^\xd4\x7f\xed\xef\xf7\xaf\x1a$\'\xca\xd0\xaf\x0c\xdfKEQ\x81r\xac\x02g\xf3~\xac\x8e\x8b2\x968\xa0L\x1ce\x9b\xc9\x04WodC\xa05lg\xdf\x84\xebk\xd4#\x06\xe8\xba\xd5eX\x99kv3\xab\xc6-\x96\xd9g\x13\xea\x9b\x8b\n`\xfe\xebZ\xc9}\xda#[\xc7{p\xb0\x88\xf7\xf0^{\xa6\x9aB\x16\xb7M\xacUQ\xfc~\xcb*^xXh\x8b\x9cA\\G,\x16m\x1a\x97j3\xda\x9a\x9c\x8c\x00f\x8b\xa2N\xbf\xf6\x9c>]S\x07$\xd7\x87N&\xeb\xc7\x9f_\xd9m\xde>\xa2\x81\xdc\x0c\x06n\xbcjG\xda\x07\xfe4\riF>\x9c7\x19z\xabUn\x89\xa5\xc7A\xe0\xb4\xf7Bb03\xbc\x0ffIQm\xdb\x96<\x9f;\xd8l\xe7o\x92V\xe8Gj\xb6\x11\x8e?\xad\xb1\xe0G\x7f\xedO\xe4\x9b\x14\xa8\x82\xd7\x1f\xe3?\x10A\x8a!}\x0c\xb9\x94\x17\x00\x14\xcc\x98\x07\xcf\x19\xec&\x81\x92\x95*J\xdeKZ\xe5\x95\xf5W\xebTI\xed\x0b\xcf N\xcc.\xb5\'S\xebI{\xa9\x0f\x0b\x15\x9d\x0b=\xd0A^dw$\xa1\xa9\x0b[\xde/\x07\xaf\xa0\xfe\\\xe7\x9eu\xc7\x1a\x1chv\x1ac\xba9\x16t\xaa*\t&*\xf2n`C\xda<`\x0e\xfd\xd42\x0c\xfb\xd9Ig`Z\xca\x94\x87(\xa79\x9e\x14\xa5P\xbeW\xb4\xcd\xa0\x94\xe5\x96\xd9\xa7,yy\xe2\x86\xd5\xb9:\xbd$\xd9D\xcc\x883\x15\x0c\xff8\x83\xb8]\xe9\xf2X\xdd\x07\x8a\x1f\x9f\xfd\xe0\x9c\x8bT\xd6\xe8\\\xa4\xd2\x96C,\xbe\xc2?\x98\xdd\x07\x86\x9f\xbd\xb8\xf1\xd56k\x94\x8c\x14\xd5\x87W\xf5\x8fK\x15\x82\x10\xf6[\x9f93K\x10\xe1\xba\x82\x8e!\xd1\xfd\xa6Ow\xc9Lw\xb5GFq_\x99\xd8<\x08_\xf2\x84m\x9e\xad\xf7\xf6\x94~R8\xbb\xe7u\xb5\xd7\x1dK\x8a\x8f\xdd\x9f\x19A\x1d\t\xf0\x8f\xe8UU\xb6\x1dhRk\xb2\xfc\xeb 2u\xe8\x98q\\\xa9Mp\xea9\xe0\x0b\x08\x96\x9f\x91\x81\xee\x80~\xab\x82%\xc1\xa3\xf9<\xa2|\x9e\xfa\x1e\xe1l\xb0\x87\xa9\x1c\x18+X\x1c*\x8b\xc6}\x8d@\x02T\xe5.\xda\xf6]\x06\x9a\xba\xda\xd6\x8b\xd6\x18\xadY\x7f\x97\\\xf9\xc9]\x0eD\xa7\x9c\xad[e\xd9\xd9\xb8\xf0\xb0\xc3\x90\xf7\xe1.\n\xfcV\xb7 \xc6\xb5x\xf8\xb4SRqL\xce\xde\x8aU\xa1\x11O9\xa1\xaa"-_>\xc9\x04g?\xc5#\x90\xec\x93\xd1\xa8/\xd5P\xa6\x04-\xae9}<\xe5\x15\x11\x033!\x058[y=79\xc4\x01\x17\xbdU\xfd\xf2\x83=\xde', 301)
Traceback (most recent call last):
  File "/usr/local/lib/python3.11/site-packages/roborock/api.py", line 317, in on_message_received
    decrypted = Utils.decrypt_cbc(data.payload[24:], self._nonce)
                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.11/site-packages/roborock/protocol.py", line 155, in decrypt_cbc
    return unpad(decipher.decrypt(ciphertext), AES.block_size)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.11/site-packages/Crypto/Util/Padding.py", line 92, in unpad
    raise ValueError("Padding is incorrect.")
ValueError: Padding is incorrect.

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "/usr/local/lib/python3.11/site-packages/roborock/api.py", line 319, in on_message_received
    raise RoborockException("Failed to decode %s for %s", data.payload, data.protocol) from err
roborock.exceptions.RoborockException: ('Failed to decode %s for %s', b'n6qWb90e\x00\x00\x00\x00\x00\x00\x00\x01\xfaX\x00\x00\x00\x00\x00\x00\x96\x96\xc9W\x05\r\xb2\xb9r)L6\xfa@\x15\xca\x9eT\xc9\x8d\x16K\x7f\xf5\xa6\x8a\xe7{\xb7\xab\xa5\xcc\xa5\xa3t\xa8\xa2\x99\x01\x99O\xc4w/\xfai\xa2\x034\x8f9\x1b\xc0\xae\x84\x9f\xe7:\xe6\xe8\xe1Q\xb7mOY\xac1#v;\x1f\xc5\xc1\xc8S\x0c\x9fHO\xfc\xb5\xf4\x00\xb9\xa7\xa3\xfc\xa3a\xff\xfe0\x87Gq\x97P]\xb3\xe0\xd2Bn\x98\x01\x04\xdf\xb1\x0c\xef\x0eE\xbdn\xf9\x0f\x0c\xcd:\x8a\xd2\xb5\x19N\xa5\x1b*\x18a\xedJfg\xa2\xc6\x964ms\xfe\x97\x86\x0b\x08\xc5R\x16mz\x1a]4\x83\xea\xabf\xc3\x89\xa3\rp\xf8oZK\xa8\xa1\xfd\xcer\x1e]w\xdb\x10w\xd8\xe4\nd\x0f^\xaf\'\x0e\x9d$\xcb`J\xb1\t\xea!un\xee\xc9\x11\xa5\xbc 2\xc5\xc5\xa8\xb6@\xefo\xeco\xd5W\x12)\x94\xd0\xc3\x93i?\x85\xf6\xf1:\xe5\xb0,\xdbaX\r\xf4\xeb\xd1\x0b\x83\x10j\x00\ri\xd7mM\xa7\xb5\xa2\x12\xe2\xb7\x08\xf7O\x134\xb1C\x16\xb4\x89\xc7lu\xc3t\xff\xf7\x8at\xb4LRV@\xf1CV\x84\xd6\xc3\xea\xea\xe5\xa2\x0e\x16\xd3\x14\x0f\x07\x19\xcc\xf9>"\x13\xa6Zo\x18lb\x10\xd5\xbf\xabL> J\xeb\x1d"\xe1\x8euk6\xcc\x13\xde3\xea\x9e\x99\x868^\xee\xa6\xa1\xd0~\xe6\xd9\xbf%\xf1}\xb7\xc9\x97\x9bF\xb7\xb7H%\x95\xeb\xfd\x16 \x9f\xf4\xd8\xf7\xed\xc6%\xc2w\xca\x90N\xb9\xfa6\xfaL\x9b\x11\xc7\'j38\x85\x1b?s0\r\xba<\xd8m\x05&\x9a\xc2/\x81rS\x15\xb7+\xc9\r\x01L\x15\xe8\xfd\xc7\x10/\x7f\x1c\x9c0\xf9\xc6d\xb6\x92*\x9fk\x02\x83\x97x\x96\x11\xb3\xa9\xa4\x84X\xf0^.\xd0\xa1\x91a6M8\n\x8e\xd9N\xa6\x9e\x8eLu\x17\xbb\xdc|\xd2\x1e\x10\xb3\xad}\xb3\xd5\xa20\xcc\x7f\x93J\xc5\xf8d7L\xb3\xf5o\xe4\xbc/\x0c\x10\xf7\x80O\xfa\x87\x17\xae\xb2E\xfe\xc3\xd2\x8b\x92\xe3p\x9f\x94\x8c\x12\r=\xb3nc\xc5l\x16\xacK\x9a.D\xfc\xb9\x05\x95Q\x06\xac\x1d\x0b\x9f\x88\x9cO\xa9\xc9o\x1d\x9a2\x07tu&T;F]\x82\xa4\xb8K\x96\xcd\xd0u\x16^b\x82\x98\x04\xb2\xb2\xf3\xcf\x82\xaf\xe9K[\xd5=\xf4o\xe1\xdd\xbe\xccT\xaawL\x01\x87Y\'\xf3!H&6\xd4<Q\x12\xd5_c\xc8\x91\xaa+\xa2\x19$\x98 \xec&\xa38E\x95\xeb=\x1e?\xb9\x9c\xe6\x19\x01\x01\xea\x9c\xc8\x8fI\r\x92$^\'\x97\xbbrsV\x1c\x11\xdf\xc2\xf3\xbc$\xc7\x14ob\xceM`\xe6\xf6\xf0\x02\xf3-Q>[\xd0\xbd\xbdg\xae\xb5\x1f\x89\x9dy\x83\x8d\xd6=f\x06J\xb9\x11]\xde@V\x8f\xa3\xe3\xdb\xb6\xe5\r\xba0\xa6\xda\xf1W\xe0\x0840\xef\xd4\xa0\x17H\xdb\xf9\xefV\xce\xdd\xec\xeb7"\xcfC\xcf\x9fn\x89\xc0\xdd&\xdc\xd1_\xc1\xb7\t}iC\x93\xc7@S<Sv\xb4\xb4\x1b\xd1\x80$(\x02\tY:\xccZ+\xed\x82F\xfd^\xdd\xa3L\xc9ltx\xa1\xf3\xde\x0c\xbc\xe4\xeeV[Zj\x06\x1d\x86i\xe1V\xad\x81\xc6d!\x9ek\xf2\xcc\x9ei\xf4\x86\xf7\xaeC=\x0cG\xb0\xd6\x13\xa9\xbf\x11\xf0\xe1\x9a\xaa3H\xd0R\x90~r\x9c_\xbf3\xfbJA=\xa7VdrMe\x82@\xd3\xa2\x8f\x94\x88S\x9f\x98\xf4\xc6\x15i\x8b;\xa2\t#sq# \xac\x9a\x17:h\xad\xf9cP\xe5 \xb0>\xcfu[\xef\xda6N\x0fK\xef\xff*J\xa1\xbcL\xae\xaf\x96|a\xf8\xa4\xd4\xb0\x18\xf3\x94\xe2s\xc8\x1c\x846\xf9V\x05o\xfdJ\xe9\x1f\x07\xd8\xbe\x19i\xc4\x17\xa1J\x03 \xd5\xae\x99\x10FDO\xb0\xdd\xb6\x83JX.\xd9\xff\xc0\xeb\xb4\xd4J_\xb0\x02\xcd\x81gsp\'\xcbH\n>\xb5\xb3\x0b&\x13i\x15\x84\xc9\xf2\xb0\xc0\xc7\xa7\xb3\xab\xfb4\x90\xd0\x7fu\x1e\x01H\xa6\xef`\r!\xb3!\xffK%Q\xa2P\xe4\xcb\xe6\x14\xdd\xe3C\xd4\xbb\xf0\xce\xad6\x92H\rO9\xa2\x9b}\xfbR\xa7\x10\xf2\xff\x0e\xe7n1\x9d\x9c\x16\xc5S\xdb\xb0Z\x01n,\x91i\xa6\xd1D\xadI\x8d\x90~C\x10\x1cU?\xfer\x8a\xf9\x08\xb9\x0f\xe3\x93\x1d\x9a\x17\x95\x03\xc4\xd8N\xa0\xdb\xbb5\x9a\xe0\xd4\xa4slB2d\x05\xe8\xf4\x06\xc1\xf4\xa7\x10DIH-\xd1=UzN\xc3\xb6\xfc\xf7\xea\xa4\x03(\xad\xa0\\7\xa7w\xc7N\x9c\x9d:\xd5\xa4\x1c@\xeaq}\x12\xbc\xa6M\xe3\xc0\xd4\xa9\xa8.\xca8\xa9\x0c\xe2\x84\xc59\x1b\xba\x80\x15ymG:\xe5\xebg\x92\x1c\xaf\xbbor#\xa9\xc6\x94P\xd4\xd8\'iN]\x8dM\xe5h\xec\xbb$\x98\xb5\xd1\xc1\xee\xca\x02\xdc\xe3\xb7\x92<\x10\x04H\xd4y\xb0\xcf[\x16\xf6`\xb9@g\xa5/\xf1@\x97o@2\xfb\x10$\xa6%@\xe6{\x7f:\xe0\xa2t\xc5\xab\\#\xfega\xc1{\xd3\xf4\xc4\xd7\x824\xdc.\x92u\x96O\xd1\x89-\x07\xb7l\x1fTK.\xb15N\xd3\xa0\n@\xaa\xfcR0lY\xb0\xbe\xec\xc9]\xa9\xc1\x9b\xc70:H\xdcw\xfbT\xee,2\x80\x94f\xd0\x16\xefHwn\xa6\x01\x99\x9c\x87`~a\xa7\x198\xe1\x12\x88\x1d\x81\x02\xd9\xc7\x98\x8fe\xac\xd12NE\xe2\x17\xb1\x0c\x0f\xf6\x03o_\x1eP\xaep\xd0^\x12o\xd5\xd29\xbd\xe5:\xe4\xaf6\xc4\xe1\xbc\xfak\x81\xad\xa2\xe8R\\\xbc\x83\x98\xc1\x7fw\x99\xef\xb4%\xde\xd1\xcb\x94?P\xa1\xd1\x05\xa28\xe5\x16\x92\x1bV\t\xac\x9b\x0e\xd0\x98\xe4\x9d_9\x15\x82\xb1\xf0l\x97\x10\xc3\xe9\xb3\xf9\x08\xe04\xca\x1c\xe8V6E\xcd\x83\xfb\x9e#\xeany\x01\xee\t,lTH\xe5\xa5\x0b\xe28\x1a\xf7LG\xd7i\xa1w\xac)\xc4\x18@\x9f\xb2\xc6~\xd7\xafH\xaa\x07\x14O>\x14Q\xb9\x7f\xd4\xf6\xa3 \xf5\xf8\\=-\xc2\xcf%!|\x1f\xf7/\x8aG<\xc0\xb5\x04\xbc\xda\x04\xd1nA1d\xff\xe5\xf5[\x04\x03:\xde\x8a\x00s\xa1(\x1d\xb3(\x9asX\xa7\x86\x00H\xf6\xc1\xafv\xd1\x81\x99T\x8c 0\xef\xa8{\xd0\x12 \x15n\xe7t|\x900\xf0\xeb\xb5Bj\x00\x82JG\xfa\x10\x97\xf7"\xb0\xaa\xf74\xfb\t\xa9\xed)\xd2\xa6\x94R\xc6\x86\xcf\xc6\x98td\x00\xa0\x10!P\x0b-\xd7\xac4\xd4\xf4\xe8\xe9\xdbf\xddB\xa7\x0c\x98_\xb9\xa6+\xb3\xe2\x85\x99}\xccI&s~\x80\xf7\x12\xe2|(\x10\xfb\xc2\xf8P\xa7G"\xae\xfc^\xf3\x9e\x9d\xc4\x1d\xad\xbe\xed\xfaj\xe7P\xbeL*\xfa\xf2{\xf9\x11\xab\x08\xa4\x030\xfe\xff\'!\x06\x8e`G){\xae\xd8\xe9\xc1\xd8T#Bcd\x03\x94\x9b\xc9A\xd7\xfc\xb4\x10Be\xbdzf\x86\x0f\'\xbc\x91\x14h\\\xfb;\xf8q\xbc!pu\xab$i\\\xa4\xb3\xab\x9f\xb6s\x0f\x9a>\xa3T+I\xf2\x07\x10\xcdR\x04\xec\xdf\x87"`7!m\xfa\x07\x19+4\x11\x93\xc6\x14\xae)*\xfc`.~\xc0u\xb0\xa0\xc7j\x04\xab\x07\xa9\x04z\x9e\xb2\x1f|\x87\n\xb8\\\xcd>c6i\xfb\xc1\x7f\xed\xa7\x8c\xa4\xba\xbbj\x07\xee\x9f%\xc4\xf4l\x98\x1b\xac-\xf1%\x9dv#b\xfb~\xaf\xc0\xe4!\xda\xc5;\x9c\x8e\xe3\xce\xc9\xd3v\x15IH\xf2W\r\xd2\xed\x15>\x0e\xf7\xfb\x1a\xc2l#y\xf9m\x97\x15M\x9acr\xdb\x8bX\xd4\xd7\xe0\xb5%\x93\x00\xd9\xed\xbd\x9d\x98U)I\xe2\xd9\xf9\x80\xceYcwO0\xdfK}\x84j\x88\xe5\xf4\x03(\x13\x8a\x9e\x81,h\\\xf8++\x90\r\xf1\x8f\xf8[tW\xf0\xa9\x9e\xde+S\xf5\x08\x04}B\x86\xa9\x1e\xc3\x83XY#H\xbc\xb0p\x0f{\x98\x83\n^LK*\xf7\xa2\xb3\xa1o\xcc\x7f0=\xbez\xdc\x03z<\xad\x92\xfc\x84\xf2p\x11\xd8\x07\xe7\xe6dT\xebE\xe4:\x8aq\x8b\x19j\x91\xa9bs\x185K\x08\xd0\xc8&\xd2\x02\xbfT\x9b%}\xf3@-\xae\xa2\xee\x96f\x17\xe8\xb7\xc10\xd6%\xa2\xdb\xc7,\xb9\xe73\xde\xc1\xdd\xcd\xf5\xdb\xf5\xf7\x18\x08n\xdc^\x95\xe2\xfe>\x9f!\xf5\xe9\x98r\xe6\xef\x16\xcf=\xae\xa5P\x02c}\xffrL\x88`d\xe1\xe4\xf4\xb6l]\x0cB,\xb4\x92\xad\x96.\xa8v\xe5/\x1e\x91v\xc2\xbdi\xd9\xe7\x07T\x19r\x11\xd4#\x0b\xd5\xd1Zx\xb9U\x05L\x95,\x1c\xb7\xbf\x01F\xd7<\xc7K\xbdI/\xc0\x1dkd\xc5:\x98N]B\x84\x15\x19\xe8k\xa1\x1cH\xd7\xfd@\xff\x1a\xda]OCB8\x19\x1bG4^\xf2\x86$\xa2m\xde\xda\x1f\xa1\xb1~\xdf\x9393\x10"\x14\xce"&\xf6@\xdd\xe6)W\xa0\tP\xc6\xbd\xe3\xa7D3\xff\x1c\xca\xd4\x7f\xb0\xe8K\xd5\x90\x02S0\xaa\xf9pI\xdfn\x06\xa8DJu\xc6\x81\x11\x9a\xb4\xfa\xd1\x1b\xaa\xe0\xdd\xeb\x18\'.\x92*\x9ct\xe71C\xec\x84-=\xdc\x03\xb0&\x8b\r\x98\xd3,M\xc2l\xfa\xe4&\xe2\xdf\xedXC\x19g\x10\xd3\xcdQ\x15\xa2\xa1\x16w\x96S\xdf\xa7\xf0@&\xc1HC4p+D\xe0=\xed\x19\x89\xfe\xe4\xb4c\tYC\xc2[\xd2h`\x88\\ \xc5\xd3\xe6\xfee\x9a3Sk\x07\xb4\xce\xaad\xe9\x87\xed\xc8\xde\x15n\xe8\x8fT\x82\xe2(G`&\xc8\xf9\xe3\xb5\xba\x03#/\x01jR\x19\x03\xcc\xbcQ\x93\x8d3\xeb\x98\xbe%\xa1\r\xfaJ\xf8W\xfee\xad\xa9Y\xcc\xa7\x1fVI\x12\xcdt\x99jd\x9e8G/\x02\xd1\x17\xcb\xa0\x11\xee\xf3\x08!\xec,\x12\xfa\t\x1d\x89\xf6\xf8\x04v\xa6\x7f\x91\x8b\x06\x94rY8\xc6vs \x19\xd4\x91\xb0V\x15/<\x8a\x93Xi\x0bG\\\x00i,J\xc0J\xc7\x08\xcd\x1e\x89\x8c\xd5\xc6\xd6\xc6#\x95\xf7W%\x9e`k\n\xff"5\xa2N\xc0\xb5\x90\xd5\x06\xefw\xe1\xeb\x0b\x879\x1d\xc6R\x84\xa4\xd5\x8fI\x90\xc8w\x91\xe0c\xa0\x13JP\n\xef{uy8G\x8bK\xd8I\x1e\x12\x96\x949iz/\xbe\xc1\x96\x7f\x9a\xfe\x91\xfd\xd9\x13\x89h\xb4\xc5L\x1b.6,\x15JV\x86>>\x9dzx\x97\xb4\xa6a\xc5\xd9n\xa2\xd7\xb9\x98\x14\x07\t\xd9I\xf8\x12\x99\xccF\xd9\xdaY\x16\xa0\x8dv\x9a\xe2sfF\xb5[\xed\xd1N\x8d\xe9\xc8I\x84\xffj\xc4)\x96\x93\xd6u\xf5\nz\x16\xe6xP9\xc5{\xedw\xb5*\x84!\xd6\xe2\x06;=\x9f,\x01|\xbe\x8a\xdb\x18\x1f\x18\xe4\xd5%\xe6\x07\x00n\x92\xe9\x01L\x94D-\xc6\xb5\x14E\xbf\xfc\xe7\xb7V\xad=C@)\xeb\x03\x83\'\xf1m\xdc\xdb\x92\x8a}\x13op\x8f\xe2b~|\x9b\xe2w;p;\x9a\x07_`\xbf{p\\-\x88\xd5\xf0\x02r\xeaq\x9c\xb7\x05#\xca\xf9\x9f\xbb\xaas\xfa\x01!\x9b\xb1\xbbKM\xe8\xec\x9fc\xbc\x83\xa2\x03\xc5w\xb4\x12\xfe\xd3\xd7\n\x9a\xa8_S\xe3\xe6\x9a\xae\xb9i\xf7\xc2\xe1\nO\x9d|\x15\x84\x9e,k\xe2\xb4\xf7\\p\x11\xa5\xc3\xe6\xf1T\x8c\xd3\x85\x98\xb2\'K\t\xa2\x90\xc3:\xd3\x8e\x8d\xd7\x97\x91[\xa4\xd7f\x9f\x19\xf3\xdc\x8a\xd8\xdf\xd5\ra$\xa5\x9f\xd2\x82\x00A\xe3\xfa\xd7"\xbb\x82\x1a\x94\t\x12\xce\x1d\x87^\xb0X\xf9\xf5\xe1\x88\xcdHf\xf3\x82\x13UJ\xaa\x87_\x00\xea\x9d\xab\xb2\xf915\xce\x1dE\xeb\xb7\xc38\xb2\xf7@1n\xc7!\xdf\xa0F\xc0\xf1\xec\xd2M\xf5\x8eN\xfd\xa4\xa0\xf9@\xef\xb4\xa9\xf9[0cM\x1a9\x0f4\x12u\xe2\x98\xcb\r\xd3\xfd\xdb\x90\x86\x1c6\xcbxEt\xf1X\x9a)\xbc\x93\xceCGd\xce\xc7\xf1\xf5\xef?\xba\xdb,\x9dA\x00\xfc\x8d3+\xa7\x1a\xd465\x91>2\x13\x01M\x06\x17L\x8e\x91\xaaY\xc47\xc1\xc2\x0c0A\x99\xfc\x85\x00\x16\xf4|f2\xc0<#\xa0\x87\x98\'\xd6\xf2,d\xb6\x1b\x02i*-\x9f$"N\x9aTK!\x01Q6\xf3\x81\x8cM\x1d\xd1\xce\\\xab\x02(\xf7g\xca8\xf93\xdcY\x12\x04\xa2f\x92p\x0fx^\x9avO\x17\xe98\xe7\x13\xc1?\x14\x8drq\xc3n\x85KpJ\xaa\xf3\xe0sI\xdd\xb5\x87,\x01x\x1da\x95\xf53\x99\x1dzT\xb7\xae\xbaK\x006I(6\xcc\x8c\xa6#]\xbb\x92\xac\xef\xa2\x15\xba\x02\x15\xfa\xf4\xb2\xf9\xe1\xf6"\xd6\xb0\xc2!\xad\xb25\x90\x0f\xb4\x95O\x99(=9\xd1s\x16S\x97\xef\x95lbsT\x8eP<\xff*2\x02"S\xb5\xec\x1es1(\x0cAY\x97KW&\xe0\x12\xb2\xa4\xcd\x19\x08\n\xc6\x00ZS\x19L\x9a\xbe\x0b#\x9cJL\x81\xe1\xba\x07\x1bX>n\xda\x19\x1e\xbcl\xb6\x91\xf2\xa6\x0b\xca\xb0\xa6|\xfcO7\xeeP&SD\xdc\x8d\xceT\x1c\xe5\xceySG\x0e\x18\xab\\N\xc2d\x02+\x11\xfdF\xff\xd4\xcf\x91+\xd3,\xb4!\xb8\xc6\xc65\xb0\xce{*\x9c\xcf\x8d|\xd3\xbe:\xc6\xac\xc1\x82\xa6\xeez\x82\xc2\xe9\xa6\x8a\x93\x95\xb7\xb6\x12v\x8b\x8b\x91c7\xcd|\xd8~\xbb=K\x8c\xb4\xfe\xde\x99\x11#\xaa}\xa1\x03\xc3y\xeekZ\x02xZ\xf6\xdf\xb5~\xac2\xfd\xb1V\xe8\x19OjZ\x0b\x9a\xe5\x1a\xbf!\x0b\xfcEn\xa0\xd3\xb0\xc6\xa5\x8a\r%\xbe(\x94\xc8\xe5\x86<J(^\xd4\x7f\xed\xef\xf7\xaf\x1a$\'\xca\xd0\xaf\x0c\xdfKEQ\x81r\xac\x02g\xf3~\xac\x8e\x8b2\x968\xa0L\x1ce\x9b\xc9\x04WodC\xa05lg\xdf\x84\xebk\xd4#\x06\xe8\xba\xd5eX\x99kv3\xab\xc6-\x96\xd9g\x13\xea\x9b\x8b\n`\xfe\xebZ\xc9}\xda#[\xc7{p\xb0\x88\xf7\xf0^{\xa6\x9aB\x16\xb7M\xacUQ\xfc~\xcb*^xXh\x8b\x9cA\\G,\x16m\x1a\x97j3\xda\x9a\x9c\x8c\x00f\x8b\xa2N\xbf\xf6\x9c>]S\x07$\xd7\x87N&\xeb\xc7\x9f_\xd9m\xde>\xa2\x81\xdc\x0c\x06n\xbcjG\xda\x07\xfe4\riF>\x9c7\x19z\xabUn\x89\xa5\xc7A\xe0\xb4\xf7Bb03\xbc\x0ffIQm\xdb\x96<\x9f;\xd8l\xe7o\x92V\xe8Gj\xb6\x11\x8e?\xad\xb1\xe0G\x7f\xedO\xe4\x9b\x14\xa8\x82\xd7\x1f\xe3?\x10A\x8a!}\x0c\xb9\x94\x17\x00\x14\xcc\x98\x07\xcf\x19\xec&\x81\x92\x95*J\xdeKZ\xe5\x95\xf5W\xebTI\xed\x0b\xcf N\xcc.\xb5\'S\xebI{\xa9\x0f\x0b\x15\x9d\x0b=\xd0A^dw$\xa1\xa9\x0b[\xde/\x07\xaf\xa0\xfe\\\xe7\x9eu\xc7\x1a\x1chv\x1ac\xba9\x16t\xaa*\t&*\xf2n`C\xda<`\x0e\xfd\xd42\x0c\xfb\xd9Ig`Z\xca\x94\x87(\xa79\x9e\x14\xa5P\xbeW\xb4\xcd\xa0\x94\xe5\x96\xd9\xa7,yy\xe2\x86\xd5\xb9:\xbd$\xd9D\xcc\x883\x15\x0c\xff8\x83\xb8]\xe9\xf2X\xdd\x07\x8a\x1f\x9f\xfd\xe0\x9c\x8bT\xd6\xe8\\\xa4\xd2\x96C,\xbe\xc2?\x98\xdd\x07\x86\x9f\xbd\xb8\xf1\xd56k\x94\x8c\x14\xd5\x87W\xf5\x8fK\x15\x82\x10\xf6[\x9f93K\x10\xe1\xba\x82\x8e!\xd1\xfd\xa6Ow\xc9Lw\xb5GFq_\x99\xd8<\x08_\xf2\x84m\x9e\xad\xf7\xf6\x94~R8\xbb\xe7u\xb5\xd7\x1dK\x8a\x8f\xdd\x9f\x19A\x1d\t\xf0\x8f\xe8UU\xb6\x1dhRk\xb2\xfc\xeb 2u\xe8\x98q\\\xa9Mp\xea9\xe0\x0b\x08\x96\x9f\x91\x81\xee\x80~\xab\x82%\xc1\xa3\xf9<\xa2|\x9e\xfa\x1e\xe1l\xb0\x87\xa9\x1c\x18+X\x1c*\x8b\xc6}\x8d@\x02T\xe5.\xda\xf6]\x06\x9a\xba\xda\xd6\x8b\xd6\x18\xadY\x7f\x97\\\xf9\xc9]\x0eD\xa7\x9c\xad[e\xd9\xd9\xb8\xf0\xb0\xc3\x90\xf7\xe1.\n\xfcV\xb7 \xc6\xb5x\xf8\xb4SRqL\xce\xde\x8aU\xa1\x11O9\xa1\xaa"-_>\xc9\x04g?\xc5#\x90\xec\x93\xd1\xa8/\xd5P\xa6\x04-\xae9}<\xe5\x15\x11\x033!\x058[y=79\xc4\x01\x17\xbdU\xfd\xf2\x83=\xde', 301)
2024-02-03 21:38:46.737 ERROR (Thread-3 (_thread_main)) [roborock.cloud_api] [Roborock S7] ('Failed to decode %s for %s', b'n6qWb90e\x00\x00\x00\x00\x00\x00\x00\x01\xfaX\x00\x00\x00\x00\x00\x00\x96\x96\xc9W\x05\r\xb2\xb9r)L6\xfa@\x15\xca\x9eT\xc9\x8d\x16K\x7f\xf5\xa6\x8a\xe7{\xb7\xab\xa5\xcc\xa5\xa3t\xa8\xa2\x99\x01\x99O\xc4w/\xfai\xa2\x034\x8f9\x1b\xc0\xae\x84\x9f\xe7:\xe6\xe8\xe1Q\xb7mOY\xac1#v;\x1f\xc5\xc1\xc8S\x0c\x9fHO\xfc\xb5\xf4\x00\xb9\xa7\xa3\xfc\xa3a\xff\xfe0\x87Gq\x97P]\xb3\xe0\xd2Bn\x98\x01\x04\xdf\xb1\x0c\xef\x0eE\xbdn\xf9\x0f\x0c\xcd:\x8a\xd2\xb5\x19N\xa5\x1b*\x18a\xedJfg\xa2\xc6\x964ms\xfe\x97\x86\x0b\x08\xc5R\x16mz\x1a]4\x83\xea\xabf\xc3\x89\xa3\rp\xf8oZK\xa8\xa1\xfd\xcer\x1e]w\xdb\x10w\xd8\xe4\nd\x0f^\xaf\'\x0e\x9d$\xcb`J\xb1\t\xea!un\xee\xc9\x11\xa5\xbc 2\xc5\xc5\xa8\xb6@\xefo\xeco\xd5W\x12)\x94\xd0\xc3\x93i?\x85\xf6\xf1:\xe5\xb0,\xdbaX\r\xf4\xeb\xd1\x0b\x83\x10j\x00\ri\xd7mM\xa7\xb5\xa2\x12\xe2\xb7\x08\xf7O\x134\xb1C\x16\xb4\x89\xc7lu\xc3t\xff\xf7\x8at\xb4LRV@\xf1CV\x84\xd6\xc3\xea\xea\xe5\xa2\x0e\x16\xd3\x14\x0f\x07\x19\xcc\xf9>"\x13\xa6Zo\x18lb\x10\xd5\xbf\xabL> J\xeb\x1d"\xe1\x8euk6\xcc\x13\xde3\xea\x9e\x99\x868^\xee\xa6\xa1\xd0~\xe6\xd9\xbf%\xf1}\xb7\xc9\x97\x9bF\xb7\xb7H%\x95\xeb\xfd\x16 \x9f\xf4\xd8\xf7\xed\xc6%\xc2w\xca\x90N\xb9\xfa6\xfaL\x9b\x11\xc7\'j38\x85\x1b?s0\r\xba<\xd8m\x05&\x9a\xc2/\x81rS\x15\xb7+\xc9\r\x01L\x15\xe8\xfd\xc7\x10/\x7f\x1c\x9c0\xf9\xc6d\xb6\x92*\x9fk\x02\x83\x97x\x96\x11\xb3\xa9\xa4\x84X\xf0^.\xd0\xa1\x91a6M8\n\x8e\xd9N\xa6\x9e\x8eLu\x17\xbb\xdc|\xd2\x1e\x10\xb3\xad}\xb3\xd5\xa20\xcc\x7f\x93J\xc5\xf8d7L\xb3\xf5o\xe4\xbc/\x0c\x10\xf7\x80O\xfa\x87\x17\xae\xb2E\xfe\xc3\xd2\x8b\x92\xe3p\x9f\x94\x8c\x12\r=\xb3nc\xc5l\x16\xacK\x9a.D\xfc\xb9\x05\x95Q\x06\xac\x1d\x0b\x9f\x88\x9cO\xa9\xc9o\x1d\x9a2\x07tu&T;F]\x82\xa4\xb8K\x96\xcd\xd0u\x16^b\x82\x98\x04\xb2\xb2\xf3\xcf\x82\xaf\xe9K[\xd5=\xf4o\xe1\xdd\xbe\xccT\xaawL\x01\x87Y\'\xf3!H&6\xd4<Q\x12\xd5_c\xc8\x91\xaa+\xa2\x19$\x98 \xec&\xa38E\x95\xeb=\x1e?\xb9\x9c\xe6\x19\x01\x01\xea\x9c\xc8\x8fI\r\x92$^\'\x97\xbbrsV\x1c\x11\xdf\xc2\xf3\xbc$\xc7\x14ob\xceM`\xe6\xf6\xf0\x02\xf3-Q>[\xd0\xbd\xbdg\xae\xb5\x1f\x89\x9dy\x83\x8d\xd6=f\x06J\xb9\x11]\xde@V\x8f\xa3\xe3\xdb\xb6\xe5\r\xba0\xa6\xda\xf1W\xe0\x0840\xef\xd4\xa0\x17H\xdb\xf9\xefV\xce\xdd\xec\xeb7"\xcfC\xcf\x9fn\x89\xc0\xdd&\xdc\xd1_\xc1\xb7\t}iC\x93\xc7@S<Sv\xb4\xb4\x1b\xd1\x80$(\x02\tY:\xccZ+\xed\x82F\xfd^\xdd\xa3L\xc9ltx\xa1\xf3\xde\x0c\xbc\xe4\xeeV[Zj\x06\x1d\x86i\xe1V\xad\x81\xc6d!\x9ek\xf2\xcc\x9ei\xf4\x86\xf7\xaeC=\x0cG\xb0\xd6\x13\xa9\xbf\x11\xf0\xe1\x9a\xaa3H\xd0R\x90~r\x9c_\xbf3\xfbJA=\xa7VdrMe\x82@\xd3\xa2\x8f\x94\x88S\x9f\x98\xf4\xc6\x15i\x8b;\xa2\t#sq# \xac\x9a\x17:h\xad\xf9cP\xe5 \xb0>\xcfu[\xef\xda6N\x0fK\xef\xff*J\xa1\xbcL\xae\xaf\x96|a\xf8\xa4\xd4\xb0\x18\xf3\x94\xe2s\xc8\x1c\x846\xf9V\x05o\xfdJ\xe9\x1f\x07\xd8\xbe\x19i\xc4\x17\xa1J\x03 \xd5\xae\x99\x10FDO\xb0\xdd\xb6\x83JX.\xd9\xff\xc0\xeb\xb4\xd4J_\xb0\x02\xcd\x81gsp\'\xcbH\n>\xb5\xb3\x0b&\x13i\x15\x84\xc9\xf2\xb0\xc0\xc7\xa7\xb3\xab\xfb4\x90\xd0\x7fu\x1e\x01H\xa6\xef`\r!\xb3!\xffK%Q\xa2P\xe4\xcb\xe6\x14\xdd\xe3C\xd4\xbb\xf0\xce\xad6\x92H\rO9\xa2\x9b}\xfbR\xa7\x10\xf2\xff\x0e\xe7n1\x9d\x9c\x16\xc5S\xdb\xb0Z\x01n,\x91i\xa6\xd1D\xadI\x8d\x90~C\x10\x1cU?\xfer\x8a\xf9\x08\xb9\x0f\xe3\x93\x1d\x9a\x17\x95\x03\xc4\xd8N\xa0\xdb\xbb5\x9a\xe0\xd4\xa4slB2d\x05\xe8\xf4\x06\xc1\xf4\xa7\x10DIH-\xd1=UzN\xc3\xb6\xfc\xf7\xea\xa4\x03(\xad\xa0\\7\xa7w\xc7N\x9c\x9d:\xd5\xa4\x1c@\xeaq}\x12\xbc\xa6M\xe3\xc0\xd4\xa9\xa8.\xca8\xa9\x0c\xe2\x84\xc59\x1b\xba\x80\x15ymG:\xe5\xebg\x92\x1c\xaf\xbbor#\xa9\xc6\x94P\xd4\xd8\'iN]\x8dM\xe5h\xec\xbb$\x98\xb5\xd1\xc1\xee\xca\x02\xdc\xe3\xb7\x92<\x10\x04H\xd4y\xb0\xcf[\x16\xf6`\xb9@g\xa5/\xf1@\x97o@2\xfb\x10$\xa6%@\xe6{\x7f:\xe0\xa2t\xc5\xab\\#\xfega\xc1{\xd3\xf4\xc4\xd7\x824\xdc.\x92u\x96O\xd1\x89-\x07\xb7l\x1fTK.\xb15N\xd3\xa0\n@\xaa\xfcR0lY\xb0\xbe\xec\xc9]\xa9\xc1\x9b\xc70:H\xdcw\xfbT\xee,2\x80\x94f\xd0\x16\xefHwn\xa6\x01\x99\x9c\x87`~a\xa7\x198\xe1\x12\x88\x1d\x81\x02\xd9\xc7\x98\x8fe\xac\xd12NE\xe2\x17\xb1\x0c\x0f\xf6\x03o_\x1eP\xaep\xd0^\x12o\xd5\xd29\xbd\xe5:\xe4\xaf6\xc4\xe1\xbc\xfak\x81\xad\xa2\xe8R\\\xbc\x83\x98\xc1\x7fw\x99\xef\xb4%\xde\xd1\xcb\x94?P\xa1\xd1\x05\xa28\xe5\x16\x92\x1bV\t\xac\x9b\x0e\xd0\x98\xe4\x9d_9\x15\x82\xb1\xf0l\x97\x10\xc3\xe9\xb3\xf9\x08\xe04\xca\x1c\xe8V6E\xcd\x83\xfb\x9e#\xeany\x01\xee\t,lTH\xe5\xa5\x0b\xe28\x1a\xf7LG\xd7i\xa1w\xac)\xc4\x18@\x9f\xb2\xc6~\xd7\xafH\xaa\x07\x14O>\x14Q\xb9\x7f\xd4\xf6\xa3 \xf5\xf8\\=-\xc2\xcf%!|\x1f\xf7/\x8aG<\xc0\xb5\x04\xbc\xda\x04\xd1nA1d\xff\xe5\xf5[\x04\x03:\xde\x8a\x00s\xa1(\x1d\xb3(\x9asX\xa7\x86\x00H\xf6\xc1\xafv\xd1\x81\x99T\x8c 0\xef\xa8{\xd0\x12 \x15n\xe7t|\x900\xf0\xeb\xb5Bj\x00\x82JG\xfa\x10\x97\xf7"\xb0\xaa\xf74\xfb\t\xa9\xed)\xd2\xa6\x94R\xc6\x86\xcf\xc6\x98td\x00\xa0\x10!P\x0b-\xd7\xac4\xd4\xf4\xe8\xe9\xdbf\xddB\xa7\x0c\x98_\xb9\xa6+\xb3\xe2\x85\x99}\xccI&s~\x80\xf7\x12\xe2|(\x10\xfb\xc2\xf8P\xa7G"\xae\xfc^\xf3\x9e\x9d\xc4\x1d\xad\xbe\xed\xfaj\xe7P\xbeL*\xfa\xf2{\xf9\x11\xab\x08\xa4\x030\xfe\xff\'!\x06\x8e`G){\xae\xd8\xe9\xc1\xd8T#Bcd\x03\x94\x9b\xc9A\xd7\xfc\xb4\x10Be\xbdzf\x86\x0f\'\xbc\x91\x14h\\\xfb;\xf8q\xbc!pu\xab$i\\\xa4\xb3\xab\x9f\xb6s\x0f\x9a>\xa3T+I\xf2\x07\x10\xcdR\x04\xec\xdf\x87"`7!m\xfa\x07\x19+4\x11\x93\xc6\x14\xae)*\xfc`.~\xc0u\xb0\xa0\xc7j\x04\xab\x07\xa9\x04z\x9e\xb2\x1f|\x87\n\xb8\\\xcd>c6i\xfb\xc1\x7f\xed\xa7\x8c\xa4\xba\xbbj\x07\xee\x9f%\xc4\xf4l\x98\x1b\xac-\xf1%\x9dv#b\xfb~\xaf\xc0\xe4!\xda\xc5;\x9c\x8e\xe3\xce\xc9\xd3v\x15IH\xf2W\r\xd2\xed\x15>\x0e\xf7\xfb\x1a\xc2l#y\xf9m\x97\x15M\x9acr\xdb\x8bX\xd4\xd7\xe0\xb5%\x93\x00\xd9\xed\xbd\x9d\x98U)I\xe2\xd9\xf9\x80\xceYcwO0\xdfK}\x84j\x88\xe5\xf4\x03(\x13\x8a\x9e\x81,h\\\xf8++\x90\r\xf1\x8f\xf8[tW\xf0\xa9\x9e\xde+S\xf5\x08\x04}B\x86\xa9\x1e\xc3\x83XY#H\xbc\xb0p\x0f{\x98\x83\n^LK*\xf7\xa2\xb3\xa1o\xcc\x7f0=\xbez\xdc\x03z<\xad\x92\xfc\x84\xf2p\x11\xd8\x07\xe7\xe6dT\xebE\xe4:\x8aq\x8b\x19j\x91\xa9bs\x185K\x08\xd0\xc8&\xd2\x02\xbfT\x9b%}\xf3@-\xae\xa2\xee\x96f\x17\xe8\xb7\xc10\xd6%\xa2\xdb\xc7,\xb9\xe73\xde\xc1\xdd\xcd\xf5\xdb\xf5\xf7\x18\x08n\xdc^\x95\xe2\xfe>\x9f!\xf5\xe9\x98r\xe6\xef\x16\xcf=\xae\xa5P\x02c}\xffrL\x88`d\xe1\xe4\xf4\xb6l]\x0cB,\xb4\x92\xad\x96.\xa8v\xe5/\x1e\x91v\xc2\xbdi\xd9\xe7\x07T\x19r\x11\xd4#\x0b\xd5\xd1Zx\xb9U\x05L\x95,\x1c\xb7\xbf\x01F\xd7<\xc7K\xbdI/\xc0\x1dkd\xc5:\x98N]B\x84\x15\x19\xe8k\xa1\x1cH\xd7\xfd@\xff\x1a\xda]OCB8\x19\x1bG4^\xf2\x86$\xa2m\xde\xda\x1f\xa1\xb1~\xdf\x9393\x10"\x14\xce"&\xf6@\xdd\xe6)W\xa0\tP\xc6\xbd\xe3\xa7D3\xff\x1c\xca\xd4\x7f\xb0\xe8K\xd5\x90\x02S0\xaa\xf9pI\xdfn\x06\xa8DJu\xc6\x81\x11\x9a\xb4\xfa\xd1\x1b\xaa\xe0\xdd\xeb\x18\'.\x92*\x9ct\xe71C\xec\x84-=\xdc\x03\xb0&\x8b\r\x98\xd3,M\xc2l\xfa\xe4&\xe2\xdf\xedXC\x19g\x10\xd3\xcdQ\x15\xa2\xa1\x16w\x96S\xdf\xa7\xf0@&\xc1HC4p+D\xe0=\xed\x19\x89\xfe\xe4\xb4c\tYC\xc2[\xd2h`\x88\\ \xc5\xd3\xe6\xfee\x9a3Sk\x07\xb4\xce\xaad\xe9\x87\xed\xc8\xde\x15n\xe8\x8fT\x82\xe2(G`&\xc8\xf9\xe3\xb5\xba\x03#/\x01jR\x19\x03\xcc\xbcQ\x93\x8d3\xeb\x98\xbe%\xa1\r\xfaJ\xf8W\xfee\xad\xa9Y\xcc\xa7\x1fVI\x12\xcdt\x99jd\x9e8G/\x02\xd1\x17\xcb\xa0\x11\xee\xf3\x08!\xec,\x12\xfa\t\x1d\x89\xf6\xf8\x04v\xa6\x7f\x91\x8b\x06\x94rY8\xc6vs \x19\xd4\x91\xb0V\x15/<\x8a\x93Xi\x0bG\\\x00i,J\xc0J\xc7\x08\xcd\x1e\x89\x8c\xd5\xc6\xd6\xc6#\x95\xf7W%\x9e`k\n\xff"5\xa2N\xc0\xb5\x90\xd5\x06\xefw\xe1\xeb\x0b\x879\x1d\xc6R\x84\xa4\xd5\x8fI\x90\xc8w\x91\xe0c\xa0\x13JP\n\xef{uy8G\x8bK\xd8I\x1e\x12\x96\x949iz/\xbe\xc1\x96\x7f\x9a\xfe\x91\xfd\xd9\x13\x89h\xb4\xc5L\x1b.6,\x15JV\x86>>\x9dzx\x97\xb4\xa6a\xc5\xd9n\xa2\xd7\xb9\x98\x14\x07\t\xd9I\xf8\x12\x99\xccF\xd9\xdaY\x16\xa0\x8dv\x9a\xe2sfF\xb5[\xed\xd1N\x8d\xe9\xc8I\x84\xffj\xc4)\x96\x93\xd6u\xf5\nz\x16\xe6xP9\xc5{\xedw\xb5*\x84!\xd6\xe2\x06;=\x9f,\x01|\xbe\x8a\xdb\x18\x1f\x18\xe4\xd5%\xe6\x07\x00n\x92\xe9\x01L\x94D-\xc6\xb5\x14E\xbf\xfc\xe7\xb7V\xad=C@)\xeb\x03\x83\'\xf1m\xdc\xdb\x92\x8a}\x13op\x8f\xe2b~|\x9b\xe2w;p;\x9a\x07_`\xbf{p\\-\x88\xd5\xf0\x02r\xeaq\x9c\xb7\x05#\xca\xf9\x9f\xbb\xaas\xfa\x01!\x9b\xb1\xbbKM\xe8\xec\x9fc\xbc\x83\xa2\x03\xc5w\xb4\x12\xfe\xd3\xd7\n\x9a\xa8_S\xe3\xe6\x9a\xae\xb9i\xf7\xc2\xe1\nO\x9d|\x15\x84\x9e,k\xe2\xb4\xf7\\p\x11\xa5\xc3\xe6\xf1T\x8c\xd3\x85\x98\xb2\'K\t\xa2\x90\xc3:\xd3\x8e\x8d\xd7\x97\x91[\xa4\xd7f\x9f\x19\xf3\xdc\x8a\xd8\xdf\xd5\ra$\xa5\x9f\xd2\x82\x00A\xe3\xfa\xd7"\xbb\x82\x1a\x94\t\x12\xce\x1d\x87^\xb0X\xf9\xf5\xe1\x88\xcdHf\xf3\x82\x13UJ\xaa\x87_\x00\xea\x9d\xab\xb2\xf915\xce\x1dE\xeb\xb7\xc38\xb2\xf7@1n\xc7!\xdf\xa0F\xc0\xf1\xec\xd2M\xf5\x8eN\xfd\xa4\xa0\xf9@\xef\xb4\xa9\xf9[0cM\x1a9\x0f4\x12u\xe2\x98\xcb\r\xd3\xfd\xdb\x90\x86\x1c6\xcbxEt\xf1X\x9a)\xbc\x93\xceCGd\xce\xc7\xf1\xf5\xef?\xba\xdb,\x9dA\x00\xfc\x8d3+\xa7\x1a\xd465\x91>2\x13\x01M\x06\x17L\x8e\x91\xaaY\xc47\xc1\xc2\x0c0A\x99\xfc\x85\x00\x16\xf4|f2\xc0<#\xa0\x87\x98\'\xd6\xf2,d\xb6\x1b\x02i*-\x9f$"N\x9aTK!\x01Q6\xf3\x81\x8cM\x1d\xd1\xce\\\xab\x02(\xf7g\xca8\xf93\xdcY\x12\x04\xa2f\x92p\x0fx^\x9avO\x17\xe98\xe7\x13\xc1?\x14\x8drq\xc3n\x85KpJ\xaa\xf3\xe0sI\xdd\xb5\x87,\x01x\x1da\x95\xf53\x99\x1dzT\xb7\xae\xbaK\x006I(6\xcc\x8c\xa6#]\xbb\x92\xac\xef\xa2\x15\xba\x02\x15\xfa\xf4\xb2\xf9\xe1\xf6"\xd6\xb0\xc2!\xad\xb25\x90\x0f\xb4\x95O\x99(=9\xd1s\x16S\x97\xef\x95lbsT\x8eP<\xff*2\x02"S\xb5\xec\x1es1(\x0cAY\x97KW&\xe0\x12\xb2\xa4\xcd\x19\x08\n\xc6\x00ZS\x19L\x9a\xbe\x0b#\x9cJL\x81\xe1\xba\x07\x1bX>n\xda\x19\x1e\xbcl\xb6\x91\xf2\xa6\x0b\xca\xb0\xa6|\xfcO7\xeeP&SD\xdc\x8d\xceT\x1c\xe5\xceySG\x0e\x18\xab\\N\xc2d\x02+\x11\xfdF\xff\xd4\xcf\x91+\xd3,\xb4!\xb8\xc6\xc65\xb0\xce{*\x9c\xcf\x8d|\xd3\xbe:\xc6\xac\xc1\x82\xa6\xeez\x82\xc2\xe9\xa6\x8a\x93\x95\xb7\xb6\x12v\x8b\x8b\x91c7\xcd|\xd8~\xbb=K\x8c\xb4\xfe\xde\x99\x11#\xaa}\xa1\x03\xc3y\xeekZ\x02xZ\xf6\xdf\xb5~\xac2\xfd\xb1V\xe8\x19OjZ\x0b\x9a\xe5\x1a\xbf!\x0b\xfcEn\xa0\xd3\xb0\xc6\xa5\x8a\r%\xbe(\x94\xc8\xe5\x86<J(^\xd4\x7f\xed\xef\xf7\xaf\x1a$\'\xca\xd0\xaf\x0c\xdfKEQ\x81r\xac\x02g\xf3~\xac\x8e\x8b2\x968\xa0L\x1ce\x9b\xc9\x04WodC\xa05lg\xdf\x84\xebk\xd4#\x06\xe8\xba\xd5eX\x99kv3\xab\xc6-\x96\xd9g\x13\xea\x9b\x8b\n`\xfe\xebZ\xc9}\xda#[\xc7{p\xb0\x88\xf7\xf0^{\xa6\x9aB\x16\xb7M\xacUQ\xfc~\xcb*^xXh\x8b\x9cA\\G,\x16m\x1a\x97j3\xda\x9a\x9c\x8c\x00f\x8b\xa2N\xbf\xf6\x9c>]S\x07$\xd7\x87N&\xeb\xc7\x9f_\xd9m\xde>\xa2\x81\xdc\x0c\x06n\xbcjG\xda\x07\xfe4\riF>\x9c7\x19z\xabUn\x89\xa5\xc7A\xe0\xb4\xf7Bb03\xbc\x0ffIQm\xdb\x96<\x9f;\xd8l\xe7o\x92V\xe8Gj\xb6\x11\x8e?\xad\xb1\xe0G\x7f\xedO\xe4\x9b\x14\xa8\x82\xd7\x1f\xe3?\x10A\x8a!}\x0c\xb9\x94\x17\x00\x14\xcc\x98\x07\xcf\x19\xec&\x81\x92\x95*J\xdeKZ\xe5\x95\xf5W\xebTI\xed\x0b\xcf N\xcc.\xb5\'S\xebI{\xa9\x0f\x0b\x15\x9d\x0b=\xd0A^dw$\xa1\xa9\x0b[\xde/\x07\xaf\xa0\xfe\\\xe7\x9eu\xc7\x1a\x1chv\x1ac\xba9\x16t\xaa*\t&*\xf2n`C\xda<`\x0e\xfd\xd42\x0c\xfb\xd9Ig`Z\xca\x94\x87(\xa79\x9e\x14\xa5P\xbeW\xb4\xcd\xa0\x94\xe5\x96\xd9\xa7,yy\xe2\x86\xd5\xb9:\xbd$\xd9D\xcc\x883\x15\x0c\xff8\x83\xb8]\xe9\xf2X\xdd\x07\x8a\x1f\x9f\xfd\xe0\x9c\x8bT\xd6\xe8\\\xa4\xd2\x96C,\xbe\xc2?\x98\xdd\x07\x86\x9f\xbd\xb8\xf1\xd56k\x94\x8c\x14\xd5\x87W\xf5\x8fK\x15\x82\x10\xf6[\x9f93K\x10\xe1\xba\x82\x8e!\xd1\xfd\xa6Ow\xc9Lw\xb5GFq_\x99\xd8<\x08_\xf2\x84m\x9e\xad\xf7\xf6\x94~R8\xbb\xe7u\xb5\xd7\x1dK\x8a\x8f\xdd\x9f\x19A\x1d\t\xf0\x8f\xe8UU\xb6\x1dhRk\xb2\xfc\xeb 2u\xe8\x98q\\\xa9Mp\xea9\xe0\x0b\x08\x96\x9f\x91\x81\xee\x80~\xab\x82%\xc1\xa3\xf9<\xa2|\x9e\xfa\x1e\xe1l\xb0\x87\xa9\x1c\x18+X\x1c*\x8b\xc6}\x8d@\x02T\xe5.\xda\xf6]\x06\x9a\xba\xda\xd6\x8b\xd6\x18\xadY\x7f\x97\\\xf9\xc9]\x0eD\xa7\x9c\xad[e\xd9\xd9\xb8\xf0\xb0\xc3\x90\xf7\xe1.\n\xfcV\xb7 \xc6\xb5x\xf8\xb4SRqL\xce\xde\x8aU\xa1\x11O9\xa1\xaa"-_>\xc9\x04g?\xc5#\x90\xec\x93\xd1\xa8/\xd5P\xa6\x04-\xae9}<\xe5\x15\x11\x033!\x058[y=79\xc4\x01\x17\xbdU\xfd\xf2\x83=\xde', 301)
Traceback (most recent call last):
  File "/usr/local/lib/python3.11/site-packages/roborock/api.py", line 317, in on_message_received
    decrypted = Utils.decrypt_cbc(data.payload[24:], self._nonce)
                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.11/site-packages/roborock/protocol.py", line 155, in decrypt_cbc
    return unpad(decipher.decrypt(ciphertext), AES.block_size)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.11/site-packages/Crypto/Util/Padding.py", line 92, in unpad
    raise ValueError("Padding is incorrect.")
ValueError: Padding is incorrect.


### Additional information

_No response_
home-assistant[bot] commented 7 months ago

Hey there @humbertogontijo, @lash-l, mind taking a look at this issue as it has been labeled with an integration (roborock) you are listed as a code owner for? Thanks!

Code owner commands Code owners of `roborock` can trigger bot actions by commenting: - `@home-assistant close` Closes the issue. - `@home-assistant rename Awesome new title` Renames the issue. - `@home-assistant reopen` Reopen the issue. - `@home-assistant unassign roborock` Removes the current integration label and assignees on the issue, add the integration domain after the command. - `@home-assistant add-label needs-more-information` Add a label (needs-more-information, problem in dependency, problem in custom component) to the issue. - `@home-assistant remove-label needs-more-information` Remove a label (needs-more-information, problem in dependency, problem in custom component) on the issue.

(message by CodeOwnersMention)


roborock documentation roborock source (message by IssueLinks)

Mysa95 commented 7 months ago

Hello, Same issue.

kajarit commented 6 months ago

Same here: 2024.2.5

strange-v commented 5 months ago

I've just discovered the same issue with sensors "water_shortage" & "water_box_attached" using S8 Pro Ultra (HA 2024.3.3). As I understand, they are populated from the get_status response, but it looks like, it contains incorrect data: "water_box_status": 1, "water_shortage_status": 0.

Please, ping me if any additional information is needed.

PS I'm planning to start digging deeper into the code, to understand how to expose additional consumables (water filter, high-speed maintenance brush) of the doc stations as sensors.

Lash-L commented 5 months ago

The integration directly reports what get_status says, outside of that there is not much I can do. water_box_status does change for me when I remove my waterbox, but it is possible it does not work for all devices.

I think water shortage is similar, I can't seem to get it to trigger on mine while i am quickly testing it, but I know some users have reported it working well for them.

strange-v commented 5 months ago

@Lash-L, thanks for the response.

Does this JSON data (get_status) come directly from the robot's API or does it return something different (e.g., bytes array) that then interpreted based on reverse-engineered protocol?

Lash-L commented 5 months ago

The bytes come in from the api, and we decode them and get the json and then put it in a dataclass.

issue-triage-workflows[bot] commented 2 months ago

There hasn't been any activity on this issue recently. Due to the high number of incoming GitHub notifications, we have to clean some of the old issues, as many of them have already been resolved with the latest updates. Please make sure to update to the latest Home Assistant version and check if that solves the issue. Let us know if that works for you by adding a comment 👍 This issue has now been marked as stale and will be closed if no further activity occurs. Thank you for your contributions.