Table of Contents
Briefkasten
Überblick
Diese Automatisierung nutzt einen Aqara MCCGQ11LM Tür-/Fenstersensor (über Zigbee2MQTT) zur Überwachung eines Briefkastens. Sie benachrichtigt bei Öffnen (z.B. Posteingang) auf zwei Handys, im Dashboard und als Popup – nur während der Postzeit (8-17 Uhr). Außerhalb dieser Zeit gibt es eine separate Warnung für ungewöhnliche Öffnungen. Zusätzlich trackt sie die Öffnungszeit und Dauer, minimiert Fehlalarme durch Self-Öffnungen und warnt bei langem Offenbleiben (z.B. blockierte Post). Throttling verhindert Spam-Benachrichtigungen.
Voraussetzungen
- Home Assistant mit Zigbee2MQTT-Integration.
- Aqara-Sensor gepairt; Entity-ID:
binary_sensor.briefkasten_contact(State: 'on' = geöffnet, 'off' = geschlossen). - HA Companion App auf zwei Handys für Benachrichtigungen (Services:
notify.mobile_app_dein_handy1undnotify.mobile_app_dein_handy2). - Custom Integration: Browser Mod (über HACS) für Dashboard-Popups.
- Helpers erstellen (Configuration > Helpers):
- Input Datetime:
input_datetime.briefkasten_letztes_oeffnen(für Timestamp). - Input Boolean:
input_boolean.briefkasten_snooze(für manuellen Override). - Input Boolean:
input_boolean.briefkasten_offen_cooldown(für Throttling).
- Sensor für Dauer-Tracking (in
configuration.yaml):
sensor: - platform: history_stats name: Briefkasten offen Dauer entity_id: binary_sensor.briefkasten_contact state: 'on' type: time start: '{{ now().replace(hour=0).replace(minute=0).replace(second=0) }}' end: '{{ now() }}'
Automatisierungen
Alle in automations.yaml oder über den visuellen Editor. Ersetze Entity-IDs bei Bedarf.
Haupt-Automatisierung: Benachrichtigung bei Öffnen (während Postzeit)
Diese Automatisierung erkennt das Öffnen des Briefkastens und überprüft, ob es sich um eine kurze Öffnung handelt (z.B. durch den Postboten), die typisch für den Einwurf von Post ist. Sie triggert nur während der definierten Postzeit (8-17 Uhr), um Fehlalarme außerhalb dieser Stunden zu vermeiden. Zuerst wartet sie auf das Schließen des Briefkastens, berechnet die Öffnungsdauer und sendet Benachrichtigungen nur, wenn die Dauer unter 30 Sekunden liegt (anpassbar). Zusätzlich speichert sie den genauen Öffnungszeitpunkt in einem Helper und benachrichtigt über Handys und Dashboard-Popup. Der Snooze-Helper verhindert Auslösungen bei manueller Deaktivierung. Der Modus 'single' stellt sicher, dass keine doppelten Auslösungen erfolgen.
automation: - id: briefkasten_benachrichtigung alias: Briefkasten geöffnet - Smarte Benachrichtigungen trigger: - platform: state entity_id: binary_sensor.briefkasten_contact from: 'off' to: 'on' condition: - condition: and conditions: - condition: time after: '08:00:00' before: '17:00:00' - condition: state entity_id: input_boolean.briefkasten_snooze state: 'off' action: - wait_for_trigger: - platform: state entity_id: binary_sensor.briefkasten_contact from: 'on' to: 'off' timeout: minutes: 5 continue_on_timeout: false - variables: open_duration: "{{ (now() - trigger.to_state.last_changed).total_seconds() }}" - condition: numeric_state entity_id: "{{ open_duration }}" below: 30 # Sekunden; anpassen für kurze Öffnungen - service: input_datetime.set_datetime target: entity_id: input_datetime.briefkasten_letztes_oeffnen data: datetime: "{{ now() }}" - service: notify.mobile_app_dein_handy1 data: title: "Post ist da!" message: "Briefkasten geöffnet für {{ open_duration }} Sekunden um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }}." - service: notify.mobile_app_dein_handy2 data: title: "Post ist da!" message: "Briefkasten geöffnet für {{ open_duration }} Sekunden um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }}." - service: browser_mod.notification data: title: "Posteingang" message: "Kurze Öffnung ({{ open_duration }} Sek) um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }}." mode: single
Warnung bei Öffnen außerhalb Postzeit
Diese separate Automatisierung dient als Sicherheitsfeature und triggert speziell bei Öffnungen des Briefkastens außerhalb der üblichen Postzeit (vor 8 Uhr oder nach 17 Uhr). Sie ist nützlich, um ungewöhnliche Aktivitäten zu erkennen, z.B. durch Dritte oder vergessene Öffnungen. Die Bedingung verwendet eine OR-Kombination für die Zeiträume, um den gesamten Tag abzudecken. Benachrichtigungen werden sofort gesendet, ohne Dauer-Überprüfung, da solche Ereignisse potenziell kritisch sind. Der Snooze-Helper erlaubt eine temporäre Deaktivierung, und der Modus 'single' verhindert Mehrfach-Benachrichtigungen bei wiederholtem Öffnen.
automation: - id: briefkasten_ausserhalb_postzeit alias: Briefkasten außerhalb Postzeit geöffnet trigger: - platform: state entity_id: binary_sensor.briefkasten_contact from: 'off' to: 'on' condition: - condition: or conditions: - condition: time after: '17:00:00' before: '23:59:59' - condition: time after: '00:00:00' before: '08:00:00' - condition: state entity_id: input_boolean.briefkasten_snooze state: 'off' action: - service: notify.mobile_app_dein_handy1 data: title: "Warnung: Briefkasten geöffnet!" message: "Briefkasten außerhalb Postzeit geöffnet um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }}." - service: notify.mobile_app_dein_handy2 data: title: "Warnung: Briefkasten geöffnet!" message: "Briefkasten außerhalb Postzeit geöffnet um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }}." - service: browser_mod.notification data: title: "Warnung: Außerhalb Postzeit" message: "Briefkasten geöffnet um {{ now().strftime('%H:%M Uhr am %d.%m.%Y') }} – Überprüfen?" duration: 60 mode: single
Warnung bei langem Offenbleiben
Diese Automatisierung überwacht, ob der Briefkasten länger als 5 Minuten (anpassbar) geöffnet bleibt, was oft auf blockierte Post oder einen nicht richtig geschlossenen Deckel hinweist. Der Trigger wartet explizit auf die Dauer, bevor er auslöst, um kurze Öffnungen zu ignorieren. Die Benachrichtigung enthält die genaue Dauer seit dem Öffnen, berechnet dynamisch. Throttling wird durch den Cooldown-Helper umgesetzt, der nach Auslösung aktiviert wird und Benachrichtigungen für eine Stunde blockiert. Der Modus 'restart' sorgt dafür, dass bei anhaltendem Offenbleiben keine Spam-Nachrichten entstehen, sondern der Timer neu gestartet wird.
automation: - id: briefkasten_offen_warnung alias: Briefkasten steht offen - Warnung trigger: - platform: state entity_id: binary_sensor.briefkasten_contact to: 'on' for: minutes: 5 condition: - condition: state entity_id: input_boolean.briefkasten_offen_cooldown state: 'off' action: - service: notify.mobile_app_dein_handy1 data: title: "Briefkasten steht offen!" message: "Der Briefkasten ist seit {{ (now() - states.binary_sensor.briefkasten_contact.last_changed).total_seconds() | int // 60 }} Minuten offen. Vielleicht blockiert Post? (Stand: {{ now().strftime('%H:%M Uhr') }})" - service: notify.mobile_app_dein_handy2 data: title: "Briefkasten steht offen!" message: "Der Briefkasten ist seit {{ (now() - states.binary_sensor.briefkasten_contact.last_changed).total_seconds() | int // 60 }} Minuten offen. Vielleicht blockiert Post? (Stand: {{ now().strftime('%H:%M Uhr') }})" - service: browser_mod.notification data: title: "Warnung: Briefkasten offen" message: "Offen seit {{ (now() - states.binary_sensor.briefkasten_contact.last_changed).total_seconds() | int // 60 }} Min. – Überprüfen?" duration: 60 - service: input_boolean.turn_on target: entity_id: input_boolean.briefkasten_offen_cooldown mode: restart
Snooze-Reset
Diese Hilfsautomatisierung setzt den Snooze-Helper automatisch zurück, nachdem er 10 Minuten aktiviert war. Sie triggert auf den 'on'-Zustand des Booleans und wartet die Dauer ab, bevor sie ihn deaktiviert. Das ermöglicht eine temporäre Unterdrückung von Benachrichtigungen (z.B. bei eigener Nutzung des Briefkastens), ohne dass man manuell eingreifen muss. Sie betrifft alle Automatisierungen, die den Snooze prüfen, und sorgt für eine nahtlose Wiederaktivierung des Systems.
automation: - id: briefkasten_snooze_reset alias: Briefkasten Snooze zurücksetzen trigger: - platform: state entity_id: input_boolean.briefkasten_snooze to: 'on' for: minutes: 10 action: - service: input_boolean.turn_off target: entity_id: input_boolean.briefkasten_snooze
Cooldown-Reset für Offen-Warnung
Ähnlich wie der Snooze-Reset, aber speziell für den Cooldown der Offen-Warnung. Sie triggert nach 1 Stunde auf den 'on'-Zustand des Booleans und setzt ihn zurück. Das implementiert Throttling, um zu verhindern, dass bei dauerhaftem Offenbleiben stündlich Benachrichtigungen gesendet werden. Es hält das System effizient und vermeidet Überflutung mit redundanten Warnungen.
automation: - id: briefkasten_offen_cooldown_reset alias: Offen-Warnung Cooldown zurücksetzen trigger: - platform: state entity_id: input_boolean.briefkasten_offen_cooldown to: 'on' for: hours: 1 action: - service: input_boolean.turn_off target: entity_id: input_boolean.briefkasten_offen_cooldown
Dashboard-Integration
- Entities Card für Sensor-Status.
- Markdown Card für Timestamp:
Letztes Öffnen: states_input_datetime.briefkasten_letztes_oeffnen - Gauge Card für Dauer:
sensor.briefkasten_offen_dauer - Button für Snooze: Toggle
input_boolean.briefkasten_snooze - Conditional Card für Warnung:
Briefkasten: offen_blockiert
Tipps und Anpassungen
- Teste mit Developer Tools > States/Services.
- Passe Dauern (z.B. 30 Sek, 5 Min) an dein Verhalten an.
- Die Postzeit (8-17 Uhr) ist in den Conditions integriert; bei Bedarf erweitern (z.B. Wochentage mit
condition: time weekday). - Erweiterbar mit Kamera oder Vibration-Sensor für bessere Genauigkeit.
Diese Setup minimiert Fehlalarme und trackt alles Elegante.
