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.
		
		
		
		
		
			
		
			
				
					
					
						
							95 lines
						
					
					
						
							2.2 KiB
						
					
					
				
			
		
		
	
	
							95 lines
						
					
					
						
							2.2 KiB
						
					
					
				| #!/bin/bash
 | |
| # info: list firewall block list
 | |
| # options: [FORMAT]
 | |
| #
 | |
| # example: v-list-firewall-ban json
 | |
| #
 | |
| # This function of obtaining the list of currently blocked ips.
 | |
| 
 | |
| #----------------------------------------------------------#
 | |
| #                Variables & Functions                     #
 | |
| #----------------------------------------------------------#
 | |
| 
 | |
| # Argument definition
 | |
| format=${1-shell}
 | |
| 
 | |
| # Includes
 | |
| # shellcheck source=/etc/hestiacp/hestia.conf
 | |
| source /etc/hestiacp/hestia.conf
 | |
| # shellcheck source=/usr/local/hestia/func/main.sh
 | |
| source $HESTIA/func/main.sh
 | |
| # load config file
 | |
| source_conf "$HESTIA/conf/hestia.conf"
 | |
| 
 | |
| # JSON list function
 | |
| json_list() {
 | |
| 	IFS=$'\n'
 | |
| 	i=1
 | |
| 	objects=$(grep IP $HESTIA/data/firewall/banlist.conf | wc -l)
 | |
| 	echo "{"
 | |
| 	while read str; do
 | |
| 		parse_object_kv_list "$str"
 | |
| 		echo -n '    "'$IP'": {
 | |
|         "IP": "'$IP'",
 | |
|         "CHAIN": "'$CHAIN'",
 | |
|         "TIME": "'$TIME'",
 | |
|         "DATE": "'$DATE'"
 | |
|     }'
 | |
| 		if [ "$i" -lt "$objects" ]; then
 | |
| 			echo ','
 | |
| 		else
 | |
| 			echo
 | |
| 		fi
 | |
| 		((i++))
 | |
| 	done < <(cat $HESTIA/data/firewall/banlist.conf)
 | |
| 	echo '}'
 | |
| }
 | |
| 
 | |
| # SHELL list function
 | |
| shell_list() {
 | |
| 	IFS=$'\n'
 | |
| 	echo "IP   CHAIN   TIME   DATE"
 | |
| 	echo "--   -----   ----   ----"
 | |
| 	while read str; do
 | |
| 		parse_object_kv_list "$str"
 | |
| 		echo "$IP $CHAIN $TIME $DATE"
 | |
| 	done < <(cat $HESTIA/data/firewall/banlist.conf)
 | |
| }
 | |
| 
 | |
| # PLAIN list function
 | |
| plain_list() {
 | |
| 	IFS=$'\n'
 | |
| 	while read str; do
 | |
| 		parse_object_kv_list "$str"
 | |
| 		echo -e "$IP\t$CHAIN\t$TIME\t$DATE"
 | |
| 	done < <(cat $HESTIA/data/firewall/banlist.conf)
 | |
| }
 | |
| 
 | |
| # CSV list function
 | |
| csv_list() {
 | |
| 	IFS=$'\n'
 | |
| 	echo "IP,CHAIN,TIME,DATE"
 | |
| 	while read str; do
 | |
| 		parse_object_kv_list "$str"
 | |
| 		echo "$IP,$CHAIN,$TIME,$DATE"
 | |
| 	done < <(cat $HESTIA/data/firewall/banlist.conf)
 | |
| }
 | |
| 
 | |
| #----------------------------------------------------------#
 | |
| #                       Action                             #
 | |
| #----------------------------------------------------------#
 | |
| 
 | |
| # Listing data
 | |
| case $format in
 | |
| 	json) json_list ;;
 | |
| 	plain) plain_list ;;
 | |
| 	csv) csv_list ;;
 | |
| 	shell) shell_list | column -t ;;
 | |
| esac
 | |
| 
 | |
| #----------------------------------------------------------#
 | |
| #                       Hestia                             #
 | |
| #----------------------------------------------------------#
 | |
| 
 | |
| exit
 |