PLC support scripts as part of myplc package.
[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 install -D -m 755 support-scripts/* root/etc/support-scripts
69
70 # Install initscripts
71 echo "* myplc: Installing initscripts"
72 find plc.d | cpio -p -d -u root/etc/
73 install -D -m 755 guest.init root/etc/init.d/plc
74 chroot root sh -c 'chkconfig --add plc; chkconfig plc on'
75
76 # fetch the release stamp from the build if any
77 # I could not come up with any more sensitive scheme 
78 if [ -f ../../../myplc-release ] ; then
79   cp ../../../myplc-release myplc-release
80 else
81   echo "Cannot find release information." > myplc-release
82   date >> myplc-release
83   echo "$HeadURL$" >> myplc-release
84 fi
85 # install it in /etc/myplc-release 
86 install -m 444 myplc-release root/etc/myplc-release
87
88 ### Thierry Parmentelat - april 16 2007
89 # fix the yum.conf as produced by mkfedora
90 # so we can use the build's fc4 mirror for various installs/upgrades
91 # within the chroot jail
92 # yum_conf_to_build_host is defined in build.functions
93 yum_conf_to_build_host > root/etc/yum.conf
94
95 ### Thierry Parmentelat - july 20 2007
96 # we now build the myplc doc
97 # beware that making the pdf file somehow overwrites the html
98 make -C doc myplc.pdf 
99 rm -f doc/myplc.html
100 make -C doc myplc.html 
101
102 # install at the same place as plcapi - better ideas ?
103 for doc in myplc.html myplc.pdf ; do
104     install -m 644 doc/$doc root/usr/share/plc_api/doc/$doc
105 done
106
107 # we now build the plcapi doc
108 # this generates a drupal php file from a docbook-generated html
109 # quick & dirty
110 docbook_html_to_drupal "${pldistro} PLCAPI Documentation" \
111     root/usr/share/plc_api/doc/PLCAPI.html \
112     root/var/www/html/planetlab/doc/plcapi.php
113 # pdf just get copied
114 install -m 644 root/usr/share/plc_api/doc/PLCAPI.pdf root/var/www/html/planetlab/doc/plcapi.pdf
115
116 docbook_html_to_drupal "Myplc User Guide" \
117     root/usr/share/plc_api/doc/myplc.html \
118     root/var/www/html/planetlab/doc/myplc.php
119 # pdf just get copied
120 install -m 644 root/usr/share/plc_api/doc/myplc.pdf root/var/www/html/planetlab/doc/myplc.pdf
121
122 # Install configuration file
123 echo "* myplc: Installing configuration file"
124 install -D -m 444 default_config.xml data/etc/planetlab/default_config.xml
125 install -D -m 444 plc_config.dtd data/etc/planetlab/plc_config.dtd
126
127 # handle root's homedir and tweak root prompt
128 echo "* myplc: root's homedir and prompt"
129 roothome=data/root
130 mkdir -p $roothome
131 cat << EOF > $roothome/.profile
132 export PS1="<plc> \$PS1"
133 EOF
134 chmod 644 $roothome/.profile
135
136 # Move "data" directories out of the installation
137 echo "* myplc: Moving data directories out of the installation"
138 pl_move_dirs root data /data "${datadirs[@]}"
139
140 # Fix permissions on tmp directories
141 pl_fixtmp_permissions data
142
143 # Remove generated bootmanager script
144 rm -f data/var/www/html/boot/bootmanager.sh
145
146 # Initialize node RPMs directory. The PlanetLab-Bootstrap.tar.bz2
147 # tarball already contains all of the node RPMs pre-installed. Only
148 # updates or optional packages should be placed in this directory.
149 install -D -m 644 $pl_DISTRO_YUMGROUPS \
150     data/var/www/html/install-rpms/planetlab/yumgroups.xml
151
152 # Make image out of directory
153 echo "* myplc: Building loopback image"
154 pl_make_image root root.img 100000000
155
156 exit 0