-
-
Save hunterjm/23c1588a9f2b8b9c2a62ffc364e17f8c to your computer and use it in GitHub Desktop.
blueprint: | |
name: Frigate Notification | |
description: | | |
## Frigate Mobile App Notification | |
This blueprint will send a notification to your device when a Frigate event for the selected camera is fired. The notification will initially include the thumbnail of the detection, but will update to include actionable notifications allowing you to view the saved clip/snapshot when available, or silence the notification for a configurable amount of time. | |
With this blueprint, you may send the notification to multiple devices by leaving "Device" blank and instead use a [notification group][1]. | |
### Required entities: | |
- Frigate Camera Name | |
- Mobile App Device **or** the name of a Notification Group | |
### Optional features: | |
- You can limit notifications to objects entering **any** pre-defined [zones][2] in Frigate. | |
- You can specify which [zones][2] to be notified about. This must be a list (e.g.): | |
```yaml | |
- backyard | |
``` | |
- You can specify what type of [objects][3] to be notified about. This must be a list (e.g.): | |
```yaml | |
- person | |
- car | |
``` | |
- You can disable notifications if a presence entity or group is "home". | |
- You can configure a cooldown for the camera to reduce the number of notifications when back-to-back events occur. | |
- You can silence future notifications for a defined amount of time through actionable notifications. This is helpful in situations where you know you will be triggering detections for an extended period of time, like when the kids are playing outside. | |
[1]: https://companion.home-assistant.io/docs/notifications/notifications-basic#sending-notifications-to-multiple-devices | |
[2]: https://blakeblackshear.github.io/frigate/configuration/cameras#zones | |
[3]: https://blakeblackshear.github.io/frigate/configuration/objects | |
domain: automation | |
source_url: https://gist.github.com/hunterjm/23c1588a9f2b8b9c2a62ffc364e17f8c | |
input: | |
camera: | |
name: Frigate Camera | |
description: The name of the camera as defined in your frigate configuration. | |
notify_device: | |
name: Device | |
description: The device must run the official Home Assistant app to receive notifications. | |
default: false | |
selector: | |
device: | |
integration: mobile_app | |
notify_group: | |
name: Notification Group | |
description: The name of the notification group to call. | |
default: "" | |
base_url: | |
name: (Optional) Base URL | |
description: > | |
The external url for your Home Assistant instance. This will default to a relative | |
URL and will open the clips in the app instead of the browser, which may cause issues | |
on some devices. | |
default: "" | |
zone_filter: | |
name: (Optional) Zone Filter | |
description: Only notify if object has entered a defined zone. | |
default: false | |
selector: | |
boolean: | |
zones: | |
name: (Optional) Trigger Zones | |
description: A list (-) of zones you wish to recieve notifications for. | |
default: [] | |
selector: | |
object: | |
labels: | |
name: (Optional) Trigger Objects | |
description: A list (-) of objects you wish to recieve notifications for. | |
default: [] | |
selector: | |
object: | |
presence_filter: | |
name: (Optional) Presence Filter | |
description: Only notify if selected presence entity is not "home". | |
default: "" | |
selector: | |
entity: | |
cooldown: | |
name: (Optional) Cooldown | |
description: Delay before sending another notification for this camera after the last event. | |
default: 30 | |
selector: | |
number: | |
max: 300 | |
min: 0 | |
unit_of_measurement: seconds | |
silence_timer: | |
name: (Optional) Silence Notifications | |
description: > | |
How long to silence notifications for this camera when requested as part of the | |
actionable notification. | |
default: 30 | |
selector: | |
number: | |
max: 300 | |
min: 0 | |
unit_of_measurement: minutes | |
mode: single | |
max_exceeded: silent | |
trigger: | |
platform: mqtt | |
topic: frigate/events | |
payload: !input camera | |
value_template: "{{ value_json['after']['camera'] }}" | |
variables: | |
id: "{{ trigger.payload_json['after']['id'] }}" | |
camera: "{{ trigger.payload_json['after']['camera'] }}" | |
camera_name: "{{ camera | replace('_', ' ') | title }}" | |
object: "{{ trigger.payload_json['after']['label'] }}" | |
label: "{{ object | title }}" | |
entered_zones: "{{ trigger.payload_json['after']['entered_zones'] }}" | |
type: "{{ trigger.payload_json['type'] }}" | |
base_url: !input base_url | |
group_target: !input notify_group | |
zone_only: !input zone_filter | |
input_zones: !input zones | |
zones: "{{ input_zones | list }}" | |
input_labels: !input labels | |
labels: "{{ input_labels | list }}" | |
presence_entity: !input presence_filter | |
condition: | |
- "{{ type != 'end' }}" | |
- "{{ not zone_only or entered_zones|length > 0 }}" | |
- "{{ not zones|length or zones|select('in', entered_zones)|list|length > 0 }}" | |
- "{{ not labels|length or object in labels }}" | |
- "{{ not presence_entity or not is_state(presence_entity, 'home') }}" | |
action: | |
- choose: | |
- conditions: "{{ not group_target }}" | |
sequence: | |
- device_id: !input notify_device | |
domain: mobile_app | |
type: notify | |
message: 'A {{ label }} was detected on the {{ camera_name }} camera.' | |
data: | |
tag: '{{ id }}' | |
group: 'frigate-notification-{{ camera }}' | |
image: '/api/frigate/notifications/{{id}}/thumbnail.jpg?format=android' # Android | |
attachment: # iOS | |
url: '/api/frigate/notifications/{{id}}/thumbnail.jpg' | |
default: | |
- service: "notify.{{ group_target }}" | |
data: | |
message: 'A {{ label }} was detected on the {{ camera_name }} camera.' | |
data: | |
tag: '{{ id }}' | |
group: 'frigate-notification-{{ camera }}' | |
image: '/api/frigate/notifications/{{id}}/thumbnail.jpg?format=android' # Android | |
attachment: # iOS | |
url: '/api/frigate/notifications/{{id}}/thumbnail.jpg' | |
- repeat: | |
sequence: | |
- wait_for_trigger: | |
- platform: mqtt | |
topic: frigate/events | |
payload: "{{ id }}" | |
value_template: "{{ value_json['after']['id'] }}" | |
timeout: | |
minutes: 2 | |
continue_on_timeout: false | |
- condition: template | |
value_template: "{{ wait.trigger.payload_json['type'] == 'end' }}" | |
- choose: | |
- conditions: "{{ not group_target }}" | |
sequence: | |
- device_id: !input notify_device | |
domain: mobile_app | |
type: notify | |
message: 'A {{ label }} was detected on the {{ camera_name }} camera.' | |
data: | |
tag: '{{ id }}' | |
group: 'frigate-notification-{{ camera }}' | |
url: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' # iOS | |
clickAction: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' # Android | |
image: '/api/frigate/notifications/{{id}}/thumbnail.jpg?format=android' # Android | |
sound: none | |
attachment: # iOS | |
url: '/api/frigate/notifications/{{id}}/thumbnail.jpg' | |
# lazy: true | |
actions: | |
- action: URI | |
title: View Clip | |
uri: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' | |
- action: URI | |
title: View Snapshot | |
uri: '{{base_url}}/api/frigate/notifications/{{id}}/snapshot.jpg' | |
- action: 'silence-{{ camera }}' | |
title: Silence Notifications | |
destructive: true | |
default: | |
- service: "notify.{{ group_target }}" | |
data: | |
message: 'A {{ label }} was detected on the {{ camera_name }} camera.' | |
data: | |
tag: '{{ id }}' | |
group: 'frigate-notification-{{ camera }}' | |
url: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' # iOS | |
clickAction: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' # Android | |
image: '/api/frigate/notifications/{{id}}/thumbnail.jpg?format=android' # Android | |
sound: none | |
attachment: # iOS | |
url: '/api/frigate/notifications/{{id}}/thumbnail.jpg' | |
# lazy: true | |
actions: | |
- action: URI | |
title: View Clip | |
uri: '{{base_url}}/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4' | |
- action: URI | |
title: View Snapshot | |
uri: '{{base_url}}/api/frigate/notifications/{{id}}/snapshot.jpg' | |
- action: 'silence-{{ camera }}' | |
title: Silence Notifications | |
destructive: true | |
until: "{{ wait.trigger.payload_json['type'] == 'end' }}" | |
- wait_for_trigger: | |
- platform: event | |
event_type: mobile_app_notification_action | |
event_data: | |
action: 'silence-{{ camera }}' | |
timeout: | |
seconds: !input cooldown | |
continue_on_timeout: false | |
- delay: | |
minutes: !input silence_timer |
As 0.10.0 is now stable, should I use this blueprint or the 0.10.0 one?
Hi
thank you for this blueprint !
looks like python maintenance has now made integers have a value - mine was not triggering needed to change blueprint to
fps: '{{ fps_value|int(0) if is_number(fps_value) or 5 }}'
giving fps_value a initial value of 0
If you're looking for the actionable notifications on iphone, just swipe left on the notification. Options and buttons are there :-)
Let me clarify - there was an error in the blueprint with an uninitialized integer variable
Which was causing automaton not to trigger
fwiw, it's still triggering just fine for me on 2022.8.6
hi.. Trying to run the blueprint, but if I test (run actions) - I get this error ...
Error rendering variables: ValueError: Template error: int got invalid input 'unknown' when rendering template '{{ fps_value|int if is_number(fps_value) or 5 }}' but no default was specified
I have no idea what it means.
@sys1aeg - thx... sometimes it stares right back at you :)
Made the error go away.. but unfortunately I am still not receiving notifications.
I have another notification - which does work.. but not this.
I selected my phone and ran the "run actions".. but to no avail. There's nothing in the logs I can find.
alias: Frigate - Notification - Martin Mobile
description: ""
use_blueprint:
path: hunterjm/frigate_0.10_notification.yaml
input:
camera: Carport
notify_device: 4cd07a06e55a8f9322d55e0686073fd5
update_thumbnail: true
@sys1aeg - I can call the notify service and I get a test message.
if I run actions in the automation I get nothing.
I cannot see.. in the blueprint.. what it does as I just select my phone .. and that translates to some long ID code in the yaml.
but I don't know if the blueprint will run the notification part on it's own.
Anyone having issues seeing the snapshot in the notification on IOS 16? After updating i dont see the snapshot, just the text.
Nice blue print. Would be nicer if it can deal with multiple cameras instead of having to set up a rule for each one.
Nice Blueprint, thanks!! I may try to update it to include alarm status as would like to be notified depending of the alarm (i.e. get notified if anyone is in the garden when alarm is in night mode)
Hi
thank you for this blueprint !
looks like python maintenance has now made integers have a value - mine was not triggering needed to change blueprint to
fps: '{{ fps_value|int(0) if is_number(fps_value) or 5 }}'
giving fps_value a initial value of 0
thank you so much I was messing around for over a week with this trying to figure it out till I found your comment edited the blueprint now it’s all working.
Guys, this blueprint isn't being updated anymore. Here's the new one:
https://community.home-assistant.io/t/frigate-mobile-app-notifications/311091/662
Is it possible to add an input boolean, so when ON the notifications are silenced?
Even with the new blueprint, for 2023.11 you need to select a device as well as a notification group. There was a change to the selector validation in core. Even with this version of the blueprint, notification groups are given priority, so it does no harm to select a device.
Thanks @hunterjm that solved the issue :)
This blueprint is incredibly helpful, thank you very much for creating it!
Hello, I haven't started using too much other work yet..
Thanks @chelming
I’ve tried that one too, but I do not get any actions or clips or snapshots either with that blueprint in iOS 17.4.
post in that thread on the HA community. There's more people there that can help :)
Good idea, thanks again.
Great blueprint!
When I click on the "View Clip" in the notification it just opens the Frigate tab of Home Assistant. Is it supposed to actually play the clip as well?