| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 1 | #!/bin/bash | 
 | 2 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 3 | # This script is run on an Ubuntu VM. | 
 | 4 | # This script is inserted into the VM by prepare_guest_template.sh | 
 | 5 | # and is run when that VM boots. | 
 | 6 | # It customizes a fresh Ubuntu install, so it is ready | 
 | 7 | # to run stack.sh | 
 | 8 | # | 
 | 9 | # This includes installing the XenServer tools, | 
 | 10 | # creating the user called "stack", | 
 | 11 | # and shuts down the VM to signal the script has completed | 
 | 12 |  | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 13 | set -o errexit | 
 | 14 | set -o nounset | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 15 | set -o xtrace | 
| Renuka Apte | ce59d64 | 2012-02-02 16:09:23 -0800 | [diff] [blame] | 16 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 17 | # Configurable nuggets | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 18 | GUEST_PASSWORD="$1" | 
 | 19 | XS_TOOLS_PATH="$2" | 
 | 20 | STACK_USER="$3" | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 21 | DOMZERO_USER="$4" | 
 | 22 |  | 
 | 23 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 24 | function setup_domzero_user { | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 25 |     local username | 
 | 26 |  | 
 | 27 |     username="$1" | 
 | 28 |  | 
 | 29 |     local key_updater_script | 
 | 30 |     local sudoers_file | 
 | 31 |     key_updater_script="/home/$username/update_authorized_keys.sh" | 
 | 32 |     sudoers_file="/etc/sudoers.d/allow_$username" | 
 | 33 |  | 
 | 34 |     # Create user | 
 | 35 |     adduser --disabled-password --quiet "$username" --gecos "$username" | 
 | 36 |  | 
 | 37 |     # Give passwordless sudo | 
 | 38 |     cat > $sudoers_file << EOF | 
 | 39 |     $username ALL = NOPASSWD: ALL | 
 | 40 | EOF | 
 | 41 |     chmod 0440 $sudoers_file | 
 | 42 |  | 
 | 43 |     # A script to populate this user's authenticated_keys from xenstore | 
 | 44 |     cat > $key_updater_script << EOF | 
 | 45 | #!/bin/bash | 
 | 46 | set -eux | 
 | 47 |  | 
 | 48 | DOMID=\$(sudo xenstore-read domid) | 
 | 49 | sudo xenstore-exists /local/domain/\$DOMID/authorized_keys/$username | 
 | 50 | sudo xenstore-read /local/domain/\$DOMID/authorized_keys/$username > /home/$username/xenstore_value | 
 | 51 | cat /home/$username/xenstore_value > /home/$username/.ssh/authorized_keys | 
 | 52 | EOF | 
 | 53 |  | 
 | 54 |     # Give the key updater to the user | 
 | 55 |     chown $username:$username $key_updater_script | 
 | 56 |     chmod 0700 $key_updater_script | 
 | 57 |  | 
 | 58 |     # Setup the .ssh folder | 
 | 59 |     mkdir -p /home/$username/.ssh | 
 | 60 |     chown $username:$username /home/$username/.ssh | 
 | 61 |     chmod 0700 /home/$username/.ssh | 
 | 62 |     touch /home/$username/.ssh/authorized_keys | 
 | 63 |     chown $username:$username /home/$username/.ssh/authorized_keys | 
 | 64 |     chmod 0600 /home/$username/.ssh/authorized_keys | 
 | 65 |  | 
 | 66 |     # Setup the key updater as a cron job | 
 | 67 |     crontab -u $username - << EOF | 
 | 68 | * * * * * $key_updater_script | 
 | 69 | EOF | 
 | 70 |  | 
 | 71 | } | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 72 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 73 | # Install basics | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 74 | apt-get update | 
 | 75 | apt-get install -y cracklib-runtime curl wget ssh openssh-server tcpdump ethtool | 
| Joe Gordon | bb1e078 | 2014-03-06 09:40:27 -0800 | [diff] [blame] | 76 | apt-get install -y curl wget ssh openssh-server python-pip git sudo python-netaddr | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 77 | pip install xenapi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 78 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 79 | # Install XenServer guest utilities | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 80 | dpkg -i $XS_TOOLS_PATH | 
 | 81 | update-rc.d -f xe-linux-distribution remove | 
 | 82 | update-rc.d xe-linux-distribution defaults | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 83 |  | 
 | 84 | # Make a small cracklib dictionary, so that passwd still works, but we don't | 
 | 85 | # have the big dictionary. | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 86 | mkdir -p /usr/share/cracklib | 
 | 87 | echo a | cracklib-packer | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 88 |  | 
 | 89 | # Make /etc/shadow, and set the root password | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 90 | pwconv | 
 | 91 | echo "root:$GUEST_PASSWORD" | chpasswd | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 92 |  | 
 | 93 | # Put the VPX into UTC. | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 94 | rm -f /etc/localtime | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 95 |  | 
 | 96 | # Add stack user | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 97 | groupadd libvirtd | 
 | 98 | useradd $STACK_USER -s /bin/bash -d /opt/stack -G libvirtd | 
 | 99 | echo $STACK_USER:$GUEST_PASSWORD | chpasswd | 
 | 100 | echo "$STACK_USER ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 101 |  | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 102 | setup_domzero_user "$DOMZERO_USER" | 
 | 103 |  | 
| Mate Lakat | b1dc9bd | 2013-08-29 11:52:20 +0100 | [diff] [blame] | 104 | # Add an udev rule, so that new block devices could be written by stack user | 
 | 105 | cat > /etc/udev/rules.d/50-openstack-blockdev.rules << EOF | 
 | 106 | KERNEL=="xvd[b-z]", GROUP="$STACK_USER", MODE="0660" | 
 | 107 | EOF | 
 | 108 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 109 | # Give ownership of /opt/stack to stack user | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 110 | chown -R $STACK_USER /opt/stack | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 111 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 112 | function setup_vimrc { | 
 | 113 |     if [ ! -e $1 ]; then | 
 | 114 |         # Simple but usable vimrc | 
 | 115 |         cat > $1 <<EOF | 
 | 116 | syntax on | 
 | 117 | se ts=4 | 
 | 118 | se expandtab | 
 | 119 | se shiftwidth=4 | 
 | 120 | EOF | 
 | 121 |     fi | 
 | 122 | } | 
 | 123 |  | 
 | 124 | # Setup simple .vimrcs | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 125 | setup_vimrc /root/.vimrc | 
 | 126 | setup_vimrc /opt/stack/.vimrc | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 127 |  | 
 | 128 | # remove self from local.rc | 
 | 129 | # so this script is not run again | 
 | 130 | rm -rf /etc/rc.local | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 131 |  | 
 | 132 | # Restore rc.local file | 
 | 133 | cp /etc/rc.local.preparebackup /etc/rc.local | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 134 |  | 
 | 135 | # shutdown to notify we are done | 
 | 136 | shutdown -h now |