Require a value is defined: is_defined

The is_defined filter checks that a value is not undefined and forces a template error if it is. If the value is defined, it passes through unchanged. This is a safety mechanism to catch typos and missing variables early rather than having them silently produce empty strings.

By default, Home Assistant is configured to be lenient with undefined variables, meaning a misspelled variable name produces an empty string instead of an error. While this is convenient for smaller templatesA template is an automation definition that can include variables for the action or data from the trigger values. This allows automations to generate dynamic actions. [Learn more], it can make debugging very difficult. If you write {{ sensr.temperature }} instead of {{ sensor.temperature }}, you get a blank value with no indication that anything is wrong. The is_defined filter lets you opt in to strict checking for specific variables, so you get an immediate error that points to the problem.

Usage

Here’s how to use this template function. Copy any example and adjust it to your setup.

As a filter
{{ my_variable | is_defined }}
Result (anyA flexible type that can be a string, number, list, or any other type. Used when a function or filter works with multiple types, and the actual result depends on what you pass in.)
the value of my_variable

Function signature

The signature is a technical summary of this template function. It shows the name of the function, the values (called parameters) it accepts, and what type of data each parameter expects (for example, a piece of text or a number).

Function parameters that have a = with a value after them are optional. If you leave them out, the default value shown is used automatically. Function parameters without a default are required.

is_defined(
    value: Any,
) -> Any

Function parameters

The following parameters can be provided to this filter.

value any Required

The value to check. If the value is an Undefined object, an error is raised. Otherwise, the value is returned unchanged.

How it works

When you reference a variable that does not exist in a template, it becomes an Undefined object. Normally, this silently renders as an empty string. The is_defined filter detects this and raises an error instead, making the problem visible.

TemplateA template is an automation definition that can include variables for the action or data from the trigger values. This allows automations to generate dynamic actions. [Learn more]: Raises an error if my_var does not exist
{{ my_var | is_defined }}

Tip

This filter is most useful in scriptsScripts are components that allow you to specify a sequence of actions to be executed by Home Assistant when turned on. [Learn more] and automationsAutomations in Home Assistant allow you to automatically respond to things that happen in and around your home. [Learn more] where variables are passed in from outside. It helps you catch cases where a required variable was not provided.

Good to know

  • This raises an error on undefined input, which is the opposite of most filters. Use it intentionally to enforce a variable’s presence.
  • A value set to None is considered defined and passes through without error.

Try it yourself

Ready to test this? Open Developer tools > Template, paste the example into the Template editor, and watch the result update on the right. Edit the values to see how the function adapts to your own 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 function comes up in automations and templates. Copy any example and adapt it to your setup.

Validate a script variable

Ensure that a required variable was passed into a scriptScripts are components that allow you to specify a sequence of actions to be executed by Home Assistant when turned on. [Learn more] before using it.

ActionActions are used in several places in Home Assistant. As part of a script or automation, actions define what is going to happen once a trigger is activated. In scripts, an action is called *sequence*. [Learn more]
action:
  - action: notify.mobile
    data:
      message: >
        Reminder: {{ message | is_defined }}

If the message variable was not provided when calling the script, this raises a clear error instead of sending an empty notification.

Guard multiple variables

Apply is_defined to each variable you depend on at the start of a template.

TemplateA template is an automation definition that can include variables for the action or data from the trigger values. This allows automations to generate dynamic actions. [Learn more]
{% set name = target_name | is_defined %}
{% set room = target_room | is_defined %}
{{ name }} is in the {{ room }}
Result (stringA piece of text, like a name, message, or entity ID. In templates, wrap strings in quotes, like "living_room" or "lights are on".)
Alice is in the Kitchen

Still stuck?

The Home Assistant community is quick to help: join Discord for real-time chat, post on the community forum with your template and expected result, or share on our subreddit /r/homeassistant.

Tip

AI assistants like ChatGPT or Claude can also explain or fix templates when you describe what you want in plain language.

Related template functions

These functions work well alongside this one: