mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2024-11-23 04:21:29 +00:00
101 lines
2.7 KiB
Python
101 lines
2.7 KiB
Python
"""Class representing Bitwarden service"""
|
|
import base64
|
|
import subprocess
|
|
from typing import Optional, List
|
|
|
|
from selfprivacy_api.utils import get_domain
|
|
|
|
from selfprivacy_api.utils.systemd import get_service_status
|
|
from selfprivacy_api.services.service import Service, ServiceStatus
|
|
from selfprivacy_api.services.forgejo.icon import FORGEJO_ICON
|
|
|
|
|
|
class Forgejo(Service):
|
|
"""Class representing Forgejo service.
|
|
|
|
Previously was Gitea, so some IDs are still called gitea for compatibility.
|
|
"""
|
|
|
|
@staticmethod
|
|
def get_id() -> str:
|
|
"""Return service id. For compatibility keep in gitea."""
|
|
return "gitea"
|
|
|
|
@staticmethod
|
|
def get_display_name() -> str:
|
|
"""Return service display name."""
|
|
return "Forgejo"
|
|
|
|
@staticmethod
|
|
def get_description() -> str:
|
|
"""Return service description."""
|
|
return "Forgejo is a Git forge."
|
|
|
|
@staticmethod
|
|
def get_svg_icon() -> str:
|
|
"""Read SVG icon from file and return it as base64 encoded string."""
|
|
return base64.b64encode(FORGEJO_ICON.encode("utf-8")).decode("utf-8")
|
|
|
|
@classmethod
|
|
def get_url(cls) -> Optional[str]:
|
|
"""Return service url."""
|
|
domain = get_domain()
|
|
return f"https://git.{domain}"
|
|
|
|
@classmethod
|
|
def get_subdomain(cls) -> Optional[str]:
|
|
return "git"
|
|
|
|
@staticmethod
|
|
def is_movable() -> bool:
|
|
return True
|
|
|
|
@staticmethod
|
|
def is_required() -> bool:
|
|
return False
|
|
|
|
@staticmethod
|
|
def get_backup_description() -> str:
|
|
return "Git repositories, database and user data."
|
|
|
|
@staticmethod
|
|
def get_status() -> ServiceStatus:
|
|
"""
|
|
Return Gitea status from systemd.
|
|
Use command return code to determine status.
|
|
Return code 0 means service is running.
|
|
Return code 1 or 2 means service is in error stat.
|
|
Return code 3 means service is stopped.
|
|
Return code 4 means service is off.
|
|
"""
|
|
return get_service_status("forgejo.service")
|
|
|
|
@staticmethod
|
|
def stop():
|
|
subprocess.run(["systemctl", "stop", "forgejo.service"])
|
|
|
|
@staticmethod
|
|
def start():
|
|
subprocess.run(["systemctl", "start", "forgejo.service"])
|
|
|
|
@staticmethod
|
|
def restart():
|
|
subprocess.run(["systemctl", "restart", "forgejo.service"])
|
|
|
|
@staticmethod
|
|
def get_configuration():
|
|
return {}
|
|
|
|
@staticmethod
|
|
def set_configuration(config_items):
|
|
return super().set_configuration(config_items)
|
|
|
|
@staticmethod
|
|
def get_logs():
|
|
return ""
|
|
|
|
@staticmethod
|
|
def get_folders() -> List[str]:
|
|
"""The data folder is still called gitea for compatibility."""
|
|
return ["/var/lib/gitea"]
|