support fake steps

main
mirkobrombin 2 years ago
parent b2c404477a
commit d9e15e3edb

@ -1,13 +1,18 @@
import logging
from ubuntu_smoother.utils import checks
from ubuntu_smoother.utils.apt import Apt
from ubuntu_smoother.utils.flatpak import Flatpak
from ubuntu_smoother.utils.snap import Snap
logger = logging.getLogger("UbuntuSmoother::Configurator")
class Configurator:
def __init__(self, config: 'Config'):
def __init__(self, config: 'Config', fake: bool = False):
self.config = config
self.fake = fake
def apply(self):
self.__enable_snap() if self.config.snap else self.__disable_snap()
@ -15,6 +20,10 @@ class Configurator:
self.__enable_apport() if self.config.apport else self.__disable_apport()
def __enable_snap(self):
if self.fake:
logger.info("Fake: Snap enabled")
return
pkgs = []
if not checks.is_snap_installed():
pkgs += ['snapd', 'gnome-software-plugin-snap']
@ -25,15 +34,44 @@ class Configurator:
Snap.install(['snap-store'])
def __disable_snap(self):
if self.fake:
logger.info("Fake: Snap disabled")
return
if checks.is_snap_installed():
Apt.purge(['snapd'])
def __enable_flatpak(self):
if self.fake:
logger.info("Fake: Flatpak enabled")
return
if not checks.is_flatpak_installed():
Apt.install(['flatpak'])
Flatpak.add_repo("https://flathub.org/repo/flathub.flatpakrepo")
Apt.update()
def __disable_flatpak(self):
if self.fake:
logger.info("Fake: Flatpak disabled")
return
if checks.is_flatpak_installed():
Apt.purge(['flatpak'])
def __enable_apport(self):
if self.fake:
logger.info("Fake: Apport enabled")
return
if not checks.is_apport_installed():
Apt.install(['apport'])
Apt.update()
def __disable_apport(self):
if self.fake:
logger.info("Fake: Apport disabled")
return
if checks.is_apport_installed():
Apt.purge(['apport'])

Loading…
Cancel
Save