Adding automations for person detection notifications

This commit is contained in:
Chris Stuurman 2025-04-18 20:31:39 +02:00
parent 51b2f58791
commit cc7a8ebaf0
7 changed files with 322 additions and 20 deletions

View File

@ -0,0 +1,25 @@
services:
deepstack:
container_name: deepstack
restart: unless-stopped
image: deepquestai/deepstack
ports:
- '5000:5000'
environment:
- VISION-DETECTION=True
- API-KEY=""
volumes:
- /Users/robin/Data/pytorch-models:/modelstore/detection
deepstack_ui:
container_name: deepstack_ui
restart: unless-stopped
image: robmarkcole/deepstack-ui:latest
environment:
- DEEPSTACK_IP=deepstack
- DEEPSTACK_PORT=5000
- DEEPSTACK_API_KEY=""
- DEEPSTACK_TIMEOUT=20
- DEEPSTACK_CUSTOM_MODEL=fire
- DEEPSTACK_UI_DEBUG_MODE=True
ports:
- '8501:8501'

View File

@ -0,0 +1,171 @@
https://www.youtube.com/watch?v=gA67NCcTwms&t=621s
# Automation yaml file
--- snip ---
alias: "FRIGATE: Notify driveway zone1 person detection"
description: FRIGATE notify - driveway
triggers:
- topic: homeassistant/events
trigger: mqtt
conditions:
- condition: template
value_template: "{{ trigger.payload_json['after']['label'] == 'person' }}"
- condition: template
value_template: "{{ 'driveway_z1' in trigger.payload_json['after']['entered_zones']}}"
actions:
- action: notify.mobile_app_sm_n986b
data_template:
message: A {{trigger.payload_json["after"]["label"]}} was detected.
title: Frigate
data:
image: >-
https://home-assistant.sthome.org/api/frigate/notifications/{{trigger.payload_json["after"]["id"]}}/thumbnail.jpg?format=android
tag: "{{trigger.payload_json[\"after\"][\"id\"]}}"
when: "{{trigger.payload_json[\"after\"][\"start_time\"]|int}}"
actions:
- action: URI
title: Open Image
uri: >-
https://home-assistant.sthome.org/api/frigate/notifications/{{trigger.payload_json["after"]["id"]}}/thumbnail.jpg?format=android
enabled: true
mode: single
--- snip ---
# Install home-assistant app on your android phone from the play store
# After installation and connection to you home-assistant server, on home-assistant server (on computer), navigate to Settings -> Devices & services -> Integrations. Look for your Mobile App in the list of integrations.
# To change the name of the device, click on the 3 dot menu next to the device name under Integration Entities and select Rename.
# open app on phone and from the Overview screen, click on hamburger menu -> Settings -> Companion app -> Notification channels
# With the device name now known, edit the yaml file above to reflect the device name, e.g.
# if device name is SM-N986B, then
- action: notify.mobile_app_samsung_sm_n986b
To create a script using GUI
----------------------------
Navigate to Settings -> Automations & Scenes -> Scripts
Click "+ CREATE SCRIPT"
Click Create New Script
To create script directly using yaml
------------------------------------
In truenas shell, go to config/scripts folder
# Create custom scripts folder to keep scripts organised
mkdir custom_scripts
# Create script file using nano editor, for example:
nano custom_scripts/send_dynamic_notification_to_all_devices.yaml
# Then edit scripts.yaml to include newly created script file
nano scripts.yaml
# Enter following line in scripts.yaml file, save and exit
script: !include_dir_merge_named custom_scripts/
-------------------------
alias: Outside - Driveway & Front Yard - Frigate Event - Cat / Dog / Person Seen
description: ''
# The trigger is mqtt and will fire whenever an object is detected by YOUR_CAMERA_NAME
trigger:
- platform: mqtt
topic: frigate/events
id: frigate-event
payload: YOUR_CAMERA_NAME
value_template: "{{ value_json['after']['camera'] }}"
variables:
after_zones: "{{ trigger.payload_json['after']['entered_zones'] }}"
before_zones: "{{ trigger.payload_json['before']['entered_zones'] }}"
camera: "{{ trigger.payload_json['after']['camera'] }}"
id: "{{ trigger.payload_json['after']['id'] }}"
label: "{{ trigger.payload_json['after']['label'] }}"
score: "{{ trigger.payload_json['after']['score'] }}"
time_clip_start: "{{ trigger.payload_json['after']['start_time'] - 10.0 }}"
# Conditions must be used to filter out objects / detections that are not of interest
condition:
# This condition is used to ensure that I am only notified of objects that are new or only just entered a zone. This is to avoid getting loads of updated notifications for the same dog in my backyard (as an example).
- condition: or
conditions:
- condition: template
value_template: "{{ trigger.payload_json['type'] == 'new' }}"
- condition: template
value_template: "{{ before_zones | length == 0 }}"
# This ensures that the object at least has one zone, this can be removed if you don't care about zones
- condition: template
value_template: '{{ trigger.payload_json["after"]["entered_zones"]|length > 0 }}'
# This specifically checks for the object to be in the driveway or front_yard zone. This can be removed or those names changed to fit your use case.
for example:
- condition: template
value_template: >-
{{ ["driveway", "front_yard"] | select("in",
after_zones) | list | length > 0 }}
alias: Object is in Driveway or Front Yard
# This filters out any car objects as I have a separate automation with different behavior for car. This can be removed if not applicable to your use case.
- condition: template
value_template: '{{ trigger.payload_json["after"]["label"] != "car" }}'
action:
- choose:
- conditions:
- condition: trigger
id: frigate-event
sequence:
# Send the initial notification with snapshot and info.
- service: script.send_dynamic_notification_to_all_devices
data:
id: "{{ id }}"
title: >-
{{ label }} was
detected on {{ camera |
replace("_", " ") | title }}
message: >-
{{ label }} detected in
the {{ after_zones[0] |
replace("_", " ") | title }}
notifTag: "{{ id }}"
notifIcon: mdi:doorbell-video
group: >-
frigate-notification-{{ camera }}
importance: max
image: >-
/api/frigate/notifications/{{ id }}/snapshot.jpg
clickAction: ''
# Wait until the end of the notification has occurred.
- repeat:
until:
- condition: template
value_template: '{{ wait.trigger.payload_json["type"] == "end" }}'
sequence:
- wait_for_trigger:
- platform: mqtt
topic: frigate/events
payload: "{{ trigger.payload_json[\"after\"][\"id\"] }}"
value_template: "{{ value_json[\"after\"][\"id\"] }}"
continue_on_timeout: false
timeout: '00:02:00'
- condition: template
value_template: '{{ wait.trigger.payload_json[''type''] == ''end'' }}'
- service: script.send_dynamic_notification_to_all_devices
data:
id: '{{ id }}'
# Uses double take for title and message to include face info if a match is detected.
title: >-
{% if (wait.trigger.payload_json["after"]["sub_label"] !=
None) -%} {{ (wait.trigger.payload_json["after"]["sub_label"])
| title }} {%- else -%} {{ label | replace("_", " ") | title
}} {%- endif %} was detected in the {{ after_zones[0] |
replace("_", " ") | title }}
message: Detected with {{ int(score | round(2) * 100) }}% confidence
notifTag: '{{ id }}'
notifIcon: mdi:doorbell-video
group: >-
frigate-notification-{{
trigger.payload_json["after"]["camera"] }}
importance: default
image: >-
/api/frigate/notifications/{{ id }}/snapshot.jpg
video: >-
HASS_URL_BASE/api/{{id}}/{{camera}}/clip.mp4
clickAction: >-
http://HASS_URL_BASE/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4
default: []
mode: parallel
max: 10

View File

@ -0,0 +1,106 @@
alias: Outside - Driveway & Front Yard - Frigate Event - Cat / Dog / Person Seen
description: ''
# The trigger is mqtt and will fire whenever an object is detected by YOUR_CAMERA_NAME
trigger:
- platform: mqtt
topic: frigate/events
id: frigate-event
payload: YOUR_CAMERA_NAME
value_template: "{{ value_json['after']['camera'] }}"
variables:
after_zones: "{{ trigger.payload_json['after']['entered_zones'] }}"
before_zones: "{{ trigger.payload_json['before']['entered_zones'] }}"
camera: "{{ trigger.payload_json['after']['camera'] }}"
id: "{{ trigger.payload_json['after']['id'] }}"
label: "{{ trigger.payload_json['after']['label'] }}"
score: "{{ trigger.payload_json['after']['score'] }}"
time_clip_start: "{{ trigger.payload_json['after']['start_time'] - 10.0 }}"
# Conditions must be used to filter out objects / detections that are not of interest
condition:
# This condition is used to ensure that I am only notified of objects that are new or only just entered a zone. This is to avoid getting loads of updated notifications for the same dog in my backyard (as an example).
- condition: or
conditions:
- condition: template
value_template: "{{ trigger.payload_json['type'] == 'new' }}"
- condition: template
value_template: "{{ before_zones | length == 0 }}"
# This ensures that the object at least has one zone, this can be removed if you don't care about zones
- condition: template
value_template: '{{ trigger.payload_json["after"]["entered_zones"]|length > 0 }}'
# This specifically checks for the object to be in the driveway or front_yard zone. This can be removed or those names changed to fit your use case.
for example:
- condition: template
value_template: >-
{{ ["driveway", "front_yard"] | select("in",
after_zones) | list | length > 0 }}
alias: Object is in Driveway or Front Yard
# This filters out any car objects as I have a separate automation with different behavior for car. This can be removed if not applicable to your use case.
- condition: template
value_template: '{{ trigger.payload_json["after"]["label"] != "car" }}'
action:
- choose:
- conditions:
- condition: trigger
id: frigate-event
sequence:
# Send the initial notification with snapshot and info.
- service: script.send_dynamic_notification_to_all_devices
data:
id: "{{ id }}"
title: >-
{{ label }} was
detected on {{ camera |
replace("_", " ") | title }}
message: >-
{{ label }} detected in
the {{ after_zones[0] |
replace("_", " ") | title }}
notifTag: "{{ id }}"
notifIcon: mdi:doorbell-video
group: >-
frigate-notification-{{ camera }}
importance: max
image: >-
/api/frigate/notifications/{{ id }}/snapshot.jpg
clickAction: ''
# Wait until the end of the notification has occurred.
- repeat:
until:
- condition: template
value_template: '{{ wait.trigger.payload_json["type"] == "end" }}'
sequence:
- wait_for_trigger:
- platform: mqtt
topic: frigate/events
payload: "{{ trigger.payload_json[\"after\"][\"id\"] }}"
value_template: "{{ value_json[\"after\"][\"id\"] }}"
continue_on_timeout: false
timeout: '00:02:00'
- condition: template
value_template: '{{ wait.trigger.payload_json[''type''] == ''end'' }}'
- service: script.send_dynamic_notification_to_all_devices
data:
id: '{{ id }}'
# Uses double take for title and message to include face info if a match is detected.
title: >-
{% if (wait.trigger.payload_json["after"]["sub_label"] !=
None) -%} {{ (wait.trigger.payload_json["after"]["sub_label"])
| title }} {%- else -%} {{ label | replace("_", " ") | title
}} {%- endif %} was detected in the {{ after_zones[0] |
replace("_", " ") | title }}
message: Detected with {{ int(score | round(2) * 100) }}% confidence
notifTag: '{{ id }}'
notifIcon: mdi:doorbell-video
group: >-
frigate-notification-{{
trigger.payload_json["after"]["camera"] }}
importance: default
image: >-
/api/frigate/notifications/{{ id }}/snapshot.jpg
video: >-
HASS_URL_BASE/api/{{id}}/{{camera}}/clip.mp4
clickAction: >-
http://HASS_URL_BASE/api/frigate/notifications/{{id}}/{{camera}}/clip.mp4
default: []
mode: parallel
max: 10

View File

@ -63,6 +63,16 @@ cp -pr /mnt/stpool1/apps/mosquitto/* /mnt/SSD1/docker/data/mosquitto/config/conf
chown -R mosquitt:mosquitt /mnt/SSD1/docker/data/mosquitto/ chown -R mosquitt:mosquitt /mnt/SSD1/docker/data/mosquitto/
chmod -R 700 /mnt/SSD1/docker/data/mosquitto/ chmod -R 700 /mnt/SSD1/docker/data/mosquitto/
Creating mosquitto user
-----------------------
# start mosquitto app with Dockge or issuing "docker compose up -d" in stacks/mosquitto folder
# open shell on mosquitto
docker exec -it mosquitto-mosquitto-1 sh
# enter following line in mosquitto app shell, replacing <username> with the appropriate mosquitto username
mosquitto_passwd -c /mosquitto/config/password.txt <username>
# enter and confirm the password
# exit mosquitto shell
Test mosquitto Test mosquitto
-------------- --------------
# TODO # TODO

View File

@ -28,7 +28,7 @@ services:
# tcp services # tcp services
# ------------- # -------------
- "traefik.tcp.services.${APPLICATION_NAME}-svc.loadbalancer.server.port=${SERVICE_PORT}" - "traefik.tcp.services.${APPLICATION_NAME}-svc.loadbalancer.server.port=${SERVICE_PORT}"
- "traefik.tcp.services.${APPLICATION_NAME}-secure-svc.loadbalancer.server.port=${SECURE_SERVICE_PORT}" #- "traefik.tcp.services.${APPLICATION_NAME}-secure-svc.loadbalancer.server.port=${SECURE_SERVICE_PORT}"
# #
# tcp routers # tcp routers
# ------------ # ------------
@ -48,6 +48,7 @@ services:
# passthrough tls # passthrough tls
- "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.tls.passthrough=true" - "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.tls.passthrough=true"
# generate certificates using following certresolver # generate certificates using following certresolver
- "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.tls.certresolver=sthomeresolver" - "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.tls.certresolver=solver-dns"
# assign svc target to routers # assign svc target to routers
- "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.service=${APPLICATION_NAME}-secure-svc" #- "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.service=${APPLICATION_NAME}-secure-svc"
- "traefik.tcp.routers.${APPLICATION_NAME}-secure-rtr.service=${APPLICATION_NAME}-svc" # use same svc as non-secure router to avoid issues with certificates on mosquitto

View File

@ -70,6 +70,10 @@ services:
published: "8883" published: "8883"
protocol: tcp protocol: tcp
mode: host mode: host
- target: 9001 # mosquitto websocket port
published: "9001"
protocol: tcp
mode: host
- target: 19132 # minecraft-bedrock port - target: 19132 # minecraft-bedrock port
published: "19132" published: "19132"
protocol: udp protocol: udp

View File

@ -52,45 +52,30 @@ entryPoints:
- "10.0.0.0/24" - "10.0.0.0/24"
- "192.168.2.0/24" - "192.168.2.0/24"
- "172.16.0.0/12" - "172.16.0.0/12"
wireguard: wireguard:
address: ":51820/udp" address: ":51820/udp"
plex: plex:
address: ":32400" address: ":32400"
http:
redirections:
entrypoint:
to: websecure
scheme: https
metrics: metrics:
address: ":8082" address: ":8082"
ping: ping:
address: ":8083" address: ":8083"
mariadb: mariadb:
address: ":8306" address: ":8306"
mysql: mysql:
address: ":9306" address: ":9306"
mqtt: mqtt:
address: ":1883" address: ":1883"
mqttsecure: mqttsecure:
address: ":8883" address: ":8883"
mqttwebsocket:
address: ":9001"
mc-bedrock: mc-bedrock:
address: ":19132/udp" address: ":19132/udp"
mc-java: mc-java:
address: ":25565/udp" address: ":25565/udp"
mc-java-rcon: mc-java-rcon:
address: ":25575" address: ":25575"
sftp1: sftp1:
address: ":2022" address: ":2022"
sftp2: sftp2: