Split cli commands into functions
This commit is contained in:
parent
15c91d5970
commit
c37435ea34
|
@ -13,41 +13,56 @@ def main():
|
||||||
containers = RunningContainers()
|
containers = RunningContainers()
|
||||||
|
|
||||||
if args.action == 'status':
|
if args.action == 'status':
|
||||||
print()
|
status(config, containers)
|
||||||
print("Backup config for compose project '{}'".format(containers.this_container.project_name))
|
|
||||||
print()
|
|
||||||
|
|
||||||
for container in containers.containers:
|
|
||||||
print('service: {}'.format(container.service_name))
|
|
||||||
for mount in container.filter_mounts():
|
|
||||||
print(' - {}'.format(mount.source))
|
|
||||||
|
|
||||||
print()
|
|
||||||
|
|
||||||
elif args.action == 'backup':
|
elif args.action == 'backup':
|
||||||
# Make sure we don't spawn multiple backup processes
|
backup(config, containers)
|
||||||
if containers.backup_process_running:
|
|
||||||
raise ValueError("Backup process already running")
|
|
||||||
|
|
||||||
print("Initializing repository")
|
|
||||||
|
|
||||||
# TODO: Errors when repo already exists
|
|
||||||
restic.init_repo(config.repository)
|
|
||||||
|
|
||||||
print("Starting backup container..")
|
|
||||||
backup_runner.run(
|
|
||||||
image=containers.this_container.image,
|
|
||||||
command='restic-volume-backup start-backup-process',
|
|
||||||
volumes=containers.this_container.volumes,
|
|
||||||
enviroment=containers.this_container.environment,
|
|
||||||
labels={"restic-volume-backup.backup_process": 'True'},
|
|
||||||
)
|
|
||||||
|
|
||||||
# Separate command to avoid spawning infinite containers :)
|
# Separate command to avoid spawning infinite containers :)
|
||||||
elif args.action == 'start-backup-process':
|
elif args.action == 'start-backup-process':
|
||||||
print("start-backup-process")
|
start_backup_process(config, containers)
|
||||||
import os
|
|
||||||
print(os.environ)
|
|
||||||
|
def start_backup_process(config, containers):
|
||||||
|
"""Start the backup process container"""
|
||||||
|
print("start-backup-process")
|
||||||
|
import os
|
||||||
|
print(os.environ)
|
||||||
|
|
||||||
|
|
||||||
|
def status(config, containers):
|
||||||
|
"""Outputs the backup config for the compse setup"""
|
||||||
|
print()
|
||||||
|
print("Backup config for compose project '{}'".format(containers.this_container.project_name))
|
||||||
|
print()
|
||||||
|
|
||||||
|
for container in containers.containers:
|
||||||
|
print('service: {}'.format(container.service_name))
|
||||||
|
for mount in container.filter_mounts():
|
||||||
|
print(' - {}'.format(mount.source))
|
||||||
|
|
||||||
|
print()
|
||||||
|
|
||||||
|
|
||||||
|
def backup(config, containers):
|
||||||
|
"""Start backup"""
|
||||||
|
# Make sure we don't spawn multiple backup processes
|
||||||
|
if containers.backup_process_running:
|
||||||
|
raise ValueError("Backup process already running")
|
||||||
|
|
||||||
|
print("Initializing repository")
|
||||||
|
|
||||||
|
# TODO: Errors when repo already exists
|
||||||
|
restic.init_repo(config.repository)
|
||||||
|
|
||||||
|
print("Starting backup container..")
|
||||||
|
backup_runner.run(
|
||||||
|
image=containers.this_container.image,
|
||||||
|
command='restic-volume-backup start-backup-process',
|
||||||
|
volumes=containers.this_container.volumes,
|
||||||
|
enviroment=containers.this_container.environment,
|
||||||
|
labels={"restic-volume-backup.backup_process": 'True'},
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def parse_args():
|
def parse_args():
|
||||||
|
|
Loading…
Reference in New Issue