Skip to main content

Send borg backup updates over MQTT

Project description

Borg -> MQTT

Send borgbackup updates over MQTT, including support for Home Assistant MQTT autodiscovery. Sensors include

  • Total/unique chunks
  • (Un)compressed size
  • Depuplicated (Un)compressed size
  • Total number of backups
  • Most recent backup

Installation

Install on any system as python library using

pip install borg2mqtt

Whatever system it is installed on will need the ssh keys for your backup locations.

Configuration

borg2mqtt reads MQTT and repository information from a configuration yaml file. An example configuration file can be generated by running

borg2mqtt -c path/config.yml generate

If portion path/config.yml is left off, borg2mqtt defaults to saving/looking for the configuration file at $HOME/.config/borg2mqtt/config.yml.

The configuration file is mostly self-explanatory and looks as follows:

# -------------- Sample configuration file -------------- #
# These are the default MQTT values - none are required
mqtt:
  host: localhost
  port: 1883
  user: ""
  password: ""

# Put in as many repositories as desired
repos:
    # Required
  - repo: user@address:/path/to/backup
    # Optional, defaults to the same as repo if not specified
    # This will be used to make entity_ids in HA
    name: Local Data
    # Optional
    key: ""
    # Optional, will use the given ssh command
    # Can be used to authenticate with a ssh key (ssh -i /path-to-key)
    rsh: ""
    # Optional, choose one of kB, MB, GB, TB. Defaults to GB.
    units: GB

Usage

To send the Home Assistant MQTT auto-discovery message, run

borg2mqtt setup

Then to update sensor information run

borg2mqtt update

This can be included in a cron job, borgmatic, etc to send updates as needed. As this is a "local push" option, it should be more efficient than any local polling option that could be included in Home Assistant.

Additionally, a single repository can be updated through it's name found in the configuration file by

borg2mqtt update -n "My Repo"

Additional Options

All options can always be shown by using flag --help. Additionally, varying levels of verbose output can be included through -vvv, put before the command type.

Contributing

All pull requests are more than welcome. Please usse the pre-commit hooks to verify your code before making a pull request. If any bugs are found, feel free to open an issue with your verbose output (-vvv) included.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

borg2mqtt-0.2.1.tar.gz (146.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

borg2mqtt-0.2.1-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file borg2mqtt-0.2.1.tar.gz.

File metadata

  • Download URL: borg2mqtt-0.2.1.tar.gz
  • Upload date:
  • Size: 146.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for borg2mqtt-0.2.1.tar.gz
Algorithm Hash digest
SHA256 7e23b68f96cef5820012a2c6fbefed70f24416e59168915e2c80bf6e803e69bf
MD5 8c2fa4aa7a1705ac3d9c3c7c1b1c5895
BLAKE2b-256 904d11ce8c9a4f8cad212bb65c3ba4c5b5af60fa2cf50e023e9eed9365a7128f

See more details on using hashes here.

Provenance

The following attestation bundles were made for borg2mqtt-0.2.1.tar.gz:

Publisher: on_main.yml on contagon/borg2mqtt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file borg2mqtt-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: borg2mqtt-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 8.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for borg2mqtt-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6fb011124da829068547080b4718a09516ce6ab15aaf0c7c493901bd1e0788e0
MD5 916ed9415a745b3513c1a8da5b6ee0fd
BLAKE2b-256 beea7c8db2b43d9ddcc84a2219e15936e7bd49ff57f6ac6d5867357be98cf47d

See more details on using hashes here.

Provenance

The following attestation bundles were made for borg2mqtt-0.2.1-py3-none-any.whl:

Publisher: on_main.yml on contagon/borg2mqtt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page