State
The State trigger is useful when you want an automation to react to a change in an entity or one of its attributes. Use it when you care about a device turning on or off, a door opening or closing, or a person arriving home.
Using this trigger from the user interface
If you prefer building automations visually, Home Assistant walks you through this trigger step by step. You pick what to watch, tweak a few options, and save. No YAML knowledge required.
To use this trigger in an automation:
- Go to Settings > Automations & scenes.
- Open an existing automation, or select Create automation > Create new automation.
- In the When section, select Add trigger.
- Select the type of trigger to add.
- Select State.
- In Entity, select the entity whose state Home Assistant should watch.
- Optional: In Attribute, select an attribute instead of the main state.
- Optional: In From and To, limit which changes should match.
- Optional: In For, enter how long the new state must last before the trigger fires.
- Select Save.
Options in the UI
Using this trigger in YAML
If you work directly in YAML, or you want to know exactly what Home Assistant does under the hood, this section has the technical reference. It lists the field names you use in YAML, their types, and which ones are required.
In YAML, use trigger: state. A basic example looks like this:
trigger: state
entity_id: binary_sensor.front_door
to: "on"
This runs when the front door changes to on.
Options in YAML
Optional starting state to exclude. You can use one state or a list of states. YAML only.
If you want to trigger on all state changes but ignore attribute-only changes, set one of from, to, not_from, or not_to to an empty value in YAML.
In YAML, from, to, not_from, and not_to each accept either one state or a list of states.
Targets of the trigger
This trigger watches one or more entities selected by entity_id.
- Use a single
entity_idto watch one entity. - Use a list of
entity_idvalues in YAML to watch more than one entity.
Good to know
- If you do not set From or To, this trigger fires on all state changes. It also fires when only an attribute changes.
- If you set From, To,
not_from, ornot_to, attribute-only changes do not fire the trigger. - You cannot combine
fromwithnot_from, ortowithnot_to. - If you use
for, the timer resets if Home Assistant restarts or automations reload.
Try it yourself
Ready to test this? Go to Settings > Automations & scenes, create a new automation, and add this trigger. Save the automation, then change the state of the targeted entity to watch the trigger fire on your actual entitiesAn entity represents a sensor, actor, or function in Home Assistant. Entities are used to monitor physical properties or to control other entities. An entity is usually part of a device or a service. [Learn more].
More examples
Real scenarios where this trigger fires in automations and scripts. Copy any example and adapt it to your setup.
You don’t need to edit YAML to use these examples. Copy a YAML snippet from this page, open the automation editor in Home Assistant, and press Ctrl+V (or Cmd+V on Mac). Home Assistant automatically converts the pasted YAML into the visual editor format, whether it’s a full automation, a single trigger, a condition, or an action.
Automation: send a reminder when a door stays open for 5 minutes
If a door stays open longer than expected, this automation sends a message to your phone.
-
Trigger: State
-
Entity: Back door sensor (
binary_sensor.back_door) -
To:
on - For: 5 minutes
-
Entity: Back door sensor (
-
Action: Send a notification message
-
Target: My Device (
notify.my_device)
-
Target: My Device (
YAML example for a door-left-open reminder
alias: "Remind me when the back door stays open"
triggers:
- trigger: state
entity_id: binary_sensor.back_door
to: "on"
for: "00:05:00"
actions:
- action: notify.send_message
target:
entity_id: notify.my_device
data:
message: "The back door has been open for 5 minutes."
Automation: send a notification when someone arrives home
If you want a message when a person arrives, this automation watches for a state change to home.
-
Trigger: State
-
Entity: Person entity (
person.sam) -
To:
home
-
Entity: Person entity (
-
Action: Send a notification message
-
Target: My Device (
notify.my_device)
-
Target: My Device (
YAML example for an arrival notification
alias: "Notify me when Sam arrives home"
triggers:
- trigger: state
entity_id: person.sam
to: "home"
actions:
- action: notify.send_message
target:
entity_id: notify.my_device
data:
message: "Sam has arrived home."
Still stuck?
The Home Assistant community is quick to help: join Discord for real-time chat, post on the community forum with the trigger you’re using and what you expected to happen, or share on our subreddit /r/homeassistant.
AI assistants like ChatGPT or Claude can also explain triggers or suggest the right one when you describe what you want in plain language.
Related triggers
These triggers work well alongside this one:
-
Numeric state: Triggers when a numeric value crosses a threshold.
-
Time: Triggers at a specific time, or from a date/time helper or timestamp-style sensor.