2022-07-25 14:08:31 +00:00
|
|
|
"""Class representing Nextcloud service."""
|
|
|
|
import base64
|
|
|
|
import subprocess
|
2022-08-25 17:03:56 +00:00
|
|
|
import typing
|
|
|
|
from selfprivacy_api.jobs import Job, Jobs
|
|
|
|
from selfprivacy_api.services.generic_service_mover import FolderMoveNames, move_service
|
|
|
|
from selfprivacy_api.services.generic_status_getter import get_service_status
|
|
|
|
from selfprivacy_api.services.service import Service, ServiceDnsRecord, ServiceStatus
|
|
|
|
from selfprivacy_api.utils import ReadUserData, WriteUserData, get_domain
|
|
|
|
from selfprivacy_api.utils.block_devices import BlockDevice
|
|
|
|
import selfprivacy_api.utils.network as network_utils
|
|
|
|
from selfprivacy_api.services.nextcloud.icon import NEXTCLOUD_ICON
|
2022-07-25 14:08:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Nextcloud(Service):
|
|
|
|
"""Class representing Nextcloud service."""
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_id() -> str:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Return service id."""
|
|
|
|
return "nextcloud"
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_display_name() -> str:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Return service display name."""
|
|
|
|
return "Nextcloud"
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_description() -> str:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Return service description."""
|
|
|
|
return "Nextcloud is a cloud storage service that offers a web interface and a desktop client."
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_svg_icon() -> str:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Read SVG icon from file and return it as base64 encoded string."""
|
2022-08-25 17:03:56 +00:00
|
|
|
return base64.b64encode(NEXTCLOUD_ICON.encode("utf-8")).decode("utf-8")
|
2022-07-25 14:08:31 +00:00
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_url() -> typing.Optional[str]:
|
|
|
|
"""Return service url."""
|
|
|
|
domain = get_domain()
|
|
|
|
return f"https://cloud.{domain}"
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def is_movable() -> bool:
|
|
|
|
return True
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def is_required() -> bool:
|
|
|
|
return False
|
|
|
|
|
2023-06-29 11:27:08 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_backup_description() -> str:
|
|
|
|
return "All the files and other data stored in Nextcloud."
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def is_enabled() -> bool:
|
2022-07-25 14:08:31 +00:00
|
|
|
with ReadUserData() as user_data:
|
2023-11-21 20:14:42 +00:00
|
|
|
return (
|
|
|
|
user_data.get("modules", {}).get("nextcloud", {}).get("enable", False)
|
|
|
|
)
|
2022-07-25 14:08:31 +00:00
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_status() -> ServiceStatus:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""
|
|
|
|
Return Nextcloud 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.
|
|
|
|
"""
|
2022-08-25 17:03:56 +00:00
|
|
|
return get_service_status("phpfpm-nextcloud.service")
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def enable():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Enable Nextcloud service."""
|
|
|
|
with WriteUserData() as user_data:
|
2023-11-21 20:14:42 +00:00
|
|
|
if "modules" not in user_data:
|
|
|
|
user_data["modules"] = {}
|
2022-07-25 14:08:31 +00:00
|
|
|
if "nextcloud" not in user_data:
|
|
|
|
user_data["nextcloud"] = {}
|
|
|
|
user_data["nextcloud"]["enable"] = True
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def disable():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Disable Nextcloud service."""
|
|
|
|
with WriteUserData() as user_data:
|
2023-11-21 20:14:42 +00:00
|
|
|
if "modules" not in user_data:
|
|
|
|
user_data["modules"] = {}
|
2022-07-25 14:08:31 +00:00
|
|
|
if "nextcloud" not in user_data:
|
|
|
|
user_data["nextcloud"] = {}
|
|
|
|
user_data["nextcloud"]["enable"] = False
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def stop():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Stop Nextcloud service."""
|
|
|
|
subprocess.Popen(["systemctl", "stop", "phpfpm-nextcloud.service"])
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def start():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Start Nextcloud service."""
|
|
|
|
subprocess.Popen(["systemctl", "start", "phpfpm-nextcloud.service"])
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def restart():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Restart Nextcloud service."""
|
|
|
|
subprocess.Popen(["systemctl", "restart", "phpfpm-nextcloud.service"])
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_configuration() -> dict:
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Return Nextcloud configuration."""
|
|
|
|
return {}
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def set_configuration(config_items):
|
2022-07-25 14:08:31 +00:00
|
|
|
return super().set_configuration(config_items)
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_logs():
|
2022-07-25 14:08:31 +00:00
|
|
|
"""Return Nextcloud logs."""
|
|
|
|
return ""
|
|
|
|
|
2023-04-17 13:47:49 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_folders() -> typing.List[str]:
|
|
|
|
return ["/var/lib/nextcloud"]
|
|
|
|
|
2022-08-25 17:03:56 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_dns_records() -> typing.List[ServiceDnsRecord]:
|
|
|
|
return [
|
|
|
|
ServiceDnsRecord(
|
|
|
|
type="A",
|
|
|
|
name="cloud",
|
|
|
|
content=network_utils.get_ip4(),
|
|
|
|
ttl=3600,
|
|
|
|
),
|
|
|
|
ServiceDnsRecord(
|
|
|
|
type="AAAA",
|
|
|
|
name="cloud",
|
|
|
|
content=network_utils.get_ip6(),
|
|
|
|
ttl=3600,
|
|
|
|
),
|
|
|
|
]
|
|
|
|
|
|
|
|
def move_to_volume(self, volume: BlockDevice) -> Job:
|
2022-10-27 14:01:11 +00:00
|
|
|
job = Jobs.add(
|
2022-08-25 17:03:56 +00:00
|
|
|
type_id="services.nextcloud.move",
|
|
|
|
name="Move Nextcloud",
|
|
|
|
description=f"Moving Nextcloud to volume {volume.name}",
|
|
|
|
)
|
|
|
|
move_service(
|
|
|
|
self,
|
|
|
|
volume,
|
|
|
|
job,
|
2023-04-19 12:43:47 +00:00
|
|
|
FolderMoveNames.default_foldermoves(self),
|
2022-08-25 17:03:56 +00:00
|
|
|
"nextcloud",
|
|
|
|
)
|
|
|
|
return job
|