##// END OF EJS Templates
version bump. Bugfix when changelog parameter was not an int. Added limit for 100 changelogs to view at once.
version bump. Bugfix when changelog parameter was not an int. Added limit for 100 changelogs to view at once.

File last commit:

r39:787e7d30 default
r211:a3a7c3e0 rhodecode-0.0.0.7.3 default
Show More
backup_manager.py
88 lines | 3.0 KiB | text/x-python | PythonLexer
'''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()