mirror of
https://github.com/borgbase/vorta
synced 2025-01-03 05:36:19 +00:00
97 lines
3.2 KiB
Markdown
97 lines
3.2 KiB
Markdown
# Vorta - A Boring GUI for BorgBackup
|
|
|
|
![](https://files.qmax.us/vorta-screencast-3.gif)
|
|
|
|
Vorta is an open source macOS/Linux GUI for [BorgBackup](https://borgbackup.readthedocs.io). It's currently in alpha status.
|
|
|
|
## Main features
|
|
|
|
- Encrypted, deduplicated and compressed backups.
|
|
- Works with any remote SSH account that has `borg` installed. Or try [BorgBase](https://www.borgbase.com) for advanced features like append-only repositories and monitoring.
|
|
- Add SSH keys and initialize repos directly from the GUI.
|
|
- Repo keys are securely stored in macOS Keychain, Secret Service or KWallet.
|
|
- Mount existing snapshots via FUSE.
|
|
- Prune and check backups periodically.
|
|
- Flexible scheduling for automatic background backups. Only allow on certain Wifis.
|
|
- View a list of snapshots and action logs.
|
|
- Exclude options/patterns.
|
|
|
|
Coming soon:
|
|
|
|
- [ ] Support multiple backup profiles (in progress)
|
|
- [ ] Full test coverage (currently: 65%)
|
|
- [ ] Packaging for Linux? How?
|
|
|
|
## Installation and Download
|
|
Vorta should work on all platforms that support Qt and Borg. Currently Borg doesn't support Windows, but this may change in the future. Setting allowed Wifi networks is currently not supported on Linux, but everything else should work.
|
|
|
|
### macOS
|
|
Download the pre-built macOS binary from [Releases](https://github.com/borgbase/vorta/releases). Just download, unzip and run.
|
|
|
|
### Linux
|
|
First install Borg and its own [dependencies](https://borgbackup.readthedocs.io/en/stable/installation.html#dependencies). Then install Vorta from Pypi:
|
|
```
|
|
$ pip install vorta
|
|
```
|
|
|
|
After installation run with the `vorta` command.
|
|
```
|
|
$ vorta
|
|
```
|
|
|
|
## Development
|
|
|
|
Install in development/editable mode while in the repo:
|
|
```
|
|
$ pip install -e .
|
|
```
|
|
|
|
Then run via
|
|
```
|
|
$ vorta
|
|
```
|
|
|
|
Install developer packages we use (pytest, tox, pyinstaller):
|
|
```
|
|
pip install -r requirements-dev.txt
|
|
```
|
|
|
|
Qt Creator is used to edit views. Install from [their site](https://www.qt.io/download) or using Homebrew and then open the .ui files in `vorta/UI`:
|
|
```
|
|
$ brew cask install qt-creator
|
|
$ brew install qt
|
|
```
|
|
|
|
To build a binary package:
|
|
```
|
|
$ pyinstaller --clean --noconfirm vorta.spec
|
|
```
|
|
|
|
### Testing (work in progress)
|
|
|
|
Tests are in the folder `/tests`. Testing happens at the level of UI components. Calls to `borg` are mocked and can be replaced with some example json-output. To run tests:
|
|
```
|
|
$ python setup.py test
|
|
```
|
|
|
|
To update and view coverage information
|
|
```
|
|
$ coverage run -m pytest
|
|
$ coverage report
|
|
```
|
|
|
|
## Privacy Policy
|
|
- No personal data is ever stored or transmitted by this application.
|
|
- During beta, crash reports are sent to [Sentry](https://sentry.io) to quickly find bugs.
|
|
|
|
## Why the Name?
|
|
[Vorta](http://memory-alpha.wikia.com/wiki/Vorta) are a race referenced in Star Trek. They serve the Dominion and are replaced by their clones if they die. Just like our backups.
|
|
|
|
## Author
|
|
(C) 2018 Manuel Riel for [BorgBase.com](https://www.borgbase.com)
|
|
|
|
## License and Credits
|
|
- Licensed under GPLv3. See LICENSE.txt for details.
|
|
- Uses the excellent [BorgBackup](https://www.borgbackup.org)
|
|
- Based on [PyQt](https://riverbankcomputing.com/software/pyqt/intro) and [Qt](https://www.qt.io).
|
|
- Icons by [FontAwesome](https://fontawesome.com)
|