2014-10-31 05:34:03 +00:00
|
|
|
from __future__ import print_function
|
|
|
|
from argparse import ArgumentParser
|
2015-07-19 02:35:29 +01:00
|
|
|
from importlib import import_module
|
|
|
|
import os
|
2014-10-31 05:34:03 +00:00
|
|
|
from subprocess import CalledProcessError
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from atticmatic.config import parse_configuration
|
|
|
|
|
|
|
|
|
2015-07-19 02:35:29 +01:00
|
|
|
DEFAULT_CONFIG_FILENAME_PATTERN = '/etc/{}/config'
|
|
|
|
DEFAULT_EXCLUDES_FILENAME_PATTERN = '/etc/{}/excludes'
|
2014-12-20 19:37:25 +00:00
|
|
|
|
|
|
|
|
2015-07-19 02:35:29 +01:00
|
|
|
def parse_arguments(command_name, *arguments):
|
2014-12-02 06:35:25 +00:00
|
|
|
'''
|
2015-07-19 02:35:29 +01:00
|
|
|
Given the name of the command with which this script was invoked and command-line arguments,
|
|
|
|
parse the arguments and return them as an ArgumentParser instance. Use the command name to
|
|
|
|
determine the default configuration and excludes paths.
|
2014-12-02 06:35:25 +00:00
|
|
|
'''
|
2014-10-31 05:34:03 +00:00
|
|
|
parser = ArgumentParser()
|
|
|
|
parser.add_argument(
|
2014-12-02 06:47:51 +00:00
|
|
|
'-c', '--config',
|
2014-10-31 05:34:03 +00:00
|
|
|
dest='config_filename',
|
2015-07-19 02:35:29 +01:00
|
|
|
default=DEFAULT_CONFIG_FILENAME_PATTERN.format(command_name),
|
2014-10-31 05:34:03 +00:00
|
|
|
help='Configuration filename',
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
'--excludes',
|
|
|
|
dest='excludes_filename',
|
2015-07-19 02:35:29 +01:00
|
|
|
default=DEFAULT_EXCLUDES_FILENAME_PATTERN.format(command_name),
|
2014-10-31 05:34:03 +00:00
|
|
|
help='Excludes filename',
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
2015-07-18 05:58:50 +01:00
|
|
|
'-v', '--verbosity',
|
|
|
|
type=int,
|
|
|
|
help='Display verbose progress (1 for some, 2 for lots)',
|
2014-10-31 05:34:03 +00:00
|
|
|
)
|
|
|
|
|
2014-12-20 19:37:25 +00:00
|
|
|
return parser.parse_args(arguments)
|
2014-12-02 06:35:25 +00:00
|
|
|
|
|
|
|
|
2015-07-19 02:35:29 +01:00
|
|
|
def load_backend(command_name):
|
|
|
|
'''
|
|
|
|
Given the name of the command with which this script was invoked, return the corresponding
|
|
|
|
backend module responsible for actually dealing with backups.
|
|
|
|
'''
|
|
|
|
backend_name = {
|
|
|
|
'atticmatic': 'attic',
|
|
|
|
'borgmatic': 'borg',
|
|
|
|
}.get(command_name, 'attic')
|
|
|
|
|
|
|
|
return import_module('atticmatic.backends.{}'.format(backend_name))
|
|
|
|
|
|
|
|
|
2014-12-02 06:35:25 +00:00
|
|
|
def main():
|
2014-10-31 05:34:03 +00:00
|
|
|
try:
|
2015-07-19 02:35:29 +01:00
|
|
|
command_name = os.path.basename(sys.argv[0])
|
|
|
|
args = parse_arguments(command_name, *sys.argv[1:])
|
2015-05-11 06:00:31 +01:00
|
|
|
config = parse_configuration(args.config_filename)
|
|
|
|
repository = config.location['repository']
|
2015-07-19 02:35:29 +01:00
|
|
|
backend = load_backend(command_name)
|
2014-10-31 05:34:03 +00:00
|
|
|
|
2015-07-19 02:35:29 +01:00
|
|
|
backend.create_archive(args.excludes_filename, args.verbosity, **config.location)
|
|
|
|
backend.prune_archives(args.verbosity, repository, config.retention)
|
|
|
|
backend.check_archives(args.verbosity, repository, config.consistency)
|
2015-03-15 17:44:18 +00:00
|
|
|
except (ValueError, IOError, CalledProcessError) as error:
|
2014-10-31 05:34:03 +00:00
|
|
|
print(error, file=sys.stderr)
|
|
|
|
sys.exit(1)
|