|  | #!/bin/bash | 
|  |  | 
|  | PROGDIR=`dirname $0` | 
|  | CHROOTCACHE=${CHROOTCACHE:-/var/cache/devstack} | 
|  |  | 
|  | # Source params | 
|  | source ./stackrc | 
|  |  | 
|  | # Store cwd | 
|  | CWD=`pwd` | 
|  |  | 
|  | NAME=$1 | 
|  | NFSDIR="/nfs/$NAME" | 
|  | DEST=${DEST:-/opt/stack} | 
|  |  | 
|  | # Option to use the version of devstack on which we are currently working | 
|  | USE_CURRENT_DEVSTACK=${USE_CURRENT_DEVSTACK:-1} | 
|  |  | 
|  | # remove old nfs filesystem if one exists | 
|  | rm -rf $DEST | 
|  |  | 
|  | # clean install of natty | 
|  | if [ ! -d $CHROOTCACHE/natty-base ]; then | 
|  | $PROGDIR/make_image.sh -C natty $CHROOTCACHE/natty-base | 
|  | # copy kernel modules... | 
|  | # NOTE(ja): is there a better way to do this? | 
|  | cp -pr /lib/modules/`uname -r` $CHROOTCACHE/natty-base/lib/modules | 
|  | # a simple password - pass | 
|  | echo root:pass | chroot $CHROOTCACHE/natty-base chpasswd | 
|  | fi | 
|  |  | 
|  | # prime natty with as many apt/pips as we can | 
|  | if [ ! -d $CHROOTCACHE/natty-dev ]; then | 
|  | rsync -azH $CHROOTCACHE/natty-base/ $CHROOTCACHE/natty-dev/ | 
|  | chroot $CHROOTCACHE/natty-dev apt-get install -y `cat files/apts/* | cut -d\# -f1 | egrep -v "(rabbitmq|libvirt-bin|mysql-server)"` | 
|  | chroot $CHROOTCACHE/natty-dev pip install `cat files/pips/*` | 
|  |  | 
|  | # Create a stack user that is a member of the libvirtd group so that stack | 
|  | # is able to interact with libvirt. | 
|  | chroot $CHROOTCACHE/natty-dev groupadd libvirtd | 
|  | chroot $CHROOTCACHE/natty-dev useradd stack -s /bin/bash -d $DEST -G libvirtd | 
|  | mkdir -p $CHROOTCACHE/natty-dev/$DEST | 
|  | chown stack $CHROOTCACHE/natty-dev/$DEST | 
|  |  | 
|  | # a simple password - pass | 
|  | echo stack:pass | chroot $CHROOTCACHE/natty-dev chpasswd | 
|  |  | 
|  | # and has sudo ability (in the future this should be limited to only what | 
|  | # stack requires) | 
|  | echo "stack ALL=(ALL) NOPASSWD: ALL" >> $CHROOTCACHE/natty-dev/etc/sudoers | 
|  | fi | 
|  |  | 
|  | # clone git repositories onto the system | 
|  | # ====================================== | 
|  |  | 
|  | if [ ! -d $CHROOTCACHE/natty-stack ]; then | 
|  | rsync -azH $CHROOTCACHE/natty-dev/ $CHROOTCACHE/natty-stack/ | 
|  | fi | 
|  |  | 
|  | # git clone only if directory doesn't exist already.  Since ``DEST`` might not | 
|  | # be owned by the installation user, we create the directory and change the | 
|  | # ownership to the proper user. | 
|  | function git_clone { | 
|  |  | 
|  | # clone new copy or fetch latest changes | 
|  | CHECKOUT=$CHROOTCACHE/natty-stack$2 | 
|  | if [ ! -d $CHECKOUT ]; then | 
|  | mkdir -p $CHECKOUT | 
|  | git clone $1 $CHECKOUT | 
|  | else | 
|  | pushd $CHECKOUT | 
|  | git fetch | 
|  | popd | 
|  | fi | 
|  |  | 
|  | # FIXME(ja): checkout specified version (should works for branches and tags) | 
|  |  | 
|  | pushd $CHECKOUT | 
|  | # checkout the proper branch/tag | 
|  | git checkout $3 | 
|  | # force our local version to be the same as the remote version | 
|  | git reset --hard origin/$3 | 
|  | popd | 
|  |  | 
|  | # give ownership to the stack user | 
|  | chroot $CHROOTCACHE/natty-stack/ chown -R stack $2 | 
|  | } | 
|  |  | 
|  | git_clone $NOVA_REPO $DEST/nova $NOVA_BRANCH | 
|  | git_clone $GLANCE_REPO $DEST/glance $GLANCE_BRANCH | 
|  | git_clone $KEYSTONE_REPO $DEST/keystone $KEYSTONE_BRANCH | 
|  | git_clone $NOVNC_REPO $DEST/novnc $NOVNC_BRANCH | 
|  | git_clone $DASH_REPO $DEST/dash $DASH_BRANCH $DASH_TAG | 
|  | git_clone $NOVACLIENT_REPO $DEST/python-novaclient $NOVACLIENT_BRANCH | 
|  | git_clone $OPENSTACKX_REPO $DEST/openstackx $OPENSTACKX_BRANCH | 
|  |  | 
|  | chroot $CHROOTCACHE/natty-stack mkdir -p $DEST/files | 
|  | wget -c http://images.ansolabs.com/tty.tgz -O $CHROOTCACHE/natty-stack$DEST/files/tty.tgz | 
|  |  | 
|  | # Use this version of devstack? | 
|  | if [ "$USE_CURRENT_DEVSTACK" = "1" ]; then | 
|  | rm -rf $CHROOTCACHE/natty-stack/$DEST/devstack | 
|  | cp -pr $CWD $CHROOTCACHE/natty-stack/$DEST/devstack | 
|  | fi | 
|  |  | 
|  | cp -pr $CHROOTCACHE/natty-stack $NFSDIR | 
|  |  | 
|  | # set hostname | 
|  | echo $NAME > $NFSDIR/etc/hostname | 
|  | echo "127.0.0.1 localhost $NAME" > $NFSDIR/etc/hosts | 
|  |  | 
|  | # injecting root's public ssh key if it exists | 
|  | if [ -f /root/.ssh/id_rsa.pub ]; then | 
|  | mkdir $NFSDIR/root/.ssh | 
|  | chmod 700 $NFSDIR/root/.ssh | 
|  | cp /root/.ssh/id_rsa.pub $NFSDIR/root/.ssh/authorized_keys | 
|  | fi |