#!/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 < /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