freedomboneeee/src/freedombone-utils-interactive

256 lines
9.4 KiB
Bash
Executable File

#!/bin/bash
# _____ _ _
# | __|___ ___ ___ _| |___ _____| |_ ___ ___ ___
# | __| _| -_| -_| . | . | | . | . | | -_|
# |__| |_| |___|___|___|___|_|_|_|___|___|_|_|___|
#
# Freedom in the Cloud
#
# Interactive install functions
#
# License
# =======
#
# Copyright (C) 2014-2018 Bob Mottram <bob@freedombone.net>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
function interactive_configuration_remote_backups {
if [[ $SYSTEM_TYPE == "mesh"* ]]; then
return
fi
if [ ! -f "/usr/local/bin/${PROJECT_NAME}-remote" ]; then
if [ ! -f "/usr/bin/${PROJECT_NAME}-remote" ]; then
echo $"The command ${PROJECT_NAME}-remote was not found"
exit 87354
fi
fi
if ! "${PROJECT_NAME}-remote" -u "$MY_USERNAME" -l "$FRIENDS_SERVERS_LIST" -m "$MINIMUM_PASSWORD_LENGTH" -r yes; then
echo $'Command failed:'
echo ''
echo $" ${PROJECT_NAME}-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH -r yes"
echo ''
exit 65892
fi
}
function interactive_configuration {
if [ ! -f "/usr/local/bin/${PROJECT_NAME}-config" ]; then
if [ ! -f "/usr/bin/${PROJECT_NAME}-config" ]; then
echo $"The command ${PROJECT_NAME}-config was not found"
exit 63935
fi
fi
if [ -f /tmp/meshuserdevice ]; then
rm -f /tmp/meshuserdevice
fi
if [ "$SOCIALINSTANCE" ]; then
"${PROJECT_NAME}-config" \
-f "$CONFIGURATION_FILE" \
-w "$PROJECT_WEBSITE" \
-m "$MINIMUM_PASSWORD_LENGTH" \
--minimal "yes" \
--social "$SOCIALINSTANCE"
else
if [[ $ONION_ONLY == "no" ]]; then
if [[ $MINIMAL_INSTALL == "no" ]]; then
"${PROJECT_NAME}-config" \
-f "$CONFIGURATION_FILE" \
-w "$PROJECT_WEBSITE" \
-m "$MINIMUM_PASSWORD_LENGTH"
else
"${PROJECT_NAME}-config" \
-f "$CONFIGURATION_FILE" \
-w "$PROJECT_WEBSITE" \
-m "$MINIMUM_PASSWORD_LENGTH" \
--minimal "yes"
fi
else
"${PROJECT_NAME}-config" \
-f "$CONFIGURATION_FILE" \
-w "$PROJECT_WEBSITE" \
-m "$MINIMUM_PASSWORD_LENGTH" \
--onion "yes"
fi
fi
if [ -f /tmp/meshuserdevice ]; then
# mesh network user device installation
rm -f /tmp/meshuserdevice
exit 0
fi
# shellcheck disable=SC2181
if [ ! "$?" = "0" ]; then
echo $'Command failed:'
echo ''
echo $" ${PROJECT_NAME}-config -u $MY_USERNAME -f $CONFIGURATION_FILE -w $PROJECT_WEBSITE -b $PROJECT_BITMESSAGE -m $MINIMUM_PASSWORD_LENGTH --minimal [yes|no]"
echo ''
exit 73594
fi
if [[ $SYSTEM_TYPE == "mesh"* ]]; then
FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
dialog --title $"Encrypted backup to other servers" \
--backtitle $"${PROJECT_NAME} Configuration" \
--defaultno \
--yesno $"\\nDo you wish to configure some remote backup locations?" 7 60
sel=$?
case $sel in
0) interactive_configuration_remote_backups;;
esac
fi
}
function interactive_site_details {
site_name="$1"
site_name_upper=${site_name^^}
SITE_BACKTITLE=$"Freedombone Configuration"
SITE_CONFIG_TITLE=$"${site_name^} Configuration"
SITE_FORM_TEXT=$"\\nPlease enter your ${site_name^} details.\\n\\nIMPORTANT: This should be a domain name which is supported by Let's Encrypt:"
SITE_DOMAIN_NAME=
SITE_CODE=
SITE_DETAILS_COMPLETE=
while [ ! $SITE_DETAILS_COMPLETE ]
do
data=$(mktemp 2>/dev/null)
if [[ $DDNS_PROVIDER == *"freedns"* ]]; then
dialog --backtitle "$SITE_BACKTITLE" \
--title "$SITE_CONFIG_TITLE" \
--form "$SITE_FORM_TEXT" 14 55 3 \
$"Domain:" 1 1 "$(grep "${site_name_upper}_DOMAIN_NAME" temp.cfg | awk -F '=' '{print $2}')" 1 16 33 40 \
$"Code:" 2 1 "$(grep "${site_name_upper}_CODE" temp.cfg | awk -F '=' '{print $2}')" 2 16 33 255 \
2> "$data"
else
dialog --backtitle "$SITE_BACKTITLE" \
--title "$SITE_CONFIG_TITLE" \
--form "$SITE_FORM_TEXT" 13 55 3 \
$"Domain:" 1 1 "$(grep "${site_name_upper}_DOMAIN_NAME" temp.cfg | awk -F '=' '{print $2}')" 1 16 33 40 \
2> "$data"
fi
sel=$?
case $sel in
1) rm -f "$data"
exit 1;;
255) rm -f "$data"
exit 1;;
esac
SITE_DOMAIN_NAME=$(sed -n 1p < "$data")
if [ "$SITE_DOMAIN_NAME" ]; then
TEST_DOMAIN_NAME=$SITE_DOMAIN_NAME
validate_domain_name
if [[ "$TEST_DOMAIN_NAME" != "$SITE_DOMAIN_NAME" ]]; then
SITE_DOMAIN_NAME=
dialog --title $"Domain name validation" --msgbox "$TEST_DOMAIN_NAME" 15 50
else
if [[ "$DDNS_PROVIDER" == *"freedns"* ]]; then
SITE_CODE=$(sed -n 2p < "$data")
validate_freedns_code "$SITE_CODE"
if [ ! "$VALID_CODE" ]; then
SITE_DOMAIN_NAME=
fi
fi
fi
fi
if [ "$SITE_DOMAIN_NAME" ]; then
SITE_DETAILS_COMPLETE="yes"
fi
rm -f "$data"
done
# save the results in the config file
write_config_param "${site_name_upper}_DOMAIN_NAME" "$SITE_DOMAIN_NAME"
site_code_str="$SITE_CODE"
if [ ${#site_code_str} -gt 1 ]; then
write_config_param "${site_name_upper}_CODE" "${SITE_CODE}"
fi
}
function interactive_site_details_with_title {
site_name="${1}"
SITE_BACKTITLE=$"Freedombone Configuration"
SITE_CONFIG_TITLE=$"${site_name^} Configuration"
SITE_FORM_TEXT=$"\nPlease enter your ${site_name^} details.\n\nIMPORTANT: This should be a domain name which is supported by Let's Encrypt:"
SITE_TITLE=
SITE_DOMAIN_NAME=
SITE_CODE=
SITE_DETAILS_COMPLETE=
while [ ! $SITE_DETAILS_COMPLETE ]
do
data=$(mktemp 2>/dev/null)
if [[ $DDNS_PROVIDER == *"freedns"* ]]; then
dialog --backtitle $"Freedombone Configuration" \
--title "$SITE_BACKTITLE" \
--form "$SITE_FORM_TEXT" 14 55 4 \
$"Domain:" 2 1 "$(grep "$SITE_DOMAIN_NAME" temp.cfg | awk -F '=' '{print $2}')" 2 16 33 40 \
$"Code:" 3 1 "$(grep "$SITE_CODE" temp.cfg | awk -F '=' '{print $2}')" 3 16 33 255 \
2> "$data"
else
dialog --backtitle "$SITE_BACKTITLE" \
--title "$SITE_CONFIG_TITLE" \
--form "$SITE_FORM_TEXT" 11 55 3 \
$"Title:" 1 1 "$(grep "$SITE_TITLE" temp.cfg | awk -F '=' '{print $2}')" 1 16 33 40 \
$"Domain:" 2 1 "$(grep "$SITE_DOMAIN_NAME" temp.cfg | awk -F '=' '{print $2}')" 2 16 33 40 \
2> "$data"
fi
sel=$?
case $sel in
1) rm -f "$data"
exit 1;;
255) rm -f "$data"
exit 1;;
esac
SITE_TITLE=$(sed -n 1p < "$data")
SITE_DOMAIN_NAME=$(sed -n 2p < "$data")
site_domain_name_str="$SITE_DOMAIN_NAME"
if [ ${#site_domain_name_str} -gt 1 ]; then
TEST_DOMAIN_NAME="$SITE_DOMAIN_NAME"
validate_domain_name
if [[ "$TEST_DOMAIN_NAME" != "${SITE_DOMAIN_NAME}" ]]; then
SITE_DOMAIN_NAME=
dialog --title $"Domain name validation" --msgbox "$TEST_DOMAIN_NAME" 15 50
else
if [[ "$DDNS_PROVIDER" == *"freedns"* ]]; then
SITE_CODE=$(sed -n 3p < "$data")
validate_freedns_code "${SITE_CODE}"
if [ ! "$VALID_CODE" ]; then
SITE_DOMAIN_NAME=
fi
fi
fi
fi
site_title_str="$SITE_TITLE"
if [ ${#site_title_str} -gt 0 ]; then
if [ ${SITE_DOMAIN_NAME} ]; then
SITE_DETAILS_COMPLETE="yes"
fi
fi
rm -f "$data"
done
# save the results in the config file
write_config_param "$2" "${SITE_TITLE}"
write_config_param "$3" "${SITE_DOMAIN_NAME}"
site_code_str="$SITE_CODE"
if [ ${#site_code_str} -gt 1 ]; then
write_config_param "$4" "${SITE_CODE}"
fi
}
# NOTE: deliberately no exit 0