uncloud-init/ucloud-init.start

74 lines
1.9 KiB
Text
Raw Normal View History

2019-08-23 11:01:23 +00:00
#!/bin/sh
# Functions
2019-08-23 11:01:23 +00:00
get_distro() {
OS=$(cat /etc/*release | grep ID | head -1 | cut -c 4-)
echo $OS
}
# Main Code Starts here
# Some common path variable declaration
ssh_authorized_keys_path='/root/.ssh/authorized_keys'
ssh_config_path='/etc/ssh/ssh_config'
sshd_config_path='/etc/ssh/sshd_config'
2019-08-23 12:54:17 +00:00
# Show output of this script
if [[ ! -e /etc/conf.d/local ]] && ! grep -q "rc_verbose=yes" /etc/conf.d/local; then
echo "rc_verbose=yes" >> /etc/conf.d/local
fi
# Check if rdnssd is installed, if not put ungleich DNS
# into /etc/resolv.conf and install rdnssd for the next time
2019-08-23 11:01:23 +00:00
if ! $(which rdnssd); then
echo "nameserver 2a0a:e5c0::3" >> /etc/resolv.conf
echo "nameserver 2a0a:e5c0::4" >> /etc/resolv.conf
apk add ndisc6
fi
# Start rdnssd to get DNS
2019-08-23 11:01:23 +00:00
rdnssd -u root -r /etc/resolv.conf
2019-08-23 11:01:23 +00:00
# Initial Package Intallation
if [[ $(get_distro) = "alpine" ]]; then
2019-08-23 11:01:23 +00:00
apk update
apk add openssh-server sfdisk util-linux jq
2019-08-23 11:01:23 +00:00
touch $ssh_authorized_keys_path
if ! grep -q "PasswordAuthentication no" $ssh_config_path; then
echo "PasswordAuthentication no" >> $ssh_config_path
fi
2019-08-23 12:54:17 +00:00
if ! grep -q "PermitRootLogin prohibit-password" $sshd_config_path; then
echo "PermitRootLogin prohibit-password" >> $sshd_config_path
2019-08-23 11:01:23 +00:00
fi
service sshd restart
else
echo "Unsupported OS"
2019-08-23 12:54:17 +00:00
exit 1
2019-08-23 11:01:23 +00:00
fi
2019-08-23 12:54:17 +00:00
# TODO: Try to replace the growpart to parted
2019-08-23 11:01:23 +00:00
wget https://git.launchpad.net/ubuntu/+source/cloud-utils/plain/bin/growpart
if [ -e growpart ]; then
sh ./growpart /dev/vda3; rm growpart
fi
2019-08-23 12:54:17 +00:00
2019-08-23 11:01:23 +00:00
# TODO: Make sure to replace the following address with http://metadata
# whenever we got http://metadata resolving to url work successfully.
metadata=$(curl http://[2a0a:e5c1:144::]:5000)
ssh_key=$(echo $metadata | jq '.["ssh-key"]')
2019-08-23 12:54:17 +00:00
ssh_key=echo $metadata | sed 's/"//g' # Removes quotation marks
# ssh_key="${ssh_key:1:-1}" # Removes quotation marks
2019-08-23 11:01:23 +00:00
if ! grep -q "$ssh_key" $ssh_authorized_keys_path; then
echo $ssh_key >> $ssh_authorized_keys_path
fi