mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-23 01:06:43 +00:00
feature(backups): graphql mutation for restore
This commit is contained in:
parent
44ddd27e84
commit
7e022e0cfe
|
@ -257,6 +257,25 @@ class Backups:
|
|||
Backups.sync_service_snapshots(service_id, upstream_snapshots)
|
||||
return [snap for snap in upstream_snapshots if snap.service_name == service_id]
|
||||
|
||||
@staticmethod
|
||||
def get_snapshot_by_id(id: str) -> Optional[Snapshot]:
|
||||
snap = Storage.get_cached_snapshot_by_id(id)
|
||||
if snap is not None:
|
||||
return snap
|
||||
|
||||
# Possibly our cache entry got invalidated, let's try one more time
|
||||
Backups.sync_all_snapshots()
|
||||
snap = Storage.get_cached_snapshot_by_id(id)
|
||||
|
||||
return snap
|
||||
|
||||
@staticmethod
|
||||
def sync_all_snapshots():
|
||||
upstream_snapshots = Backups.provider().backuper.get_snapshots()
|
||||
Storage.invalidate_snapshot_storage()
|
||||
for snapshot in upstream_snapshots:
|
||||
Storage.cache_snapshot(snapshot)
|
||||
|
||||
@staticmethod
|
||||
def restore_service_from_snapshot(service: Service, snapshot_id: str):
|
||||
repo_name = service.get_id()
|
||||
|
|
|
@ -47,6 +47,11 @@ class Storage:
|
|||
for key in redis.keys(prefix + "*"):
|
||||
redis.delete(key)
|
||||
|
||||
@staticmethod
|
||||
def invalidate_snapshot_storage():
|
||||
for key in redis.keys(REDIS_SNAPSHOTS_PREFIX + "*"):
|
||||
redis.delete(key)
|
||||
|
||||
@staticmethod
|
||||
def store_testrepo_path(path: str):
|
||||
redis.set(REDIS_REPO_PATH_KEY, path)
|
||||
|
@ -97,6 +102,13 @@ class Storage:
|
|||
snapshot_key = Storage.__snapshot_key(snapshot)
|
||||
redis.delete(snapshot_key)
|
||||
|
||||
@staticmethod
|
||||
def get_cached_snapshot_by_id(snapshot_id: str) -> Optional[Snapshot]:
|
||||
key = redis.keys(REDIS_SNAPSHOTS_PREFIX + snapshot_id)
|
||||
if not redis.exists(key):
|
||||
return None
|
||||
return hash_as_model(redis, key, Snapshot)
|
||||
|
||||
@staticmethod
|
||||
def get_cached_snapshots() -> List[Snapshot]:
|
||||
keys = redis.keys(REDIS_SNAPSHOTS_PREFIX + "*")
|
||||
|
|
|
@ -14,7 +14,7 @@ from selfprivacy_api.graphql.queries.providers import BackupProvider
|
|||
|
||||
from selfprivacy_api.backup import Backups
|
||||
from selfprivacy_api.services import get_all_services, get_service_by_id
|
||||
from selfprivacy_api.backup.tasks import start_backup
|
||||
from selfprivacy_api.backup.tasks import start_backup, restore_snapshot
|
||||
|
||||
|
||||
@strawberry.input
|
||||
|
@ -80,3 +80,13 @@ class BackupMutations:
|
|||
start_backup(service)
|
||||
|
||||
return GenericJobMutationReturn()
|
||||
|
||||
@strawberry.mutation(permission_classes=[IsAuthenticated])
|
||||
def restore_backup(self, snapshot_id: str) -> GenericJobMutationReturn:
|
||||
"""Restore backup"""
|
||||
snap = Backups.get_snapshot_by_id(snapshot_id)
|
||||
if snap in None:
|
||||
raise ValueError(f"No such snapshot: {snapshot_id}")
|
||||
restore_snapshot(snap)
|
||||
|
||||
return GenericJobMutationReturn()
|
||||
|
|
Loading…
Reference in a new issue