blacklist proteon and depca in initrd generation as they seem to cause problems with...
[grml-terminalserver.git] / grml-terminalserver-config
1 #!/bin/sh
2 # Filename:      terminalserver-config
3 # Purpose:       configuration program for grml-terminalserver
4 # Authors:       grml-team (grml.org), (c) Michael Gebetsroither <gebi@grml.org>
5 # Bug-Reports:   see http://grml.org/bugs/
6 # License:       This file is licensed under the GPL v2.
7 # Latest change: Don Nov 16 14:39:51 CET 2006 [mika]
8 ################################################################################
9
10
11 ###
12 ### __INCLUDES
13 ###
14 . /etc/grml/sh-lib
15 #. /etc/grml/sysexits-sh
16
17
18
19 ###
20 ### __VARIABLES
21 ###
22
23 verbose_=0
24
25 # this file holds all variable definitions
26 SHARED_PROG_VARS_="/usr/share/grml-terminalserver/shared_prog_vars"
27 isExistent $SHARED_PROG_VARS_ die
28 . $SHARED_PROG_VARS_
29
30 # variables used in the config file for grml-terminalserver
31 INTERFACE_=""
32 IP_=""
33 NETMASK_=""
34 GW_=""
35 NAMESERVERS_=""
36 IPRANGE_FROM_=""
37 IPRANGE_TO_=""
38 NETWORK_=""
39 OPTIONS_=""
40 BOOT_ARGS_=""
41
42
43 ###
44 ### __FUNCTIONS
45 ###
46
47 function printUsage
48 {
49   cat <<EOT
50 Usage: "$PROG_NAME__" [OPTIONS] <command>
51
52 $PROG_NAME__ is the config program for the terminalserver coming with grml.
53
54 COMMANDS:
55
56    help             This help text
57    interactive      Interactive Configuration of the grml-terminalserver
58    grubConf         Configure grub and create boot-image (for non-PXE NICs)
59    grubConfWrite    Configure grub and write image to floppy disk
60    grubWrite        Write compiled grub-image to floppy disk
61    grubMultiWrite   batchwrite grub-image to floppy disk
62    initrd           Only create the initrd
63    clean            Remove all configfiles created during user configuration
64    <default>        interactive mode
65
66 OPTIONS:
67    -v               verbose (show what is going on, v++)
68    -h               this help text
69
70 EOT
71 }
72
73
74 function writeConfig
75 {
76   local date_=""
77
78   if [ -f $CONF_FILE_ ]; then
79     mv -fb $CONF_FILE_ ${CONF_FILE_}-old
80   fi
81
82   date_=`date`
83   cat <<EOT > $CONF_FILE_
84 # GRML TERMINAL-SERVER CONFIG
85 # created on "$date_"
86 INTERFACE_="$INTERFACE_"
87 IP_="$IP_"
88 NETWORK_="$NETWORK_"
89 NETMASK_="$NETMASK_"
90 GW_="$GW_"
91 NAMESERVERS_="$NAMESERVERS_"
92 IPRANGE_FROM_="$IPRANGE_FROM_"
93 IPRANGE_TO_="$IPRANGE_TO_"
94 OPTIONS_="$OPTIONS_"
95 BOOT_ARGS_="$BOOT_ARGS_"
96
97 EOT
98   notice "config successfully safed to \"$CONF_FILE_\""
99 }
100
101
102 # AUTOMATIC CONFIGURATION  {{{
103 function checkParamArg
104 {
105   local param_name="$1"
106   local arg="$2"
107
108   #eval "echo $`echo $test`"
109   echo $arg |grep "^[-|+]" &>/dev/null || return
110
111   die "Argument from $param_name looks like another parameter \"$arg\"" 1
112 }
113
114 function actionAutoconf
115 {
116   checkParamArg "-i" "$interface_"
117 }
118 # }}}
119
120
121 # INITRD {{{
122
123 function actionMkInitrd
124 {
125   echo -n "Creating initrd $PATH_/minirt26.gz: "
126   isExistent "$PATH_/minirt26.gz" && echo && echo "$PATH_/minirt26.gz exists already, skipping initrd creation" && return 0
127   mkInitrd
128   echo done
129 }
130
131 function mkInitrd
132 {
133   TMP_DIR_=`mktemp -td terminalserver_initrd.XXXXXX`
134   local i=''
135   local tmp_loopname=''
136
137   # copying original initrd into $INITRD
138   execute "rm -r $INITRD_" 2>/dev/null
139   execute "cp $ORIGINAL_INITRD_ $TMP_DIR_/minirt26.gz" warn || return 1
140   execute "mkdir -p $INITRD_" warn || return 1
141   execute "mkdir -p $PATH_/mini-root.orig" warn || return 1
142   execute "gunzip $TMP_DIR_/minirt26.gz" warn || return 1
143   tmp_loopname=`findNextFreeLoop die`
144   execute "mount -o loop=$tmp_loopname $TMP_DIR_/minirt26 $PATH_/mini-root.orig " warn || return 1
145   execute "cp -a $PATH_/mini-root.orig/* $INITRD_" warn || return 1
146   execute "umount $PATH_/mini-root.orig" warn || return 1
147   losetup -d $tmp_loopname &>/dev/null
148   tmp_loopname=''
149   execute "rmdir $PATH_/mini-root.orig" warn || return 1
150   execute "rm $TMP_DIR_/minirt26" warn || return 1
151
152   # implanting my initrd changes into the original initrd
153
154   # copy programs, check if there are already links with this name to busybox
155   for i in $USR_SHARE_/timeout $USR_SHARE_/discover* $USR_SHARE_/udhcpc $USR_SHARE_/udhcp-config.sh $USR_SHARE_/cdir $USR_SHARE_/rdir /usr/bin/ldd ;do
156     tmp_name_="${i##*/}"
157     isNotExistent "$INITRD_/static/$tmp_name_" eprint || execute "rm $INITRD_/static/$tmp_name_"
158     cp $i "$INITRD_/static/$tmp_name_"
159   done
160   cp $USR_SHARE_/linuxrc $INITRD_/
161   mkdir -p $INITRD_/mylib
162   mkdir -p $INITRD_/myusr/i386-uclibc-linux/lib
163   for i in libdl libc libuClibc ld-uClibc; do
164     cp -a $UCLIBC_PATH_/$i*.so* $INITRD_/myusr/i386-uclibc-linux/lib
165   done
166
167   # copy data files for discover (discover-data)
168   mkdir -p $INITRD_/mylib/discover
169   cp /lib/discover/list.xml /lib/discover/pci-*.xml $INITRD_/mylib/discover/
170
171   #
172   # which modules should i put into the ramdisk
173   #
174
175   # get cards detected by discover
176   if [ -f /lib/discover/pci.lst ] ; then
177     isNotExistent $CARDS_DETECTED_BY_DISCOVER && awk '/ethernet/{print $3}' /lib/discover/pci.lst |sort |uniq > $CARDS_DETECTED_BY_DISCOVER
178   else # newer discover does not provide /lib/discover/pci.lst, get a list of all network drivers therefore
179     isNotExistent $CARDS_DETECTED_BY_DISCOVER && \
180     # find *all* network drivers, but do not include wlan/pcmcia/... related ones
181     # blacklist: proteon and depca as they seem to cause problems with udevsettle
182     find /lib/modules/`uname -r`/kernel/drivers/net/ -name \*.ko | grep -v 'wireless\|wan\|hamradio\|wlan\|ppp\|irda\|pcmcia\|depca\|proteon' | \
183          sed 's#.*./## ; s#\.ko##' | sort | uniq > $CARDS_DETECTED_BY_DISCOVER
184     # find the ones supported by discover
185     # for mod in `grep "name'>.*</data>" /lib/discover/pci-device.xml | sed "s#.*name'>## ; s#</data>##" | sort -u`; do
186     #     find /lib/modules/${KERNEL_VERSION_}/kernel/drivers/net -name ${mod}.ko | sed 's#.*./## ; s#\.ko##' >> $CARDS_DETECTED_BY_DISCOVER
187     # done
188   fi
189
190   local modules="`cat $CARDS_DETECTED_BY_DISCOVER |xargs` af_packet"
191   local modules_dep=""
192
193   # get paths of modules + paths of all dependent modules
194   echo -n "" >"$TMP_"
195   for i in $modules; do
196     tmp_=`awk -F: '{if($1~/'"$i".ko'/) {print $0}}' $MODULES_PATH_/$KERNEL_VERSION_/modules.dep`
197     echo "${tmp_%%:*}"
198     # FIXME ugly sed hack :(
199     echo "${tmp_#*:}" | xargs -n1 echo | sed 's/://'
200   done \
201   | sort | uniq | while read module relax; do
202     if [ -n "$module" ]; then
203       echo "$module" >> $TMP_
204     fi
205   done
206
207   # copy modules + dependend modules into ramdisk
208   local mod_path_="$INITRD_/mylib/modules/$KERNEL_VERSION_"
209   local tmp_dst_path_="$mod_path_/kernel"
210   mkdir -p $tmp_dst_path_
211   cat $TMP_ |sort |uniq |while read module; do
212     local tmp_path=${module#*/kernel/}
213     tmp_path=$tmp_dst_path_/${tmp_path%/*.ko}
214     local module_path=$tmp_path/${module##/*/}
215
216     isNotExistent "$tmp_path" dprint && mkdir -p "$tmp_path"
217     isNotExistent "$module_path" dprint && cp "$MODULES_PATH_ROOT_DIFF_/$module" "$module_path"
218   done
219
220   # copying additional modules
221   for i in fs/nfs/nfs.ko net/sunrpc/sunrpc.ko fs/lockd/lockd.ko net/packet/af_packet.ko; do
222     local tmp_path="$tmp_dst_path_/${i%/*}"
223     mkdir -p $tmp_path
224     cp $MODULES_PATH_/$KERNEL_VERSION_/kernel/$i "$tmp_path"
225   done
226
227   # generate modules.dep
228   cp $MODULES_PATH_/$KERNEL_VERSION_/modules.dep $mod_path_
229   #grep "^\/lib\/modules\/$KERNEL_VERSION_\/kernel\/" $MODULES_PATH_/$KERNEL_VERSION_/modules.dep |\
230   #  sed "s/\/lib\/modules\/$KERNEL_VERSION_\/kernel\//\/modules\//g" > $mod_path_/modules.dep
231
232   # put everything into the new initrd
233   local tmp_size=`du -s $INITRD_ |awk '{print $1}'`   # in kB
234   let tmp_size=$tmp_size+1000
235   if (( $tmp_size >= 16000 )); then
236     warn "Your initrd is $tmp_size kByte large => TOO BIG (should be <= 16000kB)"
237     warn "Please remove a few modules from $CARDS_DETECTED_BY_DISCOVER or edit $INITRD_ manually"
238     return 1
239   fi
240
241   execute "dd if=/dev/zero of=$TMP_DIR_/minirt26 bs=${tmp_size}k count=1 &>/dev/null" warn || \
242     warn "could not create filesystem image"
243
244   tmp_loopname=`findNextFreeLoop die`
245   execute "losetup $tmp_loopname $TMP_DIR_/minirt26" die
246   execute "mke2fs -L \"GRML NETINIT\" -b 1024 -N 8192 -O none -F -q -m 0 $tmp_loopname" warn
247
248   execute "mkdir $PATH_/minirt26_mountp" warn
249   execute "mount $tmp_loopname $PATH_/minirt26_mountp" warn
250   execute "cp -a $INITRD_/* $PATH_/minirt26_mountp" warn
251   execute "umount $PATH_/minirt26_mountp" warn
252   execute "losetup -d $tmp_loopname &>/dev/null" warn
253   execute "rmdir $PATH_/minirt26_mountp" warn
254   execute "gzip -9 $TMP_DIR_/minirt26" warn
255   execute "rm -r $INITRD_" warn
256   execute "mv $TMP_DIR_/minirt26.gz $PATH_"
257   execute "rm -fr $TMP_DIR_"
258 }
259 # }}}
260
261
262 # INTERACTIVE CONFIGURATION  {{{
263
264 function actionInteractive
265 {
266   local i=""
267
268   dprint "running in interactive mode"
269
270   local card_title_="Choose network device connected to client network"
271   local card_message_="Available network devices:"
272   local iprange_title_="IP Address range for clients"
273 local iprange_message_="
274 Please enter the desired IP-Range of addresses that should be allocated by clients, separated by a single space.
275
276 Example:
277           192.168.0.101 192.168.0.200
278
279 for addresses from 192.168.0.101 to (and including) 192.168.0.200.
280
281 "
282   local runconfig_title_="Networkcard config"
283   local runconfig_message_="Would you like to configure your interfaces now?"
284   local grub_title_="Grub configuration"
285   local grub_message_="Do you have any NON-PXE network cards you would like to boot from?"
286
287   # on witch interfaces should we listen
288   local netdevices_="$(cat /proc/net/dev | awk -F: '/eth.:|tr.:/{print $1}')"
289   local device_list_=""
290   for INTERFACE_ in $netdevices_; do device_list_="$device_list_ ${INTERFACE_} Networkcard_${INTERFACE_##eth}"; done
291     echo -n "" >"$TMP_"
292     $DIALOG_ --backtitle "$BACK_TITLE_" --title "$card_title_" --menu "$card_message_" \
293       0 0 18 $device_list_ 2>"$TMP_" || warn "could not get network-interface"
294   INTERFACE_="$(<$TMP_)" ; echo -n "" >"$TMP_"
295
296   while true; do
297     IP_=`netGetIp "$INTERFACE_" warn`
298     NETMASK_=`netGetNetmask "$INTERFACE_" warn`
299     netValidIp "$IP_" warn && break
300     $DIALOG_ --backtitle "$BACK_TITLE_" --title "$runconfig_title_" --yesno "$runconfig_message_" 18 45 && \
301       netcardconfig || die "Could not get interface" $?
302   done
303
304   IPRANGE_FROM_=`execute "ipcalc -nb $IP_/$NETMASK_" warn |awk '/HostMin/{print $2}'`
305   IPRANGE_TO_=`execute "ipcalc -nb $IP_/$NETMASK_" warn |awk '/HostMax/{print $2}'`
306   NETWORK_=`execute "ipcalc -nb $IP_/$NETMASK_" warn |awk '/Network:/{print $2}'`
307   NETWORK_=${NETWORK_%/*}
308   local iprange_=""
309   while [ -z "$IPRANGE_FROM_" -o -z "$IPRANGE_TO_" -o -z "$iprange_" ]; do
310     iprange_="$IPRANGE_FROM_ $IPRANGE_TO_"
311     echo -n "" >"$TMP_"
312     $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$iprange_title_ ($INTERFACE_=$IP_/$NETMASK_)" \
313       --inputbox "$iprange_message_" 18 75 "$iprange_" 2>"$TMP_" || die "problems getting network range" $?
314
315     iprange_="$(<$TMP_)"
316     IPRANGE_FROM_="${iprange_%% *}"
317     IPRANGE_TO_="${iprange_##* }"
318
319     for i in "$IPRANGE_FROM_" "$IPRANGE_TO_"; do
320       netValidIp "$i" warn || iprange_=""
321     done
322   done
323
324   NAMESERVERS_=`netGetNameservers warn`
325   GW_=`netGetDefaultGateway warn`
326
327
328   # grub
329   echo -n "" >"$TMP_"
330   local grub_write_="YES"
331   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$grub_title_" --yesno "$grub_message_" 5 75 && \
332     grubConfig || grub_write_="NO"
333
334
335   # get options
336   #local OPT_IPTABLES_="yes"
337   #local OPT_SSH_="yes"
338   #local OPT_DISTCC_="yes"
339   #local OPT_SQUID_=""
340
341   local OPTIONS_TITLE_="Options"
342   local OPTIONS_MESSAGE_="Please give the appropriate options you want the clients to use:
343
344 grml2hd   - Make a non-interactive remote installation
345
346
347
348 "
349 #  local OPTIONS_MESSAGE_="Please give the appropriate options you want the clients to use:
350 #
351 #iptables  - Only the server should be able to access the clients
352 #ssh       - A ssh-key will be created on the server and distributed to the clients
353 #distcc    - You want to use the clients as compile-farm (ssh options recommned)
354 #
355 #"
356
357   local OPT_IPTABLES_DESC_="Start iptables on the clients"
358   local OPT_SSH_DESC_="Start ssh on the clients"
359   local OPT_DISTCC_DESC_="Start distcc on the clients"
360   local OPT_GRML2HD_DESC_="Remote install grml on the network clients"
361   # dialog options (enable if implemented)
362   #iptables "$OPT_IPTABLES_DESC_" off \
363   #ssh "$OPT_SSH_DESC_" off \
364   #distcc "$OPT_DISTCC_DESC_" off \
365   echo -n "" >"$TMP_"
366   $DIALOG_ --clear --separate-output --backtitle "$BACK_TITLE_" --title "$OPTIONS_TITLE_" --checklist "$OPTIONS_MESSAGE_" 25 80 10 \
367   grml2hd "$OPT_GRML2HD_DESC_" off \
368     2>$TMP_ || die "could not get terminalserver options" $?
369   while read tmp_option_; do
370     OPTIONS_="$OPTIONS_ $tmp_option_"
371   done <$TMP_
372
373   # parse options
374   for i in $OPTIONS_; do
375     case "$i" in
376       grml2hd)  optGrml2Hd || return 1 ;;
377     esac
378   done
379
380   echo -n "" >"$TMP_"
381   local OPTIONS_BOOTARG_MESSAGE_="Here you can add additional boot arguments for the clients seperated by spaces:
382
383 Quite usefull examples:
384
385 ssh=<pw>              - Start ssh server and set password of user grml to pw
386 services=<1,2,3>      - Execute /etc/init.d/{1,2,3} start
387 console=ttyS0,9600n8  - Initialise seriell console
388 secure                - Boot only restricted clients (without root permissions)
389 startx                - Boot into X (should be used with secure)
390
391
392 "
393   $DIALOG_ --clear --no-collapse --backtitle "$BACK_TITLE_" --title "$OPTIONS_TITLE_" --inputbox "$OPTIONS_BOOTARG_MESSAGE_" 0 0\
394     2>$TMP_ || die "problems getting additional boot arguments"
395   BOOT_ARGS_="$BOOT_ARGS_ $(<$TMP_)"
396
397   writeConfig
398   if [ $grub_write_ == "YES" ]; then
399     grubWrite
400   fi
401   actionMkInitrd
402   notice "GRML terminalserver successfully configured"
403 }
404 # }}}
405
406 # OPTIONS GETTING DIALOG {{{
407 function optGrml2Hd
408 {
409   local GRML2HD_TITLE_='Grml2hd options dialog'
410   local tmp_=''
411   local options_='BOOT_IMAGE=grml2hd'
412
413   # get partition to install grml2hd on
414   OPTIONS_PARTITION_MSG_='Please give me the target partition where to install grml'
415   PARTITION_TITLE_='Partition selection'
416   echo -n "" >"$TMP_"
417   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$PARTITION_TITLE_" --inputbox \
418     "$OPTIONS_PARTITION_MSG_" 0 75 '/dev/hda1' 2>$TMP_ || die "problems getting partition"
419   tmp_="partition=$(<$TMP_)"
420   options_="$options_ $tmp_"
421
422   # get filesystem type
423   OPTION_FS_TYPE_='Please give me the filesystem type'
424   FS_TITLE_='Filesystem selection'
425   echo -n "" >"$TMP_"
426   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$FS_TITLE_" --inputbox \
427   "$OPTION_FS_TYPE_" 0 75 'ext3' 2>$TMP_ || die "problems getting filesystem type"
428   tmp_="filesystem=$(<$TMP_)"
429   options_="$options_ $tmp_"
430
431   # get where to save mbr
432   OPTION_MBR_='Please give me the location where to save the mbr'
433   MBR_TITLE_='Select location of mbr'
434   echo -n "" >"$TMP_"
435   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$MBR_TITLE_" --inputbox \
436     "$OPTION_MBR_" 0 75 '/dev/hda' 2>$TMP_ || die "problems getting location where to write mbr"
437   tmp_="mbr=$(<$TMP_)"
438   options_="$options_ $tmp_"
439
440   # get first user
441   OPTION_USER_='Who should be the first user on the system'
442   USER_TITLE_='User selection'
443   echo -n "" >"$TMP_"
444   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$USER_TITLE_" --inputbox \
445     "$OPTION_USER_" 0 75 'grml' 2>$TMP_ || die "problems getting first user of system"
446   tmp_="user=$(<$TMP_)"
447   options_="$options_ $tmp_"
448
449   BOOT_ARGS_="$options_"
450 }
451 #}}}
452
453 # GRUB CONFIG  {{{
454 function grubConfig
455 {
456   local tmp_=`mktemp -td terminalserver_grub.XXXXXX` || warn "could not create tmp file for grubConfig"
457   if [ -z "$tmp_" ]; then return 1; fi
458
459   grubConfigWork $tmp_
460   local ret_=$?
461   execute "rm -rf $tmp_" warn
462
463   return $ret_
464 }
465
466 function grubConfigWork
467 {
468   local tmp_="$1"
469
470   local grub_title_="Grub configuration"
471   local grub_nic_message_="
472 Give me the types of network cards you would want to boot from.
473 If you networkcard is already listed press <OK>!
474
475 WARNING: DON't add all NIC's, grub could possibly stop working!!"
476   local nics_=""
477
478   while read module_ desc_ mode_; do
479     nics_="$nics_ $module_ $desc_ $mode_"
480   done < $GRUB_NIC_CONF_
481
482   echo -n "" >$TMP_
483   local cmd_line_=""
484   $DIALOG_ --clear --separate-output --backtitle "$BACK_TITLE_" --title "$grub_title_" --checklist \
485     "$grub_nic_message_" 10 70 0 $nics_ 2>$TMP_
486   local ret_=$?
487   if [[ $ret_ -ne 0 || `wc -l <$TMP_` -eq 0 ]]; then
488     echo $ret_
489     warn "you should give me your specified NICs but didn't => DEFAULT will be used"
490     awk '/ on$/{print $1}' $GRUB_NIC_CONF_ >$TMP_
491   fi
492   while read module_; do
493     cmd_line_="$cmd_line_ --enable-$module_"
494   done < $TMP_
495
496   echo "\"$cmd_line_\""
497
498   execute "tar xzf $GRUB_SOURCE_ -C $tmp_" warn || return 1
499   execute "cd $tmp_/grub*" warn || return 1
500 cat >preset-menu <<EOT
501 # Set up the serial terminal, first of all.
502 #serial --unit=0 --speed=19200
503 #terminal --timeout=0 serial
504
505 # Initialize the network.
506 #dhcp --with-configfile
507 #bootp --with-configfile
508 dhcp
509 default 0
510 timeout 0
511 title Load config from Tftp server
512   configfile (nd)/menu.lst
513 EOT
514   #execute "./configure --enable-diskless --enable-preset-menu=./preset-menu $cmd_line_" warn || read
515   execute "CC=gcc-3.3 ./configure --enable-preset-menu=./preset-menu $cmd_line_" warn || read
516   execute "make -j2 CC=gcc-3.3" warn || read #return 1
517
518   local st1_="stage1/stage1"
519   local st2_="stage2/stage2"
520   isExistent $st1_ warn || return 1
521   isExistent $st2_ warn || return 1
522
523   execute "mv -fb $PATH_/grub.img $PATH_/grub.img.old"
524   execute "cat $st1_ $st2_ > $PATH_/grub.img" warn || return 1
525   return 0
526 }
527
528 function grubWrite
529 {
530   local grub_title_="Grub configuration"
531   $DIALOG_ --clear --backtitle "$BACK_TITLE_" --title "$grub_title_" --yesno \
532     "Do you want to write your grub image to /dev/fd0" 5 75 || return 1
533
534   execute "dd if=$PATH_/grub.img of=/dev/fd0" warn || return 0
535   return 1
536 }
537
538 function grubMultiWrite
539 {
540   local target_=${1:-'/dev/fd0'}
541
542   isExistent "$PATH_/grub.img" die "you must give me an image or run \"$PROG_NAME__ grubconf\""
543   isExistent "$target_" die "$target_ is not a valied"
544   while true; do
545     echo -n "Please insert disk into $target_ and press <ENTER> (STRG-C for end)"
546     read
547     dd if=$PATH_/grub.img of="$target_"
548   done
549 }
550 # }}}
551
552
553 function removeTmpFiles
554 {
555   execute "rm -f $TMP_" warn
556 }
557
558 function actionClean
559 {
560   for i in dhcpd.conf grub.img minirt26.gz; do
561     execute "rm -f $PATH_/$i*"
562   done
563
564   for i in $CARDS_DETECTED_BY_DISCOVER $CONF_FILE_; do
565     execute "rm -f $i"
566   done
567
568 }
569
570
571 ###
572 ### __MAIN
573 ###
574
575 while getopts "i:hv" opt; do
576   case "$opt" in
577     i) interface_=$OPTARG ;;
578     h) printUsage; exit ;;
579     v) let verbose_=$verbose_+1 ;;
580     ?) printUsage; exit 64 ;;
581   esac
582 done
583 shift $(($OPTIND - 1))  # set ARGV to the first not parsed commandline parameter
584 setVerbose $verbose_
585
586 case "$1" in
587   help)   printUsage; exit 0 ;;
588 esac
589
590 checkRoot die 'You have to be root to use this program'
591 disableSyslog
592
593 execute "mkdir -p $PATH_" die
594
595 TMP_=`mktemp -t grml-terminalserver-config.XXXXXX` || die "Could not create tmpfile" $?
596 setExitFunction 'removeTmpFiles'
597
598
599 . $DEFAULT_CONFIG_
600 . $CONFIG_
601 # used config vars:
602 # MODULES_PATH_
603 # MODULES_PATH_ROOT_DIFF_
604 # KERNEL_VERSION_
605 # ORIGINAL_INITRD_
606 if [[ $MODULES_PATH_ == "" || $KERNEL_VERSION_ == "" || $ORIGINAL_INITRD_ == "" ]]; then
607   warn "MODULES_PATH_=\"$MODULES_PATH_\" \
608 KERNEL_VERSION_=\"$KERNEL_VERSION_\" \
609 ORIGINAL_INITRD_=\"$ORIGINAL_INITRD_\""
610   die "False configuration, please update $CONFIG_"
611 fi
612
613
614 case "$1" in
615   interactive)  actionInteractive ;;
616   grubConf)   grubConfig ;;
617   grubConfWrite)  grubConfig && grubWrite ;;
618   grubWrite)    grubWrite ;;
619   grubMultiWrite)   grubMultiWrite "$2" ;;
620   initrd) actionMkInitrd ;;
621   clean)  actionClean ;;
622   *)    actionInteractive ;;
623 esac
624
625 removeTmpFiles
626 # END OF FILE
627 ################################################################################
628 # vim:foldmethod=marker tabstop=2 expandtab shiftwidth=2