190 lines
7.0 KiB
Bash
Executable File
190 lines
7.0 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
red='\033[0;31m'
|
|
green='\033[0;32m'
|
|
yellow='\033[0;33m'
|
|
plain='\033[0m'
|
|
|
|
cur_dir=$(pwd)
|
|
|
|
# check root
|
|
[[ $EUID -ne 0 ]] && echo -e "${red}Fatal error: ${plain} Please run this script with root privilege \n " && exit 1
|
|
|
|
# Check OS and set release variable
|
|
if [[ -f /etc/os-release ]]; then
|
|
source /etc/os-release
|
|
release=$ID
|
|
elif [[ -f /usr/lib/os-release ]]; then
|
|
source /usr/lib/os-release
|
|
release=$ID
|
|
else
|
|
echo "Failed to check the system OS, please contact the author!" >&2
|
|
exit 1
|
|
fi
|
|
echo "The OS release is: $release"
|
|
|
|
arch() {
|
|
case "$(uname -m)" in
|
|
x86_64 | x64 | amd64) echo 'amd64' ;;
|
|
i*86 | x86) echo '386' ;;
|
|
armv8* | armv8 | arm64 | aarch64) echo 'arm64' ;;
|
|
armv7* | armv7 | arm) echo 'armv7' ;;
|
|
*) echo -e "${green}Unsupported CPU architecture! ${plain}" && rm -f install.sh && exit 1 ;;
|
|
esac
|
|
}
|
|
|
|
echo "arch: $(arch)"
|
|
|
|
os_version=""
|
|
os_version=$(grep -i version_id /etc/os-release | cut -d \" -f2 | cut -d . -f1)
|
|
|
|
if [[ "${release}" == "centos" ]]; then
|
|
if [[ ${os_version} -lt 8 ]]; then
|
|
echo -e "${red} Please use CentOS 8 or higher ${plain}\n" && exit 1
|
|
fi
|
|
elif [[ "${release}" == "ubuntu" ]]; then
|
|
if [[ ${os_version} -lt 20 ]]; then
|
|
echo -e "${red}please use Ubuntu 20 or higher version! ${plain}\n" && exit 1
|
|
fi
|
|
|
|
elif [[ "${release}" == "fedora" ]]; then
|
|
if [[ ${os_version} -lt 36 ]]; then
|
|
echo -e "${red}please use Fedora 36 or higher version! ${plain}\n" && exit 1
|
|
fi
|
|
|
|
elif [[ "${release}" == "debian" ]]; then
|
|
if [[ ${os_version} -lt 10 ]]; then
|
|
echo -e "${red} Please use Debian 10 or higher ${plain}\n" && exit 1
|
|
fi
|
|
else
|
|
echo -e "${red}Failed to check the OS version, please contact the author!${plain}" && exit 1
|
|
fi
|
|
|
|
|
|
install_base() {
|
|
case "${release}" in
|
|
centos)
|
|
yum -y update && yum install -y -q wget curl tar tzdata
|
|
;;
|
|
fedora)
|
|
dnf -y update && dnf install -y -q wget curl tar tzdata
|
|
;;
|
|
*)
|
|
apt-get update && apt install -y -q wget curl tar tzdata
|
|
;;
|
|
esac
|
|
}
|
|
|
|
config_after_install() {
|
|
echo -e "${yellow}Migration... ${plain}"
|
|
/usr/local/s-ui/sui migrate
|
|
|
|
echo -e "${yellow}Install/update finished! For security it's recommended to modify panel settings ${plain}"
|
|
read -p "Do you want to continue with the modification [y/n]? ": config_confirm
|
|
if [[ "${config_confirm}" == "y" || "${config_confirm}" == "Y" ]]; then
|
|
echo -e "Enter the ${yellow}panel port${plain} (leave blank for existing/default value):"
|
|
read config_port
|
|
echo -e "Enter the ${yellow}panel path${plain} (leave blank for existing/default value):"
|
|
read config_path
|
|
|
|
# Sub configuration
|
|
echo -e "Enter the ${yellow}subscription port${plain} (leave blank for existing/default value):"
|
|
read config_subPort
|
|
echo -e "Enter the ${yellow}subscription path${plain} (leave blank for existing/default value):"
|
|
read config_subPath
|
|
|
|
# Set configs
|
|
echo -e "${yellow}Initializing, please wait...${plain}"
|
|
params=""
|
|
[ -z "$config_port" ] || params="$params -port $config_port"
|
|
[ -z "$config_path" ] || params="$params -path $config_path"
|
|
[ -z "$config_subPort" ] || params="$params -subPort $config_subPort"
|
|
[ -z "$config_subPath" ] || params="$params -subPath $config_subPath"
|
|
/usr/local/s-ui/sui setting ${params}
|
|
|
|
read -p "Do you want to change admin credentials [y/n]? ": admin_confirm
|
|
if [[ "${admin_confirm}" == "y" || "${admin_confirm}" == "Y" ]]; then
|
|
# First admin credentials
|
|
read -p "Please set up your username:" config_account
|
|
read -p "Please set up your password:" config_password
|
|
|
|
# Set credentials
|
|
echo -e "${yellow}Initializing, please wait...${plain}"
|
|
/usr/local/s-ui/sui admin -username ${config_account} -password ${config_password}
|
|
else
|
|
echo -e "${yellow}Your current admin credentials: ${plain}"
|
|
/usr/local/s-ui/sui admin -show
|
|
fi
|
|
else
|
|
echo -e "${red}cancel...${plain}"
|
|
if [[ ! -f "/usr/local/s-ui/db/s-ui.db" ]]; then
|
|
local usernameTemp=$(head -c 6 /dev/urandom | base64)
|
|
local passwordTemp=$(head -c 6 /dev/urandom | base64)
|
|
echo -e "this is a fresh installation,will generate random login info for security concerns:"
|
|
echo -e "###############################################"
|
|
echo -e "${green}username:${usernameTemp}${plain}"
|
|
echo -e "${green}password:${passwordTemp}${plain}"
|
|
echo -e "###############################################"
|
|
echo -e "${red}if you forgot your login info,you can type ${green}s-ui${red} for configuration menu${plain}"
|
|
/usr/local/s-ui/sui admin -username ${usernameTemp} -password ${passwordTemp}
|
|
else
|
|
echo -e "${red} this is your upgrade,will keep old settings,if you forgot your login info,you can type ${green}s-ui${red} for configuration menu${plain}"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
install_s-ui() {
|
|
cd /tmp/
|
|
|
|
if [ $# == 0 ]; then
|
|
last_version=$(curl -Ls "https://api.github.com/repos/alireza0/s-ui/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/')
|
|
if [[ ! -n "$last_version" ]]; then
|
|
echo -e "${red}Failed to fetch s-ui version, it maybe due to Github API restrictions, please try it later${plain}"
|
|
exit 1
|
|
fi
|
|
echo -e "Got s-ui latest version: ${last_version}, beginning the installation..."
|
|
wget -N --no-check-certificate -O /tmp/s-ui-linux-$(arch).tar.gz https://github.com/alireza0/s-ui/releases/download/${last_version}/s-ui-linux-$(arch).tar.gz
|
|
if [[ $? -ne 0 ]]; then
|
|
echo -e "${red}Dowanloading s-ui failed, please be sure that your server can access Github ${plain}"
|
|
exit 1
|
|
fi
|
|
else
|
|
last_version=$1
|
|
url="https://github.com/alireza0/s-ui/releases/download/${last_version}/s-ui-linux-$(arch).tar.gz"
|
|
echo -e "Begining to install s-ui v$1"
|
|
wget -N --no-check-certificate -O /tmp/s-ui-linux-$(arch).tar.gz ${url}
|
|
if [[ $? -ne 0 ]]; then
|
|
echo -e "${red}dowanload s-ui v$1 failed,please check the verison exists${plain}"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
if [[ -e /usr/local/s-ui/ ]]; then
|
|
systemctl stop s-ui
|
|
systemctl stop sing-box
|
|
fi
|
|
|
|
tar zxvf s-ui-linux-$(arch).tar.gz
|
|
rm s-ui-linux-$(arch).tar.gz -f
|
|
|
|
wget --no-check-certificate -O /usr/bin/s-ui https://raw.githubusercontent.com/alireza0/s-ui/main/s-ui.sh
|
|
|
|
chmod +x s-ui/sui s-ui/bin/sing-box s-ui/bin/runSingbox.sh /usr/bin/s-ui
|
|
cp -rf s-ui /usr/local/
|
|
cp -f s-ui/*.service /etc/systemd/system/
|
|
rm -rf s-ui
|
|
|
|
config_after_install
|
|
|
|
systemctl daemon-reload
|
|
systemctl enable s-ui --now
|
|
systemctl enable sing-box --now
|
|
|
|
echo -e "${green}s-ui v${last_version}${plain} installation finished, it is up and running now..."
|
|
echo -e ""
|
|
s-ui help
|
|
}
|
|
|
|
echo -e "${green}Excuting...${plain}"
|
|
install_base
|
|
install_s-ui $1 |