45 lines
1.2 KiB
Python
45 lines
1.2 KiB
Python
import logging
|
|
|
|
import borgmatic.borg.borg
|
|
import borgmatic.borg.rlist
|
|
import borgmatic.config.validate
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
def run_borg(
|
|
repository,
|
|
storage,
|
|
local_borg_version,
|
|
borg_arguments,
|
|
global_arguments,
|
|
local_path,
|
|
remote_path,
|
|
):
|
|
'''
|
|
Run the "borg" action for the given repository.
|
|
'''
|
|
if borg_arguments.repository is None or borgmatic.config.validate.repositories_match(
|
|
repository, borg_arguments.repository
|
|
):
|
|
logger.info(
|
|
f'{repository.get("label", repository["path"])}: Running arbitrary Borg command'
|
|
)
|
|
archive_name = borgmatic.borg.rlist.resolve_archive_name(
|
|
repository['path'],
|
|
borg_arguments.archive,
|
|
storage,
|
|
local_borg_version,
|
|
global_arguments,
|
|
local_path,
|
|
remote_path,
|
|
)
|
|
borgmatic.borg.borg.run_arbitrary_borg(
|
|
repository['path'],
|
|
storage,
|
|
local_borg_version,
|
|
options=borg_arguments.options,
|
|
archive=archive_name,
|
|
local_path=local_path,
|
|
remote_path=remote_path,
|
|
)
|