-
Notifications
You must be signed in to change notification settings - Fork 720
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add quirk for Sonoff SWV Smart Water Valve #3340
base: dev
Are you sure you want to change the base?
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## dev #3340 +/- ##
==========================================
- Coverage 88.71% 88.66% -0.06%
==========================================
Files 306 307 +1
Lines 9820 9846 +26
==========================================
+ Hits 8712 8730 +18
- Misses 1108 1116 +8 ☔ View full report in Codecov by Sentry. |
4be7627
to
79bfbfe
Compare
zhaquirks/sonoff/swv.py
Outdated
|
||
Water_Shortage = 0x1 | ||
Water_Leakage = 0x2 | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think you want Normal (0) and probably Leakage and Shortage (3).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So the absence of Normal (0) and Leakage and Shortage (3) was intentional - if you look at class you will see that this is a bitfield not an enum. Leakage and Shortage (3) would just be Water_Shortage (1) & Water_Leakage (2)
If you look what I've done in ZHR PR (zigpy/zha#189), I'm actually exporting two binary sensors, one for each bit. I personally think this is a lot nicer than how they did it in Zigbee2MQTT.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I see, I missed the bitmap8.
Two related comments:
- The docstrings say enum :)
- While this is fine for the sensor, the other part is the response when reading the attribute directly via Manage Zigbee Device interface. This is not a big issue, but it'd be nice to have the full range of values IMO.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, is there any reason you cannot use an enum here and check for the specific values on the other PR?
zhaquirks/sonoff/swv.py
Outdated
|
||
cluster_id = SONOFF_CLUSTER_FC11_ID | ||
ep_attribute = "sonoff_manufacturer" | ||
attributes = {ATTR_SONOFF_VALVE_STATUS: ("valve_status", ValveStatusBitmap, False)} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe attributes are deprecated. It might be better to use ZCLAttributeDef
to define this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks - I based this off the other Sonoff quirk, with no prior experience writing quirks. Let me look into ZCLAttributeDef
and see how easy it is to convert over.
Nice! I was testing a similar change using the Quirks Builder v2 and exposing the state as a sensor. I'll probably open a PR on Monday, as I wrote most of the code already, but I've left some comments in this PR. |
Hi @fgsch Thanks for your review comments, much appreciated! Given you've gone to the work of writing yours, I would definetly push it up. I wasn't aware of Quirks Builder v2 (with this being my first quirk), but looking at API it looks very nice and I guess it allows you to avoid a ZHA change also? What might be a pain is exporting two not one sensors like I have (which in my personal opinion makes more sense for these sensors). |
My original plan was to expose the valve status as a sensor, but I've been struggling to do so as I envisioned. As for my PR, I sort of ran out of time today. I will try to do it tomorrow. |
And finally, here's my PR: #3346 I managed to get the sensor working as I wanted with help from some devs in discord. Unfortunately, it is not yet possible to do the same with binary sensors. |
Hi, does this feature work? Where can I get the full file? |
834e068
to
c768029
Compare
Hi @fgsch Apologies for the big delay in getting back to you since you posted your pull request. I was finally able to try it out locally, V2 quirk interface is certainly a big improvement. Looks like there are still some issues with test line coverage - need to work out how to write a test for V2 quirk interface next. |
Water_Shortage = 1 | ||
Water_Leakage = 2 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To show all the possible values if querying the cluster directly, can you also add the Normal (0) and Water leakage and shortage (3) values?
return value & ValveState.Water_Shortage | ||
case self.AttributeDefs.valve_leak_state.name: | ||
return value & ValveState.Water_Leakage | ||
raise ValueError(f"Unknown attribute {key}") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Q: I suppose key would only be one of the supported attributes but perhaps for unknown keys this should return the value?
I left some comments, but it looks good. I won't be able to test it until this weekend, though. |
Hi @RogerSero To clarify, this PR/quirk only adds the sensors for diagnostic of the valve (e.g. water supply or leak). I can see from your screenshot that this appears to be working. If you want to see the sensor names to appear correctly, then zigpy/zha#234 will also be required. As it sounds like you are looking for water flow rate in particular, there is a separate PR implementing that on ZHA repository, please see here: zigpy/zha#187. I likely confused you with my screenshot above - as I had both patches locally when testing this. This implements the whole Flow cluster (with it being a Zigbee standard cluster) and therefore we don't require any special device side quirk like this patch does for the additional sensors. |
Much appreciated @fgsch - let me also go over your comments in more detail (hopefully this week) and get back to you. |
I've tested this quickly, and it works as expected. If you could address #3340 (comment) I think I'd be ready to go from my POV. |
Proposed change
Adds support for Sonoff SWV Smart Water Valve custom cluster, which exposes a new attribute called valve_status for querying if the valve is leaking or if the water supply to the valve has stopped.
Code should hopefully should be self explanatory, the only complication is the overridden
_is_manuf_specific()
property inSonoffFC11Cluster
class. This is required, as if the device receives an attribute read or notify zigbee command which has manufacturer_specific = True set (default if cluster's ID is within manufacturer specific range which this is), it will returnUNSUPPORTED_ATTRIBUTE
.This feature was requested as part of #3298
Additional information
Checklist
pre-commit
checks pass / the code has been formatted using Black