mirror of
https://github.com/billz/raspap-webgui.git
synced 2023-10-10 13:37:24 +02:00
120 lines
3.5 KiB
Bash
Executable File
120 lines
3.5 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# RaspAP Quick Installer
|
|
# author: @billz
|
|
# license: GNU General Public License v3.0
|
|
#
|
|
# Command-line options:
|
|
# -y, --yes, --assume-yes
|
|
# Assume "yes" as answer to all prompts and run non-interactively
|
|
# c, --cert, --certficate
|
|
# Installs mkcert and generates an SSL certificate for lighttpd
|
|
# -r, --repo, --repository
|
|
# Overrides the default GitHub repo (billz/raspap-webgui)
|
|
# -b, --branch
|
|
# Overrides the default git branch (master)
|
|
|
|
repo="billz/raspap-webgui"
|
|
branch="master"
|
|
usage=$(cat << EOF
|
|
Usage: raspbian.sh [OPTION]\n
|
|
-y, --yes, --assume-yes\n\tAssumes "yes" as an answer to all prompts
|
|
-c, --cert, --certficate\n\tInstalls an SSL certificate for lighttpd
|
|
-r, --repo, --repository\n\tOverrides the default GitHub repo (billz/raspap-webgui)
|
|
-b, --branch\n\tOverrides the default git branch (master)\n
|
|
EOF
|
|
)
|
|
assume_yes=0
|
|
|
|
while :; do
|
|
case $1 in
|
|
-y|--yes|--assume-yes)
|
|
assume_yes=1
|
|
apt_option="-y"
|
|
;;
|
|
-c|--cert|--certificate)
|
|
install_cert=1
|
|
;;
|
|
-r|--repo|--repository)
|
|
repo="$2"
|
|
shift
|
|
;;
|
|
-b|--branch)
|
|
branch="$2"
|
|
;;
|
|
-h|--help)
|
|
printf "$usage"
|
|
exit 1
|
|
;;
|
|
-*|--*)
|
|
echo "Unknown option: $1"
|
|
printf "$usage"
|
|
exit 1
|
|
;;
|
|
*)
|
|
break
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
VERSION=$(curl -s "https://api.github.com/repos/$repo/releases/latest" | grep -Po '"tag_name": "\K.*?(?=")' )
|
|
UPDATE_URL="https://raw.githubusercontent.com/$repo/$branch/"
|
|
|
|
# Outputs a welcome message
|
|
function display_welcome() {
|
|
raspberry='\033[0;35m'
|
|
green='\033[1;32m'
|
|
|
|
echo -e "${raspberry}\n"
|
|
echo -e " 888888ba .d888888 888888ba"
|
|
echo -e " 88 8b d8 88 88 8b"
|
|
echo -e "a88aaaa8P' .d8888b. .d8888b. 88d888b. 88aaaaa88a a88aaaa8P"
|
|
echo -e " 88 8b. 88 88 Y8ooooo. 88 88 88 88 88"
|
|
echo -e " 88 88 88. .88 88 88. .88 88 88 88"
|
|
echo -e " dP dP 88888P8 88888P 88Y888P 88 88 dP"
|
|
echo -e " 88"
|
|
echo -e " dP version ${VERSION}"
|
|
echo -e "${green}"
|
|
echo -e "The Quick Installer will guide you through a few easy steps\n\n"
|
|
}
|
|
|
|
# Outputs a RaspAP Install log line
|
|
function install_log() {
|
|
echo -e "\033[1;32mRaspAP Install: $*\033[m"
|
|
}
|
|
|
|
# Outputs a RaspAP Install Error log line and exits with status code 1
|
|
function install_error() {
|
|
echo -e "\033[1;37;41mRaspAP Install Error: $*\033[m"
|
|
exit 1
|
|
}
|
|
|
|
# Outputs a RaspAP Warning line
|
|
function install_warning() {
|
|
echo -e "\033[1;33mWarning: $*\033[m"
|
|
}
|
|
|
|
# Outputs a RaspAP divider
|
|
function install_divider() {
|
|
echo -e "\033[1;32m***************************************************************$*\033[m"
|
|
}
|
|
|
|
function update_system_packages() {
|
|
install_log "Updating sources"
|
|
sudo apt-get update || install_error "Unable to update package list"
|
|
}
|
|
|
|
if [ "${install_cert:-}" = 1 ]; then
|
|
source="mkcert"
|
|
wget -q ${UPDATE_URL}installers/${source}.sh -O /tmp/raspap_${source}.sh
|
|
source /tmp/raspap_${source}.sh && rm -f /tmp/raspap_${source}.sh
|
|
install_certificate || install_error "Unable to install certificate"
|
|
else
|
|
source="common"
|
|
wget -q ${UPDATE_URL}installers/${source}.sh -O /tmp/raspap_${source}.sh
|
|
source /tmp/raspap_${source}.sh && rm -f /tmp/raspap_${source}.sh
|
|
install_raspap || install_error "Unable to install RaspAP"
|
|
fi
|
|
|