cleaning up the root creation functions and build.common - untested
[myplc.git] / build.sh
1 #!/bin/bash
2 #
3 # Builds MyPLC, either inside the MyPLC development environment in
4 # devel/root (if PLC_DEVEL_BOOTSTRAP is true), or in the current host
5 # environment (may be itself a MyPLC development environment or a
6 # Fedora Core 4 environment with the appropriate development packages
7 # installed).
8 #
9 # root.img (loopback image)
10 # root/ (mount point)
11 # data/ (various data files)
12 # data/etc/planetlab/ (configuration files)
13 # data/root (root's homedir)
14 #
15 # Mark Huang <mlhuang@cs.princeton.edu>
16 # Copyright (C) 2006 The Trustees of Princeton University
17 #
18 # $Id$
19 #
20
21 . build.functions
22
23 # pldistro expected as $1 - defaults to planetlab
24 pldistro=planetlab
25 [ -n "$@" ] && pldistro=$1
26
27 # These directories are allowed to grow to unspecified size, so they
28 # are stored as symlinks to the /data partition. mkfedora and yum
29 # expect some of them to be real directories, however.
30 datadirs=(
31 /etc/planetlab
32 /root
33 /var/lib/pgsql
34 /var/www/html/alpina-logs
35 /var/www/html/boot
36 /var/www/html/download
37 /var/www/html/files
38 /var/www/html/sites
39 /var/www/html/generated
40 /var/www/html/install-rpms
41 /var/www/html/xml
42 /tmp
43 /usr/tmp
44 /var/tmp
45 /var/log
46 )
47
48 pl_fixdirs root "${datadirs[@]}"
49
50 echo "* myplc: Installing base filesystem"
51 mkdir -p root data
52
53 pkgsfile=$(pl_locateDistroFile ../build/ ${pldistro} myplc.pkgs)
54 pl_root_setup_chroot root -f $pkgsfile
55
56 # Install configuration scripts
57 echo "* myplc: Installing configuration scripts"
58 install -D -m 755 plc_config.py root/tmp/plc_config.py
59 chroot root sh -c 'cd /tmp; python plc_config.py build; python plc_config.py install'
60 install -D -m 755 plc-config root/usr/bin/plc-config
61 install -D -m 755 plc-config-tty root/usr/bin/plc-config-tty
62 install -D -m 755 db-config root/usr/bin/db-config
63 install -D -m 755 dns-config root/usr/bin/dns-config
64 install -D -m 755 plc-map.py root/usr/bin/plc-map.py
65 install -D -m 755 clean-empty-dirs.py root/usr/bin/clean-empty-dirs.py
66 install -D -m 755 mtail.py root/usr/bin/mtail.py
67 install -D -m 755 check-ssl-peering.py root/usr/bin/check-ssl-peering.py
68
69 # Install initscripts
70 echo "* myplc: Installing initscripts"
71 find plc.d | cpio -p -d -u root/etc/
72 install -D -m 755 guest.init root/etc/init.d/plc
73 chroot root sh -c 'chkconfig --add plc; chkconfig plc on'
74
75 # fetch the release stamp from the build if any
76 # I could not come up with any more sensitive scheme 
77 if [ -f ../../../myplc-release ] ; then
78   cp ../../../myplc-release myplc-release
79 else
80   echo "No build release information found" > myplc-release
81 fi
82 # install it in /etc/myplc-release 
83 install -m 444 myplc-release root/etc/myplc-release
84
85 ### Thierry Parmentelat - april 16 2007
86 # fix the yum.conf as produced by mkfedora
87 # so we can use the build's fc4 mirror for various installs/upgrades
88 # within the chroot jail
89 # yum_conf_to_build_host is defined in build.functions
90 yum_conf_to_build_host > root/etc/yum.conf
91
92 ### Thierry Parmentelat - may 16 2007
93 # the node-dependent image generation script requires root privilege
94 # to perform various mount operations
95 sudoers_bootcustom_apache > root/etc/sudoers
96 chown root:root root/etc/sudoers
97 chmod 400 root/etc/sudoers
98
99 ### Thierry Parmentelat - july 20 2007
100 # we now build the myplc doc
101 # beware that making the pdf file somehow overwrites the html
102 make -C doc myplc.pdf 
103 rm -f doc/myplc.html
104 make -C doc myplc.html 
105
106 # install at the same place as plcapi - better ideas ?
107 for doc in myplc.html myplc.pdf ; do
108     install -m 644 doc/$doc root/usr/share/plc_api/doc/$doc
109 done
110
111 # we now build the plcapi doc
112 # this generates a drupal php file from a docbook-generated html
113 # quick & dirty
114 docbook_html_to_drupal "OneLab PLCAPI Documentation" \
115     root/usr/share/plc_api/doc/PLCAPI.html \
116     root/var/www/html/planetlab/doc/plcapi.php
117 # pdf just get copied
118 install -m 644 root/usr/share/plc_api/doc/PLCAPI.pdf root/var/www/html/planetlab/doc/plcapi.pdf
119
120 docbook_html_to_drupal "Myplc User Guide" \
121     root/usr/share/plc_api/doc/myplc.html \
122     root/var/www/html/planetlab/doc/myplc.php
123 # pdf just get copied
124 install -m 644 root/usr/share/plc_api/doc/myplc.pdf root/var/www/html/planetlab/doc/myplc.pdf
125
126 # Install configuration file
127 echo "* myplc: Installing configuration file"
128 install -D -m 444 default_config.xml data/etc/planetlab/default_config.xml
129 install -D -m 444 plc_config.dtd data/etc/planetlab/plc_config.dtd
130
131 # handle root's homedir and tweak root prompt
132 echo "* myplc: root's homedir and prompt"
133 roothome=data/root
134 mkdir -p $roothome
135 cat << EOF > $roothome/.profile
136 export PS1="<plc> \$PS1"
137 EOF
138 chmod 644 $roothome/.profile
139
140 # Move "data" directories out of the installation
141 echo "* myplc: Moving data directories out of the installation"
142 pl_move_dirs root data /data "${datadirs[@]}"
143
144 # Fix permissions on tmp directories
145 pl_fixtmp_permissions data
146
147 # Remove generated bootmanager script
148 rm -f data/var/www/html/boot/bootmanager.sh
149
150 # Initialize node RPMs directory. The PlanetLab-Bootstrap.tar.bz2
151 # tarball already contains all of the node RPMs pre-installed. Only
152 # updates or optional packages should be placed in this directory.
153 install -D -m 644 $pl_DISTRO_YUMGROUPS \
154     data/var/www/html/install-rpms/planetlab/yumgroups.xml
155
156 # Make image out of directory
157 echo "* myplc: Building loopback image"
158 pl_make_image root root.img 100000000
159
160 exit 0