blob: 55dd7c59e6d1eb08059242f11d712432a5234ce2 (
plain) (
tree)
|
|
# Copyright (c) 2003..2006 - RZ Uni Freiburg
# Copyright (c) 2006..2011 - OpenSLX GmbH
#
# This program/file is free software distributed under the GPL version 2.
# See http://openslx.org/COPYING
#
# If you have any feedback please consult http://openslx.org/feedback and
# send your feedback to feedback@openslx.org
#
# General information about OpenSLX can be found under http://openslx.org
#
# Configuration script for general Ubuntu to configure OpenSLX Linux
# stateless clients (executed within initial ramdisk after genconfig)
# distro specific configuration variables used in the setup functions
# (formerly done via config-*, these variables are disputable ...)
# D_ETCEXCL - list of files, wildcards to be excluded from /etc when using
# bind mounts
# D_DIRINBINDMNT - lists of directories to be created in bind mounted rw part
# of the client filesystem
# D_RODIRSINRW - ReadOnly Directories in RW part of filesystem to save on
# TempFS usage
# D_DIRINDXS - directories in client filesystem which should be present anyhow
D_BINDMPTS="tmp root home media"
D_DIRINBINDMNT="/var/run /var/log /var/tmp /var/lib/gdm"
D_RODIRSINRW="/etc/X11/xkb /var/lib/gconf /var/lib/dpkg /var/lib/aspell \
/var/lib/pango /var/lib/defoma /var/cache/fontconfig /var/lib/dkms"
# creating required(?) directories like /var/run/sysconfig/tmp or
# /var/run/console does not make much sense here as they get overmounted,
# see ticket #813
D_DIRINDXS="/var/lib/nobody /var/lib/misc /var/lib/pam \
/var/lib/bluetooth /var/lib/texmf /var/lib/nfs/sm /var/lib/acpi_support \
/var/spool/cron /var/lib/alsa"
# distro specific stuff to initialize
postinit () {
if [ $DEBUGLEVEL -gt 3 ]; then
export DEBUG_UPSTART=" -v --debug"
fi
}
config_netconsole () {
local MY_IP=$1
local MY_OLDDEV=$2
local MY_DEV=$3
local T_IP=$4
local T_MAC=$(arp -n |grep $T_IP| awk '{print $5}')
# FIXME: we need to set a valid ip for ethx if we use the bridge config
# from the virtualization plugins
[ "$MY_OLDDEV" = "$MY_DEV" ] || ip a a $MY_IP dev $MY_OLDDEV
modprobe netconsole netconsole=4444@$MY_IP/$MY_OLDDEV,514@$T_IP/$T_MAC
dmesg -n 8
}
# distro specific function called from servconfig script
config_distro () {
# runlevel system changed significantly compared to pre 9.10 sys-v-init
# clean up nevertheless
for dir in rc0.d rc1.d rc2.d rc3.d rc4.d rc5.d rc6.d rcS.d ; do
rm -rf /mnt/etc/${dir}/*
done
# remove unneeded init scripts (stuff handled in stage3 which would
# interface with already existing setup)
# copy all event scripts to a special directory
testmkd /mnt/etc/init.inactive
echo -e "# This directory was created in OpenSLX stage3 and contains all \
disabled\n# upstart scripts. They are moved by servconfig to init if this is \
required." >/mnt/etc/init.inactive/README
mv /mnt/etc/init/* /mnt/etc/init.inactive
# remove plymouth component from *dm.conf (not needed with splashy)
sed "/# Check kernel c/,/done/d" -i /mnt/etc/init.inactive/*dm.conf
# copy initial upstart scripts back
for file in alsa-mixer-save control-alt-delete console-setup dbus \
dmesg hwclock hwclock-save irqbalance module-init-tools \
mountall mounted* networking procps rc* tty* udev* \
upstart-socket-bridge upstart-udev-bridge ; do
mv /mnt/etc/init.inactive/${file}.conf /mnt/etc/init >/dev/null 2>&1
done
# remove annoying udev rule set for changing eth interface and cd/dvds
rm /mnt/etc/udev/rules.d/*persistent*.rules >/dev/null 2>&1
# for screen sessions
testmkd /mnt/var/run/screen root:utmp 0777
# apt stuff
testmkd /mnt/var/cache/apt/archives/partial
# add the slx specific path (/var/opt/openslx/bin) to the PATH variable
echo -e "# stuff generated by $0 (out of InitRamFS written $date)\n\
export PATH=\"\$PATH:/var/opt/openslx/bin\"" >>/mnt/etc/profile
}
# initial boot looks different since ubuntu upstart
# (executed after plugin config in stage3)
initial_boot () {
# fix depenencies of upstart files (remove network stuff)
upstart_set_starton rc-sysinit filesystem
upstart_set_starton autofs filesystem
upstart_set_starton portmap filesystem
}
upstart_set_starton () {
local script="$1"
local starton="$2"
local file_not_found="f"
if [ -e /mnt/etc/init.inactive/${script}.conf ]; then
local script_path=/mnt/etc/init.inactive/${script}.conf
elif [ -e /mnt/etc/init/${script}.conf ]; then
local script_path=/mnt/etc/init/${script}.conf
else
local file_not_found="t"
fi
if [ "$file_not_found" = "f" ]; then
# replace multi-line dependencies with ##starton##
sed -n '1h;1!H;${;g;s/start on[\t ]*([^)]*)/start on ##starton##/g;p;}' \
-i $script_path
# replace single-line dependencies with ##starton##
sed -e 's/start on.*$/start on ##starton##/' \
-i $script_path
# replace placeholder with our new value
sed -e "s,##starton##,$starton," \
-i $script_path
else
error "Script: ${script} does not exist. Skipping modification.." nonfatal}
fi
}
# runlevel linker - mostly deprecated in the old form because of new upstart
# mechanism (with backward compatibility)
rllinker () {
local script="$1"
# activating the new way, check if a appropriate script is available, else
# try the traditional approach
if [ -e /mnt/etc/init.inactive/${script}.conf -o -e /mnt/etc/init/${script}.conf ]; then
# we have upstart scripts
if [ -e /mnt/etc/init.inactive/${script}.conf ] ; then
mv /mnt/etc/init.inactive/${script}.conf /mnt/etc/init
fi
elif [ -e /mnt/etc/init.d/${script} ]; then
# we old rc scripts
if [ -e /mnt/etc/init.d/${script} -a -n "$1" -a -n "$2" ] ; then
if [ $2 -lt 10 ] ; then
local start="0$2"; else local start="$2"
fi
if [ $3 -lt 10 ] ; then
local stop="0$3"; else local stop="$3"
fi
for i in rc2.d/K$stop$script rc3.d/K$stop$script \
rc2.d/S$start$script rc3.d/S$start$script ; do
ln -sf ../init.d/$script /mnt/etc/$i
[ "$DEBUGLEVEL" == 5 ] && echo "Linked $script"
done
fi
else
error "Script: ${script} does not exist. Skipping setup of startscipts/events.." nonfatal
fi
}
# set up localization like keytable, console
dlocale () {
# fixme -- use keytable setup script here
# echo -e "\t# entries added by $0: $date" >> /mnt/etc/init.d/boot.slx
sed -e "1i# File modified during SLX stage3 bootup (config_distro)" \
-e "s/LANG.*/LANG=\"${LANG}\"/" -i /mnt/etc/default/locale
echo "LC_ALL=\"${LANG}\"" >> /mnt/etc/default/locale
echo "LANGUAGE=\"${LANG}:en\"" >> /mnt/etc/default/locale
echo "LC_ALL=\"${LANG}\"" >> /mnt/etc/environment
}
# function for ntp configuration
config_ntp () {
if [ -f /mnt/etc/init.d/ntp -a "x$start_ntp" != "xno" ] ; then
echo -e "ntp:x:74:65534:NTP daemon:/var/lib/ntp:/bin/false" \
>>/mnt/etc/passwd
# testmkd /mnt/var/lib/ntp/var/run/ntp # see #813
fi
}
# function for atd
config_atd () {
if [ "x$start_atd" = "xyes" ]; then
# testmkd /mnt/var/spool/atjobs
# testmkd /mnt/var/spool/atspool
# chown 1:1 /mnt/var/spool/atjobs /mnt/var/spool/atspool
if [ -f /mnt/etc/init.inactive/atd ] ; then
mv /mnt/etc/init.inactive/atd /mnt/etc/init
else
error "$df_erratd" nonfatal
fi
fi
}
# function for configuration of cron services (fixme: to be moved to a plugin?)
config_cron () {
if [ "x$start_cron" = "xyes" ] ; then
if [ -f /mnt/etc/init.inactive/anacron ] ; then
mv /mnt/etc/init.inactive/anacron /mnt/etc/init
# fixme! check for proper permissions!
testmkd /mnt/var/spool/crontabs
echo -e "# /etc/crontab - file generated by $0:\n\
#\t$date\nSHELL=/bin/sh\nPATH=/usr/bin:/usr/sbin:/sbin:/bin:/usr/lib/news/bin\
\nMAILTO=\n-*/15 * * * *\troot\ttest -x /usr/lib/cron/run-crons && \
/usr/lib/cron/run-crons >/dev/null 2>&1\n" >/mnt/etc/crontab
else
error "$df_errcron" nonfatal
fi
fi
}
# secure shell service
config_sshd () {
if [ "x$start_sshd" = "xyes" ] ; then
if [ -f /mnt/etc/init.inactive/ssh.conf ] ; then
# testmkd /mnt/var/run/sshd # see #813
mv /mnt/etc/init.inactive/ssh.conf /mnt/etc/init
else
error "$df_errsshd" nonfatal
fi
fi
}
# snmp agent for remote monitoring (upstart functionality unchecked)
config_snmp () {
if [ "x$start_snmp" = "xyes" ] ; then
if [ -f /mnt/etc/init.inactive/snmpd.conf ] ; then
testmkd /mnt/var/lib/net-snmp
mv /mnt/etc/init.inactive/snmpd.conf /mnt/etc/init
else
# fixme!!
# write service monitor depending on services started
:
fi
fi
}
# acpi and powersave
config_acpi () {
if [ -f /mnt/etc/init.inactive/acpid.conf ] ; then
mv /mnt/etc/init.inactive/acpid.conf /mnt/etc/init
else
# fixme!!
# write service monitor depending on services started
:
fi
}
# configure hal, dbus, policykitd and services like that
config_dreshal () {
if [ "x$start_dreshal" = "xyes" ]; then
testmkd /mnt/var/lib/dbus
testmkd /mnt/var/lib/misc
testmkd /mnt/var/cache/hald
rm -rf /mnt/etc/dbus-1/system.d/*etwork*anager.conf \
/mnt/etc/dbus-1/system.d/nm-* \
/mnt/etc/dbus-1/event.d/*NetworkManager*
sed -i /mnt/etc/dbus-1/system.d/hal.conf \
-e "s/^\([^d]*\)deny\(.*Volume.*\)/\1allow\2/"
for dir in 10-vendor.d 20-org.d 30-site.d 50-local.d 90-mandatory.d ; do
testmkd /mnt/var/lib/polkit-1/localauthority/${dir}
done
fi
}
# initialize boot.slx - skript to be executed during early system startup
# (before most of the normal boot init scripts)
# this script should operate like a normal runlevel script (fixme!!)
d_mkrlscript () {
local switch="$1"
local name="$2"
local info="$3"
# ToDo: needs to be adapted to upstart mechanism
case "$switch" in
init)
echo -e "#!/bin/sh\n# skeleton of /etc/init.d/$name written \
from $0\n# after you applied changes to the creation scripts you have to \
rerun\n# the mkdxsinitrd script to get them applied\n\n\
. /lib/lsb/init-functions\n" >/mnt/etc/init.d/$name
echo -e "\n\ncase \"\$1\" in\n start)\n\tlog_begin_msg \"$info\"" \
>>/mnt/etc/init.d/$name
chmod u+x /mnt/etc/init.d/$name
;;
entry)
echo -e "\t${info}" >>/mnt/etc/init.d/${name}
;;
close)
echo -e "\tlog_end_msg 0\n\t;;\n stop)\n\t;;\nesac\nexit 0" \
>>/mnt/etc/init.d/$name
;;
esac
}
# configure automounter (unchecked)
config_automount () {
if [ -f /mnt/etc/init.inactive/autofs.conf ] ; then
mv /mnt/etc/init.inactive/autofs.conf /mnt/etc/init
testmkd /mnt/var/lock/subsys
sed -e "1i# /etc/default/autofs - file modified by\n#\t$0:\n#" \
-e "s,TIMEOUT.*,TIMEOUT=60," -i /mnt/etc/default/autofs
config_portmap
config_nfs
fi
}
# start portmapper (needed at least for nfsN and nis services)
config_portmap () {
if [ -f /mnt/etc/init.inactive/portmap.conf ]; then
mv /mnt/etc/init.inactive/portmap.conf /mnt/etc/init
mv /mnt/etc/init.inactive/statd.conf /mnt/etc/init
else
error "$df_errpmap" nonfatal
fi
}
# mostly unused yet (needs to be properly integrated)
config_nfs () {
[ -e /mnt/etc/init.inactive/gssd.conf ] && \
mv /mnt/etc/init.inactive/gssd.conf /mnt/etc/init
[ -e /mnt/etc/init.inactive/rpc_pipefs.conf ] && \
mv /mnt/etc/init.inactive/rpc_pipefs.conf /mnt/etc/init
[ -e /mnt/etc/init.inactive/idmapd.conf ] && \
mv /mnt/etc/init.inactive/idmapd.conf /mnt/etc/init
}
# start NIS (unchecked!! fixme - does the service is really named ypbind??)
config_nis () {
if [ -f /mnt/etc/init.inactive/ypbind.conf ] ; then
mv /mnt/etc/init.inactive/ypbind.conf /mnt/etc/init
config_portmap
testmkd /mnt/var/yp/nicknames
else
error "$df_erryp" nonfatal
fi
}
# name service caching daemon (really existing!?)
config_nscd () {
# if upstart compatible
if [ -f /mnt/etc/init.inactive/nscd.conf ] ; then
testmkd /mnt/var/cache/nscd
# otherwise the old method
elif [ -f /mnt/etc/init.d/nscd ] ; then
ln -sf /etc/init.d/nscd /mnt/etc/rc2.d/S10nscd
ln -sf /etc/init.d/nscd /mnt/etc/rc3.d/S10nscd
fi
}
|