mirror of https://github.com/borgbase/vorta
46 lines
1.3 KiB
Python
46 lines
1.3 KiB
Python
from vorta.utils import borg_compat
|
|
|
|
from .borg_job import BorgJob
|
|
|
|
|
|
class BorgListArchiveJob(BorgJob):
|
|
def started_event(self):
|
|
self.app.backup_started_event.emit()
|
|
self.app.backup_progress_event.emit(f"[{self.params['profile_name']}] {self.tr('Getting archive content…')}")
|
|
|
|
def finished_event(self, result):
|
|
self.app.backup_finished_event.emit(result)
|
|
self.app.backup_progress_event.emit(
|
|
f"[{self.params['profile_name']}] {self.tr('Done getting archive content.')}"
|
|
)
|
|
self.result.emit(result)
|
|
|
|
@classmethod
|
|
def prepare(cls, profile, archive_name):
|
|
ret = super().prepare(profile)
|
|
if not ret['ok']:
|
|
return ret
|
|
|
|
ret['archive_name'] = archive_name
|
|
ret['cmd'] = [
|
|
'borg',
|
|
'list',
|
|
'--info',
|
|
'--log-json',
|
|
'--json-lines',
|
|
'--format',
|
|
# fields to include in json output
|
|
"{mode}{user}{group}{size}{"
|
|
+ ('isomtime' if borg_compat.check('V122') else 'mtime')
|
|
+ "}{path}{source}{health}{NL}",
|
|
]
|
|
|
|
if borg_compat.check('V2'):
|
|
ret['cmd'].extend(["-r", profile.repo.url, archive_name])
|
|
else:
|
|
ret['cmd'].append(f'{profile.repo.url}::{archive_name}')
|
|
|
|
ret['ok'] = True
|
|
|
|
return ret
|