blob: 1ad4de4c1a567ee3d357e7f6685b9dd0f0c1d190 [file] [log] [blame]
#!/bin/bash
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
# This scripts before ssh.service but after cloud-early-config
. /lib/lsb/init-functions
log_it() {
echo "$(date) $@" >> /var/log/cloud.log
log_action_msg "$@"
}
# Restart journald for setting changes to apply
systemctl restart systemd-journald
# Restore the persistent iptables nat, rules and filters for IPv4 and IPv6 if they exist
nftables="/etc/iptables/rules.nftables"
if [ -e $nftables ]
then
nft -f $nftables
fi
ipv4="/etc/iptables/rules.v4"
if [ -e $ipv4 ]
then
iptables-restore < $ipv4
fi
ipv6="/etc/iptables/rules.v6"
if [ -e $ipv6 ]
then
ip6tables-restore < $ipv6
fi
CMDLINE=/var/cache/cloud/cmdline
TYPE=$(grep -Po 'type=\K[a-zA-Z]*' $CMDLINE)
# Execute cloud-init if user data is present
run_cloud_init() {
if [ ! -f "$CMDLINE" ]; then
log_it "No cmdline file found, skipping cloud-init execution"
return 0
fi
local encoded_userdata=$(grep -Po 'userdata=\K[^[:space:]]*' "$CMDLINE" || true)
if [ -z "$encoded_userdata" ]; then
log_it "No user data found in cmdline, skipping cloud-init execution"
return 0
fi
log_it "User data detected, setting up and running cloud-init"
# Update cloud-init config to use NoCloud datasource
cat <<EOF > /etc/cloud/cloud.cfg.d/cloudstack.cfg
#cloud-config
datasource_list: ['NoCloud']
network:
config: disabled
manage_etc_hosts: false
manage_resolv_conf: false
users: []
disable_root: false
ssh_pwauth: false
cloud_init_modules:
- migrator
- seed_random
- bootcmd
- write-files
- growpart
- resizefs
- disk_setup
- mounts
- rsyslog
cloud_config_modules:
- locale
- timezone
- runcmd
cloud_final_modules:
- scripts-per-once
- scripts-per-boot
- scripts-per-instance
- scripts-user
- final-message
- power-state-change
EOF
# Set up user data files (reuse the function from init.sh)
mkdir -p /var/lib/cloud/seed/nocloud
# Decode and decompress user data
local decoded_userdata
decoded_userdata=$(echo "$encoded_userdata" | base64 -d 2>/dev/null | gunzip 2>/dev/null)
if [ $? -ne 0 ] || [ -z "$decoded_userdata" ]; then
log_it "ERROR: Failed to decode or decompress user data"
return 1
fi
# Write user data
echo "$decoded_userdata" > /var/lib/cloud/seed/nocloud/user-data
chmod 600 /var/lib/cloud/seed/nocloud/user-data
# Create meta-data
local instance_name=$(grep -Po 'name=\K[^[:space:]]*' "$CMDLINE" || hostname)
cat > /var/lib/cloud/seed/nocloud/meta-data << EOF
instance-id: $instance_name
local-hostname: $instance_name
EOF
chmod 644 /var/lib/cloud/seed/nocloud/meta-data
log_it "User data files created, executing cloud-init..."
# Run cloud-init stages manually
cloud-init init --local && \
cloud-init init && \
cloud-init modules --mode=config && \
cloud-init modules --mode=final
local cloud_init_result=$?
if [ $cloud_init_result -eq 0 ]; then
log_it "Cloud-init executed successfully"
else
log_it "ERROR: Cloud-init execution failed with exit code: $cloud_init_result"
fi
return $cloud_init_result
}
if [ "$TYPE" == "router" ] || [ "$TYPE" == "vpcrouter" ] || [ "$TYPE" == "dhcpsrvr" ]
then
if [ -x /opt/cloud/bin/update_config.py ]
then
/opt/cloud/bin/update_config.py cmd_line.json || true
fi
fi
if [ "$TYPE" == "cksnode" ] || [ "$TYPE" == "sharedfsvm" ]; then
pkill -9 dhclient
fi
[ ! -f /var/cache/cloud/enabled_svcs ] && touch /var/cache/cloud/enabled_svcs
for svc in $(cat /var/cache/cloud/enabled_svcs)
do
systemctl enable --now --no-block $svc
done
[ ! -f /var/cache/cloud/disabled_svcs ] && touch /var/cache/cloud/disabled_svcs
for svc in $(cat /var/cache/cloud/disabled_svcs)
do
systemctl disable --now --no-block $svc
done
run_cloud_init
date > /var/cache/cloud/boot_up_done