@ -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 " )