Drop Latest change lines, add initial support for Debian/squeeze
[grml-live.git] / etc / grml / fai / config / scripts / GRMLBASE / 21-usersetup
1 #!/bin/sh
2 # Filename:      /etc/grml/fai/config/scripts/GRMLBASE/21-usersetup
3 # Purpose:       adjust user setup of the live-system
4 # Authors:       grml-team (grml.org), (c) Michael Prokop <mika@grml.org>
5 # Bug-Reports:   see http://grml.org/bugs/
6 # License:       This file is licensed under the GPL v2 or any later version.
7 ################################################################################
8
9 set -u
10 set -e
11
12 USERNAME=''
13 [ -r /etc/grml/grml-live.conf ]  && . /etc/grml/grml-live.conf
14 [ -r /etc/grml/grml-live.local ] && . /etc/grml/grml-live.local
15 [ -n "$USERNAME" ] || USERNAME=grml
16
17 if grep -q "$USERNAME:x:1000" $target/etc/group ; then
18    echo "group $USERNAME exists already, skipping"
19 else
20   if grep -q 'gsmsms:x:1000' $target/etc/group ; then
21      echo 'Bug #353967 detected, fixing GUID = 1000 setup for you'
22      $ROOTCMD delgroup gsmsms || /bin/true
23      $ROOTCMD deluser gsmsms  || /bin/true
24      $ROOTCMD addgroup --system gsmsms || /bin/true
25      $ROOTCMD adduser --system --ingroup gsmsms \
26                       --no-create-home --home /var/spool/sms gsmsms || /bin/true
27      $ROOTCMD adduser gsmsms dialout || /bin/true
28   fi
29   $ROOTCMD addgroup --gid 1000 $USERNAME
30 fi
31
32 if grep -q "$USERNAME:x:1000" $target/etc/passwd ; then
33    echo "user $USERNAME exists already, skipping"
34 else
35    $ROOTCMD useradd -d /home/$USERNAME -m -s /bin/zsh -g 1000 $USERNAME
36 fi
37
38 # make sure to add the user to all relevant groups:
39 add_user_to_group() {
40    [ -n "$1" ] || return 1
41    if grep -q $1 $target/etc/group ; then
42       grep "$1:x:.*$USERNAME" $target/etc/group || $ROOTCMD addgroup $USERNAME $1
43    fi
44 }
45
46 add_user_to_group audio
47 add_user_to_group camera
48 add_user_to_group cdrom
49 add_user_to_group dialout
50 add_user_to_group dip
51 add_user_to_group fax
52 add_user_to_group floppy
53 add_user_to_group fuse
54 add_user_to_group games
55 add_user_to_group nvram
56 add_user_to_group plugdev
57 add_user_to_group scanner
58 add_user_to_group sudo
59 add_user_to_group tape
60 add_user_to_group tty
61 add_user_to_group usb
62 add_user_to_group users
63 add_user_to_group video
64 add_user_to_group vlock
65 add_user_to_group voice
66
67 sed -i 's/^root::/root:*:/'            $target/etc/shadow
68 sed -i "s/^$USERNAME:!:/$USERNAME:*:/" $target/etc/shadow
69
70 # make sure users can log in on consoles 4, 5 and 6 if username != grml:
71 if [ "$USERNAME" != "grml" ] ; then
72    sed -i "s/-u grml -g grml --autologin grml/-u ${USERNAME} -g ${USERNAME} --autologin ${USERNAME}/" \
73    $target/etc/inittab.grml
74 fi
75
76 if [ -r $target/bin/zsh ] ; then
77    $ROOTCMD chsh -s /bin/zsh root
78    $ROOTCMD chsh -s /bin/zsh $USERNAME
79 fi
80
81 ## END OF FILE #################################################################
82 # vim:ft=sh expandtab ai tw=80 tabstop=4 shiftwidth=3