mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2024-11-25 13:31:27 +00:00
feat: add migration for services flake
This commit is contained in:
parent
31feeb211d
commit
4d898f4ee8
34
selfprivacy_api/migrations/update_services_flake_list.py
Normal file
34
selfprivacy_api/migrations/update_services_flake_list.py
Normal file
|
@ -0,0 +1,34 @@
|
|||
from selfprivacy_api.migrations.migration import Migration
|
||||
from selfprivacy_api.jobs import JobStatus, Jobs
|
||||
|
||||
from selfprivacy_api.services.flake_service_manager import FlakeServiceManager
|
||||
|
||||
CORRECT_SERVICES_LIST = {
|
||||
"bitwarden": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/bitwarden",
|
||||
"gitea": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/gitea",
|
||||
"jitsi-meet": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/jitsi-meet",
|
||||
"nextcloud": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/nextcloud",
|
||||
"ocserv": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/ocserv",
|
||||
"pleroma": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/pleroma",
|
||||
"simple-nixos-mailserver": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/simple-nixos-mailserver",
|
||||
"roundcube": "git+https://git.selfprivacy.org/SelfPrivacy/selfprivacy-nixos-config.git?ref=flakes&dir=sp-modules/roundcube",
|
||||
}
|
||||
|
||||
|
||||
class UpdateServicesFlakeList(Migration):
|
||||
"""Check if all required services are in the flake list"""
|
||||
|
||||
def get_migration_name(self):
|
||||
return "update_services_flake_list"
|
||||
|
||||
def get_migration_description(self):
|
||||
return "Check if all required services are in the flake list"
|
||||
|
||||
def is_migration_needed(self):
|
||||
with FlakeServiceManager:
|
||||
if not manager.services == CORRECT_SERVICES_LIST:
|
||||
return True
|
||||
|
||||
def migrate(self):
|
||||
with FlakeServiceManager:
|
||||
manager.services = CORRECT_SERVICES_LIST
|
Loading…
Reference in a new issue