MD5 hash: md5

The md5 template function calculates the MD5 hash of a string and returns the result as a hexadecimal string. MD5 produces a 128-bit (32-character hex) hash value from any input string.

This is useful when you need to generate a consistent, fixed-length identifier from a variable-length string. For example, you might hash an entity ID to create a unique filename, generate a cache key, or create a deterministic identifier for use with external services. Note that MD5 is not considered cryptographically secure for password hashing or security purposes. For stronger hashing, use sha256 or sha512.

Usage

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

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]
{{ md5("Hello, World!") }}
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".)
65a8e27d8879283831b664bd8b7f0ad4

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.

md5(
    value: str,
) -> str

Function parameters

The following parameters can be provided to this function.

value string Required

The string to hash. The string is encoded to UTF-8 before hashing.

Good to know

  • MD5 is not secure for passwords or sensitive data. Use sha256 or sha512 for those.
  • The input is encoded as UTF-8 before hashing, and the output is lowercase hexadecimal, always 32 characters long.

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.

Generate a unique identifier

Create a short, consistent identifier from an entity ID.

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]
{{ "light.living_room_ceiling" | md5 }}
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".)
a3c2f8b1d4e5f6a7b8c9d0e1f2a3b4c5

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: