Trying to add support for local destinations

This commit is contained in:
Mike 2018-09-01 18:38:43 -07:00
parent 4adfc5c94e
commit cc413a4a87

View File

@ -14,7 +14,7 @@ class MikesBackup:
_log_dir = None _log_dir = None
_remote_host = None _remote_host = None
_remote_user = None _remote_user = None
_remote_dir_base = None _destination_dir_base = None
# #
_ssh_key = None _ssh_key = None
_quiet_ssh = True _quiet_ssh = True
@ -46,7 +46,7 @@ class MikesBackup:
"--log-dir" : "_log_dir", "--log-dir" : "_log_dir",
"--remote-host" : "_remote_host", "--remote-host" : "_remote_host",
"--remote-user" : "_remote_user", "--remote-user" : "_remote_user",
"--remote-dir" : "_remote_dir_base", "--destination-dir" : "_destination_dir_base",
"--ssh-key" : "_ssh_key" "--ssh-key" : "_ssh_key"
} }
@ -102,54 +102,85 @@ class MikesBackup:
return datetime.datetime.now().strftime('%Y-%b-%d_%I%M%p') return datetime.datetime.now().strftime('%Y-%b-%d_%I%M%p')
# #
def DemandSSHStuff(self): def IsUsingSSH(self):
# #
if self._remote_host != None or self._remote_user != None or self._ssh_key != None:
return True
return False
#
def DemandSSHConfig(self):
#
if self.IsUsingSSH():
if self._remote_host == None: if self._remote_host == None:
raise Exception("Please provide remote host") raise Exception("Please provide remote host")
if self._remote_user == None: if self._remote_user == None:
raise Exception("Please provide remote user") raise Exception("Please provide remote user")
if self._remote_dir_base == None:
raise Exception("Please provide remote backup destination directory")
# #
def DoesRemoteDirectoryExist(self, remote_path): def DemandDestinationDirectoryConfig(self):
# #
command = [ if self._destination_dir_base == None:
"[ -d " + remote_path + " ]" raise Exception("Please provide backup destination directory")
]
# #
print("Trying to determine if remote path exists:", remote_path) def DoesDestinationDirectoryExist(self, destination_path):
code, stdout, stderr = self.ExecuteRemoteSSHCommand(command)
if code == 0: #
print("Remote dir was found: " + remote_path) print("Trying to determine if destination path exists:", destination_path)
# Local?
if not self.IsUsingSSH():
print("Checking for local destination path")
if os.path.isdir(destination_path):
print("Local destination path exists")
return True return True
else:
# print("Local destination path does not exist")
print("Remote dir didn't seem to exist: " + remote_path)
return False return False
# #
def DemandRemoteBaseBackupDirectory(self): print("Checking for remote destination path")
command = [
"[ -d " + destination_path + " ]"
]
# #
remote_path = self._remote_dir_base code, stdout, stderr = self.ExecuteRemoteSSHCommand(command)
if code == 0:
print("Remote destination dir was found: " + destination_path)
return True
# #
if self.DoesRemoteDirectoryExist(remote_path) == False: print("Remote dir didn't seem to exist: " + destination_path)
raise Exception("Remote backup directory doesn't exist: " + remote_path) return False
# #
def DoesRemoteFullBackupDirectoryExist(self): def DemandDestinationBaseBackupDirectory(self):
# #
remote_path = self.MakeRemoteFullBackupPath() self.DemandDestinationDirectoryConfig()
# #
print("Trying to determine if remote Full backup path exists:", remote_path) destination_path = self._destination_dir_base
return self.DoesRemoteDirectoryExist(remote_path)
#
if self.DoesDestinationDirectoryExist(destination_path) == False:
raise Exception("Backup destination directory doesn't exist: " + destination_path)
#
def DoesFullBackupDestinationDirectoryExist(self):
#
dir_path = self.MakeFullBackupDestinationPath()
#
print("Trying to determine if Full backup destination directory exists:", dir_path)
return self.DoesDestinationDirectoryExist(dir_path)
# #
def GetSourceDirectories(self): def GetSourceDirectories(self):
@ -168,7 +199,7 @@ class MikesBackup:
print("Enter: DoBackup") print("Enter: DoBackup")
# Remote base dir must exist # Remote base dir must exist
self.DemandRemoteBaseBackupDirectory() self.DemandDestinationBaseBackupDirectory()
# Forced full or differential by args? # Forced full or differential by args?
if self._force_full == True or self._force_differential == True: if self._force_full == True or self._force_differential == True:
@ -181,11 +212,11 @@ class MikesBackup:
return return
# Automatically choose full or differential # Automatically choose full or differential
if self.DoesRemoteFullBackupDirectoryExist(): if self.DoesFullBackupDestinationDirectoryExist():
print("Automatically choosing differential backup, because full backup remote dir already exists") print("Automatically choosing differential backup, because full backup destination directory already exists")
self.DoDifferentialBackup() self.DoDifferentialBackup()
else: else:
print("Automatically choosing full backup, because full backup remote dir wasn't found") print("Automatically choosing full backup, because full backup destination directory wasn't found")
self.DoFullBackup() self.DoFullBackup()
# #
@ -194,17 +225,18 @@ class MikesBackup:
# Start args # Start args
args = [] args = []
# Get directory # Get destination directory
remote_dir = self.MakeRemoteFullBackupPath() destination_dir = self.MakeFullBackupDestinationPath()
# Append source directories # Append source directories
args.extend(self.GetSourceDirectories()) args.extend(self.GetSourceDirectories())
# Append remote destination directory # Append remote destination directory
args.append( self._remote_user + "@" + self._remote_host + ":" + remote_dir) #args.append( self._remote_user + "@" + self._remote_host + ":" + remote_dir)
args.append( self.MakeRsyncRemoteDestinationPart(destination_dir) )
#print("Args", str(args)) #print("Args", str(args))
print("Remote dir:", remote_dir) print("Destination dir:", destination_dir)
self.ExecuteRsync(args) self.ExecuteRsync(args)
@ -215,23 +247,24 @@ class MikesBackup:
args = [] args = []
# Get directories # Get directories
remote_link_dest_dir = self.MakeRemoteFullBackupPath() link_dest_dir = self.MakeFullBackupDestinationPath()
remote_dir = self.MakeRemoteDifferentialBackupPath() destination_dir = self.MakeRemoteDifferentialBackupPath()
self.EnsureRemoteDirectory(remote_dir) self.EnsureDestinationDirectory(destination_dir)
# Add link dest arg # Add link dest arg
args.append("--link-dest") args.append("--link-dest")
args.append(remote_link_dest_dir) args.append(link_dest_dir)
# Append source directories # Append source directories
args.extend(self.GetSourceDirectories()) args.extend(self.GetSourceDirectories())
# Append remote destination directory # Append remote destination directory
args.append( self._remote_user + "@" + self._remote_host + ":" + remote_dir) #args.append( self._remote_user + "@" + self._remote_host + ":" + remote_dir)
args.append( self.MakeRsyncRemoteDestinationPart(destination_dir) )
#print("Args", str(args)) #print("Args", str(args))
print("Remote link dest dir:", remote_link_dest_dir) print("Link destination dir:", link_dest_dir)
print("Remote dir:", remote_dir) print("Destination dir:", destination_dir)
self.ExecuteRsync(args) self.ExecuteRsync(args)
@ -258,24 +291,41 @@ class MikesBackup:
return log_path return log_path
# #
def MakeRemoteFullBackupPath(self): def MakeFullBackupDestinationPath(self):
# #
if self._remote_dir_base == None: if self._destination_dir_base == None:
raise Exception("No remote directory was specified") raise Exception("No remote directory was specified")
# #
return os.path.join(self._remote_dir_base, "Full") return os.path.join(self._destination_dir_base, "Full")
# #
def MakeRemoteDifferentialBackupPath(self): def MakeRemoteDifferentialBackupPath(self):
# #
if self._remote_dir_base == None: if self._destination_dir_base == None:
raise Exception("No remote directory was specified") raise Exception("No remote directory was specified")
# #
return os.path.join(self._remote_dir_base, "Differential", self.GetDatetimeForFilename()) return os.path.join(self._destination_dir_base, "Differential", self.GetDatetimeForFilename())
#
def MakeRsyncRemoteDestinationPart(self, destination_dir):
#
part = ""
#
if self._remote_host != None:
if self._remote_user != None:
part += self._remote_user + "@"
part += self._remote_host + ":"
#
part += destination_dir
return part
# #
def EnsureLocalDirectory(self, d): def EnsureLocalDirectory(self, d):
@ -285,18 +335,24 @@ class MikesBackup:
os.makedirs(d) os.makedirs(d)
# #
def EnsureRemoteDirectory(self, d): def EnsureDestinationDirectory(self, d):
# #
if not self.DoesRemoteDirectoryExist(d): if not self.DoesDestinationDirectoryExist(d):
# #
print("Destination directory doesn't exist; Will create:", d)
#
if self.IsUsingSSH():
command = [ command = [
"mkdir", "mkdir",
"--parents", "--parents",
d d
] ]
self.ExecuteRemoteSSHCommand(command) self.ExecuteRemoteSSHCommand(command)
else:
os.makedirs(d)
# #
def StartRsyncArgs(self): def StartRsyncArgs(self):
@ -347,7 +403,7 @@ class MikesBackup:
def ExecuteRemoteSSHCommand(self, command): def ExecuteRemoteSSHCommand(self, command):
# #
self.DemandSSHStuff() self.DemandSSHConfig()
# #
args = [] args = []
@ -390,8 +446,10 @@ class MikesBackup:
# #
def ExecuteRsync(self, _args): def ExecuteRsync(self, _args):
# # Demand stuff
self.DemandSSHStuff() self.DemandDestinationDirectoryConfig()
if self.IsUsingSSH():
self.DemandSSHConfig()
# #
args = self.StartRsyncArgs() args = self.StartRsyncArgs()
@ -401,6 +459,12 @@ class MikesBackup:
# #
env = self.StartRsyncEnvironmentalVariables() env = self.StartRsyncEnvironmentalVariables()
#
#print("Debug -> Want to execute Rsync")
#print("Args:", str(args))
#print("Env:", str(env))
#return (0, "", "")
# Spawn Rsync in shell # Spawn Rsync in shell
#process = subprocess.Popen(args, stdout=subprocess.PIPE, stderr=subprocess.PIPE, env=env) #process = subprocess.Popen(args, stdout=subprocess.PIPE, stderr=subprocess.PIPE, env=env)
process = subprocess.Popen(args, env=env) process = subprocess.Popen(args, env=env)