aboutsummaryrefslogtreecommitdiff
path: root/tiny-ec2-bootstrap
blob: 944446d428024a0b00aa3029462aa2f919824ffc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#!/sbin/openrc-run
# vim:set ft=sh noet ts=4:

description="Provides EC2 cloud bootstrap"

# override in /etc/conf.d/tiny-ec2-bootstrap
EC2_USER=${EC2_USER:-alpine}
IMDS2_TOKEN_TTL=${IMDS2_TOKEN_TTL:-5}

depend() {
	need net
	provide cloud-final
}

_get_metadata_token() {
	echo -ne "PUT /latest/api/token HTTP/1.0\r\nX-aws-ec2-metadata-token-ttl-seconds: $IMDS2_TOKEN_TTL\r\n\r\n" |
	nc 169.254.169.254 80 | tail -n 1
}

_get_metadata() {
	local uri="$1"
	wget -qO - --header "X-aws-ec2-metadata-token: $(_get_metadata_token)" \
		"http://169.254.169.254/latest/$uri" 2>/dev/null
}

_update_hostname() {
	local ec2_fqdn="$(_get_metadata meta-data/hostname)"
	local short_hostname="${ec2_fqdn%%\.*}"
	echo "$short_hostname" > /etc/hostname
	hostname -F /etc/hostname
	echo -e "127.0.1.1\t$ec2_fqdn $short_hostname" >> /etc/hosts
}

_set_ssh_keys() {
	local user="$1"
	local group="$(getent passwd "$user" | cut -d: -f4)"
	local ssh_dir="$(getent passwd "$user" | cut -d: -f6)/.ssh"
	local keys_file="$ssh_dir/authorized_keys"

	if [ ! -d "$ssh_dir" ]; then
		mkdir -p "$ssh_dir"
		chmod 755 "$ssh_dir"
	fi

	[ -f "$keys_file" ] && rm "$keys_file"

	touch "$keys_file"
	chmod 600 "$keys_file"
	chown -R "$user:$group" "$ssh_dir"

	for key in $(_get_metadata meta-data/public-keys/); do
		_get_metadata "meta-data/public-keys/${key%=*}/openssh-key/" >> "$keys_file"
	done
}

_run_userdata() {
	local user_data="$(_get_metadata user-data)"
	if printf '%s' "$user_data" | head -n1 | grep -q '^#!/'; then
		printf '%s' "$user_data" >/var/lib/cloud/user-data.sh
		chmod +x /var/lib/cloud/user-data.sh

		local log_file=/var/log/cloud-bootstrap.log
		local ec_file=/var/log/cloud-bootstrap.exit

		{ /var/lib/cloud/user-data.sh 2>&1 ; echo $? >"$ec_file"; } | tee "$log_file"
		ec=$(cat "$ec_file")

		echo "User Data Script Exit Status: $ec"
		return $ec
	fi
}

_resize_root_partition() {
	resize2fs "$(mountpoint -n / | cut -d' ' -f1)"
}

_disable_password() {
	echo "$1:*" | chpasswd -e
}

start() {
	# Don't bootstrap if the host has already been bootstrapped
	[ -f "/var/lib/cloud/.bootstrap-complete" ] && return 0

	[ -d "/var/lib/cloud" ] || mkdir -p /var/lib/cloud

	ebegin "Disabling root password"; _disable_password root; eend $?
	ebegin "Disabling $EC2_USER password"; _disable_password "$EC2_USER"; eend $?
	ebegin "Resizing root partition"; _resize_root_partition; eend $?
	ebegin "Setting ec2 hostname"; _update_hostname; eend $?
	ebegin "Setting ec2 user ssh keys"; _set_ssh_keys "$EC2_USER"; eend $?
	ebegin "Running ec2 user data script"; _run_userdata; eend $?

	touch "/var/lib/cloud/.bootstrap-complete"
}