feat(backups): Add backup descriptions for UI

This commit is contained in:
Inex Code 2023-06-29 14:27:08 +03:00
parent 15ce344bc8
commit 64e7afe53e
10 changed files with 76 additions and 0 deletions

View file

@ -94,6 +94,7 @@ class Service:
is_required: bool is_required: bool
is_enabled: bool is_enabled: bool
can_be_backed_up: bool can_be_backed_up: bool
backup_description: str
status: ServiceStatusEnum status: ServiceStatusEnum
url: typing.Optional[str] url: typing.Optional[str]
dns_records: typing.Optional[typing.List[DnsRecord]] dns_records: typing.Optional[typing.List[DnsRecord]]
@ -126,6 +127,7 @@ def service_to_graphql_service(service: ServiceInterface) -> Service:
is_required=service.is_required(), is_required=service.is_required(),
is_enabled=service.is_enabled(), is_enabled=service.is_enabled(),
can_be_backed_up=service.can_be_backed_up(), can_be_backed_up=service.can_be_backed_up(),
backup_description=service.get_backup_description(),
status=ServiceStatusEnum(service.get_status().value), status=ServiceStatusEnum(service.get_status().value),
url=service.get_url(), url=service.get_url(),
dns_records=[ dns_records=[

View file

@ -55,6 +55,10 @@ class Bitwarden(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "Password database, encryption certificate and attachments."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -51,6 +51,10 @@ class Gitea(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "Git repositories, database and user data."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -54,6 +54,10 @@ class Jitsi(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "Secrets that are used to encrypt the communication."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -54,6 +54,10 @@ class MailServer(Service):
def is_required() -> bool: def is_required() -> bool:
return True return True
@staticmethod
def get_backup_description() -> str:
return "Mail boxes and filters."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
return True return True

View file

@ -49,6 +49,10 @@ class Nextcloud(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "All the files and other data stored in Nextcloud."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -48,6 +48,10 @@ class Ocserv(Service):
def can_be_backed_up() -> bool: def can_be_backed_up() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "Nothing to backup."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -46,6 +46,10 @@ class Pleroma(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "Your Pleroma accounts, posts and media."
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
with ReadUserData() as user_data: with ReadUserData() as user_data:

View file

@ -41,83 +41,125 @@ class Service(ABC):
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_id() -> str: def get_id() -> str:
"""
The unique id of the service.
"""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_display_name() -> str: def get_display_name() -> str:
"""
The name of the service that is shown to the user.
"""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_description() -> str: def get_description() -> str:
"""
The description of the service that is shown to the user.
"""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_svg_icon() -> str: def get_svg_icon() -> str:
"""
The monochrome svg icon of the service.
"""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_url() -> typing.Optional[str]: def get_url() -> typing.Optional[str]:
"""
The url of the service if it is accessible from the internet browser.
"""
pass pass
@classmethod @classmethod
def get_user(cls) -> typing.Optional[str]: def get_user(cls) -> typing.Optional[str]:
"""
The user that owns the service's files.
Defaults to the service's id.
"""
return cls.get_id() return cls.get_id()
@classmethod @classmethod
def get_group(cls) -> typing.Optional[str]: def get_group(cls) -> typing.Optional[str]:
"""
The group that owns the service's files.
Defaults to the service's user.
"""
return cls.get_user() return cls.get_user()
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def is_movable() -> bool: def is_movable() -> bool:
"""`True` if the service can be moved to the non-system volume."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def is_required() -> bool: def is_required() -> bool:
"""`True` if the service is required for the server to function."""
pass pass
@staticmethod @staticmethod
def can_be_backed_up() -> bool: def can_be_backed_up() -> bool:
"""`True` if the service can be backed up."""
return True return True
@staticmethod
@abstractmethod
def get_backup_description() -> str:
"""
The text shown to the user that exlplains what data will be
backed up.
"""
pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def is_enabled() -> bool: def is_enabled() -> bool:
"""`True` if the service is enabled."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def get_status() -> ServiceStatus: def get_status() -> ServiceStatus:
"""The status of the service, reported by systemd."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def enable(): def enable():
"""Enable the service. Usually this means enabling systemd unit."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def disable(): def disable():
"""Disable the service. Usually this means disabling systemd unit."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def stop(): def stop():
"""Stop the service. Usually this means stopping systemd unit."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def start(): def start():
"""Start the service. Usually this means starting systemd unit."""
pass pass
@staticmethod @staticmethod
@abstractmethod @abstractmethod
def restart(): def restart():
"""Restart the service. Usually this means restarting systemd unit."""
pass pass
@staticmethod @staticmethod

View file

@ -53,6 +53,10 @@ class DummyService(Service):
def is_required() -> bool: def is_required() -> bool:
return False return False
@staticmethod
def get_backup_description() -> str:
return "How did we get here?"
@staticmethod @staticmethod
def is_enabled() -> bool: def is_enabled() -> bool:
return True return True