mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-27 11:16:35 +00:00
BROKEN(backups): hooking up quotas to API fails. AutobackupQuotas needs to be an input type, but if input type, it fails because it needs to be an Output type, which is not documented
This commit is contained in:
parent
0c04975ea4
commit
9fdc536f9f
|
@ -11,7 +11,10 @@ from selfprivacy_api.graphql.queries.backup import BackupConfiguration
|
||||||
from selfprivacy_api.graphql.queries.backup import Backup
|
from selfprivacy_api.graphql.queries.backup import Backup
|
||||||
from selfprivacy_api.graphql.queries.providers import BackupProvider
|
from selfprivacy_api.graphql.queries.providers import BackupProvider
|
||||||
from selfprivacy_api.graphql.common_types.jobs import job_to_api_job
|
from selfprivacy_api.graphql.common_types.jobs import job_to_api_job
|
||||||
from selfprivacy_api.graphql.common_types.backup import RestoreStrategy
|
from selfprivacy_api.graphql.common_types.backup import (
|
||||||
|
RestoreStrategy,
|
||||||
|
AutobackupQuotas,
|
||||||
|
)
|
||||||
|
|
||||||
from selfprivacy_api.backup import Backups
|
from selfprivacy_api.backup import Backups
|
||||||
from selfprivacy_api.services import get_service_by_id
|
from selfprivacy_api.services import get_service_by_id
|
||||||
|
@ -33,6 +36,13 @@ class InitializeRepositoryInput:
|
||||||
password: str
|
password: str
|
||||||
|
|
||||||
|
|
||||||
|
@strawberry.input
|
||||||
|
class SetAutobackupQuotasInput:
|
||||||
|
"""A single field input to reuse AutobackupQuotas"""
|
||||||
|
|
||||||
|
quotas: AutobackupQuotas
|
||||||
|
|
||||||
|
|
||||||
@strawberry.type
|
@strawberry.type
|
||||||
class GenericBackupConfigReturn(MutationReturnInterface):
|
class GenericBackupConfigReturn(MutationReturnInterface):
|
||||||
"""Generic backup config return"""
|
"""Generic backup config return"""
|
||||||
|
@ -90,6 +100,33 @@ class BackupMutations:
|
||||||
configuration=Backup().configuration(),
|
configuration=Backup().configuration(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@strawberry.mutation(permission_classes=[IsAuthenticated])
|
||||||
|
def set_autobackup_quotas(
|
||||||
|
self, quotas: SetAutobackupQuotasInput
|
||||||
|
) -> GenericBackupConfigReturn:
|
||||||
|
"""
|
||||||
|
Set autobackup quotas.
|
||||||
|
Values <=0 for any timeframe mean no limits for that timeframe.
|
||||||
|
To disable autobackup use autobackup period setting, not this mutation.
|
||||||
|
"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
Backups.set_autobackup_quotas(quotas)
|
||||||
|
return GenericBackupConfigReturn(
|
||||||
|
success=True,
|
||||||
|
message="",
|
||||||
|
code=200,
|
||||||
|
configuration=Backup().configuration(),
|
||||||
|
)
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return GenericBackupConfigReturn(
|
||||||
|
success=False,
|
||||||
|
message=str(e),
|
||||||
|
code=400,
|
||||||
|
configuration=Backup().configuration(),
|
||||||
|
)
|
||||||
|
|
||||||
@strawberry.mutation(permission_classes=[IsAuthenticated])
|
@strawberry.mutation(permission_classes=[IsAuthenticated])
|
||||||
def start_backup(self, service_id: str) -> GenericJobMutationReturn:
|
def start_backup(self, service_id: str) -> GenericJobMutationReturn:
|
||||||
"""Start backup"""
|
"""Start backup"""
|
||||||
|
|
|
@ -13,6 +13,7 @@ from selfprivacy_api.graphql.common_types.service import (
|
||||||
SnapshotInfo,
|
SnapshotInfo,
|
||||||
service_to_graphql_service,
|
service_to_graphql_service,
|
||||||
)
|
)
|
||||||
|
from selfprivacy_api.graphql.common_types.backup import AutobackupQuotas
|
||||||
from selfprivacy_api.services import get_service_by_id
|
from selfprivacy_api.services import get_service_by_id
|
||||||
|
|
||||||
|
|
||||||
|
@ -26,6 +27,8 @@ class BackupConfiguration:
|
||||||
is_initialized: bool
|
is_initialized: bool
|
||||||
# If none, autobackups are disabled
|
# If none, autobackups are disabled
|
||||||
autobackup_period: typing.Optional[int]
|
autobackup_period: typing.Optional[int]
|
||||||
|
# None is equal to all quotas being unlimited (-1). Optional for compatibility reasons.
|
||||||
|
autobackup_quotas: typing.Optional[AutobackupQuotas]
|
||||||
# Bucket name for Backblaze, path for some other providers
|
# Bucket name for Backblaze, path for some other providers
|
||||||
location_name: typing.Optional[str]
|
location_name: typing.Optional[str]
|
||||||
location_id: typing.Optional[str]
|
location_id: typing.Optional[str]
|
||||||
|
@ -42,6 +45,7 @@ class Backup:
|
||||||
autobackup_period=Backups.autobackup_period_minutes(),
|
autobackup_period=Backups.autobackup_period_minutes(),
|
||||||
location_name=Backups.provider().location,
|
location_name=Backups.provider().location,
|
||||||
location_id=Backups.provider().repo_id,
|
location_id=Backups.provider().repo_id,
|
||||||
|
autobackup_quotas=Backups.autobackup_quotas(),
|
||||||
)
|
)
|
||||||
|
|
||||||
@strawberry.field
|
@strawberry.field
|
||||||
|
|
|
@ -4,6 +4,7 @@ from tests.common import generate_backup_query
|
||||||
|
|
||||||
|
|
||||||
from selfprivacy_api.graphql.common_types.service import service_to_graphql_service
|
from selfprivacy_api.graphql.common_types.service import service_to_graphql_service
|
||||||
|
from selfprivacy_api.graphql.common_types.backup import AutobackupQuotas
|
||||||
from selfprivacy_api.jobs import Jobs, JobStatus
|
from selfprivacy_api.jobs import Jobs, JobStatus
|
||||||
|
|
||||||
API_RELOAD_SNAPSHOTS = """
|
API_RELOAD_SNAPSHOTS = """
|
||||||
|
@ -38,6 +39,28 @@ mutation TestAutobackupPeriod($period: Int) {
|
||||||
}
|
}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
API_SET_AUTOBACKUP_QUOTAS_MUTATION = """
|
||||||
|
mutation TestAutobackupQuotas($input: SetAutobackupQuotasInput!) {
|
||||||
|
backup {
|
||||||
|
setAutobackupQuotas(quotas: $input) {
|
||||||
|
success
|
||||||
|
message
|
||||||
|
code
|
||||||
|
configuration {
|
||||||
|
provider
|
||||||
|
encryptionKey
|
||||||
|
isInitialized
|
||||||
|
autobackupPeriod
|
||||||
|
locationName
|
||||||
|
locationId
|
||||||
|
autobackupQuotas
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
API_REMOVE_REPOSITORY_MUTATION = """
|
API_REMOVE_REPOSITORY_MUTATION = """
|
||||||
mutation TestRemoveRepo {
|
mutation TestRemoveRepo {
|
||||||
backup {
|
backup {
|
||||||
|
@ -177,6 +200,17 @@ def api_set_period(authorized_client, period):
|
||||||
return response
|
return response
|
||||||
|
|
||||||
|
|
||||||
|
def api_set_quotas(authorized_client, quotas):
|
||||||
|
response = authorized_client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_SET_AUTOBACKUP_QUOTAS_MUTATION,
|
||||||
|
"variables": {"input": {"quotas": quotas}},
|
||||||
|
},
|
||||||
|
)
|
||||||
|
return response
|
||||||
|
|
||||||
|
|
||||||
def api_remove(authorized_client):
|
def api_remove(authorized_client):
|
||||||
response = authorized_client.post(
|
response = authorized_client.post(
|
||||||
"/graphql",
|
"/graphql",
|
||||||
|
@ -323,6 +357,22 @@ def test_remove(authorized_client, generic_userdata):
|
||||||
assert configuration["isInitialized"] is False
|
assert configuration["isInitialized"] is False
|
||||||
|
|
||||||
|
|
||||||
|
def test_autobackup_quotas_nonzero(authorized_client):
|
||||||
|
quotas = AutobackupQuotas(
|
||||||
|
daily=2,
|
||||||
|
weekly=4,
|
||||||
|
monthly=13,
|
||||||
|
yearly=14,
|
||||||
|
total=3,
|
||||||
|
)
|
||||||
|
response = api_set_quotas(authorized_client, quotas)
|
||||||
|
data = get_data(response)["backup"]["setAutobackupQuotas"]
|
||||||
|
assert_ok(data)
|
||||||
|
|
||||||
|
configuration = data["configuration"]
|
||||||
|
assert configuration["autobackupQuotas"] == quotas
|
||||||
|
|
||||||
|
|
||||||
def test_autobackup_period_nonzero(authorized_client):
|
def test_autobackup_period_nonzero(authorized_client):
|
||||||
new_period = 11
|
new_period = 11
|
||||||
response = api_set_period(authorized_client, new_period)
|
response = api_set_period(authorized_client, new_period)
|
||||||
|
|
Loading…
Reference in a new issue