2 # Filename: /etc/grml/fai/config/hooks/instsoft.GRML
3 # Purpose: grml specific Debian installation in the chroot
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 ################################################################################
12 # visualize chroot inside zsh:
13 echo grml_chroot > $target/etc/debian_chroot
16 [ -r /etc/grml/grml-live.conf ] && . /etc/grml/grml-live.conf
17 [ -r /etc/grml/grml-live.local ] && . /etc/grml/grml-live.local
18 [ -n "$HOSTNAME" ] || HOSTNAME=grml
19 echo "$HOSTNAME" > $target/etc/hostname
21 if [ "$FAI_ACTION" = "softupdate" ] ; then
22 echo "Softupdate of FAI via grml-live running"
24 if [ -r /etc/resolv.conf ] ; then
25 if [ -r $target/etc/resolvconf/run/resolv.conf ] ; then
26 cat /etc/resolv.conf >> $target/etc/resolvconf/run/resolv.conf
28 cat /etc/resolv.conf >> $target/etc/resolv.conf
32 if [ -r $target/etc/policy-rc.d.conf ] ; then
33 sed -i "s/EXITSTATUS=.*/EXITSTATUS='101'/" $target/etc/policy-rc.d.conf
36 # we definitely don't want to fail running fai sofupdate just
37 # because of some well known bugs:
38 [ -d $target/etc/apt/apt.conf.d ] || mkdir $target/etc/apt/apt.conf.d
39 cat > $target/etc/apt/apt.conf.d/10apt-listbugs << EOF
40 // Check all packages whether they has critical bugs before they are installed.
41 // If you don't like it, comment it out.
42 //DPkg::Pre-Install-Pkgs {"/usr/sbin/apt-listbugs apt || exit 10"};
43 //DPkg::Tools::Options::/usr/sbin/apt-listbugs "";
44 //DPkg::Tools::Options::/usr/sbin/apt-listbugs::Version "2";
47 # make sure we can handle kernel upgrades:
48 if [ -r $target/etc/kernel-img.conf ] ; then
49 if ! grep -q "silent_modules = Yes" $target/etc/kernel-img.conf ; then
50 echo "silent_modules = Yes" >> $target/etc/kernel-img.conf
54 # FAI softupdate executes upgrade only with the sources.list being
55 # present in the chroot :-/ - so let's do it on our own:
56 if [ -r /etc/grml/fai/apt/sources.list ] ; then
57 if [ -L $target/etc/apt/sources.list ] ; then
58 rm $target/etc/apt/sources.list
60 cp /etc/grml/fai/apt/sources.list $target/etc/apt/sources.list
63 # run it on our own, as updatebase is used at the wrong stage for our needs,
64 # see /etc/grml/fai/config/hooks/updatebase.GRMLBASE
65 $ROOTCMD apt-get update
66 if ! [ -x $target/usr/bin/aptitude ] ; then
67 $ROOTCMD apt-get -y install aptitude
70 if [ -x $target/usr/bin/aptitude ] ; then
71 if $ROOTCMD aptitude --help | grep -q safe-upgrade ; then
72 $ROOTCMD aptitude -y safe-upgrade
74 $ROOTCMD aptitude -y upgrade
77 $ROOTCMD apt-get -y upgrade
80 else # no softupdate but fresh installation
82 # install all apt related files
83 if [ -r /etc/grml/fai/files/etc/apt ] ; then
84 cp -a /etc/grml/fai/files/etc/apt/* $target/etc/apt/
87 # install all present (but at least the grml) gpg keys:
88 if [ -r /etc/grml/fai/files/etc/apt/grml.key ] ; then
89 for file in /etc/grml/fai/files/etc/apt/*.key ; do
90 FILE="$(basename $file)"
91 # installed via 'cp -a /etc/grml/fai/files/etc/apt/* $target/etc/apt/' above already
92 # cp $file $target/etc/apt/"$FILE"
93 $ROOTCMD apt-key add /etc/apt/"$FILE"
96 gpg --keyserver subkeys.pgp.net --recv-keys F61E2E7CECDEA787 || \
97 gpg --keyserver blackhole.pca.dfn.de --recv-keys F61E2E7CECDEA787
98 gpg --export F61E2E7CECDEA787 > $target/etc/apt/grml.key
99 $ROOTCMD apt-key add /etc/apt/grml.key
102 # work around http://trac.lighttpd.net/trac/ticket/657
103 if ! grep -q 'Acquire::http::Pipeline-Depth.*0' $target/etc/apt/apt.conf ; then
104 echo "Acquire::http::Pipeline-Depth 0; // added by grml-live" >> $target/etc/apt/apt.conf
107 # Recommends just pull in way tooooo much packages, so disable it:
108 if ! grep -q 'APT::Install-Recommends.*false' $target/etc/apt/apt.conf ; then
109 echo "APT::Install-Recommends false; // added by grml-live" >> $target/etc/apt/apt.conf
112 # Notice: deprecated with aptitude (0.4.11-1):
113 if ! grep -q 'Aptitude::Recommends-Important.*false' $target/etc/apt/apt.conf ; then
114 echo "Aptitude::Recommends-Important false; // added by grml-live" >> $target/etc/apt/apt.conf
117 # make sure we have file-rc available before
118 # package_config/GRML is being executed:
119 $ROOTCMD apt-get update
120 $ROOTCMD aptitude -f -y install file-rc
122 # Workaround #443481 of snort for Debian/etch:
123 mkdir -p $target/etc/snort
124 echo 'LOGDIR=/var/log/snort' >> $target/etc/snort/snort.common.parameters
126 # we definitely don't want to fail running fai dirinstall just
127 # because of some well known bugs:
128 [ -d $target/etc/apt/apt.conf.d ] || mkdir $target/etc/apt/apt.conf.d
129 cat > $target/etc/apt/apt.conf.d/10apt-listbugs << EOF
130 // Check all packages whether they has critical bugs before they are installed.
131 // If you don't like it, comment it out.
132 //DPkg::Pre-Install-Pkgs {"/usr/sbin/apt-listbugs apt || exit 10"};
133 //DPkg::Tools::Options::/usr/sbin/apt-listbugs "";
134 //DPkg::Tools::Options::/usr/sbin/apt-listbugs::Version "2";
137 # make sure /dev/MAKEDEV is available:
138 if [ -x "$target"/sbin/MAKEDEV ] && ! [ -r "$target"/dev/MAKEDEV ] ; then
139 ln -s /sbin/MAKEDEV "$target"/dev/MAKEDEV
142 # we don't need the invoke-rc.d.d diversion (we have grml-policyrcd :)):
143 if [ -L "$target"/usr/sbin/invoke-rc.d ] ; then
144 rm -f "$target"/usr/sbin/invoke-rc.d
145 $ROOTCMD dpkg-divert --package fai --rename --remove /usr/sbin/invoke-rc.d
148 fi # end of FAI_ACTION = softupdate
150 ## END OF FILE #################################################################
151 # vim:ft=sh expandtab ai tw=80 tabstop=4 shiftwidth=3