| #!/bin/bash | 
 |  | 
 | # Configurable nuggets | 
 | GUEST_PASSWORD=${GUEST_PASSWORD:-secrete} | 
 | STAGING_DIR=${STAGING_DIR:-stage} | 
 | DO_TGZ=${DO_TGZ:-1} | 
 | KERNEL_VERSION=3.0.0-12-virtual | 
 |  | 
 | # Debootstrap base system | 
 | if [ ! -d $STAGING_DIR ]; then | 
 |     apt-get install debootstrap | 
 |     debootstrap --arch amd64 oneiric $STAGING_DIR http://us.archive.ubuntu.com/ubuntu/ | 
 | fi | 
 |  | 
 | # Sources.list | 
 | cat <<EOF >$STAGING_DIR/etc/apt/sources.list | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric main restricted | 
 | deb-src http://us.archive.ubuntu.com/ubuntu/ oneiric main restricted | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric-updates main restricted | 
 | deb-src http://us.archive.ubuntu.com/ubuntu/ oneiric-updates main restricted | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric universe | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric-updates universe | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric multiverse | 
 | deb http://us.archive.ubuntu.com/ubuntu/ oneiric-updates multiverse | 
 | EOF | 
 |  | 
 | # Install basics | 
 | chroot $STAGING_DIR apt-get update | 
 | chroot $STAGING_DIR apt-get install -y linux-image-$KERNEL_VERSION | 
 | chroot $STAGING_DIR apt-get install -y cracklib-runtime curl wget ssh openssh-server tcpdump ethtool | 
 | chroot $STAGING_DIR apt-get install -y curl wget ssh openssh-server python-pip git vim-nox sudo | 
 | chroot $STAGING_DIR pip install xenapi | 
 |  | 
 | # Install guest utilities | 
 | XEGUEST=xe-guest-utilities_5.6.100-651_amd64.deb | 
 | wget http://images.ansolabs.com/xen/$XEGUEST -O $XEGUEST | 
 | cp $XEGUEST $STAGING_DIR/root | 
 | chroot $STAGING_DIR dpkg -i /root/$XEGUEST | 
 | chroot $STAGING_DIR update-rc.d -f xe-linux-distribution remove | 
 | chroot $STAGING_DIR update-rc.d xe-linux-distribution defaults | 
 |  | 
 | # Make a small cracklib dictionary, so that passwd still works, but we don't | 
 | # have the big dictionary. | 
 | mkdir -p $STAGING_DIR/usr/share/cracklib | 
 | echo a | chroot $STAGING_DIR cracklib-packer | 
 |  | 
 | # Make /etc/shadow, and set the root password | 
 | chroot $STAGING_DIR "pwconv" | 
 | echo "root:$GUEST_PASSWORD" | chroot $STAGING_DIR chpasswd | 
 |  | 
 | # Put the VPX into UTC. | 
 | rm -f $STAGING_DIR/etc/localtime | 
 |  | 
 | # Add stack user | 
 | chroot $STAGING_DIR groupadd libvirtd | 
 | chroot $STAGING_DIR useradd stack -s /bin/bash -d /opt/stack -G libvirtd | 
 | echo stack:$GUEST_PASSWORD | chroot $STAGING_DIR chpasswd | 
 | echo "stack ALL=(ALL) NOPASSWD: ALL" >> $STAGING_DIR/etc/sudoers | 
 |  | 
 | # Give ownership of /opt/stack to stack user | 
 | chroot $STAGING_DIR chown -R stack /opt/stack | 
 |  | 
 | # Make our ip address hostnames look nice at the command prompt | 
 | echo "export PS1='${debian_chroot:+($debian_chroot)}\\u@\\H:\\w\\$ '" >> $STAGING_DIR/opt/stack/.bashrc | 
 | echo "export PS1='${debian_chroot:+($debian_chroot)}\\u@\\H:\\w\\$ '" >> $STAGING_DIR/root/.bashrc | 
 | echo "export PS1='${debian_chroot:+($debian_chroot)}\\u@\\H:\\w\\$ '" >> $STAGING_DIR/etc/profile | 
 |  | 
 | function setup_vimrc { | 
 |     if [ ! -e $1 ]; then | 
 |         # Simple but usable vimrc | 
 |         cat > $1 <<EOF | 
 | syntax on | 
 | se ts=4 | 
 | se expandtab | 
 | se shiftwidth=4 | 
 | EOF | 
 |     fi | 
 | } | 
 |  | 
 | # Setup simple .vimrcs | 
 | setup_vimrc $STAGING_DIR/root/.vimrc | 
 | setup_vimrc $STAGING_DIR/opt/stack/.vimrc | 
 |  | 
 | if [ "$DO_TGZ" = "1" ]; then | 
 |     # Compress | 
 |     rm -f stage.tgz | 
 |     tar cfz stage.tgz stage | 
 | fi |