selfprivacy-rest-api/selfprivacy_api/services/service.py

152 lines
2.6 KiB
Python
Raw Permalink Normal View History

2022-07-25 14:08:31 +00:00
"""Abstract class for a service running on a server"""
from abc import ABC, abstractmethod
from enum import Enum
import typing
2022-07-25 14:08:31 +00:00
from pydantic import BaseModel
from selfprivacy_api.jobs import Job
from selfprivacy_api.utils.block_devices import BlockDevice
2022-07-25 14:08:31 +00:00
class ServiceStatus(Enum):
"""Enum for service status"""
ACTIVE = "ACTIVE"
RELOADING = "RELOADING"
INACTIVE = "INACTIVE"
FAILED = "FAILED"
ACTIVATING = "ACTIVATING"
DEACTIVATING = "DEACTIVATING"
2022-07-25 14:08:31 +00:00
OFF = "OFF"
class ServiceDnsRecord(BaseModel):
type: str
name: str
content: str
ttl: int
priority: typing.Optional[int] = None
2022-07-25 14:08:31 +00:00
class Service(ABC):
"""
Service here is some software that is hosted on the server and
can be installed, configured and used by a user.
"""
@staticmethod
@abstractmethod
def get_id() -> str:
pass
@staticmethod
@abstractmethod
def get_display_name() -> str:
pass
@staticmethod
@abstractmethod
def get_description() -> str:
pass
@staticmethod
@abstractmethod
def get_svg_icon() -> str:
pass
@staticmethod
@abstractmethod
def get_url() -> typing.Optional[str]:
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def is_movable() -> bool:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def is_required() -> bool:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def is_enabled() -> bool:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_status() -> ServiceStatus:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def enable():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def disable():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def stop():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def start():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def restart():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_configuration():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def set_configuration(config_items):
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_logs():
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_storage_usage() -> int:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_dns_records() -> typing.List[ServiceDnsRecord]:
2022-07-25 14:08:31 +00:00
pass
@staticmethod
2022-07-25 14:08:31 +00:00
@abstractmethod
def get_drive() -> str:
2022-07-25 14:08:31 +00:00
pass
# @staticmethod
# @abstractmethod
# def get_folders() -> str:
# pass
@abstractmethod
def move_to_volume(self, volume: BlockDevice) -> Job:
pass
2023-02-08 15:27:49 +00:00
def pre_backup(self):
pass
def post_restore(self):
pass