[displaymanager] Move basic setup to DM classes

- For all the DMs that have some kind of basic setup,
   introduce a method in the DM class for doing just that.
 - The Python code now doesn't call basic setup anywhere,
   so this specific revision isn't going to work properly.
main
Adriaan de Groot 6 years ago
parent 47b58083f7
commit cd0cdfc9af

@ -114,6 +114,12 @@ class DisplayManager(metaclass=abc.ABCMeta):
as well. as well.
""" """
@abc.abstractmethod
def basic_setup(self):
"""
Do basic setup (e.g. users, groups, directory creation) for this DM.
"""
class DMmdm(DisplayManager): class DMmdm(DisplayManager):
name = "mdm" name = "mdm"
@ -156,6 +162,38 @@ class DMmdm(DisplayManager):
else: else:
mdm_conf.write('AutomaticLoginEnable=False\n') mdm_conf.write('AutomaticLoginEnable=False\n')
def basic_setup(self):
if libcalamares.utils.target_env_call(
['getent', 'group', 'mdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '128', 'mdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'mdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-c', '"Linux Mint Display Manager"',
'-u', '128',
'-g', 'mdm',
'-d', '/var/lib/mdm',
'-s', '/usr/bin/nologin',
'mdm'
]
)
libcalamares.utils.target_env_call(
['passwd', '-l', 'mdm']
)
libcalamares.utils.target_env_call(
['chown', 'root:mdm', '/var/lib/mdm']
)
libcalamares.utils.target_env_call(
['chmod', '1770', '/var/lib/mdm']
)
class DMgdm(DisplayManager): class DMgdm(DisplayManager):
name = "gdm" name = "gdm"
@ -211,6 +249,36 @@ class DMgdm(DisplayManager):
userfile.write("Icon=\n") userfile.write("Icon=\n")
def basic_setup(self):
if libcalamares.utils.target_env_call(
['getent', 'group', 'gdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '120', 'gdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'gdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-c', '"Gnome Display Manager"',
'-u', '120',
'-g', 'gdm',
'-d', '/var/lib/gdm',
'-s', '/usr/bin/nologin',
'gdm'
]
)
libcalamares.utils.target_env_call(
['passwd', '-l', 'gdm']
)
libcalamares.utils.target_env_call(
['chown', '-R', 'gdm:gdm', '/var/lib/gdm']
)
class DMkdm(DisplayManager): class DMkdm(DisplayManager):
name = "kdm" name = "kdm"
executable = "kdm" executable = "kdm"
@ -255,6 +323,33 @@ class DMkdm(DisplayManager):
"KDM config file {!s} does not exist".format(kdm_conf_path) "KDM config file {!s} does not exist".format(kdm_conf_path)
) )
def basic_setup(self):
if libcalamares.utils.target_env_call(
['getent', 'group', 'kdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '135', 'kdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'kdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-u', '135',
'-g', 'kdm',
'-d', '/var/lib/kdm',
'-s', '/bin/false',
'-r',
'-M',
'kdm'
]
)
libcalamares.utils.target_env_call(
['chown', '-R', '135:135', 'var/lib/kdm']
)
class DMlxdm(DisplayManager): class DMlxdm(DisplayManager):
name = "lxdm" name = "lxdm"
@ -284,6 +379,24 @@ class DMlxdm(DisplayManager):
"LXDM config file {!s} does not exist".format(lxdm_conf_path) "LXDM config file {!s} does not exist".format(lxdm_conf_path)
) )
def basic_setup(self):
if libcalamares.utils.target_env_call(
['getent', 'group', 'lxdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '--system', 'lxdm']
)
libcalamares.utils.target_env_call(
['chgrp', '-R', 'lxdm', '/var/lib/lxdm']
)
libcalamares.utils.target_env_call(
['chgrp', 'lxdm', '/etc/lxdm/lxdm.conf']
)
libcalamares.utils.target_env_call(
['chmod', '+r', '/etc/lxdm/lxdm.conf']
)
class DMlightdm(DisplayManager): class DMlightdm(DisplayManager):
name = "lightdm" name = "lightdm"
@ -332,6 +445,41 @@ class DMlightdm(DisplayManager):
) )
def basic_setup(self):
libcalamares.utils.target_env_call(
['mkdir', '-p', '/run/lightdm']
)
if libcalamares.utils.target_env_call(
['getent', 'group', 'lightdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '620', 'lightdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'lightdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd', '-c',
'"LightDM Display Manager"',
'-u', '620',
'-g', 'lightdm',
'-d', '/var/run/lightdm',
'-s', '/usr/bin/nologin',
'lightdm'
]
)
libcalamares.utils.target_env_call('passwd', '-l', 'lightdm')
libcalamares.utils.target_env_call(
['chown', '-R', 'lightdm:lightdm', '/run/lightdm']
)
libcalamares.utils.target_env_call(
['chmod', '+r' '/etc/lightdm/lightdm.conf']
)
class DMslim(DisplayManager): class DMslim(DisplayManager):
name = "slim" name = "slim"
executable = "slim" executable = "slim"
@ -364,6 +512,10 @@ class DMslim(DisplayManager):
) )
def basic_setup(self):
pass
class DMsddm(DisplayManager): class DMsddm(DisplayManager):
name = "sddm" name = "sddm"
executable = "sddm" executable = "sddm"
@ -398,6 +550,10 @@ class DMsddm(DisplayManager):
sddm_config.write(sddm_config_file, space_around_delimiters=False) sddm_config.write(sddm_config_file, space_around_delimiters=False)
def basic_setup(self):
pass
class DMsysconfig(DisplayManager): class DMsysconfig(DisplayManager):
name = "sysconfig" name = "sysconfig"
executable = None executable = None
@ -415,6 +571,10 @@ class DMsysconfig(DisplayManager):
) )
def basic_setup(self):
pass
# Collect all the subclasses of DisplayManager defined above, # Collect all the subclasses of DisplayManager defined above,
# and index them based on the name property of each class. # and index them based on the name property of each class.
display_managers = [ display_managers = [
@ -520,40 +680,6 @@ def run():
root_mount_point, "etc/lightdm/lightdm.conf" root_mount_point, "etc/lightdm/lightdm.conf"
) )
if enable_basic_setup:
libcalamares.utils.target_env_call(
['mkdir', '-p', '/run/lightdm']
)
if libcalamares.utils.target_env_call(
['getent', 'group', 'lightdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '620', 'lightdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'lightdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd', '-c',
'"LightDM Display Manager"',
'-u', '620',
'-g', 'lightdm',
'-d', '/var/run/lightdm',
'-s', '/usr/bin/nologin',
'lightdm'
]
)
libcalamares.utils.target_env_call('passwd', '-l', 'lightdm')
libcalamares.utils.target_env_call(
['chown', '-R', 'lightdm:lightdm', '/run/lightdm']
)
libcalamares.utils.target_env_call(
['chmod', '+r' '/etc/lightdm/lightdm.conf']
)
if default_desktop_environment is not None: if default_desktop_environment is not None:
os.system( os.system(
"sed -i -e \"s/^.*user-session=.*/user-session={!s}/\" " "sed -i -e \"s/^.*user-session=.*/user-session={!s}/\" "
@ -596,34 +722,7 @@ def run():
# Setup gdm # Setup gdm
if "gdm" in displaymanagers: if "gdm" in displaymanagers:
if have_dm("gdm", root_mount_point): if have_dm("gdm", root_mount_point):
if enable_basic_setup: pass
if libcalamares.utils.target_env_call(
['getent', 'group', 'gdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '120', 'gdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'gdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-c', '"Gnome Display Manager"',
'-u', '120',
'-g', 'gdm',
'-d', '/var/lib/gdm',
'-s', '/usr/bin/nologin',
'gdm'
]
)
libcalamares.utils.target_env_call(
['passwd', '-l', 'gdm']
)
libcalamares.utils.target_env_call(
['chown', '-R', 'gdm:gdm', '/var/lib/gdm']
)
else: else:
libcalamares.utils.debug("gdm selected but not installed") libcalamares.utils.debug("gdm selected but not installed")
displaymanagers.remove("gdm") displaymanagers.remove("gdm")
@ -631,38 +730,6 @@ def run():
# Setup mdm # Setup mdm
if "mdm" in displaymanagers: if "mdm" in displaymanagers:
if have_dm("mdm", root_mount_point): if have_dm("mdm", root_mount_point):
if enable_basic_setup:
if libcalamares.utils.target_env_call(
['getent', 'group', 'mdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '128', 'mdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'mdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-c', '"Linux Mint Display Manager"',
'-u', '128',
'-g', 'mdm',
'-d', '/var/lib/mdm',
'-s', '/usr/bin/nologin',
'mdm'
]
)
libcalamares.utils.target_env_call(
['passwd', '-l', 'mdm']
)
libcalamares.utils.target_env_call(
['chown', 'root:mdm', '/var/lib/mdm']
)
libcalamares.utils.target_env_call(
['chmod', '1770', '/var/lib/mdm']
)
if default_desktop_environment is not None: if default_desktop_environment is not None:
os.system( os.system(
"sed -i \"s|default.desktop|{!s}.desktop|g\" " "sed -i \"s|default.desktop|{!s}.desktop|g\" "
@ -678,24 +745,6 @@ def run():
# Setup lxdm # Setup lxdm
if "lxdm" in displaymanagers: if "lxdm" in displaymanagers:
if have_dm("lxdm", root_mount_point): if have_dm("lxdm", root_mount_point):
if enable_basic_setup:
if libcalamares.utils.target_env_call(
['getent', 'group', 'lxdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '--system', 'lxdm']
)
libcalamares.utils.target_env_call(
['chgrp', '-R', 'lxdm', '/var/lib/lxdm']
)
libcalamares.utils.target_env_call(
['chgrp', 'lxdm', '/etc/lxdm/lxdm.conf']
)
libcalamares.utils.target_env_call(
['chmod', '+r', '/etc/lxdm/lxdm.conf']
)
if default_desktop_environment is not None: if default_desktop_environment is not None:
os.system( os.system(
"sed -i -e \"s|^.*session=.*|session={!s}|\" " "sed -i -e \"s|^.*session=.*|session={!s}|\" "
@ -711,32 +760,7 @@ def run():
# Setup kdm # Setup kdm
if "kdm" in displaymanagers: if "kdm" in displaymanagers:
if have_dm("kdm", root_mount_point): if have_dm("kdm", root_mount_point):
if enable_basic_setup: pass
if libcalamares.utils.target_env_call(
['getent', 'group', 'kdm']
) != 0:
libcalamares.utils.target_env_call(
['groupadd', '-g', '135', 'kdm']
)
if libcalamares.utils.target_env_call(
['getent', 'passwd', 'kdm']
) != 0:
libcalamares.utils.target_env_call(
['useradd',
'-u', '135',
'-g', 'kdm',
'-d', '/var/lib/kdm',
'-s', '/bin/false',
'-r',
'-M',
'kdm'
]
)
libcalamares.utils.target_env_call(
['chown', '-R', '135:135', 'var/lib/kdm']
)
else: else:
libcalamares.utils.debug("kdm selected but not installed") libcalamares.utils.debug("kdm selected but not installed")
displaymanagers.remove("kdm") displaymanagers.remove("kdm")

Loading…
Cancel
Save