Services#
Services are the core of Auto Backup, they are the only methods that cause Auto Backup to do anything.
auto_backup.backup
#
Create a full or partial backup.
This is the primary method and includes the functionality of the backup_full
and backup_partial
services.
Parameter | Description | Type | Example |
---|---|---|---|
name |
Optional name, defaults to the current date and time. | string |
Automatic Backup {{ now().strftime('%Y-%m-%d') }} |
include_addons |
List of addons to include in the backup (name or slug). Wildcards supported for slugs. | list |
["Almond", "glances", "core_mariadb", "core_*"] |
include_folders |
List of folders to include in the backup. | list |
["Local add-ons", "homeassistant", "share"] |
exclude_addons |
List of addons to exclude from the backup (name or slug). Wildcards supported for slugs. | list |
["Almond", "glances", "core_mariadb", "core_*"] |
exclude_folders |
List of folders to exclude from the backup. | list |
["Local add-ons", "homeassistant", "share"] |
encrypted |
Encrypt backups with the default encryption key found in backup settings (default: false) | bool |
true |
password |
Optional custom password to encrypt the backup with. | string |
1234 |
keep_days |
The number of days to keep the backup. | float |
2 |
location |
Name of a backup network storage to put backup (or /backup) | string |
my_backup_mount |
download_path |
Locations to download the backup to after creation. | list |
["/usb_drive"] |
compressed |
Use compressed archives (default: true) | bool |
true |
Create a full backup
service: auto_backup.backup
data:
name: "Full Backup"
keep_days: 2
Create a partial backup
service: auto_backup.backup
data:
name: "Partial Backup"
include_folders:
- config
keep_days: 2
Create an empty partial backup
service: auto_backup.backup
data:
name: "Partial Backup"
include: {}
keep_days: 2
Alternate include/exclude config
service: auto_backup.backup
data:
name: "Partial Backup"
include:
addons: [...]
folders: [...]
exclude:
addons: [...]
folders: [...]
keep_days: 2
Addon and folder names#
Addon names are case-insensitive and can be the addon name/title, these are the same names seen when creating a partial backup through the Supervisor backups page. They can also be the addons slug (slug must be lowercase). You can also use wildcards for matching slugs, such as core_*
to include all core addons.
Folder names are also case-insensitive and use the names seen when creating a partial backup through the Supervisor backups page. Currently, accepted values are (ignoring case):
ssl
share
media
addons
orlocal add-ons
oraddons/local
config
orhome assistant configuration
orhomeassistant
Keep Days#
The keep_days
parameter allows you to specify how long the backup should be kept for before being deleted. Default is forever. You can specify a float value for keep days, e.g. to keep a backup for 12 hours use 0.5
.
Encryption#
By default, all backups created by Auto Backup are unencrypted, if you want to create encrypted backups you can set the encrypted
parameter to true
. If you want to use a custom password for encryption you can set the password
parameter to the desired password. If you do not specify a password, the default encryption key added in Home Assistant 2025.1 will be used. It can be found in Settings → System → Backups → Backup Settings → Configure Backup Settings → Encryption key.
Do note that you have to go through Home Assistant's "Set up backups" flow to view the key, you likely do not want to use their automatic backups if you are using this integration so when it asks you to "Set up automatic backups" select "Custom", then disable "Enable automatic backups" and click "Next", if you have already set up automatic backups you can disable them on the backup settings page.
Custom Locations#
Home Assistant 2023.6 included support for adding custom backup locations, and even changing the default backup location. Auto Backup supports specifying an alternative location using the location
option. Additional backup locations can be added by navigating to Settings → System → Storage, and clicking the Add network storage button.
Download Path#
The download_path
parameter allows you to specify a location or of list of locations to download the backup to after creation. This directory must be accessible from Home Assistant. If you are running in docker your paths will be relative to the container for example your Home Assistant configuration directory is stored under /config
and the share folder is under /share
.
Tip
The backup will still be stored under /backup
and show up on the backups page, it will only be copied/downloaded to the location specified, to immediately delete the backup use a negative value for keep_days
(e.g. keep_days: -1
).
Info
A slugified version of the backups name will be used for the filename, if a file with that name already exists the backups id (slug) will be used instead.
Note
When running on Home Assistant Core backups will be copied not downloaded. When running Home Assistant Supervised integrations do not have direct access to the /backup
folder, which is why the backup is downloaded and not simply copied.
auto_backup.backup_full
#
Create a full backup with optional exclusions.
Parameter | Description | Type | Example |
---|---|---|---|
name |
Optional name, defaults to the current date and time. | string |
Automatic Backup {{ now().strftime('%Y-%m-%d') }} |
exclude |
Addons/Folders to exclude from the backup. | Exclude Object |
{"addons": ["MariaDB"], "folders": ["Local add-ons", "share"]} |
encrypted |
Encrypt backups with the default encryption key found in backup settings (default: false) | bool |
true |
password |
Optional custom password to encrypt the backup with. | string |
1234 |
keep_days |
The number of days to keep the backup. | float |
2 |
location |
Name of a backup network storage to put backup (or /backup) | string |
my_backup_mount |
download_path |
Locations to download the backup to after creation. | list |
["/usb_drive"] |
compressed |
Use compressed archives (default: true) | bool |
true |
Exclude Object#
Parameter | Description | Type | Example |
---|---|---|---|
addons |
List of addons to exclude from the backup (name or slug). | list |
["Almond", "glances", "core_mariadb"] |
folders |
List of folders to exclude from the backup. | list |
["Local add-ons", "homeassistant", "share"] |
auto_backup.backup_partial
#
Create a partial backup.
Parameter | Description | Type | Example |
---|---|---|---|
name |
Optional name, defaults to the current date and time. | string |
Automatic Backup {{ now().strftime('%Y-%m-%d') }} |
addons |
List of addons to backup (name or slug). | list |
["Almond", "glances", "core_mariadb"] |
folders |
List of folders to backup. | list |
["Local add-ons", "homeassistant", "share"] |
encrypted |
Encrypt backups with the default encryption key found in backup settings (default: false) | bool |
true |
password |
Optional custom password to encrypt the backup with. | string |
1234 |
keep_days |
The number of days to keep the backup. | float |
2 |
location |
Name of a backup network storage to put backup (or /backup) | string |
my_backup_mount |
download_path |
Locations to download the backup to after creation. | list |
["/usb_drive"] |
compressed |
Use compressed archives (default: true) | bool |
true |
auto_backup.purge
#
Purge expired backups.
There are no parameters here, just call the service, and it will remove any expired backups.
This service is useful if you want to manually specify when to purge backups, such as doing a batch delete at 12AM.
Info
Expired backups are automatically purged when creating new backups, this can be disabled in the options menu.