* tentative merge of the onelab build, be sure to run
[build.git] / vbuild-init-vserver.sh
1 #!/bin/bash
2 # -*-shell-*-
3
4 COMMAND=$(basename $0)
5
6 function failure () {
7     echo "$COMMAND : Bailing out"
8     exit 1
9 }
10
11 # overwrite vserver's internal yum config from what is in
12 # .distributions/<distrib>/yum/yum.conf and /yum.repos.d 
13 # note : on fc6 I've had trouble with yum.conf, I haven't created a custom yum.conf
14 # when using the default yum.conf, 
15 # vserver build -m yum complained that /vservers/<v>/var/log/yum.log could not be created
16
17 function configure_yum_in_vserver () {
18     set -x 
19     set -e 
20     trap failure ERR INT
21
22     vserver=$1; shift
23     fcdistro=$1; shift
24
25     cd /etc/vservers/.distributions/${fcdistro}
26     if [ -f yum/yum.conf ] ; then
27         echo "Initializing yum.conf in $vserver from $(pwd)/yum"
28         cp yum/yum.conf /vservers/$vserver/etc/yum.conf
29     else
30         echo "Cannot initialize yum.conf in $vserver - using $fcdistro default"
31     fi
32
33     if [ -d yum.repos.d ] ; then
34         echo "Initializing yum.repos.d in $vserver from $(pwd)/yum.repos.d"
35         rm -rf /vservers/$vserver/etc/yum.repos.d
36         tar cf - yum.repos.d | tar -C /vservers/$vserver/etc -xvf -
37     else
38         echo "Cannot initialize yum.repos.d in $vserver"
39     fi
40     cd -
41 }    
42
43 function setup_vserver () {
44
45     set -x
46     set -e
47     trap failure ERR INT
48
49     vserver=$1; shift
50     fcdistro=$1; shift
51     personality=$1; shift
52
53     # create the new vserver
54     [ ! -d /etc/vservers/$vserver ] && $personality vserver $VERBOSE $vserver build -m yum -- -d $fcdistro
55
56     if [ ! -z "$personality" ] ; then
57         l32=$(grep $personality /etc/vservers/$vserver/personality | wc -l)
58         [ $l32 -eq 0 ] && echo $personality >> /etc/vservers/$vserver/personality
59     fi
60
61     # set up appropriate vserver capabilities to mount, mknod and IPC_LOCK
62     BCAPFILE=/etc/vservers/$vserver/bcapabilities
63     touch $BCAPFILE
64     cap=$(grep ^CAP_SYS_ADMIN /etc/vservers/$vserver/bcapabilities | wc -l)
65     [ $cap -eq 0 ] && echo 'CAP_SYS_ADMIN' >> /etc/vservers/$vserver/bcapabilities
66     cap=$(grep ^CAP_MKNOD /etc/vservers/$vserver/bcapabilities | wc -l)
67     [ $cap -eq 0 ] && echo 'CAP_MKNOD' >> /etc/vservers/$vserver/bcapabilities
68     cap=$(grep ^CAP_IPC_LOCK /etc/vservers/$vserver/bcapabilities | wc -l)
69     [ $cap -eq 0 ] && echo 'CAP_IPC_LOCK' >> /etc/vservers/$vserver/bcapabilities
70
71     # start the vserver so we can do the following operations
72     $personality vyum $vserver -- -y install yum
73     $personality vserver $VERBOSE $vserver pkgmgmt internalize
74     $personality vserver $VERBOSE $vserver start
75     $personality vserver $VERBOSE $vserver exec rm -f /var/lib/rpm/__db*
76     $personality vserver $VERBOSE $vserver exec rpm --rebuilddb
77
78     configure_yum_in_vserver $vserver $fcdistro
79
80     # set up resolv.conf
81     cp /etc/resolv.conf /vservers/$vserver/etc/resolv.conf
82
83 }
84
85 function devel_tools () {
86
87     set -x 
88     set -e 
89     trap failure ERR INT
90
91     vserver=$1; shift
92     fcdistro=$1; shift
93     pldistro=$1; shift
94     personality=$1; shift
95
96     # check for .lst file based on pldistro
97     lst=${pldistro}-${fcdistro}-devel.lst
98     if [ -f $lst ] ; then
99         echo "$COMMAND: Using $lst"
100     else
101         echo "$COMMAND : Cannot locate $lst - exiting"
102         usage
103     fi
104
105     # install individual packages, then groups
106     packages=$(grep "^package:" $lst | sed -e s,package:,,)
107     groups=$(grep "^group:" $lst | sed -e s,group:,,)
108
109     [ -n "$packages" ] && $personality vserver $vserver exec yum -y install $packages
110     [ -n "$groups" ] && $personality vserver $vserver exec yum -y groupinstall $groups
111     return 0
112 }
113
114 function post_install () {
115
116     set -x 
117     set -e 
118     trap failure ERR INT
119
120     vserver=$1; shift
121     personality=$1; shift
122
123 ### From myplc-devel-native.spec
124 # be careful to backslash $ in this, otherwise it's the root context that's going to do the evaluation
125     cat << EOF | $personality vserver $VERBOSE $vserver exec bash -x
126     # set up /dev/loop* in vserver
127     for i in \$(seq 0 7) ; do
128         mknod -m 640 /dev/loop\$i b 7 \$i
129     done
130     
131     # create symlink for /dev/fd
132     ln -fs /proc/self/fd /dev/fd
133
134     # modify /etc/rpm/macros to not use /sbin/new-kernel-pkg
135     sed -i 's,/sbin/new-kernel-pkg:,,' /etc/rpm/macros
136     if [ -h "/sbin/new-kernel-pkg" ] ; then
137         filename=\$(readlink -f /sbin/new-kernel-pkg)
138         if [ "\$filename" == "/sbin/true" ] ; then
139                 echo "WARNING: /sbin/new-kernel-pkg symlinked to /sbin/true"
140                 echo "\tmost likely /etc/rpm/macros has /sbin/new-kernel-pkg declared in _netsharedpath."
141                 echo "\tPlease remove /sbin/new-kernel-pkg from _netsharedpath and reintall mkinitrd."
142                 exit 1
143         fi
144     fi
145     
146     uid=2000
147     gid=2000
148     
149     # add a "build" user to the system
150     builduser=\$(grep "^build:" /etc/passwd | wc -l)
151     if [ \$builduser -eq 0 ] ; then
152         groupadd -o -g \$gid build;
153         useradd -o -c 'Automated Build' -u \$uid -g \$gid -n -M -s /bin/bash build;
154     fi
155
156 # Allow build user to build certain RPMs as root
157     if [ -f /etc/sudoers ] ; then
158         buildsudo=\$(grep "^build.*ALL=(ALL).*NOPASSWD:.*ALL"  /etc/sudoers | wc -l)
159         if [ \$buildsudo -eq 0 ] ; then
160             echo "build   ALL=(ALL)       NOPASSWD: ALL" >> /etc/sudoers
161         fi
162         sed -i 's,^Defaults.*requiretty,#Defaults requiretty,' /etc/sudoers
163     fi
164 #
165 EOF
166
167 }
168
169 function usage () {
170     set +x 
171     echo "Usage: $COMMAND [-s] [-p] [-v] vserver-name distribution pldistro [personality]"
172     echo "Requirements: you need to have a vserver-compliant kernel,"
173     echo "  as well as the util-vserver RPM installed"
174     echo "Description:"
175     echo "  This command creates a fresh vserver instance, with the specified name"
176     echo "  The root filesystem is created from the specified distribution, e.g. fc6"
177     echo "  The third argument denotes a pldistro, e.g. onelab"
178     echo "  The last, optional, argument defaults to linux32"
179     echo "This is done in three steps"
180     echo " (*) setup phase : vserver creation, yum internalization and config (from /etc/vservers)"
181     echo " (*) tools install : the tools required for building are installed"
182     echo "    to this end we search for a .lst file that specifies the pkgs & groups"
183     echo "    assuming the above that pldistro is onelab:"
184     echo "    (*) we first check for onelab-devel-fc6.lst"
185     echo "    (*) and then for onelab-devel.lst"
186     echo " (*) post-install : create a build user, + various tunings required"
187     echo "Options:"
188     echo " -s : skips the setup phase"
189     echo " -t : skips the tools phase"
190     echo " -p : skips the post-install"
191     echo " -v : passes -v to calls to vserver"
192     exit 1
193 }
194
195 ### parse args and 
196 function main () {
197
198     set -e
199     trap failure ERR INT
200
201     DO_SETUP=true
202     DO_TOOLS=true
203     DO_POST=true
204     VERBOSE=
205     while getopts "stpvh" opt ; do
206         case $opt in
207             s) DO_SETUP="" ;;
208             t) DO_TOOLS="" ;;
209             p) DO_POST="" ;;
210             v) VERBOSE="-v" ;;
211             h|*) usage ;;
212         esac
213     done
214         
215     shift $(($OPTIND - 1))
216     
217     [[ -z "$@" ]] && usage
218     vserver=$1 ; shift
219     [[ -z "$@" ]] && usage
220     fcdistro=$1 ; shift
221     [[ -z "$@" ]] && usage
222     pldistro=$1 ; shift
223     if [[ -z "$@" ]] ; then
224         personality=linux32
225     else
226         personality=$1; shift
227     fi
228     [[ -n "$@" ]] && usage
229
230     [ -n "$DO_SETUP" ] && setup_vserver $vserver $fcdistro $personality
231     [ -n "$DO_TOOLS" ] && devel_tools $vserver $fcdistro $pldistro $personality
232     [ -n "$DO_POST" ] && post_install $vserver $personality
233
234 }
235
236 main "$@"