Skip to content
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

Open
wants to merge 2 commits into
base: dev
Choose a base branch
from

Conversation

benbancroft
Copy link

@benbancroft benbancroft commented Aug 31, 2024

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 in SonoffFC11Cluster 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 return UNSUPPORTED_ATTRIBUTE.

This feature was requested as part of #3298

Additional information

Checklist

  • The changes are tested and work correctly
  • pre-commit checks pass / the code has been formatted using Black
  • Tests have been added to verify that the new code works

Copy link

codecov bot commented Aug 31, 2024

Codecov Report

Attention: Patch coverage is 69.23077% with 8 lines in your changes missing coverage. Please review.

Project coverage is 88.66%. Comparing base (fa734ad) to head (c768029).
Report is 87 commits behind head on dev.

Files with missing lines Patch % Lines
zhaquirks/sonoff/swv.py 69.23% 8 Missing ⚠️
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.
📢 Have feedback on the report? Share it here.

Comment on lines 34 to 18

Water_Shortage = 0x1
Water_Leakage = 0x2

Copy link
Contributor

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).

Copy link
Author

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.

Screenshot 2024-08-31 201932

Copy link
Contributor

@fgsch fgsch Sep 2, 2024

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.

Copy link
Contributor

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?


cluster_id = SONOFF_CLUSTER_FC11_ID
ep_attribute = "sonoff_manufacturer"
attributes = {ATTR_SONOFF_VALVE_STATUS: ("valve_status", ValveStatusBitmap, False)}
Copy link
Contributor

@fgsch fgsch Sep 1, 2024

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.

Copy link
Author

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.

@fgsch
Copy link
Contributor

fgsch commented Sep 1, 2024

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.

@benbancroft
Copy link
Author

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).

@fgsch
Copy link
Contributor

fgsch commented Sep 2, 2024

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.
I don't know if it's me or if it's just not possible, but unfortunately, no other zha quirks are using this.
Might be a good time to ask around.

As for my PR, I sort of ran out of time today. I will try to do it tomorrow.

@fgsch
Copy link
Contributor

fgsch commented Sep 3, 2024

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.

@TheJulianJES TheJulianJES added the new quirk Adds support for a new device label Sep 16, 2024
@RogerSero
Copy link

Hi, does this feature work? Where can I get the full file?

@benbancroft
Copy link
Author

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.
Based on your commit, I think I've come up with a clean way of handling the binary sensors instead of enum approach. Please let me know what you think.

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.

Comment on lines +15 to +16
Water_Shortage = 1
Water_Leakage = 2
Copy link
Contributor

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}")
Copy link
Contributor

@fgsch fgsch Oct 15, 2024

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?

@fgsch
Copy link
Contributor

fgsch commented Oct 15, 2024

I left some comments, but it looks good. I won't be able to test it until this weekend, though.

@RogerSero
Copy link

I'm doing something wrong, because with the quirk file, it doesn't show me the water flow. What could it be?
Captura de pantalla 2024-10-16 104233

@benbancroft
Copy link
Author

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.

@benbancroft
Copy link
Author

Much appreciated @fgsch - let me also go over your comments in more detail (hopefully this week) and get back to you.

@fgsch
Copy link
Contributor

fgsch commented Nov 3, 2024

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.

@TheJulianJES TheJulianJES added the v2 quirk Quirks using v2 API. Might add custom entities that need translation keys in HA. label Nov 24, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
new quirk Adds support for a new device v2 quirk Quirks using v2 API. Might add custom entities that need translation keys in HA.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants