Initial
This commit is contained in:
104
bin/v-list-sys-ips
Executable file
104
bin/v-list-sys-ips
Executable file
@@ -0,0 +1,104 @@
|
||||
#!/bin/bash
|
||||
# info: list system IPs
|
||||
# options: [FORMAT]
|
||||
#
|
||||
# example: v-list-sys-ips
|
||||
#
|
||||
# This function for obtaining the list of system IP addresses.
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# 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/func/ip.sh
|
||||
source $HESTIA/func/ip.sh
|
||||
# load config file
|
||||
source_conf "$HESTIA/conf/hestia.conf"
|
||||
|
||||
# JSON list function
|
||||
json_list() {
|
||||
echo '{'
|
||||
ip_count="$(ls $HESTIA/data/ips/ | wc -l)"
|
||||
i=1
|
||||
while read IP; do
|
||||
source_conf "$HESTIA/data/ips/$IP"
|
||||
echo -n ' "'$IP'": {
|
||||
"OWNER": "'$OWNER'",
|
||||
"STATUS": "'$STATUS'",
|
||||
"NAME": "'$NAME'",
|
||||
"U_SYS_USERS": "'$U_SYS_USERS'",
|
||||
"U_WEB_DOMAINS": "'$U_WEB_DOMAINS'",
|
||||
"INTERFACE": "'$INTERFACE'",
|
||||
"NETMASK": "'$NETMASK'",
|
||||
"NAT": "'$NAT'",
|
||||
"TIME": "'$TIME'",
|
||||
"DATE": "'$DATE'"
|
||||
}'
|
||||
if [ "$i" -lt "$ip_count" ]; then
|
||||
echo ','
|
||||
else
|
||||
echo
|
||||
fi
|
||||
((i++))
|
||||
done < <(ls $HESTIA/data/ips/)
|
||||
echo '}'
|
||||
}
|
||||
|
||||
# SHELL list function
|
||||
shell_list() {
|
||||
echo "IP MASK NAT STATUS WEB DATE"
|
||||
echo "-- ---- --- ------ --- ----"
|
||||
while read IP; do
|
||||
source_conf "$HESTIA/data/ips/$IP"
|
||||
if [ -z "$NAT" ]; then
|
||||
NAT='no'
|
||||
fi
|
||||
echo "$IP $NETMASK $NAT $STATUS $U_WEB_DOMAINS $DATE"
|
||||
done < <(ls $HESTIA/data/ips/)
|
||||
}
|
||||
|
||||
# PLAIN list function
|
||||
plain_list() {
|
||||
while read IP; do
|
||||
source_conf "$HESTIA/data/ips/$IP"
|
||||
echo -ne "$IP\t$OWNER\t$STATUS\t$NAME\t$U_SYS_USERS\t$U_WEB_DOMAINS\t"
|
||||
echo -e "$INTERFACE\t$NETMASK\t$NAT\t$TIME\t$DATE"
|
||||
done < <(ls $HESTIA/data/ips/)
|
||||
}
|
||||
|
||||
# CSV list function
|
||||
csv_list() {
|
||||
echo -n "IP,OWNER,STATUS,NAME,U_SYS_USERS,U_WEB_DOMAINS,INTERFACE"
|
||||
echo "NETMASK,NAT,TIME,DATE"
|
||||
while read IP; do
|
||||
source_conf "$HESTIA/data/ips/$IP"
|
||||
echo -n "$IP,$OWNER,$STATUS,$NAME,\"$U_SYS_USERS\",$U_WEB_DOMAINS,"
|
||||
echo "$INTERFACE, $NETMASK,$NAT,$TIME,$DATE"
|
||||
done < <(ls $HESTIA/data/ips/)
|
||||
}
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# Action #
|
||||
#----------------------------------------------------------#
|
||||
|
||||
# Listing data
|
||||
case $format in
|
||||
json) json_list ;;
|
||||
plain) plain_list ;;
|
||||
csv) csv_list ;;
|
||||
shell) shell_list | column -t ;;
|
||||
esac
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# Hestia #
|
||||
#----------------------------------------------------------#
|
||||
|
||||
exit
|
||||
Reference in New Issue
Block a user