Preparing app setup
This commit is contained in:
parent
9ce622b5bd
commit
03ff899399
|
@ -42,56 +42,7 @@ source $PROJECT_INSTALL_DIR/${PROJECT_NAME}-vars
|
||||||
|
|
||||||
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
|
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
|
||||||
|
|
||||||
# Array containing names of available apps
|
source $PROJECT_INSTALL_DIR/${PROJECT_NAME}-utils-selector
|
||||||
APPS_AVAILABLE=()
|
|
||||||
|
|
||||||
# Array containing 1 or 0 indicating installed apps
|
|
||||||
APPS_INSTALLED=()
|
|
||||||
|
|
||||||
# Apps selected with checklist
|
|
||||||
APPS_CHOSEN=()
|
|
||||||
|
|
||||||
function item_in_array {
|
|
||||||
local e
|
|
||||||
for e in "${@:2}"; do [[ "$e" == "$1" ]] && return 0; done
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
function app_is_installed {
|
|
||||||
app_name="$1"
|
|
||||||
if [ ! -f $COMPLETION_FILE ]; then
|
|
||||||
echo "0"
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! grep -Fxq "install_${app_name}" $COMPLETION_FILE; then
|
|
||||||
echo "0"
|
|
||||||
else
|
|
||||||
echo "1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_apps_installed {
|
|
||||||
for a in "${APPS_AVAILABLE[@]}"
|
|
||||||
do
|
|
||||||
APPS_INSTALLED+=("$(app_is_installed $a)")
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
function detect_apps {
|
|
||||||
FILES=$PROJECT_INSTALL_DIR/${PROJECT_NAME}-app-*
|
|
||||||
|
|
||||||
# for all the app scripts
|
|
||||||
for filename in $FILES
|
|
||||||
do
|
|
||||||
app_name=$(echo "${filename}" | awk -F '-app-' '{print $2}')
|
|
||||||
if [[ $(item_in_array ${app_name} ${APPS_AVAILABLE[@]}) != 0 ]]; then
|
|
||||||
APPS_AVAILABLE+=("${app_name}")
|
|
||||||
APPS_CHOSEN+=("0")
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
get_apps_installed
|
|
||||||
}
|
|
||||||
|
|
||||||
function show_apps {
|
function show_apps {
|
||||||
applist=""
|
applist=""
|
||||||
|
@ -124,7 +75,7 @@ function show_apps {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function remove_apps {
|
function remove_apps_interactive {
|
||||||
# which apps need to be removed?
|
# which apps need to be removed?
|
||||||
removals=""
|
removals=""
|
||||||
app_index=0
|
app_index=0
|
||||||
|
@ -162,20 +113,10 @@ function remove_apps {
|
||||||
|
|
||||||
# remove the apps
|
# remove the apps
|
||||||
read_configuration
|
read_configuration
|
||||||
for a in "${APPS_AVAILABLE[@]}"
|
remove_apps
|
||||||
do
|
|
||||||
if [[ ${APPS_INSTALLED[$app_index]} == "1" ]]; then
|
|
||||||
if [[ ${APPS_CHOSEN[$app_index]} == "0" ]]; then
|
|
||||||
echo $"Removing application: ${a}"
|
|
||||||
remove_${a}
|
|
||||||
echo $"${a} was removed"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
app_index=$[app_index+1]
|
|
||||||
done
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function install_apps {
|
function install_apps_interactive {
|
||||||
# which apps need to be installed?
|
# which apps need to be installed?
|
||||||
installs=""
|
installs=""
|
||||||
app_index=0
|
app_index=0
|
||||||
|
@ -213,17 +154,7 @@ function install_apps {
|
||||||
|
|
||||||
# install the apps
|
# install the apps
|
||||||
read_configuration
|
read_configuration
|
||||||
for a in "${APPS_AVAILABLE[@]}"
|
install_apps
|
||||||
do
|
|
||||||
if [[ ${APPS_INSTALLED[$app_index]} == "0" ]]; then
|
|
||||||
if [[ ${APPS_CHOSEN[$app_index]} == "1" ]]; then
|
|
||||||
echo $"Installing application: ${a}"
|
|
||||||
install_${a}
|
|
||||||
echo $"${a} was installed"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
app_index=$[app_index+1]
|
|
||||||
done
|
|
||||||
}
|
}
|
||||||
|
|
||||||
${PROJECT_NAME}-tests
|
${PROJECT_NAME}-tests
|
||||||
|
@ -242,7 +173,7 @@ show_apps
|
||||||
|
|
||||||
clear
|
clear
|
||||||
|
|
||||||
remove_apps
|
remove_apps_interactive
|
||||||
install_apps
|
install_apps_interactive
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|
|
@ -0,0 +1,113 @@
|
||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# .---. . .
|
||||||
|
# | | |
|
||||||
|
# |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
|
||||||
|
# | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
|
||||||
|
# ' ' --' --' -' - -' ' ' -' -' -' ' - --'
|
||||||
|
#
|
||||||
|
# Freedom in the Cloud
|
||||||
|
#
|
||||||
|
# Functions for selecting which apps to install or remove
|
||||||
|
#
|
||||||
|
# License
|
||||||
|
# =======
|
||||||
|
#
|
||||||
|
# Copyright (C) 2015-2016 Bob Mottram <bob@robotics.uk.to>
|
||||||
|
#
|
||||||
|
# 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/>.
|
||||||
|
|
||||||
|
# Array containing names of available apps
|
||||||
|
APPS_AVAILABLE=()
|
||||||
|
|
||||||
|
# Array containing 1 or 0 indicating installed apps
|
||||||
|
APPS_INSTALLED=()
|
||||||
|
|
||||||
|
# Apps selected with checklist
|
||||||
|
APPS_CHOSEN=()
|
||||||
|
|
||||||
|
function item_in_array {
|
||||||
|
local e
|
||||||
|
for e in "${@:2}"; do [[ "$e" == "$1" ]] && return 0; done
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function app_is_installed {
|
||||||
|
app_name="$1"
|
||||||
|
if [ ! -f $COMPLETION_FILE ]; then
|
||||||
|
echo "0"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! grep -Fxq "install_${app_name}" $COMPLETION_FILE; then
|
||||||
|
echo "0"
|
||||||
|
else
|
||||||
|
echo "1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_apps_installed {
|
||||||
|
for a in "${APPS_AVAILABLE[@]}"
|
||||||
|
do
|
||||||
|
APPS_INSTALLED+=("$(app_is_installed $a)")
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
function detect_apps {
|
||||||
|
FILES=$PROJECT_INSTALL_DIR/${PROJECT_NAME}-app-*
|
||||||
|
|
||||||
|
APPS_AVAILABLE=()
|
||||||
|
APPS_CHOSEN=()
|
||||||
|
|
||||||
|
# for all the app scripts
|
||||||
|
for filename in $FILES
|
||||||
|
do
|
||||||
|
app_name=$(echo "${filename}" | awk -F '-app-' '{print $2}')
|
||||||
|
if [[ $(item_in_array ${app_name} ${APPS_AVAILABLE[@]}) != 0 ]]; then
|
||||||
|
APPS_AVAILABLE+=("${app_name}")
|
||||||
|
APPS_CHOSEN+=("0")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
get_apps_installed
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_apps {
|
||||||
|
app_index=0
|
||||||
|
for a in "${APPS_AVAILABLE[@]}"
|
||||||
|
do
|
||||||
|
if [[ ${APPS_INSTALLED[$app_index]} == "1" ]]; then
|
||||||
|
if [[ ${APPS_CHOSEN[$app_index]} == "0" ]]; then
|
||||||
|
echo $"Removing application: ${a}"
|
||||||
|
remove_${a}
|
||||||
|
echo $"${a} was removed"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
app_index=$[app_index+1]
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
function install_apps {
|
||||||
|
app_index=0
|
||||||
|
for a in "${APPS_AVAILABLE[@]}"
|
||||||
|
do
|
||||||
|
if [[ ${APPS_INSTALLED[$app_index]} == "0" ]]; then
|
||||||
|
if [[ ${APPS_CHOSEN[$app_index]} == "1" ]]; then
|
||||||
|
echo $"Installing application: ${a}"
|
||||||
|
install_${a}
|
||||||
|
echo $"${a} was installed"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
app_index=$[app_index+1]
|
||||||
|
done
|
||||||
|
}
|
|
@ -326,24 +326,13 @@ function setup_web {
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_apps {
|
function setup_apps {
|
||||||
install_zeronet
|
function_check detect_apps
|
||||||
install_syncthing
|
detect_apps
|
||||||
install_gogs
|
|
||||||
install_xmpp
|
# TODO choose apps based upon variants
|
||||||
install_tox
|
|
||||||
install_irc
|
function_check install_apps
|
||||||
install_mumble
|
install_apps
|
||||||
install_sip
|
|
||||||
install_wiki
|
|
||||||
install_blog
|
|
||||||
install_gnusocial
|
|
||||||
install_rss
|
|
||||||
install_hubzilla
|
|
||||||
#install_webmail
|
|
||||||
#install_search_engine
|
|
||||||
install_dlna
|
|
||||||
#install_mediagoblin
|
|
||||||
#install_ipfs
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# NOTE: deliberately no exit 0
|
# NOTE: deliberately no exit 0
|
||||||
|
|
Loading…
Reference in New Issue