Package Search Help

You can use boolean logic (e.g. AND/OR/NOT) for complex search queries. For more help and examples, see the search documentation.

Search by package name:
my-package (implicit)
name:my-package (explicit)

Search by package filename:
filename:my-package.ext 

Search by package tag:
tag:latest 

Search by package version:
version:1.0.0  prerelease:true (prereleases)
prerelease:false (no prereleases)

Search by package architecture:
architecture:x86_64 

Search by package distribution:
distribution:el 

Search by package license:
license:MIT 

Search by package format:
format:deb 

Search by package status:
status:in_progress 

Search by package file checksum:
checksum:5afba 

Search by package security status:
severity:critical 

Search by package vulnerabilities:
vulnerabilities:>1 
vulnerabilities:<1000 

Search by # of package downloads:
downloads:>8 
downloads:<100 

Search by package type:
type:binary 
type:source 

Search by package size (bytes):
size:>50000 
size:<10000 

Search by dependency name/version:
dependency:log4j 
dependency:log4j=1.0.0 
dependency:log4j>1.0.0 

Search by uploaded date:
uploaded:>"1 day ago" 
uploaded:<"August 14, 2022 EST" 

Search by entitlement token (identifier):
entitlement:3lKPVJPosCsY 

Search by policy violation:
policy_violated:true
deny_policy_violated:true
license_policy_violated:true
vulnerability_policy_violated:true

Search by repository:
repository:repo-name

Search by last download date:
last_downloaded:<"30 days ago" 
last_downloaded:>"August 14, 2022 EST" 

Search queries for all Debian-specific (and related) package types

Search by component:
deb_component:unstable

Search queries for all Maven-specific (and related) package types

Search by group ID:
maven_group_id:org.apache

Search queries for all Docker-specific (and related) package types

Search by image digest:
docker_image_digest:sha256:7c5..6d4
(full hashref only)

Search by layer digest:
docker_layer_digest:sha256:4c4..ae4
(full hashref only)

Search queries for all Generic-specific package types

Search by file path:
generic_filepath:path/to/file.txt

Search by directory:
generic_directory:path/to

Field type modifiers (depending on the type, you can influence behaviour)

For all queries, you can use:
~foo for negation

For string queries, you can use:
^foo to anchor to start of term
foo$ to anchor to end of term
foo*bar for fuzzy matching

For number/date or version queries, you can use:
>foo for values greater than
>=foo for values greater / equal
<foo for values less than
<=foo for values less / equal

Need a secure and centralised artifact repository to deliver Alpine, Cargo, CocoaPods, Composer, Conan, Conda, CRAN, Dart, Debian, Docker, Generic, Go, Helm, Hex, HuggingFace, LuaRocks, Maven, MCP, npm, NuGet, P2, Python, RedHat, Ruby, Swift, Terraform, Vagrant, VSX, Raw & More packages?

Cloudsmith is the new standard in Package / Artifact Management and Software Distribution.

With support for all major package formats, you can trust us to manage your software supply chain.

Start My Free Trial

Python logo butter-backup  3.5.1

One-liner (summary)

Vollverschlüsselte, pseudoinkrementelle Sicherungskopien leicht gemacht

Description

[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black) [![Imports: isort](https://img.shields.io/badge/%20imports-isort-%231674b1?style=flat&labelColor=ef8336)](https://pycqa.github.io/isort/) [![Checked with mypy](http://www.mypy-lang.org/static/mypy_badge.svg)](http://mypy-lang.org/) [![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](http://www.gnu.org/licenses/gpl-3.0)

<img src="logo.png" alt="ButterBackup-Logo" height="150px" align="right">

# ButterBackup - Backups so geschmeidig wie Butter!

Inkrementelle Vollbackups dank BtrFS

## Installation

poetry build pipx install dist/butter-backup-<version>.whl

## Benutzung

[![asciicast](https://asciinema.org/a/HTFzRxEWw8ltCoP6NDNo6tITP.svg)](https://asciinema.org/a/HTFzRxEWw8ltCoP6NDNo6tITP)

## Gefährdungsszenario

ButterBackup wurde entworfen, um gegen eine Reihe spezieller Gefährdungsszenarien zu schützen. Die konkreten Bedrohungen und die entsprechenden Gegenmaßnahmen gibt die folgende Tabelle an. Auf die Übersichtstabelle folgt eine etwas ausführlichere Diskussion der Maßnahmen.

Bedrohung | Gegenmaßnahme |
-------------------------------------------------- | ------------------------------------ |
Dateien verschlüsselnde Schadsoftware | physikalisch getrennte Aufbewahrung |
fehlerhafte Sicherungskopien durch Fehlbenutzung | sehr einfache Benutzung |
Verlust des Datenträgers | Vollverschlüsselung des Datenträgers |
Zerstörung des Datenträgers durch Spannungsspitzen | physikalisch getrennte Aufbewahrung |
zu seltene Sicherungskopien | sehr einfache Benutzung |

Diese Bedrohungen werden dadurch reduziert, dass eine sehr einfache Benutzung die physikalisch getrennte Aufbewahrung des die Sicherungskopien enthaltenen Datenträgers ermöglicht.

Eine einfach umzusetzende und verlässliche Maßnahme, um den Datenträger vor Zerstörung durch Spannungsspitzen zu schützen, ist, ihn vom Computer physikalisch getrennt aufzubewahren. Gleichzeitig schützt diese Maßnahme auch sehr gut vor der Zerstörung der Sicherungskopien durch Schadsoftware, da sich die Sicherungskopien außerhalb des Zugriffs der Schadsoftware befinden.

Durch die physikalisch getrennte Aufbewahrung ergibt sich aber eine Bedrohung durch Bequemlichkeit. Ein Prozess, für dessen Durchführung manuelle Schritte nötig sind, ist fehleranfällig und läuft Gefahr, im Zweifel nicht ausgeführt zu werden. Das Anlegen von Sicherungskopien stellt hier keine Ausnahme dar.

ButterBackup begegnet dieser Gefahr dadurch, dass es das Anlegen einer Sicherungskopie auf zwei manuelle Schritte reduziert. Es genügt, die Festplatte mit dem Computer zu verbinden und das Programm zu starten. Alle weiteren Schritte, z.B. Entschlüsselung, Kopie der Daten und Unmounten, werden von ButterBackup übernommen.

Insgesamt ermöglicht ButterBackup, Sicherungskopien so sicher wie möglich aufzubewahren ohne dabei zu verkomplizieren, neue Sicherungskopien anzulegen.

## Ausführung der Tests

ButterBackup hat eine umfangreiche Testsuite, die viele relevanten Aspekte des Programms abdeckt. Diese wird ergänzt durch die ähnlich umfangreichen Testsuites der Abhängigkeiten storage-device-managers und shell-interface. Diese beiden Abhängigkeiten sind aus ButterBackup hervorgegangen, womit deren Testsuite weitere für ButterBackup wichtige Aspekte gründlich abdeckt.

Für die schnelle Ausführung während der Entwicklung bietet es sich an, die Testsuite direkt auszuführen. Dies ist wird im Abschnitt "schnell" erläutert. Spätestens vor einem Release sollten aber auch die distributionsübergreifenden Tests ausgeführt werden, da diese garantieren, dass ButterBackup auch unter Arch und allen unterstützten Pythonversionen funktioniert.

### Schnell

#### Direkt

poetry run ruff check . poetry run mypy . poetry run pytest

#### Mittels Makefile

make check-format check-linters run-undockered-tests

### Plattformübergreifende Tests

Es existiert eine umfassende Testsuite, die auch gewisse Plattformabhängigkeiten erkennen kann. Die Docker-Tests existieren überhaupt nur, weil es Probleme mit Arch gab.

Die Testsuite kann mittels make ausgeführt werden. Es ist auch eine Parallelisierung mittels make -j N möglich, wobei N die Anzahl der Prozesse angibt.

Diese Tests werden ergänzt durch eine Testmatrix auf Github. Diese Testmatrix deckt Ubuntu mit allen unterstützten Pythonversionen ab. Dies erlaubt ggf., die sehr lang laufende Docker-Testsuite seltener auszuführen.

## Designentscheidungen

### Beibehaltung von nicht mehr vermerkten Zielordnern und -dateien

In den Konfigurationen müssen Zielordner und Dateien angegeben werden. Nun ist es denkbar, dass einige dieser Ziele umbenannt oder entfernt werden. Als Beispiel diene hier das Backup des Ordners Videos-Quelle nach Videos-Ziel. Ein Nutzer könnte sich nun entscheiden, aus Platzgründen Videos-Quelle auf eine externe Festplatte auszulagern. Die Backup-Anweisung könnte damit entfernt werden.

In diesem Fall wird ButterBackup Videos-Ziel nicht löschen. Der offensichtlichste Grund ist, dass dies das Programm verkomplizieren würde. Es ist ohne weiteres möglich, über butter-backup open die Sicherungskopien zu öffnen und nicht mehr benötigte Ordner händisch zu löschen.

Außerdem ist es vorstellbar, dass die Quelle zwar gelöscht wurde, aber im Backup archiviert werden soll. Dieser Anwendungsfall würde unmöglich gemacht, würden nicht mehr gelistete Ziele aus der Sicherungskopie entfernt.

## Ausstehende Aufgaben

  • README schreiben und übersetzen
  • Testsuite umstellen von Docker auf virtuelle Maschinen
  • Alias für Einzelkonfigurationen?
  • butter-backup exec / run - nimmt Befehl als Zeichenkette und führt diesen im BackupRootDir aus - butter-backup exec [<uuid>] <cmd> --> open; cd; cmd; cd -; close - sollte Mapping auf Umgebungsvariablen unterstützen, z.B. RepoPassCmd -> RESTIC_PASSWORD_COMMAND
  • Verbesserte Fehlermeldungen - wenn unmount nicht möglich ist - wenn BackupRepository nicht vorhanden ist
  • SudoPassCmd
  • Konfiguration der gewünschten Kompression ermöglichen (zlib, zstd, none, etc.)

Size

23.5 KB

Downloads

5

Status  Completed
Checksum (MD5) df357c5d4347bc6669869666757b1d2c
Checksum (SHA-1) fa883d38a3050d2042b7af429adb9ab0d1635bcb
Checksum (SHA-256) ab89d30fe65a8eeb300658c6f5f4a05f0627e89d88e8b8794617df4720940902
Checksum (SHA-512) 148ec17417d192c435dc87b63cce74814de7b2c272e1c32f81e87e46578fa17e58…
GPG Signature
GPG Fingerprint 6811684bac0b8895434e97bdd4391b8fb999e537
Storage Region  Dublin, Ireland
Type  Binary (contains binaries and binary artifacts)
Uploaded At 4 months, 3 weeks ago
Uploaded By Fetched by Cloudsmith
Slug Id butter_backup-351-py3-none-anywhl-52bz
Unique Id k9VmkwOJrF6D4YnN
Version (Raw) 3.5.1
Version (Parsed)
  • Major: 3
  • Minor: 5
  • Patch: 1
  • Type: SemVer (Compat)
  extended metadata
Author Max Görner <max@familie-goerner.eu>
Classifiers License :: OSI Approved :: GNU General Public License v3 or later (GPLv3+) | Programming Language :: Python :: 3 | Programming Language :: Python :: 3.10 | Programming Language :: Python :: 3.11 | Programming Language :: Python :: 3.12 | Programming Language :: Python :: 3.13 | Programming Language :: Python :: 3.9
Metadata Version 2.3
Py Filetype bdist_wheel
Py Version py3
Requires Dist loguru (>=0.7.3) | pydantic (>=2.10.6) | rich (>=13.9.4) ; extra == "all" | shell-interface (>=1.0.0) | storage-device-managers (>=1.0.0) | typer (>=0.15.1)
Requires Python >=3.9,<4.0.0
pkg butter_backup-3.5.1-py3-none-an… 5
23.5 KB
md5 sha1 sha256 sha512
Package Contents (butter_backup-3.5.1-py3-none-any.whl)
Loading...

This package has 14 files/directories.

Last scanned

4 months, 3 weeks ago

Scan result

Clean

Vulnerability count

0

Max. severity

Unknown

You can embed a badge in another website that shows this or the latest version of this package.

To embed the badge for this specific package version, use the following:

[![This version of 'butter-backup' @ Cloudsmith](https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true)](https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/)
|This version of 'butter-backup' @ Cloudsmith|
.. |This version of 'butter-backup' @ Cloudsmith| image:: https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true
   :target: https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/
image::https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true[link="https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/",title="This version of 'butter-backup' @ Cloudsmith"]
<a href="https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/"><img src="https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/3.5.1/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true" alt="This version of 'butter-backup' @ Cloudsmith" /></a>

rendered as: This version of 'butter-backup' @ Cloudsmith

To embed the badge for the latest package version, use the following:

[![Latest version of 'butter-backup' @ Cloudsmith](https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true&show_latest=true)](https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/)
|Latest version of 'butter-backup' @ Cloudsmith|
.. |Latest version of 'butter-backup' @ Cloudsmith| image:: https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true&show_latest=true
   :target: https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/
image::https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true&show_latest=true[link="https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/",title="Latest version of 'butter-backup' @ Cloudsmith"]
<a href="https://cloudsmith.io/~demo-docs/repos/awesome-repo/packages/detail/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/"><img src="https://api.cloudsmith.com/v1/badges/version/demo-docs/awesome-repo/python/butter-backup/latest/a=noarch;xf=bdist_wheel;xn=butter-backup;xv=py3/?render=true&show_latest=true" alt="Latest version of 'butter-backup' @ Cloudsmith" /></a>

rendered as: Latest version of 'butter-backup' @ Cloudsmith

These instructions assume you have setup the repository first (or read it).

To install/use butter-backup @ version 3.5.1 ...

pip install 'butter-backup==3.5.1'

You can also install the latest version of this package:

pip install --upgrade 'butter-backup'

If necessary, you can specify the repository directly:

pip install \
  --index-url=https://dl.cloudsmith.io/public/demo-docs/awesome-repo/python/simple/ \
  butter-backup==3.5.1

If you've got a project requirements.txt file, you can specify this as a dependency:

--index-url=https://dl.cloudsmith.io/public/demo-docs/awesome-repo/python/simple/
butter-backup==3.5.1

In addition, you can use this repository as an extra index url. However, please read our documentation on this parameter before using it. For example in a requirements.txt file:

--extra-index-url=https://dl.cloudsmith.io/public/demo-docs/awesome-repo/python/simple/
butter-backup==3.5.1
Warning: We highly recommend using pip (or similar) rather than installing directly.
Top