Rev 1 | Go to most recent revision | Blame | Last modification | View Log | Download | RSS feed
#!/bin/bash################################################################## LiveCD customization script## Run this script on a SL Installation# to prepare the system for a LiveCD## Urs Beyerle, PSI################################################################# source livecd.conf. livecd.conf###############################################################function usage() {## Usage# ----------------------------------------------------------cat <<EOFOptional Options:-h: print this screen-psi: customize for PSI Live CD-dvd: customize for Live DVD-mini: customize for Mini Live CDEOF}############################################################################################################################### Definitions################################################################## read options from command-linePSI=""while [ $# -gt 0 ]; docase "$1" in-h)usage; exit;;-psi)PSI=-psi; shift; continue;;-dvd)DVD=-dvd; shift; continue;;-mini)MINI=-mini; shift; continue;;*)usage; exit;;esacdone### arch x86_64 or i686 ?ARCH=$( /bin/arch )[ "$ARCH" != "x86_64" ] && ARCH=i686### Local usernameif [ $PSI ]; thenLOCALUSER=l_psielseLOCALUSER=sluserfi################################################################ Backup some original files###############################################################echo "Backup original files ..."ori_files="/etc/init.d/netfs \/etc/init.d/autofs \/etc/init.d/halt \/etc/init.d/network/etc/init.d/functions \/etc/rc.d/rc.sysinit \/etc/sysconfig/afs \/etc/motd \/etc/redhat-release \/etc/rc.d/rc.sysinit \/etc/resolv.conf"for file in $ori_files; do[ ! -e ${file}.ori ] && cp -a ${file} ${file}.ori 2>/dev/nulldone################################################################ Configure system###############################################################echo "Configure system ..."# build nvidia kernel modulesif [ -x /usr/sbin/mknvidia ]; thenmknvidiafi# build vpnclient kernel moduleif [ -x /usr/sbin/mkvpnclient ]; thenmkvpnclientfi# Update Virus definitions# run freshclamif [ -x /usr/bin/freshclam ]; thenecho; echo "Run /usr/bin/freshclam:"/etc/init.d/clamd status || /etc/init.d/clamd start && /usr/bin/freshclam/etc/init.d/clamd stopechofi# update f-prot and uvscan[ -x /usr/local/f-prot/tools/check-updates.pl ] && /usr/local/f-prot/tools/check-updates.pl[ -x /usr/local/uvscan/update-dat ] && /usr/local/uvscan/update-dat# run depmod -a for the LiveCD kernelsecho "Run depmod -a $KERNEL ..."; depmod -a $KERNELif [ $SMP ]; thenecho "Run depmod -a ${KERNEL}smp ..."depmod -a ${KERNEL}smpfi# delete users (just to be sure)userdel -r $LOCALUSER 2>/dev/nulluserdel -r l_psi 2>/dev/nulluserdel -r sluser 2>/dev/nulluserdel -r user 2>/dev/null# move /opt to /usr/opt and link /opt -> /usr/opt# (if not already yet done before)if [ ! -L /opt ]; thenecho "Move /opt to /usr/opt"mv /opt /usr/ln -s /usr/opt /optfi# umount PSI masterif [ $PSI ]; thenumount /mnt/master 2>/dev/nullfi# copy back /etc/yum.repos.dif [ ! $PSI ]; thenif [ -d /etc/yum.repos.d.ori ]; thencp -a /etc/yum.repos.d.ori /etc/yum.repos.dfifi# run cfagentif [ $PSI ]; then# cfagent needs running afs/etc/init.d/afs startecho "Run cfagent ..."cfagentfiecho "done."echo "--------------------------------------------"################################################################ Clean up and delete files###############################################################echo "Cleaning up ..."### set LANGexport LANG=C### stop AFS/etc/init.d/afs stop 2>/dev/null### clean up yumyum clean all >/dev/nullrm -rf /var/cache/yum/*### remove cfengine log filesrm -f /var/cfengine/*log### delete log filesfind /var/log/ -type f -exec rm -f {} \;### clean rpm databaserm -rf /var/lib/rpm/__db.*### clean /var/spool/mailrm -rf /var/spool/mail/*touch /var/spool/mail/rootchmod 600 /var/spool/mail/root### delete .cfsaved Filesif [ $PSI ]; thenecho -n "Delete .cfsaved Files, please wait: "find / -xdev -name "*\.cfsaved" -exec rm -f {} \;echo "ok."fi### delete .rpmori .rpm Files in /etcfind /etc -name "*\.rpmorig" -exec rm -f {} \;find /etc -name "*\.rpmnew" -exec rm -f {} \;### delete *~ files in /etcfind /etc | grep "~$" | while read f; do rm -f "$f"; done### clean up /rootrm -f /root/.bash_historyrm -f /root/.ssh/known_hosts### clean AFS cacheif [ -d /usr/vice/cache ]; thenrm -rf /usr/vice/cachemkdir /usr/vice/cachefiif [ -d /var/cache/openafs ]; thenrm -rf /var/cache/openafsmkdir /var/cache/openafsfi### clean up /var/tmprm -rf /var/tmp/*### remove root passwdsed -i "s|^root:.*|root:\*:12943:0:99999:7:::|" /etc/shadowsed -i "s|^root:.*:0:0|root:x:0:0|" /etc/passwd### remove /.autofsckrm -rf /.autofsck### disable cfagentrm -f /etc/cron.d/cfengine### disable check_update in rc.local.psiif [ $PSI ]; thensed -i "s|/etc/init.d/check_update|# /etc/init.d/check_update|" /etc/rc.d/rc.local.psifi### create in /boot link to LiveCD kernel(s)ln -fs /boot/vmlinuz-$KERNEL /boot/vmlinuz[ $SMP ] && ln -fs /boot/vmlinuz-${KERNEL}smp /boot/vmlinuz${SMP}### Files to removeFILES_REMOVE="/etc/ssh/ssh_host_key \/etc/ssh/ssh_host_key.pub \/etc/ssh/ssh_host_rsa_key.pub \/etc/ssh/ssh_host_dsa_key \/etc/ssh/ssh_host_dsa_key.pub"for file in $FILES_REMOVE; dorm -rf $filedone### remove useless cronjobsmkdir -p /etc/cron_backupmv /etc/cron.d/sysstat /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/00-makewhatis.cron /etc/cron_backup/ 2>/dev/nullmv /etc/cron.weekly/00-makewhatis.cron /etc/cron_backup/00-makewhatis.cron.weekly 2>/dev/nullmv /etc/cron.daily/rpm /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/slocate.cron /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/tetex.cron /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/yum.cron /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/prelink /etc/cron_backup/ 2>/dev/nullmv /etc/cron.daily/00-logwatch /etc/cron_backup/ 2>/dev/null### remove desktop entry from crossoverif [ $PSI ]; thenrm -rf "/usr/share/apps/kdesktop/DesktopLinks/Internet Explorer.desktop"fi### remove backup of /etc/X11/xorg.confrm -f /etc/X11/xorg.conf.ori 2>/dev/nullrm -f /etc/X11/xorg.conf.backup 2>/dev/null### remove unused dirs in /lib/modulesls /lib/modules/ | grep -v $KERNEL | while read mod_dir; dorpm -qf --quiet /lib/modules/$mod_dirif [ $? != "0" ]; thenif [ $mod_dir != "" ]; thencleaned_dir=/tmp/cleaned-$( date +%Y%m%d%H%M )mkdir -p $cleaned_direcho "Move dir /lib/modules/$mod_dir to $cleaned_dir"mv -f /lib/modules/$mod_dir $cleaned_dir/fifidone### move some unneeded files to /mini (not for LiveDVD and miniCD)if [ ! $DVD ] && [ ! $MINI ]; then# to save disk spacemkdir -p /mini# move some dirs in /usr/share/doc to /minimkdir -p /mini/usr/share/docmv /usr/share/doc/openafs-* /mini/usr/share/doc 2>/dev/nullmv /usr/share/doc/gcc-* /mini/usr/share/doc 2>/dev/nullmv /usr/share/doc/pine-* /mini/usr/share/doc 2>/dev/nullmv /usr/share/doc/ntp-* /mini/usr/share/doc 2>/dev/null# move zipped java source to /mini, if j2sdk is installedjava_src=$( rpm -ql j2sdk 2>/dev/null | grep src.zip )[ -e "$java_src" ] && mv "$java_src" /mini/fiecho "done."echo "--------------------------------------------"################################################################ Modify files###############################################################echo "Modify files ..."### remove AFS startup warning about cacheif [ $PSI ]; thensed -i "/\!\!\!/d" /etc/init.d/afsfi### disable umount of loop device during shutdown# this is done really dirty at the moment:# -> just replace "loop" with non existing device "lo_fake"[ -e /etc/init.d/netfs ] && sed -i "s|/loop/|/lo_fake/|g" /etc/init.d/netfs[ -e /etc/init.d/autofs ] && sed -i "s|/loop/|/lo_fake/|g" /etc/init.d/autofs[ -e /etc/init.d/halt ] && sed -i "s|/loop/|/lo_fake/|g" /etc/init.d/halt[ -e /etc/init.d/functions ] && sed -i "s|/loop/|/lo_fake/|g" /etc/init.d/functions# do not shuttdown loopback interfacesed -i "s|[^#]action \$\"Shutting down loopback interface:|\t#action \$\"Shutting down loopback interface:|" /etc/init.d/network### copy new /etc/init.d/haltcp -a customize/sl${OS_RELEASE}/halt /etc/init.d/halt### in /etc/rc.d/rc.sysinit# comment out 'initlog -c "fsck -T -a $rootdev $fsckoptions"'# to disable fsck of root filesystemsed -i "s|\tfsck -T -a \$rootdev|\tsleep 0; #fsck -T -a \$rootdev|" /etc/rc.d/rc.sysinitsed -i "s|\tinitlog -c \"fsck -T -a \$rootdev|\tsleep 0; #initlog -c \"fsck -T -a \$rootdev|" /etc/rc.d/rc.sysinit# disable "Remounting root filesystem in read-write mode"sed -i "s| action \$\"Remounting root filesystem|#action \$\"Remounting root filesystem|" /etc/rc.d/rc.sysinit### start afs with option -memcache !if [ -e /etc/sysconfig/afs ]; thenif [ $PSI ]; thensed -i "s|^EXTRA_OPTIONS=.*|EXTRA_OPTIONS='-fakestat -memcache'|" /etc/sysconfig/afselsegrep -q "\-fakestat \-memcache" /etc/sysconfig/afsif [ "$?" != "0" ]; thensed -i "s|-fakestat|-fakestat -memcache|" /etc/sysconfig/afsfififi### source /etc/sysconfig/cfengine[ $PSI ] && . /etc/sysconfig/cfengine### Set /etc/motdif [ "$ARCH" = "x86_64" ]; thenLiveCD="LiveCD 64bit"elseLiveCD="LiveCD"fiif [ $PSI ]; thenecho "Welcome to PSI ${LiveCD} (${CLASS} ${SUBCLASS} SL${RELEASE})" > /etc/motdelseecho "Welcome to $LIVECD_OS ${LiveCD}" > /etc/motdfi### Set hostname to psi or slinux (not really necessary)if [ $PSI ]; thenHOSTNAME="psi"sed -i "s/hostname=.*/hostname=${HOSTNAME}.psi.ch/" /etc/ssmtp/ssmtp.confsed -i "s/HOSTNAME=.*/HOSTNAME=${HOSTNAME}/" /etc/sysconfig/cfengineelseHOSTNAME="slinux"fi# change hostnamesed -i "s/HOSTNAME=.*/HOSTNAME=${HOSTNAME}/" /etc/sysconfig/networksed -i "s/DHCP_HOSTNAME=.*/DHCP_HOSTNAME==${HOSTNAME}/" /etc/sysconfig/networking/devices/ifcfg-eth0 2>/dev/null### Modify /etc/redhat-releaseADD=" - LiveCD"grep -q "$ADD" /etc/redhat-releaseif [ "$?" != "0" ]; thenecho "$( cat /etc/redhat-release )${ADD}" > /etc/redhat-releasefiif [ $DVD ]; thensed -i "s|CD|DVD|" /etc/redhat-releasefi### Make scratchif [ $PSI ]; thenrm -rf /home/scratchmkdir -p /home/scratchchmod 1777 /home/scratchrm -rf /scratchln -s /home/scratch /scratchelserm -rf /home/scratchrm -rf /scratchmkdir -p /scratchchmod 1777 /scratchfi### set default runlevel to $RUNLEVELif [ $RUNLEVEL ]; thensed -i "s/id:.:initdefault:/id:$RUNLEVEL:initdefault:/" /etc/inittabfi### edit /etc/sysconfig/desktopif [ $DESKTOP ]; thensed -i "/^DESKTOP=.*/d" /etc/sysconfig/desktop 2&>/dev/nullecho "DESKTOP=$DESKTOP" >> /etc/sysconfig/desktopfiif [ $DISPLAYMANAGER ]; thensed -i "/^DISPLAYMANAGER=.*/d" /etc/sysconfig/desktop 2&>/dev/nullecho "DISPLAYMANAGER=$DISPLAYMANAGER" >> /etc/sysconfig/desktopfi### GDM login backgroundif [ -e /usr/share/gdm/themes/SL/background.png ]; thencp -a customize/sl${OS_RELEASE}/background.png /usr/share/gdm/themes/SL/background.pngfi### KDE default backgroundif [ ! $PSI ]; thenif [ -e /usr/share/backgrounds/images/default.png ]; thencp -a customize/sl${OS_RELEASE}/default.png /usr/share/backgrounds/images/default.pngfifi### KDE startup/exit soundif [ -e /usr/share/config/knotify.eventsrc ]; thencp -a customize/sl/knotify.eventsrc /usr/share/config/knotify.eventsrccp -a customize/sl/kmixrc /usr/share/config/kmixrcfi### KDE session manager; start at login# kmix, krandrtrayif [ -e /usr/share/config/ksmserverrc ]; thencp -a customize/sl/ksmserverrc /usr/share/config/ksmserverrcfi### Configure SELinuxif [ $SELINUX ]; thenif [ -e /etc/selinux/config ]; thensed -i "s|^SELINUX=.*|SELINUX=$SELINUX|" /etc/selinux/configfifi### Do not like jumping CD icon when starting autorun.desktopif [ -e /etc/skel/.kde/Autostart/Autorun.desktop ]; thengrep -q "StartupNotify=false" /etc/skel/.kde/Autostart/Autorun.desktopif [ "$?" != "0" ]; thenecho "StartupNotify=false" >> /etc/skel/.kde/Autostart/Autorun.desktopfifiecho "done."echo "--------------------------------------------"################################################################ Add-ons###############################################################echo "Add-ons ..."### System icon on desktopif [ -d /usr/share/apps/kdesktop/DesktopLinks ]; thencp -a customize/System.desktop /usr/share/apps/kdesktop/DesktopLinks/fi### files for PSI User, will be copied during bootup to /home/$LOCALUSER/if [ $PSI ]; thenrm -rf /usr/share/$LOCALUSERcp -a customize/$LOCALUSER /usr/share/fi### psi-menu, psi-scanvirusif [ $PSI ]; thencp -a customize/psi/psi-menu /usr/bin/cp -a customize/psi/psi-scanvirus /usr/bin/[ -d /usr/local/uvscan ] && cp -a customize/psi/update-dat /usr/local/uvscan/[ -x /usr/bin/freshclam ] && cp -a customize/psi/psi-freshclam /usr/bin/fiecho "done."echo "--------------------------------------------"################################################################ Create special files###############################################################echo "Create special files ..."################################################################ /etc/rc.d/init.d/kudzu-auto### Noninteractive HW detection and configurationcp -a customize/kudzu-auto /etc/init.d/kudzu-autochmod +x /etc/rc.d/init.d/kudzu-autoln -sf /etc/rc.d/init.d/kudzu-auto /etc/rc.d/rc5.d/S04kudzu-autoln -sf /etc/rc.d/init.d/kudzu-auto /etc/rc.d/rc3.d/S04kudzu-auto################################################################ /etc/rc.d/init.d/runveryfirst### Fix some things during bootup - run VERY first# runveryfirst will run at the begining of /etc/rc.d/rc.sysinitcp -a customize/runveryfirst /etc/init.d/runveryfirstchmod +x /etc/rc.d/init.d/runveryfirst# execute runveryfirst just before "Initialize hardware"grep -q runveryfirst /etc/rc.d/rc.sysinitif [ "$?" != "0" ]; thensed -i -e "/^# Initialize hardware/a\/etc\/init.d\/runveryfirst" /etc/rc.d/rc.sysinitfi################################################################ /etc/rc.d/init.d/runfirst### Fix some things during bootup - run first# runfirst will run at the end of /etc/rc.d/rc.sysinitcp -a customize/runfirst /etc/init.d/runfirstchmod +x /etc/rc.d/init.d/runfirstsysinit_line="/etc/rc.d/init.d/runfirst"grep -q "$sysinit_line" /etc/rc.d/rc.sysinitif [ "$?" != "0" ]; thenecho "$sysinit_line" >> /etc/rc.d/rc.sysinitecho >> /etc/rc.d/rc.sysinitfi################################################################ /etc/rc.d/init.d/login### Provides directly login over xinitcp -a customize/login /etc/init.d/loginchmod +x /etc/rc.d/init.d/login################################################################ /etc/rc.d/init.d/runlast### Fix some things during bootup - run lastcp -a customize/runlast /etc/init.d/runlastchmod +x /etc/rc.d/init.d/runlast### Add /etc/rc.d/init.d/runlast to rc.localLINE=/etc/rc.d/init.d/runlastgrep -q $LINE /etc/rc.d/rc.localif [ "$?" != "0" ]; then# add lineecho "" >> /etc/rc.d/rc.localecho $LINE >> /etc/rc.d/rc.localecho "" >> /etc/rc.d/rc.localfi################################################################ /usr/bin/save-localdata### stores data on a usbstickcp -a customize/save-localdata /usr/bin/save-localdatachmod +x /usr/bin/save-localdata# add /usr/bin/save-localdata to /etc/sudoersgrep -q "save-localdata" /etc/sudoers 2>/dev/nullif [ "$?" != "0" ]; thenecho "$LOCALUSER ALL = NOPASSWD: /usr/bin/save-localdata" >> /etc/sudoersfi# create menu entrycp -a customize/save-localdata.desktop /usr/share/applications/################################################################ /usr/bin/set-volume### unmute all mixers and set volumescp -a customize/set-volume /usr/bin/set-volumechmod +x /usr/bin/set-volume################################################################ /etc/sysconfig/networking/devices/ifcfg-eth0# /etc/sysconfig/networking/devices/ifcfg-eth1for iface in eth0 eth1; do# remove it firstrm -f /etc/sysconfig/networking/devices/ifcfg-${iface} 2>/dev/nullrm -f /etc/sysconfig/networking/profiles/default/ifcfg-${iface} 2>/dev/nullrm -f /etc/sysconfig/network-scripts/ifcfg-${iface} 2>/dev/null# create it, if we have a sampleif [ -e customize/sl${OS_RELEASE}/ifcfg-${iface} ]; thencp -a customize/sl${OS_RELEASE}/ifcfg-${iface} /etc/sysconfig/networking/devices/ifcfg-${iface}# make hard linkscp -lf /etc/sysconfig/networking/devices/ifcfg-${iface} /etc/sysconfig/networking/profiles/default/cp -lf /etc/sysconfig/networking/devices/ifcfg-${iface} /etc/sysconfig/network-scripts/fidone################################################################ /etc/profile.d/setsysfont.sh### setsysfontcat > /etc/profile.d/setsysfont.sh <<EOF# setsysfont onceif [ ! -e /tmp/.sysfont_has_been_set ]; thentouch /tmp/.sysfont_has_been_set/bin/setfont 2>/dev/null/sbin/setsysfont 2>/dev/nullfiEOFchmod 755 /etc/profile.d/setsysfont.sh################################################################ /etc/profile.d/setsysfont.csh### setsysfontcat > /etc/profile.d/setsysfont.csh <<EOF# setsysfont onceif ( ! -e /tmp/.sysfont_has_been_set ) thentouch /tmp/.sysfont_has_been_set/bin/setfont 2>/dev/null/sbin/setsysfont 2>/dev/nullendifEOFchmod 755 /etc/profile.d/setsysfont.csh################################################################ /etc/cron.d/psi### PSI specific cronjobsif [ $PSI ]; thencp -a customize/psi/cron_psi /etc/cron.d/psichmod +x /etc/cron.d/psifiecho "done."echo "--------------------------------------------"################################################################ Configure services###############################################################echo "Configure services ..."# services offif [ $PSI ]; thenchkconfig cfenvd off 2>/dev/nullchkconfig cfexecd off 2>/dev/nullchkconfig cfservd off 2>/dev/nullfiif [ ! "$SERVICES_OFF" = "" ]; thenfor service in $SERVICES_OFF; dochkconfig $service off 2>/dev/nulldonefi# we do kudzu-autochkconfig kudzu off# services onif [ $PSI ]; thenchkconfig vpnclient_init on 2>/dev/nullfiif [ ! "$SERVICES_ON" = "" ]; thenfor service in $SERVICES_ON; dochkconfig $service on 2>/dev/nulldonefiecho "done."echo "--------------------------------------------"################################################################ Empty files###############################################################echo "Empty files ..."### /etc/security/usersif [ $PSI ]; thenrm -f /etc/security/userstouch /etc/security/usersfi### Files to emptyFILES_TOUCH="/etc/sysconfig/hwconf \/etc/resolv.conf \/etc/adjtime \/etc/modprobe.conf \/etc/dhclient-eth0.conf"for file in $FILES_TOUCH; dorm -rf $filetouch $filedoneecho "done."echo "--------------------------------------------"################################################################ Update locate db, prelink, makewhatis################################################################## run slocateif [ -x /usr/bin/updatedb ]; thenecho "Run updatedb...". /etc/updatedb.conf 2>/dev/nullrpm -q mlocate >/dev/nullif [ "$?" = "0" ]; then/usr/bin/updatedb -e "/media /sfs /tmp /boot /livecd /home /net"else/usr/bin/updatedb -e /media,/tmp,/boot,/livecd,/home,/netfiecho "done."fi### run prelinkif [ -x /etc/cron.daily/prelink ]; thenecho "Run prelink..."/etc/cron.daily/prelinkecho "done."fiif [ -x /etc/cron_backup/prelink ]; thenecho "Run prelink..."/etc/cron_backup/prelinkecho "done."fi# clean logrm -f /var/log/prelink/prelink.log 2>/dev/nullrm -f /var/log/prelink.log 2>/dev/null### run makewhatisif [ -x /usr/bin/makewhatis ]; thenecho "Run makewhatis..."makewhatis -u -wfiecho "done."echo "--------------------------------------------"###############################################################