2020-10-07 22:45:39 +00:00
|
|
|
# GRAVITY SYNC BY VMSTAN #####################
|
|
|
|
# gs-install.sh ##############################
|
|
|
|
|
|
|
|
# For documentation or downloading updates visit https://github.com/vmstan/gravity-sync
|
|
|
|
# This code will be called from a curl call via installation instructions
|
|
|
|
|
|
|
|
# Run this script on your primary Pi-hole to aid in preparing for Gravity Sync installation.
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# Script Colors
|
|
|
|
RED='\033[0;91m'
|
|
|
|
GREEN='\033[0;92m'
|
|
|
|
CYAN='\033[0;96m'
|
|
|
|
YELLOW='\033[0;93m'
|
|
|
|
PURPLE='\033[0;95m'
|
|
|
|
BLUE='\033[0;94m'
|
|
|
|
BOLD='\033[1m'
|
|
|
|
NC='\033[0m'
|
|
|
|
|
|
|
|
# Variables
|
|
|
|
CROSSCOUNT="0"
|
2020-10-19 18:48:23 +00:00
|
|
|
PHFAILCOUNT="0"
|
2020-10-07 22:45:39 +00:00
|
|
|
CURRENTUSER=$(whoami)
|
|
|
|
|
|
|
|
# Header
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "========================================================"
|
|
|
|
echo -e "${YELLOW}Gravity Sync by ${BLUE}@vmstan${YELLOW} - Online Installation${NC}"
|
|
|
|
echo -e "${CYAN}https://github.com/vmstan/gravity-sync${NC}"
|
|
|
|
echo -e "========================================================"
|
2021-01-12 16:38:40 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] Checking Short Range Sensors"
|
2020-10-07 22:45:39 +00:00
|
|
|
|
|
|
|
# Check Root
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Validating System Authorization${NC}"
|
2020-10-07 22:45:39 +00:00
|
|
|
if [ ! "$EUID" -ne 0 ]
|
2020-12-31 02:49:54 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] Current User (${CURRENTUSER}) is ROOT"
|
|
|
|
LOCALADMIN="root"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
if hash sudo 2>/dev/null
|
|
|
|
then
|
|
|
|
echo -e "[${GREEN}✓${NC}] Sudo Utility Detected"
|
|
|
|
# Check Sudo
|
|
|
|
sudo --validate
|
|
|
|
if [ "$?" != "0" ]
|
|
|
|
then
|
|
|
|
echo -e "[${RED}✗${NC}] Current User (${CURRENTUSER}) Cannot SUDO"
|
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
LOCALADMIN="nosudo"
|
|
|
|
else
|
|
|
|
echo -e "[${GREEN}✓${NC}] Current User (${CURRENTUSER}) Has SUDO Powers"
|
|
|
|
LOCALADMIN="sudo"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo -e "[${RED}✗${NC}] Sudo Utility Not Detected"
|
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
LOCALADMIN="nosudo"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$LOCALADMIN" != "sudo" ]
|
|
|
|
then
|
|
|
|
echo -e "[${RED}✗${NC}] Current User (${CURRENTUSER}) Cannot SUDO"
|
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
LOCALADMIN="nosudo"
|
|
|
|
fi
|
2020-10-07 22:45:39 +00:00
|
|
|
fi
|
|
|
|
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Scanning for Required Components${NC}"
|
|
|
|
# Check OpenSSH
|
|
|
|
if hash ssh 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] OpenSSH Binaries Detected"
|
|
|
|
else
|
|
|
|
echo -e "[${RED}✗${NC}] OpenSSH Binaries Not Installed"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
2020-10-19 18:48:23 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check Rsync
|
|
|
|
if hash rsync 2>/dev/null
|
|
|
|
then
|
|
|
|
echo -e "[${GREEN}✓${NC}] RSYNC Binaries Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${RED}✗${NC}] RSYNC Binaries Not Installed"
|
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
2020-10-07 22:45:39 +00:00
|
|
|
fi
|
|
|
|
|
2020-10-19 18:48:23 +00:00
|
|
|
# Check Sudo
|
|
|
|
if hash sudo 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] SUDO Binaries Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${RED}✗${NC}] SUDO Binaries Not Installed"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
2020-10-19 18:48:23 +00:00
|
|
|
# Check Crontab
|
|
|
|
if hash crontab 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] CRONTAB Binaries Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${RED}✗${NC}] CRONTAB Binaries Not Installed"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Check SQLITE3
|
2020-10-16 03:31:09 +00:00
|
|
|
if hash sqlite3 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] SQLITE3 Binaries Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${RED}✗${NC}] SQLITE3 Binaries Not Installed"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Check GIT
|
2020-10-16 03:31:09 +00:00
|
|
|
if hash git 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] GIT Binaries Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${RED}✗${NC}] GIT Binaries Not Installed"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Performing Warp Core Diagnostics${NC}"
|
2020-10-07 22:45:39 +00:00
|
|
|
# Check Pihole
|
2020-10-16 03:33:01 +00:00
|
|
|
if hash pihole 2>/dev/null
|
2020-10-07 22:45:39 +00:00
|
|
|
then
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${GREEN}✓${NC}] Local Pi-hole Install Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}No Local Pi-hole Install Detected${NC}"
|
|
|
|
# echo -e "[${PURPLE}!${NC}] ${PURPLE}Attempting To Compensate${NC}"
|
|
|
|
if hash docker 2>/dev/null
|
|
|
|
then
|
|
|
|
echo -e "[${GREEN}✓${NC}] Docker Binaries Detected"
|
|
|
|
|
|
|
|
if [ "$LOCALADMIN" == "sudo" ]
|
|
|
|
then
|
|
|
|
FTLCHECK=$(sudo docker container ls | grep 'pihole/pihole')
|
|
|
|
elif [ "$LOCALADMIN" == "nosudo" ]
|
|
|
|
then
|
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}No Docker Pi-hole Container Detected (unable to scan)${NC}"
|
|
|
|
# CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
PHFAILCOUNT=$((PHFAILCOUNT+1))
|
|
|
|
else
|
|
|
|
FTLCHECK=$(docker container ls | grep 'pihole/pihole')
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$LOCALADMIN" != "nosudo" ]
|
|
|
|
then
|
|
|
|
if [ "$FTLCHECK" != "" ]
|
|
|
|
then
|
|
|
|
echo -e "[${GREEN}✓${NC}] Pi-Hole Docker Container Detected"
|
|
|
|
else
|
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}No Docker Pi-hole Container Detected${NC}"
|
|
|
|
# CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
PHFAILCOUNT=$((PHFAILCOUNT+1))
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# echo -e "[${RED}✗${NC}] No Local Pi-hole Install Detected"
|
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}No Docker Pi-hole Alternative Detected${NC}"
|
|
|
|
# CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
PHFAILCOUNT=$((PHFAILCOUNT+1))
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$PHFAILCOUNT" != "0" ]
|
|
|
|
then
|
|
|
|
echo -e "[${RED}✗${NC}] No Usable Pi-hole Install Detected"
|
2020-10-07 22:45:39 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
2020-10-20 02:41:17 +00:00
|
|
|
# echo -e "[${YELLOW}i${NC}] ${YELLOW}Target Folder Analysis${NC}"
|
2020-10-20 02:29:24 +00:00
|
|
|
if [ "$GS_INSTALL" == "secondary" ]
|
|
|
|
then
|
|
|
|
if [ "$LOCALADMIN" == "sudo" ]
|
|
|
|
then
|
|
|
|
THISDIR=$(pwd)
|
|
|
|
if [ "$THISDIR" != "$HOME" ]
|
|
|
|
then
|
|
|
|
echo -e "[${RED}✗${NC}] ${CURRENTUSER} Must Install to $HOME"
|
2020-10-20 02:41:17 +00:00
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}Use 'root' Account to Install in $THISDIR${NC}"
|
2020-10-20 02:29:24 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
2020-10-20 02:31:09 +00:00
|
|
|
fi
|
2020-10-20 02:29:24 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-10-20 02:45:16 +00:00
|
|
|
if [ -d gravity-sync ]
|
2020-10-20 02:41:17 +00:00
|
|
|
then
|
|
|
|
echo -e "[${RED}✗${NC}] Folder gravity-sync Already Exists"
|
2020-10-21 14:37:23 +00:00
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}Use './gravity-sync.sh update' to Update Instead${NC}"
|
2020-10-20 02:41:17 +00:00
|
|
|
CROSSCOUNT=$((CROSSCOUNT+1))
|
|
|
|
fi
|
|
|
|
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Status Report${NC}"
|
2020-10-07 22:45:39 +00:00
|
|
|
# Combine Outputs
|
|
|
|
if [ "$CROSSCOUNT" != "0" ]
|
|
|
|
then
|
2020-10-19 22:28:50 +00:00
|
|
|
echo -e "[${RED}*${NC}] ${RED}${CROSSCOUNT} Critical Issue(s) Detected${NC}"
|
|
|
|
echo -e "[${PURPLE}!${NC}] ${PURPLE}Please Correct Failures and Re-Execute${NC}"
|
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Installation Exiting (without changes)${NC}"
|
2020-10-07 22:45:39 +00:00
|
|
|
else
|
2020-10-19 18:48:23 +00:00
|
|
|
echo -e "[${YELLOW}i${NC}] ${YELLOW}Executing Gravity Sync Deployment${NC}"
|
|
|
|
|
|
|
|
if [ "$LOCALADMIN" == "sudo" ]
|
|
|
|
then
|
|
|
|
echo -e "[${BLUE}>${NC}] Creating Sudoers.d File"
|
|
|
|
touch /tmp/gs-nopasswd.sudo
|
|
|
|
echo -e "${CURRENTUSER} ALL=(ALL) NOPASSWD: ALL" > /tmp/gs-nopasswd.sudo
|
|
|
|
sudo install -m 0440 /tmp/gs-nopasswd.sudo /etc/sudoers.d/gs-nopasswd
|
|
|
|
fi
|
2020-12-31 02:49:54 +00:00
|
|
|
|
|
|
|
if [ "$GS_INSTALL" != "secondary" ]
|
|
|
|
then
|
|
|
|
echo -e "[${YELLOW}i${NC}] Gravity Sync Preperation Complete"
|
|
|
|
echo -e "[${YELLOW}i${NC}] Execute on Installer on Secondary"
|
|
|
|
echo -e "[${YELLOW}i${NC}] Check Documentation for Instructions"
|
|
|
|
echo -e "[${YELLOW}i${NC}] Installation Exiting (without changes)"
|
|
|
|
else
|
|
|
|
echo -e "[${BLUE}>${NC}] Creating Gravity Sync Directories"
|
|
|
|
git clone https://github.com/vmstan/gravity-sync.git
|
|
|
|
echo -e "[${BLUE}>${NC}] Starting Gravity Sync Configuration"
|
|
|
|
echo -e "========================================================"
|
|
|
|
./gravity-sync/gravity-sync.sh configure <&1
|
|
|
|
# echo -e "[${YELLOW}i${NC}] This host is now prepared to configure Gravity Sync!"
|
|
|
|
# echo -e "[${YELLOW}i${NC}] Please run './gravity-sync configure' from $HOME/gravity-sync"
|
|
|
|
# echo -e "[${YELLOW}i${NC}] Visit https://github.com/vmstan/gravity-sync for more instructions."
|
|
|
|
fi
|
|
|
|
|
2020-10-07 22:45:39 +00:00
|
|
|
fi
|
|
|
|
|
2020-10-20 02:31:09 +00:00
|
|
|
exit
|