mirror of
https://gitlab.alpinelinux.org/alpine/cloud/tiny-cloud.git
synced 2025-12-16 03:42:44 +03:00
Change whitespace from spaces to tabs
This commit is contained in:
parent
834cac92da
commit
1f4f4fccb8
@ -1,5 +1,5 @@
|
|||||||
#!/sbin/openrc-run
|
#!/sbin/openrc-run
|
||||||
# vim:set ft=sh et ts=4 sts=4 sw=4:
|
# vim:set ft=sh noet ts=4:
|
||||||
|
|
||||||
description="Provides EC2 cloud bootstrap"
|
description="Provides EC2 cloud bootstrap"
|
||||||
|
|
||||||
@ -8,81 +8,81 @@ EC2_USER=${EC2_USER:-alpine}
|
|||||||
IMDS2_TOKEN_TTL=${IMDS2_TOKEN_TTL:-5}
|
IMDS2_TOKEN_TTL=${IMDS2_TOKEN_TTL:-5}
|
||||||
|
|
||||||
depend() {
|
depend() {
|
||||||
need net
|
need net
|
||||||
provide cloud-final
|
provide cloud-final
|
||||||
}
|
}
|
||||||
|
|
||||||
_get_metadata_token() {
|
_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" |
|
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
|
nc 169.254.169.254 80 | tail -n 1
|
||||||
}
|
}
|
||||||
|
|
||||||
_get_metadata() {
|
_get_metadata() {
|
||||||
local uri="$1"
|
local uri="$1"
|
||||||
wget -qO - --header "X-aws-ec2-metadata-token: $(_get_metadata_token)" \
|
wget -qO - --header "X-aws-ec2-metadata-token: $(_get_metadata_token)" \
|
||||||
"http://169.254.169.254/latest/$uri" 2>/dev/null
|
"http://169.254.169.254/latest/$uri" 2>/dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
_update_hostname() {
|
_update_hostname() {
|
||||||
local ec2_fqdn="$(_get_metadata meta-data/hostname)"
|
local ec2_fqdn="$(_get_metadata meta-data/hostname)"
|
||||||
local short_hostname="${ec2_fqdn%%\.*}"
|
local short_hostname="${ec2_fqdn%%\.*}"
|
||||||
echo "$short_hostname" > /etc/hostname
|
echo "$short_hostname" > /etc/hostname
|
||||||
hostname -F /etc/hostname
|
hostname -F /etc/hostname
|
||||||
echo -e "127.0.1.1\t$ec2_fqdn $short_hostname" >> /etc/hosts
|
echo -e "127.0.1.1\t$ec2_fqdn $short_hostname" >> /etc/hosts
|
||||||
}
|
}
|
||||||
|
|
||||||
_set_ssh_keys() {
|
_set_ssh_keys() {
|
||||||
local user="$1"
|
local user="$1"
|
||||||
local group="$(getent passwd "$user" | cut -d: -f4)"
|
local group="$(getent passwd "$user" | cut -d: -f4)"
|
||||||
local ssh_dir="$(getent passwd "$user" | cut -d: -f6)/.ssh"
|
local ssh_dir="$(getent passwd "$user" | cut -d: -f6)/.ssh"
|
||||||
local keys_file="$ssh_dir/authorized_keys"
|
local keys_file="$ssh_dir/authorized_keys"
|
||||||
|
|
||||||
if [ ! -d "$ssh_dir" ]; then
|
if [ ! -d "$ssh_dir" ]; then
|
||||||
mkdir -p "$ssh_dir"
|
mkdir -p "$ssh_dir"
|
||||||
chmod 755 "$ssh_dir"
|
chmod 755 "$ssh_dir"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[ -f "$keys_file" ] && rm "$keys_file"
|
[ -f "$keys_file" ] && rm "$keys_file"
|
||||||
|
|
||||||
touch "$keys_file"
|
touch "$keys_file"
|
||||||
chmod 600 "$keys_file"
|
chmod 600 "$keys_file"
|
||||||
chown -R "$user:$group" "$ssh_dir"
|
chown -R "$user:$group" "$ssh_dir"
|
||||||
|
|
||||||
for key in $(_get_metadata meta-data/public-keys/); do
|
for key in $(_get_metadata meta-data/public-keys/); do
|
||||||
_get_metadata "meta-data/public-keys/${key%=*}/openssh-key/" >> "$keys_file"
|
_get_metadata "meta-data/public-keys/${key%=*}/openssh-key/" >> "$keys_file"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
_run_userdata() {
|
_run_userdata() {
|
||||||
user_data=$(_get_metadata user-data)
|
user_data=$(_get_metadata user-data)
|
||||||
if echo "$user_data" | grep -q '^#!/'; then
|
if echo "$user_data" | grep -q '^#!/'; then
|
||||||
echo "$user_data" > /var/lib/cloud/user-data.sh
|
echo "$user_data" > /var/lib/cloud/user-data.sh
|
||||||
chmod +x /var/lib/cloud/user-data.sh
|
chmod +x /var/lib/cloud/user-data.sh
|
||||||
/var/lib/cloud/user-data.sh 2>&1 | tee /var/log/cloud-bootstrap.log
|
/var/lib/cloud/user-data.sh 2>&1 | tee /var/log/cloud-bootstrap.log
|
||||||
echo "User Data Script Exit Status: $?"
|
echo "User Data Script Exit Status: $?"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
_resize_root_partition() {
|
_resize_root_partition() {
|
||||||
resize2fs "$(mountpoint -n / | cut -d' ' -f1)"
|
resize2fs "$(mountpoint -n / | cut -d' ' -f1)"
|
||||||
}
|
}
|
||||||
|
|
||||||
_disable_password() {
|
_disable_password() {
|
||||||
echo "$1:*" | chpasswd -e
|
echo "$1:*" | chpasswd -e
|
||||||
}
|
}
|
||||||
|
|
||||||
start() {
|
start() {
|
||||||
# Don't bootstrap if the host has already been bootstrapped
|
# Don't bootstrap if the host has already been bootstrapped
|
||||||
[ -f "/var/lib/cloud/.bootstrap-complete" ] && return 0
|
[ -f "/var/lib/cloud/.bootstrap-complete" ] && return 0
|
||||||
|
|
||||||
[ -d "/var/lib/cloud" ] || mkdir -p /var/lib/cloud
|
[ -d "/var/lib/cloud" ] || mkdir -p /var/lib/cloud
|
||||||
|
|
||||||
ebegin "Disabling root password"; _disable_password root; eend $?
|
ebegin "Disabling root password"; _disable_password root; eend $?
|
||||||
ebegin "Disabling $EC2_USER password"; _disable_password "$EC2_USER"; eend $?
|
ebegin "Disabling $EC2_USER password"; _disable_password "$EC2_USER"; eend $?
|
||||||
ebegin "Resizing root partition"; _resize_root_partition; eend $?
|
ebegin "Resizing root partition"; _resize_root_partition; eend $?
|
||||||
ebegin "Setting ec2 hostname"; _update_hostname; eend $?
|
ebegin "Setting ec2 hostname"; _update_hostname; eend $?
|
||||||
ebegin "Setting ec2 user ssh keys"; _set_ssh_keys "$EC2_USER"; eend $?
|
ebegin "Setting ec2 user ssh keys"; _set_ssh_keys "$EC2_USER"; eend $?
|
||||||
ebegin "Running ec2 user data script"; _run_userdata; eend $?
|
ebegin "Running ec2 user data script"; _run_userdata; eend $?
|
||||||
|
|
||||||
touch "/var/lib/cloud/.bootstrap-complete"
|
touch "/var/lib/cloud/.bootstrap-complete"
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user