move borg_interface out of this repository.
This project is getting too big for this repository. I've created a seperate repository at https://git.2li.ch/Nebucatnetzer/borg_interface
This commit is contained in:
parent
e93f6a610a
commit
7edef0bd9c
|
@ -1,12 +0,0 @@
|
|||
.idea
|
||||
__pycache__
|
||||
# swap
|
||||
[._]*.s[a-w][a-z]
|
||||
[._]s[a-w][a-z]
|
||||
# session
|
||||
Session.vim
|
||||
# temporary
|
||||
.netrwhist
|
||||
*~
|
||||
# auto-generated tag files
|
||||
tags
|
|
@ -1,5 +0,0 @@
|
|||
[DEFAULT]
|
||||
server: fileserver.2li.local
|
||||
user: borg
|
||||
repository_path: /home/borg/backup/gwyn
|
||||
password: iEw74xjem7gvsJrShCVCbYrAwX7yUo
|
|
@ -1,83 +0,0 @@
|
|||
#!/usr/bin/env python3
|
||||
import os
|
||||
import sys
|
||||
import configparser
|
||||
import subprocess
|
||||
|
||||
chosen_activity = None
|
||||
mount_point = None
|
||||
|
||||
# setup the config parser
|
||||
config = configparser.ConfigParser()
|
||||
|
||||
# read config file
|
||||
config.read('borg_interface.cfg')
|
||||
|
||||
# assign the repository variable
|
||||
if 'server' in config:
|
||||
repository = (config['DEFAULT']['user']
|
||||
+ "@"
|
||||
+ config['DEFAULT']['server']
|
||||
+ ":"
|
||||
+ config['DEFAULT']['repository_path'])
|
||||
else:
|
||||
repository = config['DEFAULT']['repository_path']
|
||||
|
||||
# assign the password variable
|
||||
password = config['DEFAULT']['password']
|
||||
|
||||
# set the environment variables
|
||||
os.environ['BORG_REPO'] = repository
|
||||
os.environ['BORG_PASSPHRASE'] = password
|
||||
|
||||
# The main menu starts there
|
||||
while chosen_activity != 0:
|
||||
print("What would you like to do?")
|
||||
# Start the chosen activity and go back to the activity selector.
|
||||
print("1: List Backups, 2: Show archive details, 3: Mount Archive, "
|
||||
"4: Restore Backup, 0: Exit")
|
||||
try:
|
||||
chosen_activity = int(input("Choose the desired activity: "))
|
||||
if chosen_activity == 1:
|
||||
# prints all the archives in the repository and lists them with
|
||||
# less
|
||||
os.system('borg list | less')
|
||||
if chosen_activity == 2:
|
||||
# Displays all the information related to the archive name the user
|
||||
# enters
|
||||
archive_name = input("Please enter the archive name: ")
|
||||
os.system('borg info ::' + archive_name)
|
||||
if chosen_activity == 3:
|
||||
# mounts a chosen archive to /tmp/archive name
|
||||
archive_name = input("Please enter the archive name: ")
|
||||
mount_point = "/tmp/" + archive_name
|
||||
if not os.path.exists(mount_point):
|
||||
os.makedirs(mount_point)
|
||||
os.system('borg mount ::' + archive_name + " " + mount_point)
|
||||
print()
|
||||
print("Archive mounted at " + mount_point + "/")
|
||||
print()
|
||||
if chosen_activity == 4:
|
||||
archive_name = input("Please enter the archive name: ")
|
||||
restore_path = input("Please enter the path where you want to "
|
||||
"restore to: ")
|
||||
working_directory = os.system('pwd')
|
||||
if not os.path.exists(restore_path):
|
||||
os.makedirs(restore_path)
|
||||
p = subprocess.Popen(['borg', 'extract', ':: + archive_name],
|
||||
cwd=restore_path)
|
||||
p.wait()
|
||||
print()
|
||||
print("Archive extracted to " + restore_path)
|
||||
print()
|
||||
elif chosen_activity == 0:
|
||||
if (not mount_point):
|
||||
print()
|
||||
else:
|
||||
print()
|
||||
print("Unmount Archive and remove folder.")
|
||||
print()
|
||||
os.system('fusermount -u' + " " + mount_point)
|
||||
os.rmdir(mount_point)
|
||||
except ValueError:
|
||||
print("Please enter a full number.")
|
Reference in New Issue