SuperNotifier¶
Easy multi-channel rich notifications.
An extension of HomeAssistant’s built in notify.notify
that can greatly simplify multiple notification channels and
complex scenarios, including multi-channel notifications, conditional notifications, mobile actions, chimes and template based HTML emails. Can substitute directly for existing notifications to mobile push, email, etc.
Features¶
- Send out notifications on multiple channels from one call, removing repetitive config and code from automations
- Standard
notify
implementation so easy to switch out for other notify implementations, ornotify.group
- Conditional notification using standard Home Assistant
condition
config - Reuse chunks of conditional logic as scenarios across multiple notifications
- Streamlined conditionals for selecting channels per priority and scenario, or for sending only to people in or out of the property
- Use
person
for all notification configuration, regardless of channel - Unified Person model currently missing from Home Assistant
- HTML email templates, using Jinja2, with a general default template supplied
- Single set up of consistent mobile actions across multiple notifications
- Flexible image snapshots, supporting cameras, MQTT Images and image URLs.
- Cameras can be repositioned using PTZ before and after a snapshot is taken.
- Defaulting of targets and data in static config, and overridable at notification time
- Generic support for any notification method
- Plus canned delivery methods to simplify common cases, especially for tricky ones like Apple Push
- Reloadable configuration
- Tunable duplicate notification detection
- Well-behaved
notify
extension, so can use data templating,notify.group
and other notify features. - Refactor out repetitive configuration for ease of maintenance
- Debugging support,
- Optional archival of message structures
- Additional actions ( previously known as services ) to pull back live configuration or last known notification details.
Installation¶
- Add git repo to HACS as custom repo
- Select SuperNotify in the list of available integrations in HACS and install
- Add a
notify
config for thesupernotifier
integration, seeexamples
folder - In order to use email attachments, e.g. from camera snapshot or a
snapshot_url
, you must set theallowlist_external_dirs
in main HomeAssistant config to the same asmedia_path
in the supernotify configuration
Usage¶
Minimal¶
- action: notify.supernotifier
data:
title: Security Notification
message: '{{state_attr(sensor,"friendly_name")}} triggered'
More features¶
- action: notify.supernotifier
data:
title: Security Notification
message: '{{state_attr(sensor,"friendly_name")}} triggered'
target:
- person.jim_bob
- person.neighbour
priority: high
apply_scenarios:
- home_security
- garden
delivery:
mobile_push:
data:
clickAction: https://my.home.net/dashboard
clickAction
is defined only on the mobile_push
delivery. However
its also possible to define everything at the top level data
section and let the individual
deliveries pick out the attributes they need. This is helpful either if you don’t care about
fine tuning delivery configurations, or using existing notification blueprints, such as the popular
Frigate Camera Notification Blueprints.
Templated¶
- action: notify.supernotifier
data:
message:
data_template:
title: Tank Notification
message: "Fuel tank depth is {{ state_attr('sensor.tank', 'depth') }}"
data:
priority: {% if {{ state_attr('sensor.tank', 'depth') }}<10 }critical{% else %}medium {% endif %}
Delivery Methods¶
Mobile Push¶
Send a push message out, with option for camera integration, mobile actions, and translate general priority to Apple specific push priority.
Some functionality may also work with Android push, though has not been tested.
Although SuperNotifier will automatically set most useful mobile push options, its also possible to directly set them, as in this example:
- action: notify.supernotifier
data:
message: Movement at garden gate
data:
priority: high
media:
camera_entity_id: camera.porch
camera_ptz_preset: garden_gate
action_groups:
- security_actions
delivery:
mobile_push:
data:
tag: "backyard-motion-detected"
presentation_options:
- alert
- badge
push:
sound:
name: "US-EN-Alexa-Motion-Detected-Generic.wav"
volume: 1.0
Chime¶
Provide a list of switch
, siren
, media_player
or script
entities to use for chimes
and it will call the switch.turn_on
, script.turn_on
or media_player.play_media
actions automatically for each.
See https://github.com/alandtse/alexa_media_player/wiki#known-available-sounds for a list of known tunes that work with Alexa devices.
Optionally chime aliases can be set up so that simple names can be given for Amazon tune paths, or multiple types of chime all mapped to same name. This can be used in combination with method default targets for concise notifications.
Switches are a little special, in that they are binary on/off. However, since many
433Mhz ones can take an additional melody code, its common to have different melodies
represented by separate switch
entities for the same underlying devices.
Example¶
methods:
chime:
target:
- media_player.kitchen_echo
- media_player.bedroom
options:
chime_aliases:
doorbell:
media_player:
# resolves to media_player/play_media with sound configured for this path
tune: home/amzn_sfx_doorbell_chime_02
# device defaults to `target` of method default or action call
media_player_alt:
# Not all the media players are Amazon Alexa based, so override for other flavours
domain: media_player
tune: raindrops_and_roses.mp4
entity_id:
- media_player.hall_custom
switch:
# resolves to switch/turn_on with entity id switch.ding_dong
entity_id: switch.chime_ding_dong
siren:
# resolves to siren/turn_on with tune bleep, only front door siren called
tune: bleep
entity_id: siren.front_door
red_alert:
# non-dict defaults to a dict keyed on `tune`
alexa: scifi/amzn_sfx_scifi_alarm_04
siren: emergency
With this chime config, a doorbell notification can be sent to multiple devices just by selecting a tune.
SMS¶
Uses the phone_number
attribute of recipient, and truncates message to fit in an SMS.
The title_only
option can be sent to restrict content to just title, when both title and
message on a notification. Otherwise, the combined title/message is sent out.
Generic¶
Use to call any action (previously known in Home Assistant as ‘service’ ).
If action is in notify
domain, then message
,title
,target
and data
will be
passed in the Action (Service) Data, otherwise the data
supplied will be passed directly
as the Action Data.
- action: notify.supernotify
data:
title: "My Home Notification"
message: "Notify via custom chat"
delivery:
chat_notify:
data:
channel: 3456
- action: notify.supernotify
data:
delivery:
mqtt_notify:
data:
topic: alert/family_all
payload: something happened
Email¶
Can be used for plain or HTML template emails, and handle images as attachments or embedded HTML.
Also supports message_html
override to supply html that will be ignored for other notification
types, and does not require templates. In this case, HTML will automatically be tagged onto the
end to include any attached images.
Media Image¶
Show an image on a media player, e.g. an Alexa Show ( where that actually works, depending on model )
Alexa Announce¶
Announce a message on an Alexa Echo device using the alexa_media_player
integration
The title_only
option can be set to False
to override the restriction of content to just title, when both title and message on a notification. Otherwise, only the title is announced.
Persistent¶
Place a notification on Home Assistant application screen.
Pass a notification ID
Media support¶
Images can be included by:
- camera entity, as created by any Camera Integration
- image entity, for example an MQTT Image, ideal for Frigate or cameras that stream to MQTT
snapshot_url
Additionally a video clip can be referenced by clip_url
where supported by a delivery method (currently mobile push only).
An optional PTZ preset can also be referenced in data
, a PTZ delay before snapshot taken,
and a choice of onvif
or frigate
for the PTZ control. After the snap, an additional PTZ will be commanded to return to the ptz_default_preset
defined for the camera.This image will taken once and then reused across all supporting delivery methods.
Some cameras, like Hikvision, add JPEG comment blocks which confuse the very simplistic media
detection in the SMTP integration, and leads to spurious log entries. Supernotify will automatically rewrite JPEGs into simpler standard forms to avoid this, and optionally JPEG_ARGS
can be set, for example to reduce image quality for smaller email attachments.
Flexible Configuration¶
Delivery configuration can be done in lots of different ways to suit different configurations and to keep those configuration as minimal as possible.
Priority order of application
Where | When | Notes |
---|---|---|
Action Data | Runtime call | |
Recipient delivery override | Runtime call | |
Scenario delivery override | Runtime call | Multiple scenarios applied in no special order |
Delivery definition | Startup | message and title override Action Data |
Method defaults | Startup | |
Target notification action defaults | Downstream call |
- Action Data passed at runtime call
- Recipient delivery override
- Scenario delivery override
- Delivery definition
- Method defaults
- Target notification action defaults, e.g. mail recipients ( this isn’t applied inside supernotifier )
Setup¶
Register this GitHub repo as a custom repo in your HACS configuration.
Configure in the main Home Assistant config yaml, or an included notify.yaml
See examples
directory for working minimal and maximal configuration examples.
Cameras¶
Use this for additional camera info:
- Link a
device_tracker
to the camera - Notifications will first check its online, then use an alternative if primary is down
- Define alternative cameras to use if first fails using
alt_camera
- For ONVIF or Frigate cameras set up for PTZ
- Home preset can be defined using
ptz_default_preset
so camera can be reset after taking a snapshot - Delay between PTZ command and snapshot can be defined using
ptz_delay
- Choose between ONVIF or Frigate PTZ control using
ptz_method
- Note that ONVIF may have numeric reference for presets while Frigate uses labels
Delivery Method Options¶
All of these set by passing an options
block in delivery config or method defaults.
Option | Methods | Description |
---|---|---|
chime_aliases | chime | Map tunes to device name or config |
jpeg_flags | Tune image grabs | |
title_only | sms, alexa | Suppress message body |
timestamp | all | Add a timestamp to message. |
jpeg_flags
can also be set per runtime call by passing in the media
block.
Snoozing¶
Snoozing can be done for a set time, or notifications can be silenced until further notice ( or currently until reboot ).
Mobile Actions¶
Mobile actions will be handled according to scheme:
SUPERNOTIFY_
Scenarios¶
Scenarios can be defined both as a set of conditions which switch on the scenario and/or as a set of overrides to apply if the scenario is active.
For example, a scenario could be defined by conditions such as alarm panel arm state, occupancy and time to indicate when notifications should be minimized, and then different chime sounds could be selected or deliveries switched off.
Scenarios can override specific delivery configurations, general media configuration or
the delivery_selection
basis.
For more on the conditions, see the Home Assistant Conditions documentation since the conditions are all evaluated at time of notification by the standard Home Assistant module.
Example Scenarios¶
This scenario could be used to select more obtrusive notifications, like email or Alexa announcements, from a combination of conditions, hence simplifying separate notification calls, and providing one place to tune multiple notifications.
more_attention:
alias: time to make more of a fuss
condition:
condition: and
conditions:
- not:
- condition: state
entity_id: alarm_control_panel.home_alarm_control
state: disarmed
- condition: time
after: "21:30:00"
before: "06:30:00"
In this example, selecting the scenario by name in a notification call switches on
a set of delivery methods, which saves repetitive declaration in many notification calls. Delivery
Selection is made implicit
so not switching off any other deliveries that would have applied.
red_alert:
delivery_selection: implicit
delivery:
chime_red_alert:
upstairs_siren:
downstairs_siren:
Delivery selection can also be passed in the data
of an action call, in which case it can
also be fixed
, which disables scenarios from enabling or disabling deliveries and leaves it solely
to defaults or what’s listed in the action call.
Conditions aren’t essential for scenarios, since they can also be switched on by a notification.
For example in this case, where the home_security
and garden
scenarios are explicitly
triggered, and so any overrides declared in those scenarios will be applied.
- action: notify.supernotifier
data:
title: Security Notification
message: '{{state_attr(sensor,"friendly_name")}} triggered'
priority: high
apply_scenarios:
- home_security
- garden
Additional variables for conditions¶
Scenario and DeliveryMethod conditions have access to everything that any other Home Assistant conditions can access, such as entities, templating etc. In addition, supernotifier makes additional variables automatically available:
Template Variable | Description |
---|---|
notification_priority | Priority of current notification, explicitly selected or default |
notification_message | Message of current notification |
notification_title | Title of current notification |
applied_scenarios | Scenarios explicitly selected in current notification call |
required_scenarios | Scenarios a notification mandates to be enabled or else suppressed |
occupancy | One or more occupancy states, e.g. ALL_HOME, LONE_HOME |
Tips¶
Message formatting¶
To send a glob of html to include in email, set message_html
in action data. This will be ignored
by other delivery methods that don’t handle email. This can be also be used to have a notification
with only a title ( that gets picked up for mobile push, alexa and other brief communications ) with
a much more detailed body only for email.
Use data_template
to build the data
dictionary with Jinja2 logic from automations or scripts.