summaryrefslogtreecommitdiff
path: root/scripts/install/install-get-partition
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2009-12-03 16:13:02 -0800
committerStephen Hemminger <stephen.hemminger@vyatta.com>2009-12-03 16:13:02 -0800
commit1e64d65f2aa75817294fe76937f0170bf8d4f81a (patch)
treeb234afa0e67474e18c234d47c909a67e8aa636b8 /scripts/install/install-get-partition
parent1a16bbc6fbe43233b43b0c82092d248880448b17 (diff)
downloadvyatta-cfg-quagga-1e64d65f2aa75817294fe76937f0170bf8d4f81a.tar.gz
vyatta-cfg-quagga-1e64d65f2aa75817294fe76937f0170bf8d4f81a.zip
Preserve ssh host keys in install-image
Similar to previous change to install-system
Diffstat (limited to 'scripts/install/install-get-partition')
-rwxr-xr-xscripts/install/install-get-partition126
1 files changed, 78 insertions, 48 deletions
diff --git a/scripts/install/install-get-partition b/scripts/install/install-get-partition
index d79200e9..5ab44a86 100755
--- a/scripts/install/install-get-partition
+++ b/scripts/install/install-get-partition
@@ -402,44 +402,62 @@ rename_old_config() {
## check_config_partition
# look to see if this partition contains a config file
# and back it up
-check_config_partition() {
- lpart=$1
+save_old_config() {
# Cleanup from possible partial last run
rm -fr /mnt/config
- # Look to see if this is a config partition
- mkdir -p /mnt/tmp
- output=$(mount /dev/$lpart /mnt/tmp 2>&1)
- if [ $? != 0 ]; then
- lecho "Cannot mount /dev/$lpart"."\nmount /dev/$ldrive$part /mnt/tmp\nExiting..."
- lecho "$output"
- else
- # Look to see if there is a config partition there
- if [ -f /mnt/tmp/opt/vyatta/etc/config/.vyatta_config ] \
- || [ -f /mnt/tmp/.vyatta_config ]; then
- response=''
- while [ -z "$response" ]; do
+ # Look to see if there is a config partition there
+ response=''
+ while [ -z "$response" ]; do
echo "/dev/$lpart has an old configuration directory!"
echo -ne "Would you like me to save the data on it\nbefore I delete it? (Yes/No) [Yes]: "
response=$(get_response "Yes" "Yes No Y N")
- if [ "$response" == "yes" ] || [ "$response" == "y" ]; then
- mkdir -p /mnt/config
- if [ -d /mnt/tmp/opt/vyatta/etc/config ]; then
- output=$(cp -pR /mnt/tmp/opt/vyatta/etc/config/* /mnt/config)
- else
- output=$(cp -pR /mnt/tmp/* /mnt/config)
- fi
- if [ -n "$output" ]; then
- echo -e "Warning: error in copying the old config partition.\nSee $INSTALL_LOG for more details."
+ done
+
+ if [ "$response" == "yes" ] || [ "$response" == "y" ]; then
+ mkdir -p /mnt/config
+ if [ -d /mnt/tmp/opt/vyatta/etc/config ]; then
+ output=$(cp -pR /mnt/tmp/opt/vyatta/etc/config/* /mnt/config)
+ else
+ output=$(cp -pR /mnt/tmp/* /mnt/config)
+ fi
+ if [ -n "$output" ]; then
+ echo -e "Warning: error in copying the old config partition.\nSee $INSTALL_LOG for more details."
lecho "Warning: error in copying the old config partition.\ncp -pR /mnt/tmp/* /mnt/config\n$output\n"
fi
- rename_old_config
+ rename_old_config
+ fi
+}
+
+save_old_keys() {
+ local response=''
+
+ while [ -z "$response" ]
+ do
+ echo "/dev/$lpart has SSH host keys"
+ echo -ne "Would you like me to keep SSH keys on new install? (Yes/No) [Yes]: "
+ response=$(get_response "Yes" "Yes No Y N")
+ done
+
+ if [ "$response" == "yes" ] || [ "$response" == "y" ]; then
+ mkdir -p /mnt/ssh
+ output=$(cp -p /mnt/tmp/etc/ssh/ssh_host_* /mnt/ssh)
+
+ if [ -n "$output" ]; then
+ echo -e "Warning: error in copying the old ssh keys."
+ echo -e "See $INSTALL_LOG for more details."
+ echo "Warning: error in copying the old ssh keys." >> $INSTALL_LOG
+ echo "cp -pR /mnt/tmp/etc/ssh/ssh_host_* /mnt/ssh" >> $INSTALL_LOG
+ echo "$output\n">> $INSTALL_LOG
+ return
fi
- done
+
+ # reset modes on keys (should already be set)
+ chmod 600 /mnt/ssh/*_key
+ chmod 644 /mnt/ssh/*.pub
+ chown root /mnt/ssh/*
fi
- umount /mnt/tmp
- fi
}
# Delete all existing partitions for an automated install
@@ -453,22 +471,40 @@ delete_partitions () {
partitions=$(cat /proc/partitions | grep $ldrive[p]*[0-9] \
| awk '{ print $4 }' | sed 's/\(.*\)\([0-9]$\)/\2/g' \
| grep -v "^$")
+ mkdir -p /mnt/tmp
# now for each part, blow it away
for part in $partitions; do
- # Look to see if this is a config partition
- check_config_partition "$ldrive$part"
-
- lecho "Removing partition $part on /dev/$ldrive"
- output=$(parted /dev/$ldrive rm $part)
- status=$?
- if [ "$status" != 0 ]; then
- echo -e "Warning: cannot delete partition $part on $ldrive.\nPlease see $INSTALL_LOG for more details."
- lecho "Warning: cannot delete partition $part on $ldrive.\nparted /dev/$ldrive rm $part\n$output"
- fi
-
- # We add a bogus sleep here because the loop needs to wait for udev
- sleep 5
+ output=$(mount /dev/$lpart /mnt/tmp 2>&1)
+ if [ $? != 0 ]; then
+ lecho "Cannot mount /dev/$lpart"."\n"
+ lecho "mount /dev/$ldrive$part /mnt/tmp\nExiting..."
+ lecho "$output"
+ else
+ # Look to see if this is a config partition
+ if [ -f /mnt/tmp/opt/vyatta/etc/config/.vyatta_config ] \
+ || [ -f /mnt/tmp/.vyatta_config ]; then
+ save_old_config
+ fi
+ if [ -d /mnt/tmp/etc/ssh ]; then
+ save_old_keys
+ fi
+
+ umount /mnt/tmp
+ fi
+
+ lecho "Removing partition $part on /dev/$ldrive"
+ output=$(parted /dev/$ldrive rm $part)
+ status=$?
+ if [ "$status" != 0 ]; then
+ echo -e "Warning: cannot delete partition $part on $ldrive.\n"
+ echo -e "Please see $INSTALL_LOG for more details."
+ lecho "Warning: cannot delete partition $part on $ldrive.\n"
+ lecho "parted /dev/$ldrive rm $part\n$output"
+ fi
+
+ # We add a bogus sleep here because the loop needs to wait for udev
+ sleep 5
done
}
@@ -542,14 +578,8 @@ create_partitions() {
# sets ROOT_FSTYPE based on disk size
set_root_fstype () {
local drv=$1
- local sz=$(get_drive_size "$drv")
- # If disk is small, it is probably a CF device or virtual environment
- # so avoid the overhead of a journal
- if (( $sz < 11000 )); then
- ROOT_FSTYPE=ext2
- else
- ROOT_FSTYPE=ext3
- fi
+ # always use ext3 for stability
+ ROOT_FSTYPE=ext3
}
# ask for user input on the parted and skip setup methods