2019-02-07 23:19:21 -08:00
|
|
|
#!/usr/bin/python3
|
2019-03-13 02:19:20 -07:00
|
|
|
"""
|
|
|
|
Run a backup.
|
|
|
|
|
|
|
|
Command-Line Arguments
|
|
|
|
======================
|
|
|
|
"""
|
|
|
|
import argparse
|
|
|
|
import logging
|
|
|
|
import os.path
|
|
|
|
import rbackup.rsync as rsync
|
|
|
|
|
2019-03-13 20:43:12 -07:00
|
|
|
from rbackup.hierarchy import Repository, Snapshot
|
2019-03-13 02:19:20 -07:00
|
|
|
|
|
|
|
# ========== Constants ==========
|
|
|
|
RSYNC_DEFAULT_OPTS = [
|
|
|
|
"--archive",
|
|
|
|
"--hard-links",
|
|
|
|
"--prune-dirs",
|
|
|
|
"--backup",
|
2019-03-13 20:43:12 -07:00
|
|
|
"--xattrs",
|
2019-03-13 02:19:20 -07:00
|
|
|
"--ignore-missing-args",
|
|
|
|
]
|
2019-03-13 20:43:12 -07:00
|
|
|
EXTRA_RSYNC_OPTS = {
|
|
|
|
"dry_run": "--dry-run",
|
|
|
|
"delete": "--delete-after",
|
|
|
|
"checksum": "--checksum",
|
|
|
|
"update": "--update",
|
|
|
|
}
|
2019-03-13 02:19:20 -07:00
|
|
|
|
|
|
|
# ========== Logging Setup ==========
|
2019-03-13 20:43:12 -07:00
|
|
|
console_formatter = logging.Formatter(LOGFORMAT)
|
|
|
|
syslog = logging.getLogger("packaging_scripts")
|
|
|
|
syslog.setLevel(logging.DEBUG)
|
|
|
|
|
|
|
|
stdout_handler = logging.StreamHandler(sys.stdout)
|
|
|
|
stdout_handler.setLevel(logging.INFO)
|
|
|
|
stdout_handler.setFormatter(console_formatter)
|
|
|
|
stdout_handler.addFilter(lambda record: record.levelno <= logging.INFO)
|
|
|
|
|
|
|
|
stderr_handler = logging.StreamHandler(sys.stderr)
|
|
|
|
stderr_handler.setLevel(logging.WARNING)
|
|
|
|
stderr_handler.setFormatter(console_formatter)
|
|
|
|
|
|
|
|
syslog.addHandler(stdout_handler)
|
|
|
|
syslog.addHandler(stderr_handler)
|
2019-03-13 02:19:20 -07:00
|
|
|
|
|
|
|
# ========== Main Script ==========
|
|
|
|
if __name__ == "__main__":
|
|
|
|
parser = argparse.ArgumentParser()
|
2019-03-13 20:43:12 -07:00
|
|
|
parser.add_argument(
|
|
|
|
"-c",
|
|
|
|
"--use-checksums",
|
|
|
|
action="store_const",
|
|
|
|
dest="extra_rsync_opts",
|
|
|
|
const=EXTRA_RSYNC_OPTS["checksum"],
|
|
|
|
help="use rsync's checksumming feature to look for changed files"
|
|
|
|
)
|
2019-03-13 02:19:20 -07:00
|
|
|
parser.add_argument(
|
|
|
|
"-d",
|
|
|
|
"--dry-run",
|
|
|
|
action="append_const",
|
|
|
|
dest="extra_rsync_opts",
|
|
|
|
const=EXTRA_RSYNC_OPTS["dry_run"],
|
|
|
|
help="pass --dry-run to rsync",
|
|
|
|
)
|
2019-03-13 20:43:12 -07:00
|
|
|
parser.add_argument(
|
|
|
|
"-v", "--verbose", action="store_true", help="increase script verbosity"
|
|
|
|
)
|
|
|
|
parser.add_argument("operation", help="the operation to perform", metavar="op")
|
|
|
|
parser.add_argument("repository", help="repository to back up to", metavar="repo")
|
2019-03-13 02:19:20 -07:00
|
|
|
|
|
|
|
args = parser.parser_args()
|
2019-03-13 20:43:12 -07:00
|
|
|
repo = Repository(args.repository)
|
2019-03-13 02:19:20 -07:00
|
|
|
|
|
|
|
link_dest = hier.prev_snapshot
|
|
|
|
|
2019-03-13 20:43:12 -07:00
|
|
|
if args.verbose:
|
|
|
|
stdout_handler.setLevel(logging.DEBUG)
|
|
|
|
|
|
|
|
# Handle empty repository
|
|
|
|
|
|
|
|
# else handle regular repository
|
|
|
|
|
2019-03-13 02:19:20 -07:00
|
|
|
# Backup to hier.curr_snapshot
|
|
|
|
|
2019-03-13 20:43:12 -07:00
|
|
|
# Relink 'prev' to point to latest snapshot
|
2019-03-13 02:19:20 -07:00
|
|
|
os.remove(hier.prev_snapshot_link)
|
|
|
|
os.symlink(curr_snapshot, hier.prev_snapshot_link, target_is_directory=True)
|