#!/bin/bash main() { dir=$(pwd) altSrvrName="nanoweb" srvrName="Nanoweb" ansr=$(zenity --text "Please chose an option." --radiolist --list \ --column "Options" --column "Descriptions" \ TRUE "Scan Dirs?" \ FALSE "Edit main settings" \ FALSE "Start or Stop ${srvrName}") case "$ansr" in "Scan Dirs?" ) dirScan;; "Edit main settings" ) passwdReq;; "Start or Stop ${srvrName}" ) webSrvrStrt;; esac } dirScan() { find . -type d > /tmp/lzyDirList.txt filename="/tmp/lzyDirList.txt" while read -r line ; do pre=\""${line}" name=`echo ${pre} | sed "s|\".|"${dir}"|g" | sed "s|*|*\"|g"` if [[ "${name}" == *"resources"* ]] || \ [[ "${name}" == *"Uploads"* ]]; then echo "This is a resources dir..." else if [ -f "${name}"/index.php ]; then echo "Index.php for "${name}" already present..." else work fi fi done < "${filename}" } work() { mv lazyShareScan.sh "${name}/" cd "${name}/" bash ./lazyShareScan.sh mv lazyShareScan.sh "${dir}" cd "${dir}" } ################## SETTINGS SECTION ################## passwdReq() { PASSWD="$(zenity --password --title=Authentication)\n" srvrEdit; } srvrEdit() { auto="Turn psudo auto scan ON or Off" theme="Change Theme" portng="Set Port" polcing="Set User And Group" logng="Set Logging Status" docdir="Set DocumentRoot" nanoSrvr="Open The ServerConf In Nano" main="START MENU" exit="Exit Script" selec=$(zenity --list \ --text "What would you like to edit in the ServerConf file?" \ --radiolist --column "Select" --column "Options" \ TRUE "Change Theme" \ FALSE "Set Port" \ FALSE "Set User And Group" \ FALSE "Set Logging Status" \ FALSE "Set DocumentRoot" \ FALSE "Open The ServerConf In Nano" \ FALSE "START MENU" FALSE "Exit Script" \ --height 300); case "$selec" in "${theme}" ) theme;; "${portng}" ) port;; "${polcing}" ) policy;; "${logng}" ) logs;; "${docdir}" ) docRoot;; "${nanoSrvr}" ) nanoSrvrConf;; "${main}" ) main;; "${exit}" ) exit;; esac } autoOnNOff() { x=$(zenity --entry --text "Turn On/Off psudo auto scanning? Default is : off . " --entry-text "off"); sed -i 1s/"auto=*.*;"/"auto=${x};"/g $HOME/.config/lazyShareSettings/config.txt srvrEdit; } theme() { theme=$(zenity --list \ --text "What would you like to edit in the ServerConf file?" \ --radiolist --column "Select" --column "Options" \ TRUE "List On The Left" \ FALSE "List Centered" \ FALSE "Horizontal List" \ FALSE "Grid List" \ --height 175); case "${theme}" in "List On The Left" ) echo "" > ./resources/settings-notes/css.css cat ./resources/themes/"List On The Left.css" > ./resources/settings-notes/css.css;; "List Centered" ) echo "" > ./resources/settings-notes/css.css cat ./resources/themes/"List Centered.css" > ./resources/settings-notes/css.css;; "Horizontal List" ) echo "" > ./resources/settings-notes/css.css cat ./resources/themes/"Horizontal List.css" > ./resources/settings-notes/css.css;; "Grid List" ) echo "" > ./resources/settings-notes/css.css cat ./resources/themes/"Grid List.css" > ./resources/settings-notes/css.css;; esac srvrEdit } port() { x=$(zenity --entry --text "What will be the port that the server runs on? Anything bellow 1024 means the server must run as root. Default is port: 80 . " --entry-text "80"); echo -e $PASSWD | sudo -S sed -i 13s/"ListenPort = *.*"/"ListenPort = ${x}"/g /etc/nanoweb/nanoweb.conf srvrEdit; } policy() { User=$(zenity --entry --text "What will be the User for the server? (::-WARNING-::) Please leave as default unless you know EXACTLY what you are doing! Changing user and group policies can affect security of the system! The default is : www-data ." --entry-text "www-data"); echo -e $PASSWD | sudo -S sed -i 187s/"User = *.*"/"User = ${User}"/g /etc/nanoweb/nanoweb.conf Group=$(zenity --entry --text "What will be the Group for the server? (::-WARNING-::) Please leave as default unless you know EXACTLY what you are doing! Changing user and group policies can affect security of the system! The default is : www-data." --entry-text "www-data"); echo -e $PASSWD | sudo -S sed -i 188s/"Group = *.*"/"Group = ${Group}"/g /etc/nanoweb/nanoweb.conf srvrEdit; } logs() { logs=$(zenity --list --text "Do you wish to have AccessLog and ErrorLog enabled? If this server isn't running 24/7 nor a production server then it can be OK to keep logging off. It may also lessen the system resource load and speed up the server. If this server runs 24/7 or is a production server then we advise keeping logging on as added security. Respectively, it may add more resource demands and slow down the server. Frankly, the effects are negligible in both instances so it's up to you. The default is : Enabled . " --radiolist --column "Select" --column "Options" TRUE Enable FALSE Disable --height 280); yes="Enable" no="Disable" if [[ "${logs}" == "${yes}" ]]; then echo -e $PASSWD | sudo -S sed -i 194s/"#LoggerProcess = *.*"/"LoggerProcess = 2"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 197s/"#LoggerUser"/"LoggerUser"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 198s/"#LoggerGroup"/"LoggerGroup"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 201s/"#LogDir"/"LogDir"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 207s/"#Log"/"Log"/g /etc/nanoweb/nanoweb.conf elif [[ "${logs}" == "${no}" ]]; then echo -e $PASSWD | sudo -S sed -i 194s/"LoggerProcess = *.*"/"#LoggerProcess = 0"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 197s/"LoggerUser"/"#LoggerUser"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 198s/"LoggerGroup"/"#LoggerGroup"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 201s/"LogDir"/"#LogDir"/g /etc/nanoweb/nanoweb.conf echo -e $PASSWD | sudo -S sed -i 207s/"Log"/"#Log"/g /etc/nanoweb/nanoweb.conf fi srvrEdit; } nanoSrvrConf() { echo -e $PASSWD | sudo -S xterm -e nano /etc/nanoweb/nanoweb.conf srvrEdit; } docRoot() { docDir=$(zenity --entry \ --text "What do you wish to set as DocumentRoot? Document root is what the server defines as the directory in which files will be served from. Group permissions must allow for the directory to be used so please be aware of that. The default is : /var/www/nanoweb ." --entry-text "/var/www/nanoweb"); echo -e $PASSWD | sudo -S sed -i 204s,"DocumentRoot = *.*","DocumentRoot = ${docDir}",g /etc/nanoweb/nanoweb.conf srvrEdit; } webSrvrStrt() { noRtStrt="Start $srvrName No Root?" ; noRtStp="Stop $srvrName No Root?" ; rtStrt="Start $srvrName Root?" ; rtStp="Stop $srvrName Root?"; main="START MENU" ; exit="Exit Script" ; ansr=$(zenity --list --text "Please select an option bellow to apply!! " --radiolist --column "Select" --column "Options " TRUE "Start $srvrName No Root?" FALSE "Stop $srvrName No Root? " FALSE "Start $srvrName Root?" FALSE "Stop $srvrName Root? " FALSE "START MENU" FALSE "Exit Script" --height 330); case "${ansr}" in "${noRtStrt}" ) $altSrvrName & main;; "${noRtStp}" ) pkill $altSrvrName & main;; "${rtStrt}" ) PASSWD="$(zenity --password --title=Authentication)\n" echo -e $PASSWD | sudo -S $altSrvrName & main;; "${rtStp}" ) PASSWD="$(zenity --password --title=Authentication)\n" echo -e $PASSWD | sudo -S pkill $altSrvrName & main;; "${main}" ) main;; "${exit}" ) exit;; esac } main