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