Skip to content

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
Partial backup including just the config folder
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 or local add-ons or addons/local
  • config or home assistant configuration or homeassistant

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 SettingsSystemBackupsBackup SettingsConfigure Backup SettingsEncryption 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 SettingsSystemStorage, and clicking the Add network storage button.

Open your Home Assistant instance and show storage information.

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.