Bryan Kearney
2008-Nov-10  19:22 UTC
[Ovirt-devel] [PATCH node] Password configuration script for the root password and sasl users
---
 scripts/ovirt-config-password |   92 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 92 insertions(+), 0 deletions(-)
diff --git a/scripts/ovirt-config-password b/scripts/ovirt-config-password
index 8b13789..af99915 100755
--- a/scripts/ovirt-config-password
+++ b/scripts/ovirt-config-password
@@ -1 +1,93 @@
+#!/bin/bash
+#
+# Set the root password and others
+
+ROOT_PASSWORD=""
+
+function sasl_password {
+	printf "adding user $1 to the sasl list for libvirt\n"
+	echo $2 | saslpasswd2 -a libvirt -p $1
+}
+
+function set_root_password {
+	while true; do
+		printf "\nPlease enter the new root password (hit return to skip) "
+		read -s	
+		if [[ $REPLY == "" ]]; then
+			return 1
+		fi
+		ROOT_PASSWORD=$REPLY
+		printf "\nPlease enter again to confirm "				
+		read -s 
+		ROOT_PASSWORD_CONFIRM=$REPLY
+		if [[ $ROOT_PASSWORD == $ROOT_PASSWORD_CONFIRM ]]; then
+			echo $ROOT_PASSWORD | passwd --stdin root
+			sasl_password root $ROOT_PASSWORD
+			break 
+		else
+			printf "\nPaswords did not match. Please try again"
+		fi
+	done
+	return 0
+}
+
+# Prompts the user for a single username, password combo
+function prompt_sasl_user {
+	while true; do	
+		printf "\nPlease enter a new user (hit return to skip) "
+		read
+		if [[ $REPLY == "" ]]; then
+			break
+		fi	
+		SASL_USER=$REPLY	
+		printf "\nPlease enter the password for $SASL_USER (hit return to skip)
"
+		read -s	
+		if [[ $REPLY == "" ]]; then
+			return 1
+		fi
+		SASL_PASSWORD=$REPLY
+		printf "\nPlease enter again to confirm "				
+		read -s 
+		SASL_PASSWORD_CONFIRM=$REPLY
+		if [[ $SASL_PASSWORD == $SASL_PASSWORD_CONFIRM ]]; then
+			sasl_password $SASL_USER $SASL_PASSWORD
+			break 
+		else
+			printf "\nPaswords did not match. Please try again"
+		fi	
+	done
+	
+}
+
+#Check for the root user first
+while true ; do 
+	printf "\nWould you like to set the root password (Y|N) "
+	read
+	case $REPLY in
+	Y|y) 
+		set_root_password
+		if [[ $? == 0 ]] ; then
+			break ;
+		fi
+		;;
+	N|n)
+		break ;
+		;;
+	esac
+done
+
+#Check for any sasl users
+while true ; do 
+	printf "\nWould you like to add a new sasl user for libvirt (Y|N) "
+	read
+	case $REPLY in
+	Y|y) 
+		prompt_sasl_user
+		;;
+	N|n)
+		break ;
+		;;
+	esac
+done
+
 
-- 
1.5.6.5
Alan Pevec
2008-Nov-11  22:15 UTC
[Ovirt-devel] [PATCH node] Password configuration script for the root password and sasl users
From: Bryan Kearney <bkearney at redhat.com>
REPOST - removed whitespaces and rebased to apply after mcpierce's script
stubs
from [PATCH node] Added a script that runs during first boot for the node.
---
 scripts/ovirt-config-password |   90 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 90 insertions(+), 0 deletions(-)
diff --git a/scripts/ovirt-config-password b/scripts/ovirt-config-password
index c856ef1..1dcc336 100755
--- a/scripts/ovirt-config-password
+++ b/scripts/ovirt-config-password
@@ -1,2 +1,92 @@
 #!/bin/bash
 #
+# Set the root password and others
+
+ROOT_PASSWORD=""
+
+function sasl_password {
+	printf "adding user $1 to the sasl list for libvirt\n"
+	echo $2 | saslpasswd2 -a libvirt -p $1
+}
+
+function set_root_password {
+	while true; do
+		printf "\nPlease enter the new root password (hit return to skip) "
+		read -s
+		if [[ $REPLY == "" ]]; then
+			return 1
+		fi
+		ROOT_PASSWORD=$REPLY
+		printf "\nPlease enter again to confirm "
+		read -s
+		ROOT_PASSWORD_CONFIRM=$REPLY
+		if [[ $ROOT_PASSWORD == $ROOT_PASSWORD_CONFIRM ]]; then
+			echo $ROOT_PASSWORD | passwd --stdin root
+			sasl_password root $ROOT_PASSWORD
+			break
+		else
+			printf "\nPaswords did not match. Please try again"
+		fi
+	done
+	return 0
+}
+
+# Prompts the user for a single username, password combo
+function prompt_sasl_user {
+	while true; do
+		printf "\nPlease enter a new user (hit return to skip) "
+		read
+		if [[ $REPLY == "" ]]; then
+			break
+		fi
+		SASL_USER=$REPLY
+		printf "\nPlease enter the password for $SASL_USER (hit return to skip)
"
+		read -s
+		if [[ $REPLY == "" ]]; then
+			return 1
+		fi
+		SASL_PASSWORD=$REPLY
+		printf "\nPlease enter again to confirm "
+		read -s
+		SASL_PASSWORD_CONFIRM=$REPLY
+		if [[ $SASL_PASSWORD == $SASL_PASSWORD_CONFIRM ]]; then
+			sasl_password $SASL_USER $SASL_PASSWORD
+			break
+		else
+			printf "\nPaswords did not match. Please try again"
+		fi
+	done
+
+}
+
+#Check for the root user first
+while true ; do
+	printf "\nWould you like to set the root password (Y|N) "
+	read
+	case $REPLY in
+	Y|y)
+		set_root_password
+		if [[ $? == 0 ]] ; then
+			break ;
+		fi
+		;;
+	N|n)
+		break ;
+		;;
+	esac
+done
+
+#Check for any sasl users
+while true ; do
+	printf "\nWould you like to add a new sasl user for libvirt (Y|N) "
+	read
+	case $REPLY in
+	Y|y)
+		prompt_sasl_user
+		;;
+	N|n)
+		break ;
+		;;
+	esac
+done
+
-- 
1.5.6.5
Jim Meyering
2008-Nov-13  15:17 UTC
[Ovirt-devel] [PATCH node] Password configuration script for the root password and sasl users
Bryan Kearney <bkearney at redhat.com> wrote:> diff --git a/scripts/ovirt-config-password b/scripts/ovirt-config-password > index 8b13789..af99915 100755 > --- a/scripts/ovirt-config-password > +++ b/scripts/ovirt-config-password > @@ -1 +1,93 @@ > +#!/bin/bash > +# > +# Set the root password and others > + > +ROOT_PASSWORD="" > + > +function sasl_password { > + printf "adding user $1 to the sasl list for libvirt\n" > + echo $2 | saslpasswd2 -a libvirt -p $1You need quotes here. Otherwise, a password with e.g., "foo bar" would be shortened (tokenized) to "foo bar". Also, you can't use echo, because that would honor (i.e., ignore) a leading -n, -e, or -E option in the password string. printf '%s\n' "$2" | saslpasswd2 -a libvirt -p "$1" Even with a tiny function like this, it's more readable and slightly more maintainable (less risk of confusing $1 and $2) to give names to the parameters, e.g., function sasl_password { user=$1 passwd=$2 printf "adding user $user to the sasl list for libvirt\n" printf '%s\n' "$passwd" | saslpasswd2 -a libvirt -p "$user" }> +} > + > +function set_root_password { > + while true; do > + printf "\nPlease enter the new root password (hit return to skip) " > + read -s > + if [[ $REPLY == "" ]]; then > + return 1 > + fi > + ROOT_PASSWORD=$REPLY > + printf "\nPlease enter again to confirm " > + read -s > + ROOT_PASSWORD_CONFIRM=$REPLY > + if [[ $ROOT_PASSWORD == $ROOT_PASSWORD_CONFIRM ]]; then > + echo $ROOT_PASSWORD | passwd --stdin root > + sasl_password root $ROOT_PASSWORDBoth of the above require quotes, too: printf '%s\n' "$ROOT_PASSWORD" | passwd --stdin root sasl_password root "$ROOT_PASSWORD"> + break > + else > + printf "\nPaswords did not match. Please try again"Don't you want a "\n" at the end, here? Probably instead of the one at the beginning.> + fi > + done > + return 0 > +}These two functions are similar enough that they should use the same code.> +# Prompts the user for a single username, password combo > +function prompt_sasl_user { > + while true; do > + printf "\nPlease enter a new user (hit return to skip) " > + read > + if [[ $REPLY == "" ]]; then > + break > + fi > + SASL_USER=$REPLY > + printf "\nPlease enter the password for $SASL_USER (hit return to skip) " > + read -s > + if [[ $REPLY == "" ]]; then > + return 1 > + fi > + SASL_PASSWORD=$REPLY > + printf "\nPlease enter again to confirm " > + read -s > + SASL_PASSWORD_CONFIRM=$REPLY > + if [[ $SASL_PASSWORD == $SASL_PASSWORD_CONFIRM ]]; then > + sasl_password $SASL_USER $SASL_PASSWORD > + break > + else > + printf "\nPaswords did not match. Please try again" > + fi > + done > + > +}How about this (untested): # Usage: set_SASL_password USER # Prompt(twice) for a password for the specified USER. # If they match, set that user's system password, # and add USER to the SASL list for libvirt. set_SASL_password() { user=$1 while : ; do printf "\nPlease enter the new $user password (hit return to skip) " read -s test -z "$REPLY" && return 1 local passwd=$REPLY printf "\nPlease enter again to confirm " read -s local confirm=$REPLY if test "$passwd" = "$confirm"; then printf '%s\n' "$passwd" | passwd --stdin "$user" sasl_password "$user" "$passwd" return 0 fi printf "Paswords did not match. Please try again\n" done } Then you'd use set_SASL_passwd root Prompt for SASL_USER separately, then set_SASL_passwd $SASL_USER> +#Check for the root user first > +while true ; do > + printf "\nWould you like to set the root password (Y|N) " > + read > + case $REPLY in > + Y|y) > + set_root_password > + if [[ $? == 0 ]] ; then > + break ; > + fiThe more maintainable/readable idiom for the above 4 lines is like this: set_root_password && break> + ;; > + N|n) > + break ; > + ;;This makes the code treat any non-Y/y response like "N". If you want to treat a response like "yes" differently, you can add a catch-all case: *) printf "invalid response: %s\n" "$REPLY" ;;> + esac > +done > + > +#Check for any sasl users > +while true ; do > + printf "\nWould you like to add a new sasl user for libvirt (Y|N) " > + read > + case $REPLY in > + Y|y) > + prompt_sasl_user > + ;; > + N|n) > + break ; > + ;; > + esac > +done > +