]> git.immae.eu Git - perso/Immae/Projets/Puppet.git/blame - bin/install_script.sh
Fix python script ovh path
[perso/Immae/Projets/Puppet.git] / bin / install_script.sh
CommitLineData
ec1096d8
IB
1#!/bin/bash
2
248bd83e
IB
3set -e
4
5host_user=root
6git_branch=master
7
8while [ -n "$1" ]; do
9 case "$1" in
10 --vps)
11 vps_name="$2"
12 shift
13 ;;
14 --reinstall-first)
15 reinstall_first=1
16 ;;
17 --password)
18 password="$2"
19 shift
20 ;;
21 --host-user)
22 host_user="$2"
23 shift
24 ;;
25 --no-reboot)
26 no_reboot=1
27 ;;
28 --no-reboot-start)
29 no_reboot_start=1
30 ;;
31 --no-reboot-end)
32 no_reboot_end=1
33 ;;
34 --git-branch)
35 git_branch="$2"
36 shift
37 ;;
38 esac
39
40 shift
41done
42
ec1096d8
IB
43DIRECTORY=$(cd `dirname $0` && pwd)
44PYTHON_DIRECTORY="$DIRECTORY/../python"
45
248bd83e 46if [ -z "$vps_name" ]; then
ec1096d8
IB
47 read -p "Nom du vps : " vps_name
48fi
49
248bd83e
IB
50if [ -n "$reinstall_first" ]; then
51 echo "Réinstallation du système"
52 python $PYTHON_DIRECTORY/reinstall_vps_server.py --use-current "$vps_name"
53
54 read -p "Appuyer sur une touche quand le serveur est prêt" ready
55fi
56
57if [ -z "$no_reboot" -a -z "$no_reboot_start" ]; then
58 echo "Patienter le temps du reboot"
59 python $PYTHON_DIRECTORY/reboot_vps_server.py --rescue "$vps_name"
60fi
ec1096d8 61
248bd83e
IB
62if [ -z "$password" ]; then
63 stty -echo
64 read -p "Mot de passe reçu par e-mail : " password; echo
65 stty echo
66fi
ec1096d8
IB
67
68ARCH_DIR=`mktemp -d`
69ARCH_HOST_SCRIPT="$ARCH_DIR/arch_host_script.sh"
70ARCH_CHROOT_SCRIPT="$ARCH_DIR/arch_chroot_script.sh"
71ARCH_INSTALL_SCRIPT="$ARCH_DIR/arch_install_script.sh"
503e4cf5
IB
72ARCH_HOST_PUPPET_CONFIGURATION_SCRIPT="$ARCH_DIR/arch_host_puppet_configuration_script.sh"
73ARCH_PUPPET_CONFIGURATION_SCRIPT="$ARCH_DIR/arch_puppet_configuration_script.sh"
248bd83e 74ARCH_PUPPET_INITIAL_CONFIGURATION="$ARCH_DIR/puppet_variables.json"
ec1096d8
IB
75
76trap "rm -rf $ARCH_DIR" EXIT
77
503e4cf5 78#### Base installation stage
248bd83e
IB
79python $PYTHON_DIRECTORY/get_initial_configuration.py $vps_name > $ARCH_PUPPET_INITIAL_CONFIGURATION
80
ec1096d8
IB
81cat > $ARCH_HOST_SCRIPT <<EOF
82#!/bin/bash
83
84apt-get update
85apt-get install -y haveged
86haveged &
87
88cd /tmp
89
90LATEST=\$(curl https://mirrors.kernel.org/archlinux/iso/latest/sha1sums.txt | grep "bootstrap" | head -n1)
91SHA1=\$(echo "\$LATEST" | cut -d' ' -f1)
92NAME=\$(echo "\$LATEST" | cut -d' ' -f3)
93
94curl -O "https://mirrors.kernel.org/archlinux/iso/latest/\$NAME"
95
96tar -xzf "\$NAME"
97
98echo 'Server = http://archlinux.mirrors.ovh.net/archlinux/\$repo/os/\$arch' > /tmp/root.x86_64/etc/pacman.d/mirrorlist
99
100DEVICE_STR=\$(cat /proc/mounts | grep "/dev/sd.. /mnt/")
101DEVICE=\$(echo "\$DEVICE_STR" | cut -d' ' -f1)
102MOUNTPOINT=\$(echo "\$DEVICE_STR" | cut -d' ' -f2)
103
104umount "\$DEVICE"
105UUID=\$(lsblk -rno UUID "\$DEVICE")
106
107echo "\$UUID" > /tmp/root.x86_64/device_uuid
108
109cp /tmp/arch_chroot_script.sh /tmp/root.x86_64/
110
111/tmp/root.x86_64/bin/arch-chroot /tmp/root.x86_64/ /arch_chroot_script.sh
112
113mount "\$DEVICE"
114
115cp /tmp/arch_install_script.sh "\$MOUNTPOINT/root/"
248bd83e 116cp /tmp/puppet_variables.json "\$MOUNTPOINT/root/"
ec1096d8
IB
117
118/tmp/root.x86_64/bin/arch-chroot "\$MOUNTPOINT" /root/arch_install_script.sh
119EOF
120
121
122cat > $ARCH_CHROOT_SCRIPT <<EOF
123#!/bin/bash
124
125pacman-key --init
126pacman-key --populate archlinux
127
128UUID=\$(cat /device_uuid)
129PART="/dev/disk/by-uuid/\$UUID"
130DEVICE=\$(realpath "\$PART")
131
132# mkfs.ext4 -F -U "\$UUID" "\$DEVICE"
133mount "\$DEVICE" /mnt
134
135##### FIXME: mkfs.ext4 would be better ####
136for i in /mnt/*; do
137 if [ "\$i" = "/mnt/boot" ]; then
138 # keep /boot/grub
139 rm -f \$i/*
140 else
141 rm -rf \$i
142 fi
143done
144##### /FIXME ####
145
146pacstrap /mnt base git puppet
147
148echo "\$PART / auto defaults 0 1" > /mnt/etc/fstab
149
150umount /mnt
151EOF
152
153cat > $ARCH_INSTALL_SCRIPT <<EOF
154CODE_PATH="/etc/puppetlabs/code"
155rm -rf \$CODE_PATH
248bd83e 156git clone -b $git_branch --recursive https://git.immae.eu/perso/Immae/Projets/Puppet.git \$CODE_PATH
ec1096d8
IB
157puppet apply --test \$CODE_PATH/manifests/site.pp
158# The password seed requires puppet to be run twice
159puppet apply --test \$CODE_PATH/manifests/site.pp
160EOF
161
162chmod a+x $ARCH_HOST_SCRIPT $ARCH_CHROOT_SCRIPT $ARCH_INSTALL_SCRIPT
163
164expect -f - <<EOF
165set timeout -1
248bd83e 166spawn scp -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o CheckHostIP=no $ARCH_PUPPET_INITIAL_CONFIGURATION $ARCH_HOST_SCRIPT $ARCH_CHROOT_SCRIPT $ARCH_INSTALL_SCRIPT $host_user@$vps_name:/tmp
ec1096d8
IB
167expect "assword:"
168send "$password\n"
169expect eof
248bd83e 170spawn ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o CheckHostIP=no $host_user@$vps_name /tmp/arch_host_script.sh
ec1096d8
IB
171expect "assword:"
172send "$password\r"
173expect eof
174EOF
175
503e4cf5
IB
176### Role specific stage
177read -p "Press key when LDAP is configured" i
178
179cat > $ARCH_PUPPET_CONFIGURATION_SCRIPT <<EOF
180CODE_PATH="/etc/puppetlabs/code"
181puppet apply --test \$CODE_PATH/manifests/site.pp
182EOF
183
184cat > $ARCH_HOST_PUPPET_CONFIGURATION_SCRIPT <<EOF
185DEVICE_STR=\$(cat /proc/mounts | grep "/dev/sd.. /mnt/")
186DEVICE=\$(echo "\$DEVICE_STR" | cut -d' ' -f1)
187MOUNTPOINT=\$(echo "\$DEVICE_STR" | cut -d' ' -f2)
188
189cp /tmp/arch_puppet_configuration_script.sh "\$MOUNTPOINT/root/"
190
191/tmp/root.x86_64/bin/arch-chroot "\$MOUNTPOINT" /root/arch_puppet_configuration_script.sh
192EOF
193
194chmod a+x $ARCH_PUPPET_CONFIGURATION_SCRIPT $ARCH_HOST_PUPPET_CONFIGURATION_SCRIPT
195
196expect -f - <<EOF
197set timeout -1
248bd83e 198spawn scp -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o CheckHostIP=no $ARCH_PUPPET_CONFIGURATION_SCRIPT $ARCH_HOST_PUPPET_CONFIGURATION_SCRIPT $host_user@$vps_name:/tmp
503e4cf5
IB
199expect "assword:"
200send "$password\n"
201expect eof
248bd83e 202spawn ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o CheckHostIP=no $host_user@$vps_name /tmp/arch_host_puppet_configuration_script.sh
503e4cf5
IB
203expect "assword:"
204send "$password\r"
205expect eof
206EOF
207
208### Installation finished
248bd83e 209if [ -z "$no_reboot" -a -z "$no_reboot_end" ]; then
ec1096d8
IB
210 echo "Rebooting"
211 python $PYTHON_DIRECTORY/reboot_vps_server.py --local "$vps_name"
212fi