#!/bin/bash # # Init file for Password Download Client # # chkconfig: 345 98 02 # description: Password Download Client # 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. # Modify this line to specify the user (default is root) user=root # Detect main interface name NETINT=$(ip -o -4 route show to default | awk '{print $5}') # Add network provider variables here (default means that interface for network manager is eth0) NETPLAN=/etc/netplan IFUPDOWN=/etc/network/interfaces NETMAN=/etc/sysconfig/network-scripts # Add dhcp variables PASSWORD_SERVER_PORT=8080 password_received=0 error_count=0 file_count=0 # OS is using netplan if [ -d "$NETPLAN" ]; then logger -t "cloud" "Operating System is using netplan" PASSWORD_SERVER_IP=$(netplan ip leases $NETINT | grep SERVER_ADDRESS | awk '{split($0,a,"="); print a[2]}') if [ -n "$PASSWORD_SERVER_IP" ]; then logger -t "cloud" "Found password server IP $PASSWORD_SERVER_IP in netplan config" fi fi # OS is using ifupdown if [ -f "$IFUPDOWN" ]; then logger -t "cloud" "Operating System is using ifupdown" DHCP_FOLDERS="/var/lib/dhclient/* /var/lib/dhcp3/* /var/lib/dhcp/*" for DHCP_FILE in $DHCP_FOLDERS; do if [ -f $DHCP_FILE ]; then file_count=$((file_count+1)) PASSWORD_SERVER_IP=$(grep dhcp-server-identifier $DHCP_FILE | tail -1 | awk '{print $NF}' | tr -d '\;') if [ -n "$PASSWORD_SERVER_IP" ]; then logger -t "cloud" "Found password server IP $PASSWORD_SERVER_IP in $DHCP_FILE" break fi fi done fi # OS is using network interfaces if [ -d "$NETMAN" ]; then logger -t "cloud" "Operating System is using network manager" PASSWORD_SERVER_IP=$(nmcli -f IP4.GATEWAY device show $NETINT | sed 's/ //g' | awk '{split($0,a,":"); print a[2]}') if [ -n "$PASSWORD_SERVER_IP" ]; then logger -t "cloud" "Found password server IP $PASSWORD_SERVER_IP in nmcli output" fi fi #start sequence if [ -z "$PASSWORD_SERVER_IP" ] ; then logger -t "cloud" "Unable to determine the password server, falling back to data-server" PASSWORD_SERVER_IP=data-server fi logger -t "cloud" "Sending request to password server at $PASSWORD_SERVER_IP" password=$(wget -q -t 3 -T 20 -O - --header "DomU_Request: send_my_password" http://$PASSWORD_SERVER_IP:$PASSWORD_SERVER_PORT) if [ $? -eq 0 ]; then password=$(echo $password | tr -d '\r') logger -t "cloud" "Got response from server at $PASSWORD_SERVER_IP" case $password in "") logger -t "cloud" "Password server at $PASSWORD_SERVER_IP did not have any password for the VM" ;; "bad_request") logger -t "cloud" "VM sent an invalid request to password server at $PASSWORD_SERVER_IP" error_count=$((error_count+1)) ;; "saved_password") logger -t "cloud" "VM has already saved a password from the password server at $PASSWORD_SERVER_IP" ;; *) logger -t "cloud" "VM got a valid password from server at $PASSWORD_SERVER_IP" password_received=1 ;; esac else logger -t "cloud" "Failed to send request to password server at $PASSWORD_SERVER_IP" error_count=$((error_count+1)) fi if [ "$password_received" == "0" ]; then if [ "$error_count" == "$file_count" ]; then logger -t "cloud" "Failed to get password from any server" exit 1 else logger -t "cloud" "Did not need to change password." exit 0 fi fi logger -t "cloud" "Changing password for user $user" echo $user:$password | chpasswd if [ $? -gt 0 ]; then usermod -p `mkpasswd -m SHA-512 $password` $user if [ $? -gt 0 ]; then logger -t "cloud" "Failed to change password for user $user" exit 1 else logger -t "cloud" "Successfully changed password for user $user" fi fi logger -t "cloud" "Sending acknowledgment to password server at $PASSWORD_SERVER_IP" wget -q -t 3 -T 20 -O - --header "DomU_Request: saved_password" $PASSWORD_SERVER_IP:$PASSWORD_SERVER_PORT exit 0