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