keepassxc.md 2.9 KB


title: KeePassXC passwords eleventyNavigation: key: KeePassXC

parent: 🔒 Credentials

New in version 1.9.11 borgmatic supports reading passwords from the KeePassXC password manager. To use this feature, start by creating an entry in your KeePassXC database, putting your password into the "Password" field of that entry and making sure it's saved.

Then, you can consume that password in your borgmatic configuration file. For instance, if the entry's title is "borgmatic" and your KeePassXC database is located at /etc/keys.kdbx, do this:

encryption_passphrase: "{credential keepassxc /etc/keys.kdbx borgmatic}"

But if the entry's title is multiple words like borg pw, you'll need to quote it:

encryption_passphrase: "{credential keepassxc /etc/keys.kdbx 'borg pw'}"

With this in place, borgmatic runs the keepassxc-cli command to retrieve the passphrase on demand. But note that keepassxc-cli will prompt for its own passphrase in order to unlock its database, so be prepared to enter it when running borgmatic.

The {credential ...} syntax works for several different options in a borgmatic configuration file besides just encryption_passphrase. For instance, the username, password, and API token options within database and monitoring hooks support {credential ...}:

postgresql_databases:
    - name: invoices
      username: postgres
      password: "{credential keepassxc /etc/keys.kdbx database}"

Custom command

You can also optionally override the keepassxc-cli command that borgmatic calls to load passwords:

keepassxc:
    keepassxc_cli_command: /usr/local/bin/keepassxc-cli

Another example:

keepassxc:
    keepassxc_cli_command: docker exec keepassxc keepassxc-cli

Key file

KeePassXC supports unlocking a database with a separate key file instead of or in addition to a password. To configure borgmatic for that, use the key_file option:

keepassxc:
    key_file: /path/to/keyfile

By default, keepassxc-cli prompts the user for the password to unlock a database. But if you only want to provide a key file to unlock your database and not a password, for instance to support unattended backups, use the ask_for_password option:

keepassxc:
    ask_for_password: false
    key_file: /path/to/keyfile

YubiKey

KeePassXC also supports unlocking a database with the help of a YubiKey. To configure borgmatic for that, use the yubikey option:

keepassxc:
    yubikey: 1:7370001

The value here is the YubiKey slot number (e.g., 1 or 2) and optional serial number (e.g., 7370001) used to access the KeePassXC database. Join the two values with a colon, but omit the colon if you're leaving out the serial number.