2019-01-10 19:58:40 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
2019-01-29 08:22:08 +00:00
|
|
|
import argparse
|
2019-01-10 19:58:40 +00:00
|
|
|
import logging
|
2021-05-27 21:40:54 +00:00
|
|
|
import os.path
|
2019-01-29 08:22:08 +00:00
|
|
|
import pathlib
|
2021-10-22 21:36:39 +00:00
|
|
|
import shutil
|
2019-01-10 19:58:40 +00:00
|
|
|
import sys
|
|
|
|
|
|
2021-06-10 16:16:23 +00:00
|
|
|
from spqr.curateipsum.backup import initiate_backup
|
|
|
|
|
|
|
|
|
|
_lg = logging.getLogger("spqr.curateipsum")
|
2021-10-24 18:20:05 +00:00
|
|
|
SUPPORTED_PLATFORMS = ("linux", "darwin")
|
2019-01-10 19:58:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2019-01-29 08:22:08 +00:00
|
|
|
formatter = logging.Formatter("{asctime}|{levelname}|{message}", style="{")
|
|
|
|
|
console_handler = logging.StreamHandler()
|
|
|
|
|
console_handler.setFormatter(formatter)
|
|
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(
|
2021-06-10 16:16:23 +00:00
|
|
|
prog="cura-te-ipsum", description="cura-te-ipsum, my personal backup software.",
|
2019-01-29 08:22:08 +00:00
|
|
|
)
|
|
|
|
|
parser.add_argument("-V", "--version", action="version", version="%(prog)s 0.1")
|
2021-06-21 05:27:18 +00:00
|
|
|
parser.add_argument("-v", "--verbose",
|
|
|
|
|
action="store_true",
|
|
|
|
|
default=False,
|
|
|
|
|
help="print verbose information")
|
|
|
|
|
parser.add_argument("-b",
|
|
|
|
|
dest="backup_dir",
|
|
|
|
|
metavar="BACKUP_DIR",
|
|
|
|
|
type=pathlib.Path,
|
|
|
|
|
required=True,
|
|
|
|
|
help="directory, where all backups will be stored")
|
|
|
|
|
parser.add_argument("-n", "--dry-run",
|
|
|
|
|
action="store_true",
|
|
|
|
|
default=False,
|
|
|
|
|
help="Do not do create backup")
|
2021-06-23 17:11:42 +00:00
|
|
|
parser.add_argument("--external-rsync",
|
|
|
|
|
action="store_true",
|
|
|
|
|
default=False,
|
|
|
|
|
help="Use external rsync for copying")
|
2021-10-24 18:20:05 +00:00
|
|
|
parser.add_argument("--external-hardlink",
|
|
|
|
|
action="store_true",
|
|
|
|
|
default=False,
|
|
|
|
|
help="Use cp command for creating hardlink copies")
|
2021-06-21 05:27:18 +00:00
|
|
|
parser.add_argument("sources",
|
|
|
|
|
nargs="+",
|
|
|
|
|
metavar="SOURCE",
|
|
|
|
|
type=pathlib.Path,
|
|
|
|
|
help="backup source (file/dir/smth else)")
|
2019-01-29 08:22:08 +00:00
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
|
|
loglevel = logging.DEBUG if args.verbose else logging.INFO
|
|
|
|
|
logging.basicConfig(level=loglevel, handlers=[console_handler])
|
|
|
|
|
|
2021-06-10 16:16:23 +00:00
|
|
|
_lg.info("Starting %s: %s", parser.prog, args)
|
2021-10-24 18:20:05 +00:00
|
|
|
|
|
|
|
|
if sys.platform not in SUPPORTED_PLATFORMS:
|
|
|
|
|
_lg.error(f"Not supported platform: {sys.platform}. Supported platforms: {SUPPORTED_PLATFORMS}")
|
|
|
|
|
return 1
|
|
|
|
|
|
2021-10-22 21:36:39 +00:00
|
|
|
if args.external_rsync and not shutil.which("rsync"):
|
|
|
|
|
_lg.error("rsync should be installed to use --external-rsync option.")
|
|
|
|
|
return 1
|
|
|
|
|
|
2021-10-24 18:20:05 +00:00
|
|
|
cp_program = "gcp" if sys.platform == "darwin" else "cp"
|
|
|
|
|
if args.external_hardlink and not shutil.which(cp_program):
|
|
|
|
|
_lg.error(f"{cp_program} should be installed to use --external-hardlink option.")
|
|
|
|
|
return 1
|
|
|
|
|
|
2021-06-10 16:16:23 +00:00
|
|
|
backup_dir_abs = pathlib.Path(os.path.abspath(args.backup_dir))
|
2021-05-27 21:40:54 +00:00
|
|
|
if not os.path.isdir(backup_dir_abs):
|
|
|
|
|
_lg.error("Backup directory %s does not exist, exiting", args.backup_dir)
|
|
|
|
|
return 1
|
2019-01-29 08:22:08 +00:00
|
|
|
|
2021-06-10 16:16:23 +00:00
|
|
|
for src_dir in args.sources:
|
|
|
|
|
if not os.path.isdir(src_dir):
|
|
|
|
|
_lg.error("Source directory %s does not exist", src_dir)
|
|
|
|
|
return 1
|
|
|
|
|
|
2021-06-23 17:11:42 +00:00
|
|
|
initiate_backup(
|
2021-10-24 18:20:05 +00:00
|
|
|
sources=args.sources,
|
|
|
|
|
backup_dir=backup_dir_abs,
|
2021-06-23 17:11:42 +00:00
|
|
|
dry_run=args.dry_run,
|
|
|
|
|
external_rsync=args.external_rsync,
|
2021-10-24 18:20:05 +00:00
|
|
|
external_hardlink=args.external_hardlink,
|
2021-06-23 17:11:42 +00:00
|
|
|
)
|
2019-01-29 08:22:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2019-01-16 20:02:35 +00:00
|
|
|
sys.exit(main())
|