|
|
'''BACKUP MANAGER'''
|
|
|
import logging
|
|
|
from mercurial import config
|
|
|
import tarfile
|
|
|
import os
|
|
|
import datetime
|
|
|
import sys
|
|
|
import subprocess
|
|
|
logging.basicConfig(level=logging.DEBUG,
|
|
|
format="%(asctime)s %(levelname)-5.5s %(message)s")
|
|
|
|
|
|
class BackupManager(object):
|
|
|
def __init__(self):
|
|
|
self.repos_path = None
|
|
|
self.backup_file_name = None
|
|
|
self.id_rsa_path = '/home/pylons/id_rsa'
|
|
|
self.check_id_rsa()
|
|
|
cur_dir = os.path.realpath(__file__)
|
|
|
dn = os.path.dirname
|
|
|
self.backup_file_path = os.path.join(dn(dn(dn(cur_dir))), 'data')
|
|
|
cfg = config.config()
|
|
|
try:
|
|
|
cfg.read(os.path.join(dn(dn(dn(cur_dir))), 'hgwebdir.config'))
|
|
|
except IOError:
|
|
|
logging.error('Could not read hgwebdir.config')
|
|
|
sys.exit()
|
|
|
self.set_repos_path(cfg.items('paths'))
|
|
|
logging.info('starting backup for %s', self.repos_path)
|
|
|
logging.info('backup target %s', self.backup_file_path)
|
|
|
|
|
|
if not os.path.isdir(self.repos_path):
|
|
|
raise Exception('Not a valid directory in %s' % self.repos_path)
|
|
|
|
|
|
def check_id_rsa(self):
|
|
|
if not os.path.isfile(self.id_rsa_path):
|
|
|
logging.error('Could not load id_rsa key file in %s',
|
|
|
self.id_rsa_path)
|
|
|
sys.exit()
|
|
|
|
|
|
def set_repos_path(self, paths):
|
|
|
repos_path = paths[0][1].split('/')
|
|
|
if repos_path[-1] in ['*', '**']:
|
|
|
repos_path = repos_path[:-1]
|
|
|
if repos_path[0] != '/':
|
|
|
repos_path[0] = '/'
|
|
|
self.repos_path = os.path.join(*repos_path)
|
|
|
|
|
|
def backup_repos(self):
|
|
|
today = datetime.datetime.now().weekday() + 1
|
|
|
self.backup_file_name = "mercurial_repos.%s.tar.gz" % today
|
|
|
bckp_file = os.path.join(self.backup_file_path, self.backup_file_name)
|
|
|
tar = tarfile.open(bckp_file, "w:gz")
|
|
|
|
|
|
for dir_name in os.listdir(self.repos_path):
|
|
|
logging.info('backing up %s', dir_name)
|
|
|
tar.add(os.path.join(self.repos_path, dir_name), dir_name)
|
|
|
tar.close()
|
|
|
logging.info('finished backup of mercurial repositories')
|
|
|
|
|
|
|
|
|
|
|
|
def transfer_files(self):
|
|
|
params = {
|
|
|
'id_rsa_key': self.id_rsa_path,
|
|
|
'backup_file_path':self.backup_file_path,
|
|
|
'backup_file_name':self.backup_file_name,
|
|
|
}
|
|
|
cmd = ['scp', '-l', '40000', '-i', '%(id_rsa_key)s' % params,
|
|
|
'%(backup_file_path)s/%(backup_file_name)s' % params,
|
|
|
'root@192.168.2.102:/backups/mercurial' % params]
|
|
|
|
|
|
subprocess.call(cmd)
|
|
|
logging.info('Transfered file %s to %s', self.backup_file_name, cmd[4])
|
|
|
|
|
|
|
|
|
def rm_file(self):
|
|
|
logging.info('Removing file %s', self.backup_file_name)
|
|
|
os.remove(os.path.join(self.backup_file_path, self.backup_file_name))
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
B_MANAGER = BackupManager()
|
|
|
B_MANAGER.backup_repos()
|
|
|
B_MANAGER.transfer_files()
|
|
|
B_MANAGER.rm_file()
|
|
|
|
|
|
|
|
|
|