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.
109 lines
3.0 KiB
109 lines
3.0 KiB
#!/bin/bash
|
|
# info: List firewall ipset
|
|
# options: [FORMAT]
|
|
#
|
|
# example: v-list-firewall-ipset json
|
|
#
|
|
# This function prints defined ipset lists
|
|
|
|
#----------------------------------------------------------#
|
|
# 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
|
|
# shellcheck source=/usr/local/hestia/conf/hestia.conf
|
|
source $HESTIA/conf/hestia.conf
|
|
# load config file
|
|
source_conf "$HESTIA/conf/hestia.conf"
|
|
|
|
#----------------------------------------------------------#
|
|
# Verifications #
|
|
#----------------------------------------------------------#
|
|
|
|
is_system_enabled "$FIREWALL_SYSTEM" 'FIREWALL_SYSTEM'
|
|
|
|
#----------------------------------------------------------#
|
|
# Action #
|
|
#----------------------------------------------------------#
|
|
|
|
# JSON list function
|
|
json_list() {
|
|
IFS=$'\n'
|
|
i=1
|
|
objects=$(grep LISTNAME $HESTIA/data/firewall/ipset.conf | wc -l)
|
|
echo "{"
|
|
while read str; do
|
|
[[ -z "$str" ]] && continue
|
|
parse_object_kv_list "$str"
|
|
echo -n ' "'$LISTNAME'": {
|
|
"IP_VERSION": "'$IP_VERSION'",
|
|
"AUTOUPDATE": "'$AUTOUPDATE'",
|
|
"SUSPENDED": "'$SUSPENDED'",
|
|
"SOURCE": "'$SOURCE'",
|
|
"TIME": "'$TIME'",
|
|
"DATE": "'$DATE'"
|
|
}'
|
|
[[ "$i" -lt "$objects" ]] && echo ',' || echo
|
|
((i++))
|
|
done < <(cat $HESTIA/data/firewall/ipset.conf)
|
|
echo '}'
|
|
}
|
|
|
|
# SHELL list function
|
|
shell_list() {
|
|
IFS=$'\n'
|
|
echo "LISTNAME^IP_VERSION^AUTOUPDATE^SUSPENDED^SOURCE^TIME^DATE"
|
|
echo "----^------^-----^----^--^----^----"
|
|
while read str; do
|
|
[[ -z "$str" ]] && continue
|
|
parse_object_kv_list "$str"
|
|
echo "$LISTNAME^$IP_VERSION^$AUTOUPDATE^$SUSPENDED^$SOURCE^$TIME^$DATE"
|
|
done < <(cat $HESTIA/data/firewall/ipset.conf)
|
|
}
|
|
|
|
# PLAIN list function
|
|
plain_list() {
|
|
IFS=$'\n'
|
|
while read str; do
|
|
[[ -z "$str" ]] && continue
|
|
parse_object_kv_list "$str"
|
|
echo -ne "$LISTNAME\t$IP_VERSION\t$AUTOUPDATE\t$SUSPENDED\t$SOURCE\t"
|
|
echo -e "$TIME\t$DATE"
|
|
done < <(cat $HESTIA/data/firewall/ipset.conf)
|
|
}
|
|
|
|
# CSV list function
|
|
csv_list() {
|
|
IFS=$'\n'
|
|
echo "LISTNAME,IP_VERSION,AUTOUPDATE,SUSPENDED,SOURCE,SUSPENDED,TIME,DATE"
|
|
while read str; do
|
|
[[ -z "$str" ]] && continue
|
|
parse_object_kv_list "$str"
|
|
echo -n "$LISTNAME,$IP_VERSION,$AUTOUPDATE,$SUSPENDED,\"$SOURCE\","
|
|
echo "$TIME,$DATE"
|
|
done < <(cat $HESTIA/data/firewall/ipset.conf)
|
|
}
|
|
|
|
[ ! -f "$HESTIA/data/firewall/ipset.conf" ] && touch "$HESTIA/data/firewall/ipset.conf"
|
|
|
|
# Listing data
|
|
case $format in
|
|
json) json_list ;;
|
|
plain) plain_list ;;
|
|
csv) csv_list ;;
|
|
shell) shell_list | column -t -s '^' ;;
|
|
esac
|
|
|
|
#----------------------------------------------------------#
|
|
# Hestia #
|
|
#----------------------------------------------------------#
|
|
|
|
exit
|