From 32322960234c8ec91e0d42835a3ec5ee63305070 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 2 Feb 2019 11:00:00 +0100 Subject: Adding upstream version 20190202. Signed-off-by: Daniel Baumann --- system-config/components/0040-sudo | 97 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100755 system-config/components/0040-sudo (limited to 'system-config/components/0040-sudo') diff --git a/system-config/components/0040-sudo b/system-config/components/0040-sudo new file mode 100755 index 0000000..8b828cb --- /dev/null +++ b/system-config/components/0040-sudo @@ -0,0 +1,97 @@ +#!/bin/sh + +## live-config(7) - System Configuration Components +## Copyright (C) 2006-2015 Daniel Baumann +## +## This program comes with ABSOLUTELY NO WARRANTY; for details see COPYING. +## This is free software, and you are welcome to redistribute it +## under certain conditions; see COPYING for details. + + +#set -e + +Cmdline () +{ + # Reading kernel command line + for _PARAMETER in ${LIVE_CONFIG_CMDLINE} + do + case "${_PARAMETER}" in + live-config.noroot|noroot) + LIVE_CONFIG_NOROOT="true" + ;; + + live-config.username=*|username=*) + LIVE_USERNAME="${_PARAMETER#*username=}" + ;; + esac + done +} + +Init () +{ + # Disable root access, no matter what mechanism + case "${LIVE_CONFIG_NOROOT}" in + true) + exit 0 + ;; + esac + + # Checking if package is installed or already configured + if [ ! -e /var/lib/dpkg/info/sudo.list ] || \ + [ -e /var/lib/live/config/sudo ] + then + exit 0 + fi + + echo -n " sudo" + +} + +Config () +{ + # Skip sudo configuration if username is root + case "${LIVE_USERNAME}" in + root) + exit 0 + ;; + esac + + # Checking if package is already configured differently + if grep -qs "^${LIVE_USERNAME}" /etc/sudoers.d/live + then + exit 0 + fi + + echo "${LIVE_USERNAME} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers.d/live + chmod 0440 /etc/sudoers.d/live + + sudo -u "${LIVE_USERNAME}" sh -c "echo 'SU_TO_ROOT_SU=sudo' >> /home/${LIVE_USERNAME}/.su-to-rootrc" + + if [ -x /usr/bin/gconftool-2 ] + then + sudo -u "${LIVE_USERNAME}" gconftool-2 -s -t bool /apps/gksu/sudo-mode true + sudo -u "${LIVE_USERNAME}" gconftool-2 -s -t bool /apps/gksu/display-no-pass-info false + fi + + sudo -u "${LIVE_USERNAME}" sh -c "umask 0077 && mkdir -p /home/${LIVE_USERNAME}/.kde/share/config && cat > /home/${LIVE_USERNAME}/.kde/share/config/kdesurc" << EOF +[super-user-command] +super-user-command=sudo +EOF + + if [ -e /usr/share/apps/konsole/sumc.desktop ] + then + sudo -u "${LIVE_USERNAME}" sh -c "umask 0077 && mkdir -p /home/${LIVE_USERNAME}/.kde/share/apps/konsole && sed -e's/Exec=su.*$/Exec=sudo mc -c/' /usr/share/apps/konsole/sumc.desktop > /home/${LIVE_USERNAME}/.kde/share/apps/konsole/sumc.desktop" + fi + + if [ -e /usr/share/apps/konsole/su.desktop ] + then + sudo -u "${LIVE_USERNAME}" sh -c "umask 0077 && mkdir -p /home/${LIVE_USERNAME}/.kde/share/apps/konsole && sed -e's/Exec=su.*$/Exec=sudo -i/' /usr/share/apps/konsole/su.desktop > /home/${LIVE_USERNAME}/.kde/share/apps/konsole/su.desktop" + fi + + # Creating state file + touch /var/lib/live/config/sudo +} + +Cmdline +Init +Config -- cgit v1.2.3