parseconfig.sh revision 211485
1#!/bin/sh 2#- 3# Copyright (c) 2010 iXsystems, Inc. All rights reserved. 4# 5# Redistribution and use in source and binary forms, with or without 6# modification, are permitted provided that the following conditions 7# are met: 8# 1. Redistributions of source code must retain the above copyright 9# notice, this list of conditions and the following disclaimer. 10# 2. Redistributions in binary form must reproduce the above copyright 11# notice, this list of conditions and the following disclaimer in the 12# documentation and/or other materials provided with the distribution. 13# 14# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24# SUCH DAMAGE. 25# 26# $FreeBSD: head/usr.sbin/pc-sysinstall/backend/parseconfig.sh 211485 2010-08-19 05:59:27Z imp $ 27 28# Main install configuration parsing script 29# 30 31# Source our functions scripts 32. ${BACKEND}/functions.sh 33. ${BACKEND}/functions-bsdlabel.sh 34. ${BACKEND}/functions-cleanup.sh 35. ${BACKEND}/functions-disk.sh 36. ${BACKEND}/functions-extractimage.sh 37. ${BACKEND}/functions-installcomponents.sh 38. ${BACKEND}/functions-installpackages.sh 39. ${BACKEND}/functions-localize.sh 40. ${BACKEND}/functions-mountdisk.sh 41. ${BACKEND}/functions-networking.sh 42. ${BACKEND}/functions-newfs.sh 43. ${BACKEND}/functions-packages.sh 44. ${BACKEND}/functions-parse.sh 45. ${BACKEND}/functions-runcommands.sh 46. ${BACKEND}/functions-ftp.sh 47. ${BACKEND}/functions-unmount.sh 48. ${BACKEND}/functions-upgrade.sh 49. ${BACKEND}/functions-users.sh 50 51# Check that the config file exists 52if [ ! -e "${1}" ] 53then 54 echo "ERROR: Install configuration $1 does not exist!" 55 exit 1 56fi 57 58# Set our config file variable 59CFGF="$1" 60 61# Check the dirname of the provided CFGF and make sure its a full path 62DIR="`dirname ${CFGF}`" 63if [ "${DIR}" = "." ] 64then 65 CFGF="`pwd`/${CFGF}" 66fi 67export CFGF 68 69# Start by doing a sanity check, which will catch any obvious mistakes in the config 70file_sanity_check "installMode disk0 installType installMedium packageType" 71 72# We passed the Sanity check, lets grab some of the universal config settings and store them 73check_value installMode "fresh upgrade" 74check_value bootManager "bsd none" 75check_value installType "PCBSD FreeBSD" 76check_value installMedium "dvd usb ftp rsync" 77check_value packageType "uzip tar rsync split" 78if_check_value_exists partition "all ALL s1 s2 s3 s4 free FREE" 79if_check_value_exists mirrorbal "load prefer round-robin split" 80 81# We passed all sanity checks! Yay, lets start the install 82echo "File Sanity Check -> OK" 83 84# Lets load the various universal settings now 85get_value_from_cfg installMode 86INSTALLMODE="${VAL}" ; export INSTALLMODE 87 88get_value_from_cfg installType 89INSTALLTYPE="${VAL}" ; export INSTALLTYPE 90 91get_value_from_cfg installMedium 92INSTALLMEDIUM="${VAL}" ; export INSTALLMEDIUM 93 94get_value_from_cfg packageType 95PACKAGETYPE="${VAL}" ; export PACKAGETYPE 96 97# Check if we are doing any networking setup 98start_networking 99 100# If we are not doing an upgrade, lets go ahead and setup the disk 101if [ "${INSTALLMODE}" = "fresh" ] 102then 103 104 # Lets start setting up the disk slices now 105 setup_disk_slice 106 107 # Disk setup complete, now lets parse WORKINGSLICES and setup the bsdlabels 108 setup_disk_label 109 110 # Now we've setup the bsdlabels, lets go ahead and run newfs / zfs 111 # to setup the filesystems 112 setup_filesystems 113 114 # Lets mount the partitions now 115 mount_all_filesystems 116 117 # We are ready to begin extraction, lets start now 118 init_extraction 119 120 # Check if we have any optional modules to load 121 install_components 122 123 # Check if we have any packages to install 124 install_packages 125 126 # Do any localization in configuration 127 run_localize 128 129 # Save any networking config on the installed system 130 save_networking_install 131 132 # Now add any users 133 setup_users 134 135 # Now run any commands specified 136 run_commands 137 138 # Do any last cleanup / setup before unmounting 139 run_final_cleanup 140 141 # Unmount and finish up 142 unmount_all_filesystems 143 144 echo_log "Installation finished!" 145 exit 0 146 147else 148 # We're going to do an upgrade, skip all the disk setup 149 # and start by mounting the target drive/slices 150 mount_upgrade 151 152 # Start the extraction process 153 init_extraction 154 155 # Do any localization in configuration 156 run_localize 157 158 # Now run any commands specified 159 run_commands 160 161 # Merge any old configuration files 162 merge_old_configs 163 164 # Check if we have any optional modules to load 165 install_components 166 167 # Check if we have any packages to install 168 install_packages 169 170 # All finished, unmount the file-systems 171 unmount_upgrade 172 173 echo_log "Upgrade finished!" 174 exit 0 175fi 176 177