diff --git a/advanced/Scripts/piholeCheckout.sh b/advanced/Scripts/piholeCheckout.sh index 5125a2b4..977d1552 100644 --- a/advanced/Scripts/piholeCheckout.sh +++ b/advanced/Scripts/piholeCheckout.sh @@ -26,170 +26,170 @@ source "${PI_HOLE_FILES_DIR}/automated install/basic-install.sh" source "${setupVars}" warning1() { - echo " Please note that changing branches severely alters your Pi-hole subsystems" - echo " Features that work on the master branch, may not on a development branch" - echo -e " ${COL_LIGHT_RED}This feature is NOT supported unless a Pi-hole developer explicitly asks!${COL_NC}" - read -r -p " Have you read and understood this? [y/N] " response - case "${response}" in - [yY][eE][sS]|[yY]) - echo "" - return 0 - ;; - *) - echo -e "\\n ${INFO} Branch change has been cancelled" - return 1 - ;; - esac + echo " Please note that changing branches severely alters your Pi-hole subsystems" + echo " Features that work on the master branch, may not on a development branch" + echo -e " ${COL_LIGHT_RED}This feature is NOT supported unless a Pi-hole developer explicitly asks!${COL_NC}" + read -r -p " Have you read and understood this? [y/N] " response + case "${response}" in + [yY][eE][sS]|[yY]) + echo "" + return 0 + ;; + *) + echo -e "\\n ${INFO} Branch change has been cancelled" + return 1 + ;; + esac } checkout() { - local corebranches - local webbranches + local corebranches + local webbranches - # Avoid globbing - set -f + # Avoid globbing + set -f - # This is unlikely - if ! is_repo "${PI_HOLE_FILES_DIR}" ; then - echo -e " ${COL_LIGHT_RED}Error: Core Pi-hole repo is missing from system! - Please re-run install script from https://github.com/pi-hole/pi-hole${COL_NC}" - exit 1; - fi - if [[ "${INSTALL_WEB_INTERFACE}" == "true" ]]; then - if ! is_repo "${webInterfaceDir}" ; then - echo -e " ${COL_LIGHT_RED}Error: Web Admin repo is missing from system! - Please re-run install script from https://github.com/pi-hole/pi-hole${COL_NC}" - exit 1; + # This is unlikely + if ! is_repo "${PI_HOLE_FILES_DIR}" ; then + echo -e " ${COL_LIGHT_RED}Error: Core Pi-hole repo is missing from system!" + echo -e " Please re-run install script from https://github.com/pi-hole/pi-hole${COL_NC}" + exit 1; fi - fi - - if [[ -z "${1}" ]]; then - echo -e " ${COL_LIGHT_RED}Invalid option${COL_NC} - Try 'pihole checkout --help' for more information." - exit 1 - fi - - if ! warning1 ; then - exit 1 - fi - - if [[ "${1}" == "dev" ]] ; then - # Shortcut to check out development branches - echo -e " ${INFO} Shortcut \"dev\" detected - checking out development / devel branches..." - echo "" - echo -e " ${INFO} Pi-hole Core" - fetch_checkout_pull_branch "${PI_HOLE_FILES_DIR}" "development" || { echo " ${CROSS} Unable to pull Core developement branch"; exit 1; } if [[ "${INSTALL_WEB_INTERFACE}" == "true" ]]; then - echo "" - echo -e " ${INFO} Web interface" - fetch_checkout_pull_branch "${webInterfaceDir}" "devel" || { echo " ${CROSS} Unable to pull Web development branch"; exit 1; } - fi - #echo -e " ${TICK} Pi-hole Core" - - get_binary_name - local path - path="development/${binary}" - echo "development" > /etc/pihole/ftlbranch - elif [[ "${1}" == "master" ]] ; then - # Shortcut to check out master branches - echo -e " ${INFO} Shortcut \"master\" detected - checking out master branches..." - echo -e " ${INFO} Pi-hole core" - fetch_checkout_pull_branch "${PI_HOLE_FILES_DIR}" "master" || { echo " ${CROSS} Unable to pull Core master branch"; exit 1; } - if [[ ${INSTALL_WEB_INTERFACE} == "true" ]]; then - echo -e " ${INFO} Web interface" - fetch_checkout_pull_branch "${webInterfaceDir}" "master" || { echo " ${CROSS} Unable to pull Web master branch"; exit 1; } - fi - #echo -e " ${TICK} Web Interface" - get_binary_name - local path - path="master/${binary}" - echo "master" > /etc/pihole/ftlbranch - elif [[ "${1}" == "core" ]] ; then - str="Fetching branches from ${piholeGitUrl}" - echo -ne " ${INFO} $str" - if ! fully_fetch_repo "${PI_HOLE_FILES_DIR}" ; then - echo -e "${OVER} ${CROSS} $str" - exit 1 - fi - corebranches=($(get_available_branches "${PI_HOLE_FILES_DIR}")) - - if [[ "${corebranches[*]}" == *"master"* ]]; then - echo -e "${OVER} ${TICK} $str - ${INFO} ${#corebranches[@]} branches available for Pi-hole Core" - else - # Print STDERR output from get_available_branches - echo -e "${OVER} ${CROSS} $str\\n\\n${corebranches[*]}" - exit 1 + if ! is_repo "${webInterfaceDir}" ; then + echo -e " ${COL_LIGHT_RED}Error: Web Admin repo is missing from system!" + echo -e " Please re-run install script from https://github.com/pi-hole/pi-hole${COL_NC}" + exit 1; + fi fi - echo "" - # Have the user choose the branch they want - if ! (for e in "${corebranches[@]}"; do [[ "$e" == "${2}" ]] && exit 0; done); then - echo -e " ${INFO} Requested branch \"${2}\" is not available" - echo -e " ${INFO} Available branches for Core are:" - for e in "${corebranches[@]}"; do echo " - $e"; done - exit 1 - fi - checkout_pull_branch "${PI_HOLE_FILES_DIR}" "${2}" - elif [[ "${1}" == "web" ]] && [[ "${INSTALL_WEB_INTERFACE}" == "true" ]] ; then - str="Fetching branches from ${webInterfaceGitUrl}" - echo -ne " ${INFO} $str" - if ! fully_fetch_repo "${webInterfaceDir}" ; then - echo -e "${OVER} ${CROSS} $str" - exit 1 - fi - webbranches=($(get_available_branches "${webInterfaceDir}")) - - if [[ "${webbranches[*]}" == *"master"* ]]; then - echo -e "${OVER} ${TICK} $str - ${INFO} ${#webbranches[@]} branches available for Web Admin" - else - # Print STDERR output from get_available_branches - echo -e "${OVER} ${CROSS} $str\\n\\n${webbranches[*]}" - exit 1 - fi - - echo "" - # Have the user choose the branch they want - if ! (for e in "${webbranches[@]}"; do [[ "$e" == "${2}" ]] && exit 0; done); then - echo -e " ${INFO} Requested branch \"${2}\" is not available" - echo -e " ${INFO} Available branches for Web Admin are:" - for e in "${webbranches[@]}"; do echo " - $e"; done - exit 1 - fi - checkout_pull_branch "${webInterfaceDir}" "${2}" - elif [[ "${1}" == "ftl" ]] ; then - get_binary_name - local path - path="${2}/${binary}" - - if check_download_exists "$path"; then - echo " ${TICK} Branch ${2} exists" - echo "${2}" > /etc/pihole/ftlbranch - FTLinstall "${binary}" - start_service pihole-FTL - enable_service pihole-FTL - else - echo " ${CROSS} Requested branch \"${2}\" is not available" - ftlbranches=( $(git ls-remote https://github.com/pi-hole/ftl | grep 'heads' | sed 's/refs\/heads\///;s/ //g' | awk '{print $2}') ) - echo -e " ${INFO} Available branches for FTL are:" - for e in "${ftlbranches[@]}"; do echo " - $e"; done + if [[ -z "${1}" ]]; then + echo -e " ${COL_LIGHT_RED}Invalid option${COL_NC}" + echo -e " Try 'pihole checkout --help' for more information." exit 1 fi - else - echo -e " ${INFO} Requested option \"${1}\" is not available" - exit 1 - fi - - # Force updating everything - if [[ ! "${1}" == "web" && ! "${1}" == "ftl" ]]; then - echo -e " ${INFO} Running installer to upgrade your installation" - if "${PI_HOLE_FILES_DIR}/automated install/basic-install.sh" --unattended; then - exit 0 - else - echo -e " ${COL_LIGHT_RED} Error: Unable to complete update, please contact support${COL_NC}" - exit 1 + if ! warning1 ; then + exit 1 + fi + + if [[ "${1}" == "dev" ]] ; then + # Shortcut to check out development branches + echo -e " ${INFO} Shortcut \"dev\" detected - checking out development / devel branches..." + echo "" + echo -e " ${INFO} Pi-hole Core" + fetch_checkout_pull_branch "${PI_HOLE_FILES_DIR}" "development" || { echo " ${CROSS} Unable to pull Core developement branch"; exit 1; } + if [[ "${INSTALL_WEB_INTERFACE}" == "true" ]]; then + echo "" + echo -e " ${INFO} Web interface" + fetch_checkout_pull_branch "${webInterfaceDir}" "devel" || { echo " ${CROSS} Unable to pull Web development branch"; exit 1; } + fi + #echo -e " ${TICK} Pi-hole Core" + + get_binary_name + local path + path="development/${binary}" + echo "development" > /etc/pihole/ftlbranch + elif [[ "${1}" == "master" ]] ; then + # Shortcut to check out master branches + echo -e " ${INFO} Shortcut \"master\" detected - checking out master branches..." + echo -e " ${INFO} Pi-hole core" + fetch_checkout_pull_branch "${PI_HOLE_FILES_DIR}" "master" || { echo " ${CROSS} Unable to pull Core master branch"; exit 1; } + if [[ ${INSTALL_WEB_INTERFACE} == "true" ]]; then + echo -e " ${INFO} Web interface" + fetch_checkout_pull_branch "${webInterfaceDir}" "master" || { echo " ${CROSS} Unable to pull Web master branch"; exit 1; } + fi + #echo -e " ${TICK} Web Interface" + get_binary_name + local path + path="master/${binary}" + echo "master" > /etc/pihole/ftlbranch + elif [[ "${1}" == "core" ]] ; then + str="Fetching branches from ${piholeGitUrl}" + echo -ne " ${INFO} $str" + if ! fully_fetch_repo "${PI_HOLE_FILES_DIR}" ; then + echo -e "${OVER} ${CROSS} $str" + exit 1 + fi + corebranches=($(get_available_branches "${PI_HOLE_FILES_DIR}")) + + if [[ "${corebranches[*]}" == *"master"* ]]; then + echo -e "${OVER} ${TICK} $str" + echo -e "${INFO} ${#corebranches[@]} branches available for Pi-hole Core" + else + # Print STDERR output from get_available_branches + echo -e "${OVER} ${CROSS} $str\\n\\n${corebranches[*]}" + exit 1 + fi + + echo "" + # Have the user choose the branch they want + if ! (for e in "${corebranches[@]}"; do [[ "$e" == "${2}" ]] && exit 0; done); then + echo -e " ${INFO} Requested branch \"${2}\" is not available" + echo -e " ${INFO} Available branches for Core are:" + for e in "${corebranches[@]}"; do echo " - $e"; done + exit 1 + fi + checkout_pull_branch "${PI_HOLE_FILES_DIR}" "${2}" + elif [[ "${1}" == "web" ]] && [[ "${INSTALL_WEB_INTERFACE}" == "true" ]] ; then + str="Fetching branches from ${webInterfaceGitUrl}" + echo -ne " ${INFO} $str" + if ! fully_fetch_repo "${webInterfaceDir}" ; then + echo -e "${OVER} ${CROSS} $str" + exit 1 + fi + webbranches=($(get_available_branches "${webInterfaceDir}")) + + if [[ "${webbranches[*]}" == *"master"* ]]; then + echo -e "${OVER} ${TICK} $str" + echo -e "${INFO} ${#webbranches[@]} branches available for Web Admin" + else + # Print STDERR output from get_available_branches + echo -e "${OVER} ${CROSS} $str\\n\\n${webbranches[*]}" + exit 1 + fi + + echo "" + # Have the user choose the branch they want + if ! (for e in "${webbranches[@]}"; do [[ "$e" == "${2}" ]] && exit 0; done); then + echo -e " ${INFO} Requested branch \"${2}\" is not available" + echo -e " ${INFO} Available branches for Web Admin are:" + for e in "${webbranches[@]}"; do echo " - $e"; done + exit 1 + fi + checkout_pull_branch "${webInterfaceDir}" "${2}" + elif [[ "${1}" == "ftl" ]] ; then + get_binary_name + local path + path="${2}/${binary}" + + if check_download_exists "$path"; then + echo " ${TICK} Branch ${2} exists" + echo "${2}" > /etc/pihole/ftlbranch + FTLinstall "${binary}" + start_service pihole-FTL + enable_service pihole-FTL + else + echo " ${CROSS} Requested branch \"${2}\" is not available" + ftlbranches=( $(git ls-remote https://github.com/pi-hole/ftl | grep 'heads' | sed 's/refs\/heads\///;s/ //g' | awk '{print $2}') ) + echo -e " ${INFO} Available branches for FTL are:" + for e in "${ftlbranches[@]}"; do echo " - $e"; done + exit 1 + fi + + else + echo -e " ${INFO} Requested option \"${1}\" is not available" + exit 1 + fi + + # Force updating everything + if [[ ! "${1}" == "web" && ! "${1}" == "ftl" ]]; then + echo -e " ${INFO} Running installer to upgrade your installation" + if "${PI_HOLE_FILES_DIR}/automated install/basic-install.sh" --unattended; then + exit 0 + else + echo -e " ${COL_LIGHT_RED} Error: Unable to complete update, please contact support${COL_NC}" + exit 1 + fi fi - fi }