mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-25 18:26:34 +00:00
feature(backups): implement inplace restore strategy
This commit is contained in:
parent
c74b3df32c
commit
af5edb695f
|
@ -209,14 +209,28 @@ class Backups:
|
||||||
|
|
||||||
### Restoring
|
### Restoring
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _ensure_active_restore_job(service, snapshot) -> Job:
|
def _ensure_queued_restore_job(service, snapshot) -> Job:
|
||||||
job = get_restore_job(service)
|
job = get_restore_job(service)
|
||||||
if job is None:
|
if job is None:
|
||||||
job = add_restore_job(snapshot)
|
job = add_restore_job(snapshot)
|
||||||
|
|
||||||
Jobs.update(job, status=JobStatus.RUNNING)
|
Jobs.update(job, status=JobStatus.CREATED)
|
||||||
return job
|
return job
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _inplace_restore(service: Service, snapshot: Snapshot, job: Job):
|
||||||
|
failsafe_snapshot = Backups.back_up(service)
|
||||||
|
|
||||||
|
Jobs.update(job, status=JobStatus.RUNNING)
|
||||||
|
try:
|
||||||
|
Backups._restore_service_from_snapshot(service, snapshot.id, verify=False)
|
||||||
|
except Exception as e:
|
||||||
|
Backups._restore_service_from_snapshot(
|
||||||
|
service, failsafe_snapshot.id, verify=False
|
||||||
|
)
|
||||||
|
raise e
|
||||||
|
Backups.forget_snapshot(failsafe_snapshot)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def restore_snapshot(
|
def restore_snapshot(
|
||||||
snapshot: Snapshot, strategy=RestoreStrategy.DOWNLOAD_VERIFY_OVERWRITE
|
snapshot: Snapshot, strategy=RestoreStrategy.DOWNLOAD_VERIFY_OVERWRITE
|
||||||
|
@ -226,13 +240,21 @@ class Backups:
|
||||||
raise ValueError(
|
raise ValueError(
|
||||||
f"snapshot has a nonexistent service: {snapshot.service_name}"
|
f"snapshot has a nonexistent service: {snapshot.service_name}"
|
||||||
)
|
)
|
||||||
|
job = Backups._ensure_queued_restore_job(service, snapshot)
|
||||||
job = Backups._ensure_active_restore_job(service, snapshot)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
Backups._assert_restorable(snapshot)
|
Backups._assert_restorable(snapshot)
|
||||||
Backups._restore_service_from_snapshot(service, snapshot.id)
|
|
||||||
|
if strategy == RestoreStrategy.INPLACE:
|
||||||
|
Backups._inplace_restore(service, snapshot, job)
|
||||||
|
else: # verify_before_download is our default
|
||||||
|
Jobs.update(job, status=JobStatus.RUNNING)
|
||||||
|
Backups._restore_service_from_snapshot(
|
||||||
|
service, snapshot.id, verify=True
|
||||||
|
)
|
||||||
|
|
||||||
service.post_restore()
|
service.post_restore()
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
Jobs.update(job, status=JobStatus.ERROR)
|
Jobs.update(job, status=JobStatus.ERROR)
|
||||||
raise e
|
raise e
|
||||||
|
@ -256,7 +278,7 @@ class Backups:
|
||||||
)
|
)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _restore_service_from_snapshot(service: Service, snapshot_id: str):
|
def _restore_service_from_snapshot(service: Service, snapshot_id: str, verify=True):
|
||||||
folders = service.get_folders()
|
folders = service.get_folders()
|
||||||
|
|
||||||
Backups.provider().backupper.restore_from_backup(
|
Backups.provider().backupper.restore_from_backup(
|
||||||
|
|
|
@ -30,7 +30,7 @@ class AbstractBackupper(ABC):
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@abstractmethod
|
@abstractmethod
|
||||||
def restore_from_backup(self, snapshot_id: str, folders: List[str]):
|
def restore_from_backup(self, snapshot_id: str, folders: List[str], verify=True):
|
||||||
"""Restore a target folder using a snapshot"""
|
"""Restore a target folder using a snapshot"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue