mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-11 18:39:30 +00:00
refactor(backups): privatize assert_restorable and restore_snapshot_from_id
This commit is contained in:
parent
cb2273323f
commit
f2161f0532
|
@ -209,31 +209,6 @@ class Backups:
|
||||||
|
|
||||||
### Restoring
|
### Restoring
|
||||||
|
|
||||||
# to be deprecated/internalized in favor of restore_snapshot()
|
|
||||||
@staticmethod
|
|
||||||
def restore_service_from_snapshot(service: Service, snapshot_id: str):
|
|
||||||
folders = service.get_folders()
|
|
||||||
|
|
||||||
Backups.provider().backupper.restore_from_backup(
|
|
||||||
snapshot_id,
|
|
||||||
folders,
|
|
||||||
)
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def assert_restorable(snapshot: Snapshot):
|
|
||||||
service = get_service_by_id(snapshot.service_name)
|
|
||||||
if service is None:
|
|
||||||
raise ValueError(
|
|
||||||
f"snapshot has a nonexistent service: {snapshot.service_name}"
|
|
||||||
)
|
|
||||||
|
|
||||||
needed_space = Backups.service_snapshot_size(snapshot.id)
|
|
||||||
available_space = Backups.space_usable_for_service(service)
|
|
||||||
if needed_space > available_space:
|
|
||||||
raise ValueError(
|
|
||||||
f"we only have {available_space} bytes "
|
|
||||||
f"but snapshot needs {needed_space}"
|
|
||||||
)
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def restore_snapshot(snapshot: Snapshot):
|
def restore_snapshot(snapshot: Snapshot):
|
||||||
|
@ -253,8 +228,8 @@ class Backups:
|
||||||
status=JobStatus.RUNNING,
|
status=JobStatus.RUNNING,
|
||||||
)
|
)
|
||||||
try:
|
try:
|
||||||
Backups.assert_restorable(snapshot)
|
Backups._assert_restorable(snapshot)
|
||||||
Backups.restore_service_from_snapshot(
|
Backups._restore_service_from_snapshot(
|
||||||
service,
|
service,
|
||||||
snapshot.id,
|
snapshot.id,
|
||||||
)
|
)
|
||||||
|
@ -271,6 +246,31 @@ class Backups:
|
||||||
status=JobStatus.FINISHED,
|
status=JobStatus.FINISHED,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _assert_restorable(snapshot: Snapshot):
|
||||||
|
service = get_service_by_id(snapshot.service_name)
|
||||||
|
if service is None:
|
||||||
|
raise ValueError(
|
||||||
|
f"snapshot has a nonexistent service: {snapshot.service_name}"
|
||||||
|
)
|
||||||
|
|
||||||
|
needed_space = Backups.service_snapshot_size(snapshot.id)
|
||||||
|
available_space = Backups.space_usable_for_service(service)
|
||||||
|
if needed_space > available_space:
|
||||||
|
raise ValueError(
|
||||||
|
f"we only have {available_space} bytes "
|
||||||
|
f"but snapshot needs {needed_space}"
|
||||||
|
)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _restore_service_from_snapshot(service: Service, snapshot_id: str):
|
||||||
|
folders = service.get_folders()
|
||||||
|
|
||||||
|
Backups.provider().backupper.restore_from_backup(
|
||||||
|
snapshot_id,
|
||||||
|
folders,
|
||||||
|
)
|
||||||
|
|
||||||
### Snapshots
|
### Snapshots
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
|
|
@ -222,7 +222,7 @@ def test_restore(backups, dummy_service):
|
||||||
remove(p)
|
remove(p)
|
||||||
assert not path.exists(p)
|
assert not path.exists(p)
|
||||||
|
|
||||||
Backups.restore_service_from_snapshot(dummy_service, snap.id)
|
Backups._restore_service_from_snapshot(dummy_service, snap.id)
|
||||||
for p, content in zip(paths_to_nuke, contents):
|
for p, content in zip(paths_to_nuke, contents):
|
||||||
assert path.exists(p)
|
assert path.exists(p)
|
||||||
with open(p, "r") as file:
|
with open(p, "r") as file:
|
||||||
|
|
Loading…
Reference in a new issue