cura-te-ipsum/main.py

111 lines
3.9 KiB
Python
Raw Normal View History

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
import shutil
2019-01-10 19:58:40 +00:00
import sys
2021-11-12 08:30:11 +00:00
import time
2019-01-10 19:58:40 +00:00
2021-11-11 23:53:21 +00:00
import spqr.curateipsum.backup as 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(
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",
2021-11-08 21:43:18 +00:00
type=str,
2021-06-21 05:27:18 +00:00
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-11-12 08:30:11 +00:00
parser.add_argument("-f", "--force",
action="store_true",
default=False,
help="Force run when previous backup is still in process")
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",
2021-11-08 21:43:18 +00:00
type=str,
2021-06-21 05:27:18 +00:00
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])
_lg.info("Starting %s: %s", parser.prog, args)
2021-10-24 18:20:05 +00:00
if sys.platform not in SUPPORTED_PLATFORMS:
2021-11-11 23:53:21 +00:00
_lg.error("Not supported platform: %s. Supported platforms: %s",
sys.platform, SUPPORTED_PLATFORMS)
2021-10-24 18:20:05 +00:00
return 1
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):
2021-11-11 23:53:21 +00:00
_lg.error("%s should be installed to use --external-hardlink option.",
cp_program)
2021-10-24 18:20:05 +00:00
return 1
2021-11-08 21:43:18 +00:00
backup_dir_abs = 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
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-11-12 08:30:11 +00:00
start_time = time.time()
2021-11-11 23:53:21 +00:00
2021-11-12 08:30:11 +00:00
if not backup.set_backups_lock(backup_dir_abs, args.force):
_lg.warning("Previous backup is still in process, exiting")
return 1
backup.cleanup_old_backups(backup_dir=backup_dir_abs, dry_run=args.dry_run)
2021-11-11 23:53:21 +00:00
backup.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
2021-11-12 08:30:11 +00:00
backup.release_backups_lock(backup_dir_abs)
end_time = time.time()
spent_time = end_time - start_time
_lg.info("Finished, time spent: %.3fs", spent_time)
2019-01-29 08:22:08 +00:00
if __name__ == "__main__":
sys.exit(main())