You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							75 lines
						
					
					
						
							2.1 KiB
						
					
					
				
			
		
		
	
	
							75 lines
						
					
					
						
							2.1 KiB
						
					
					
				| #!/bin/bash
 | |
| 
 | |
| # Includes
 | |
| # shellcheck source=/etc/hestiacp/hestia.conf
 | |
| source /etc/hestiacp/hestia.conf
 | |
| # load config file
 | |
| source_conf "$HESTIA/conf/hestia.conf"
 | |
| 
 | |
| # Variables and arguments
 | |
| HESTIA="/usr/local/hestia"
 | |
| script=$1
 | |
| log=$2
 | |
| mode=${3-$2}
 | |
| 
 | |
| if [ "$DEBUG_MODE" = "no" ] || [ -z "$DEBUG_MODE" ]; then
 | |
| 	echo "ERROR: Developer mode is disabled."
 | |
| 	echo "Enable with v-change-sys-config-value DEBUG_MODE yes"
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| if [ -z "$script" ]; then
 | |
| 	echo "ERROR: No script specified."
 | |
| 	echo "Usage:    v-generate-debug-report v-script-name LOG_OUTPUT"
 | |
| 	echo ""
 | |
| 	echo "Example:  v-generate-debug-report v-add-user yes"
 | |
| 	echo "          Log output to file located in ~/hst-debug/"
 | |
| 	echo ""
 | |
| 	echo "Example:  v-generate-debug-report v-list-web-domains"
 | |
| 	echo "          Show output in console."
 | |
| 	echo ""
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| # Install shellcheck
 | |
| package_check=$(dpkg -l | grep shellcheck)
 | |
| if [ -z "$package_check" ]; then
 | |
| 	echo "[ * ] Updating APT package cache..."
 | |
| 	apt-get -qq update > /dev/null 2>&1
 | |
| 	echo "[ * ] Installing shellcheck code linter..."
 | |
| 	apt-get -qq install -y shellcheck > /dev/null 2>&1
 | |
| fi
 | |
| 
 | |
| # Set debug path and ensure it exists
 | |
| DEBUG_PATH="$HOME/hst-debug/"
 | |
| if [ ! -d "$DEBUG_PATH" ]; then
 | |
| 	mkdir "$DEBUG_PATH"
 | |
| fi
 | |
| 
 | |
| # Generate timestamp
 | |
| time_n_date=$(date +'%F %T')
 | |
| time_n_date=$(echo "$time_n_date" | sed "s|:||g" | sed "s| |_|g")
 | |
| 
 | |
| # If logging specified, export shellcheck output to log
 | |
| if [ "$log" = "yes" ]; then
 | |
| 	if [ "$mode" = "all" ]; then
 | |
| 		shellcheck -x "$BIN/$script" > "$DEBUG_PATH/${script}_$time_n_date.log"
 | |
| 	fi
 | |
| 	if [ "$mode" = "warn" ]; then
 | |
| 		shellcheck -x -e "SC2086,SC1090,SC2154,SC2153" "$BIN/$script" > "$DEBUG_PATH/${script}_$time_n_date.log"
 | |
| 	else
 | |
| 		shellcheck -x -e "SC2086,SC2016,SC2153,SC2154,SC1090,SC2034,SC2119" "$BIN/$script" > "$DEBUG_PATH/${script}_$time_n_date.log"
 | |
| 	fi
 | |
| else
 | |
| 	# Prompt user to scroll output from shellcheck
 | |
| 	clear
 | |
| 	if [ "$mode" = "all" ]; then
 | |
| 		shellcheck -x "$BIN/$script"
 | |
| 	fi
 | |
| 	if [ "$mode" = "warn" ]; then
 | |
| 		shellcheck -x -e "SC2086,SC1090,SC2154,SC2153" "$BIN/$script"
 | |
| 	else
 | |
| 		shellcheck -x -e "SC2086,SC2016,SC2153,SC2154,SC1090,SC2034,SC2119" "$BIN/$script"
 | |
| 	fi
 | |
| fi
 |