It’s also not working for me.
If I try to change any of the settings (volume, melody …), i got the green V, but it doesn’t change anything.
I am in version 2022.11.1
I had problems with reliability and so moved to Zigbee2mqtt, which is much easier to configure, once I’d got used to it.
Has anyone figured out the data that needs to be written to TuyaMCUSiren (Endpoint id: 1, Id: 0x0006, Type: in) for the various settings (volume, melodies etc.)?
Jim
Has anyone been able to make this work without having a degree in computer science…?
I would have thought that an alarm/siren would be a useful and popular addition to HA and therefore well supported, but it seems not!
Jim
If using the ZHA integration then suggest that you first open a new device support request (issue) to the ZHA Device Handlers integration to get help expanding a quirk for ZHA that maps all standard functions.
https://www.home-assistant.io/integrations/zha#how-to-add-support-for-new-and-unsupported-devices
https://github.com/zigpy/zha-device-handlers/issues
But frontend for ZHA integration is in need of UI development / user experience design improvements.
If you are talking about advanced device features in the ZHA integration UI in Home Assistant frontend then those are still not as user-friendly or easy to use as they could be if and when Home Assistant developers will ever add default support for some kind of device templating concept in the future (at least Nabu Casa’s user experience designers and UI developers discussed some ideas for the future that was along those lines during the second part of the State of the Open Home 2022 presentation video at around 1:20:00 timestamp), so while things in Home Assistant and the ZHA integration UI are getting easier but the ZHA UI and underlying features needed are not there yet.
https://www.youtube.com/live/D936T1Ze8-4?feature=share&t=4976
Quote: “Home Assistant gives you a lot of building blocks, it allows you to do a lot, but you need to build it yourself. That requires knowledge, that requires you to learn how to use it, and I think we can do better.” - Bram Kragten (Nabu Casa)
Until then, for better a worse, you need to understand that the ZHA integration is currently not yet a high-level application but rather more of a mid-level Zigbee implementation, meaning it does not offer full device abstraction for all known devices (such as the Philips Hue Bridge or IKEA Trådfri Gateway does and even Zigbee2MQTT does to some extent), but instead the ZHA integration currently only support a few specific device types mapped against existing Home Assistant device classes, as well as expose additional standard Zigbee clusters and attributes as entities in Home Assistant.
Also recommend you read through the whole ZHA integration documentation (which needs work too):
https://www.home-assistant.io/integrations/zha
So for now probably need to create a template and use templating with exposed entities in a Blueprint.
https://www.home-assistant.io/integrations/template/
https://www.home-assistant.io/docs/configuration/templating/
https://www.home-assistant.io/docs/automation/using_blueprints/
When you know what Zigbee clusters and attributes exposed as entities do then you have the option to simply use them ‘as is’ or make use of templates and configuring variables as template into Blueprints.
https://www.home-assistant.io/blog/2020/12/13/release-202012/#blueprints
https://www.home-assistant.io/docs/automation/using_blueprints/
https://www.home-assistant.io/docs/blueprint/
Also check out Selectors and Input Helpers for use in Blueprint automations for UI configuration:
https://www.home-assistant.io/docs/blueprint/selectors/
https://www.home-assistant.io/integrations/input_boolean/
In addition to searching the community to find out if there is an existing Blueprints for alarms (with siren):
https://community.home-assistant.io/c/configuration/blueprints/54
https://community.home-assistant.io/search?q=alarm%20%23configuration%3Ablueprints
There is also custom integrations and scripts that can use a siren, such as Alarmo based alarm system:
https://github.com/nielsfaber/alarmo
https://community.home-assistant.io/t/homeassiatant-alarm-management-alarm-control-panel/581471
In order to find out what all Zigbee clutsers and attribues do currently you will need to look up standard Zigbee clusters and attributes exposed as entities in Home Assistant then suggest that you ask the manufacturer if they can give you documentation or specification of which Zigbee clusters and attributes it exposes then you can look up those in the Zigbee specifications to see which options are available, see → https://github.com/zigpy/zha-device-handlers/blob/dev/README.md#primer
PS: ZHA (“Zigbee Home Automation”) is among the most popular integrations today according to Home Assistant Analytics so hopefully the future holds many UI improvements for streamlining experiences:
https://analytics.home-assistant.io/integrations/
https://www.home-assistant.io/blog/2022/01/19/streamlining-experiences/
It is now 2023 and I have the same problem as in this post. Was this ever resolved.
I update the cluster attributes to change the melody and get a green tick. But the melody on the device does not change.
Is there something else I need to do??
Hi jerrm,
I’d like to know if your neo siren can be connected via Sonoff dongle or third-party hub?
I’ve used it with the Sonoff ZBDongle-P under both ZHA and z2m.
I would expect it should work with other coordinators supported by those platforms.
There is a switch but no way to change the actual alarm…just a switch
The attributes were never exposed as entities in ZHA, at least not 1+ years ago when I had it under ZHA.
You had to manage with zha service calls, see script above.
yeah,I setup zigbee2mqtt. That seems to expose the rest of the entities. Thanks
I just followed the istruction you left.
Thank you very much, was very very halpfull.
As a novice on the HA world, in the first moments I was lost on what or how to do with your script.
May I try to integrate with this steps for other novice like me:
- Go under Settings (left down corner) -->Automations & scenes–> Tap Scripts → add script (right top corner) → create a new script → edit in YAML (top right corner)
- Paste as is the code shared and save (the one who starts with “alias: Tuya Siren ZHA” )
- Go under Developer Tools → services
- Type “Script: Tuya Siren ZHA” and click to “go to YAML mode”
- Paste the code of second screenshot (value of variables just for example)
data:
ieee_id: (you can find it under ZHA coordinator, select your device and in the left corner "Zigbee info")
melody: 1
duration: 60
volume: 1
alarm: "on"
-
Use the following page as reference for what type of melody you want to set:
Neo Siren with Temperature & Humidity Sensor NAS-AB02B2 Zigbee compatibility (unter the section “Table of Tunes”)
Quick recap of the page:
Melody: 0-18
Volume: 0-low, to 2-high
Duration: Duration in seconds -
After modified as needed, press “Call service”
This was very helpful. Thank you.
For anyone else who was stuck wondering how to change the settings for different use cases without going into the services section, see the following:
-
First follow the steps recommended by everyone from before this post.
-
Then, play around with the services section that Brubba wrote about to figure out what tunes and other settings you’d like to use.
-
Create a new automation with whatever triggers you’d like to set it off (OPTIONAL but highly recommended to reduce the number of automations you need and cluttering HA - use trigger IDs so that one automation controls all siren setting changes).
-
Prepare presets under a ‘choose’ action that will be used for whatever you specify based off this (but make sure you use YOUR correct IEEE ID from the ZHA info section).
-
Now, you’ll have different chimes for different trigger IDs. In my case, the doorbell being rung will play a ringing sound, and my perimeter alarm will use the siren sound effect at maximum volume.
Thanks to everyone in this thread for the tips and initial scripts!
I was having an issue where @jerrm 's script would work but only on every other service call. I wasn’t able to figure out why this was the cause BUT I was able to fix it by modifying the script to normally toggle the siren if the melody hadn’t changed since the last call.
I also took the liberty of improving the UI experience and adding more defaults to the script to make usage easier.
Based on jerrm’s script and @Brubba 's setup steps from above here is the Idiot’s Guide to the ZHA Neo Siren:
STEP 1: Gather Setup Info and Variables
- Create an Input Text to save last used melody
- Settings → Services & Services → Helpers → Create Helper → Text
- Name:
neo_alarm_melody
- Name:
- Create
- Settings → Services & Services → Helpers → Create Helper → Text
- Get required device values
- Settings → Devices → Zigbee Home Automation → Devices → find the siren device and open device details page
- Device Info → Zigbee info → IEEE
- Example:
a4:c1:38:a0:19:76:33:8b
- Example:
- Controls → Switch
- Click on Switch to open its details → Gear icon → Look for Entity ID
- Example
switch.neo_siren_switch
- Example
- Click on Switch to open its details → Gear icon → Look for Entity ID
- Device Info → Zigbee info → IEEE
- Settings → Devices → Zigbee Home Automation → Devices → find the siren device and open device details page
You now have three pieces of information needed to set up the script:
- Input Text helper Entity ID you created EX
neo_alarm_melody
- IEEE ID of the ZHA siren device EX
a4:c1:38:a0:19:76:33:8b
- Siren Switch Entity ID (used to toggle siren) EX
neo_siren_switch
STEP 2: Setup Script
- Go to Settings → Automations & scenes → Scripts → Add Script → Create new script
- In the New Script page click “…” in the top right corner → Edit in YAML
- Delete the existing contents (or replace it) with the code below:
# based on https://community.home-assistant.io/t/zigbee-neo-siren-ab02b2-v2-trying-to-switch-melody/425552/8
#
# This script includes these improvements:
#
# * Add full UI fields with descriptions and predefined values
# * Add default variables to make service call usage easier
# * Improve performance by only calling ZHA device write actions when currently set melody is different than parameter melody
# * Done by using input_text to store last set melody type
#
# SETUP: See instructions at bottom of the script
#
alias: Tuya Siren ZHA
sequence:
- if:
- condition: not
conditions:
- condition: template
value_template: >-
{{ is_state('input_text.' + (melody_entity_id |
default(default_melody_id)), (melody | default(default_melody)))
}}
then:
- service: input_text.set_value
target:
entity_id: input_text.{{(melody_entity_id | default(default_melody_id))}}
data:
value: "{{ melody }}"
- service: zha.set_zigbee_cluster_attribute
data:
ieee: "{{ ieee_id | default(default_ieed) }}"
endpoint_id: 1
cluster_id: 6
cluster_type: in
attribute: 1126
value: "{{ melody | default(default_melody) }}"
- service: zha.set_zigbee_cluster_attribute
data:
ieee: "{{ ieee_id | default(default_ieed) }}"
endpoint_id: 1
cluster_id: 6
cluster_type: in
attribute: 615
value: "{{ duration | default(default_duration) }}"
- service: zha.set_zigbee_cluster_attribute
data:
ieee: "{{ ieee_id | default(default_ieed) }}"
endpoint_id: 1
cluster_id: 6
cluster_type: in
attribute: 1140
value: "{{ volume | default(default_volume) }}"
- service: zha.set_zigbee_cluster_attribute
data:
ieee: "{{ ieee_id | default(default_ieed) }}"
endpoint_id: 1
cluster_id: 6
cluster_type: in
attribute: 0
value: "{{ alarm | default(1) }}"
- service: switch.turn_on
target:
entity_id: switch.{{ (siren_entity_id | default(default_siren_id)) }}
data: {}
description: Tuya Siren ZHA
fields:
ieee_id:
default: a4:c1:38:a0:19:76:33:8b
description: IEEE value found under 'Zigbee Info' on the siren 'Device Info' page in HA
example: a4:c1:38:00:12:34:56:78
selector:
text: null
melody:
default: "0"
description: "Melody that will be played based on ID from https://zigbee.blakadder.com/Neo_NAS-AB02B2.html"
example: 1-18
selector:
select:
mode: dropdown
# https://zigbee.blakadder.com/Neo_NAS-AB02B2.html
options:
- label: Doorbell Chime
value: "0"
- label: Fur Elise
value: "1"
- label: Westminster Chimes
value: "2"
- label: Fast double door bell
value: "3"
- label: William Tell Overture
value: "4"
- label: Turkish March
value: "5"
- label: Safe/Security Alarm
value: "6"
- label: Chemical Spill Alert
value: "7"
- label: Piercing Alarm Clock
value: "8"
- label: Smoke Alarm
value: "9"
- label: Dog Barking
value: "10"
- label: Police Siren
value: "11"
- label: Doorbell Chime (reverb)
value: "12"
- label: Mechanical Telephone
value: "13"
- label: Fire/Ambulance
value: "14"
- label: 3/1 Elevator
value: "15"
- label: Buzzing Alarm Clock
value: "16"
- label: School Bell
value: "17"
duration:
default: 4
description: Duration melody will be played for
selector:
number:
min: 0
max: 100
mode: box
unit_of_measurement: "seconds"
volume:
default: "1"
description: Volume of the melody
selector:
select:
options:
- label: Low
value: "0"
- label: Medium
value: "1"
- label: High
value: "2"
alarm:
default: "on"
description: When writing alarm settings, should alarm be on? Leave as default
example: on or off
selector:
select:
options:
- label: "Off"
value: "off"
- label: "On"
value: "on"
neo_siren_switch:
default: neo_siren_switch
selector:
entity: {}
name: siren_entity_id
description: The switch entity for the siren
neo_melody_text:
default: neo_alarm_melody
description: The text_input helper entity that stores the current melody type
selector:
entity: {}
name: melody_entity_id
variables:
# THESE ARE THE DEFAULTS ACTUALLY USED when using this script through a service call and fields are not set
# the defaults in the fields above ^^ are only used when enabling a field through the UI
#
# Ideally, should set the field defaults above and the variable defaults below to the same value
#
#
# IEEE value found under 'Zigbee Info' on the siren 'Device Info' page in HA
default_ieed: a4:c1:38:a0:19:76:33:8b
# melody ID found at https://zigbee.blakadder.com/Neo_NAS-AB02B2.html
default_melody: 0
default_duration: 4
default_volume: 1
# CREATE AN INPUT HELPER (input_text) and use its entity id here
default_melody_id: neo_alarm_melody
# The entity id of the siren's switch
default_siren_id: neo_siren_switch
mode: parallel
Now replace the following sections with the data you gathered in STEP 1:
- fields → ieee_id → default → IEED ID
- fields → neo_siren_switch → default → Siren Siwtch Entity ID
- fields → neo_melody_text → default → Input Text helper Entity ID
- variables → default_ieed → IEED ID
- variables → default_melody_id → Input Text helper Entity ID
- variables → default_siren_id → Siren Siwtch Entity ID
Then Save Script
STEP 3: Using the script
Congratulations, you can now use the script! Compared to the original script and other examples in this thread you do not need to specify any parameters when calling the script now. However you may stay specify everything/anything if you want.
Using in the UI (in an automation or via service call) you will now have pre-filled fields
Using in YAML mode is the same but you only need to specify melody, volume, and duration (optimally).
This whole thread has been very helpful and educational.
I find in one of my orders I received both AB02B0 as well as AB02B2 models (I think someone just grabbing boxes off a shelf) and the B0 doesn’t seem to respond the same way. Anyone know of a thread providing similar directions for that version? It does not respond at all to the B2 methods
Many thanks for pulling the notes together, tweaking the script and providing the detailed guide on this.
Following your script implementation for ZHA, I’ve set up the helper text input and kept the name,“neo_alarm_melody”
I configured the script as you documented with my siren’s IEEE and switch entity as instructed. However, I’m encountering some inconsistencies:
In the Developer Tools, adjusting script variables to change the melodie, it typically fails on the first attempt if it’s a change from the previous melody. Here’s the error:
“Failed to call service script.1707788213189. Failed to set attribute: value: 1 attribute: 1140 cluster_id: 61184 endpoint_id: 1”
The script runs without error on the second try as it uses the melody value from the text input helper and is not trying to change the cluster value.
About 20% of the time, changing the melody to a new melody in Developer tools works on the first run.
It’s the same behavior within an automation making a service call to the script, it rarely successfully changes the melody on the first attempt, usually taking 7-10 seconds before a popup error:
“Failed to set attribute: value: 1 attribute: 1140 cluster_id: 61184 endpoint_id: 1”
After this delay, if I manually run the script again, it works-- as expected based on the same behavior in the Developer Tools.
I’ve added a 10-second wait event in my automation to counter this, but it feels clunky and further slows down the intent of the automation-- to notify me based on a trigger.
I’ve made no modifications to your original script, just adapted it to my siren’s IEEE ID and the correct entity names for the text input helper and the siren switch as shown in the device settings.
Is this your experience too?
Many thanks again.
Clarification-- after my wait event, the automation re-runs the script. So, two service calls to the script separated by a wait event as the first one will fail with the error, but it does update the cluster and change the melody. The second execution simply plays the melody as the script knows not to perform the zha.set_zigbee_cluster_attribute, it just toggles the siren switch.
I managed to get the changes to take place more reliably when I just put in a loop to repeat them, so they each get 40 attempts. No extra time delays. This is in MQTT not ZHA. But is still isn’t 100% - in fact I can’t even get the device to reliably make any sound when switched on by an automation. I put in a loop of 40 tries to make sure it did. It usually does sound but not always. I’ve made a barebones automation to gather data.
The automatic config looks like this
alias: Test bell reduced
> description: ''
> trigger: []
> condition: []
> action:
> - repeat:
> count: 40
> sequence:
> - type: turn_on
> device_id: d8c939486d1d8527887d804022281d7b
> entity_id: 2ffe11a53a56dd0825c47c4b665bf012
> domain: switch
> mode: single
When it doesn’t work the trace timeline shows “Turn on unknown entity” 21 times, every line is the same.
On one of the lines when it works it says (switch.office_noisemaker_alarm) turned on. The rest say Turn on unknown entity.
It seems that if you run it fairly quickly after a fail it does not fail but if it’s left a bit it is more likely to fail - but that isn’t really a particularly scientific observation.
I was hoping to use this as a mutli purpose device, including as a doorbell, so I don’t want to include to many pauses!
I have the traces downloaded but can’t see how to attach them here.
If anyone has any idea how to take this forward I’d appreciate it.
As an update, it always works from the UI, along with changing volume, melody and duration.