|
@@ -17,6 +17,55 @@ format=${2-shell}
|
|
|
source $VESTA/conf/vesta.conf
|
|
source $VESTA/conf/vesta.conf
|
|
|
source $VESTA/func/main.sh
|
|
source $VESTA/func/main.sh
|
|
|
|
|
|
|
|
|
|
+# Json list function
|
|
|
|
|
+json_list_search() {
|
|
|
|
|
+ echo '{'
|
|
|
|
|
+ fileds_count=$(echo $fields| wc -w )
|
|
|
|
|
+ while read line; do
|
|
|
|
|
+ eval $line
|
|
|
|
|
+ if [ -n "$list_data" ]; then
|
|
|
|
|
+ echo -e ' },'
|
|
|
|
|
+ fi
|
|
|
|
|
+ i=1
|
|
|
|
|
+ IFS=' '
|
|
|
|
|
+ for field in $fields; do
|
|
|
|
|
+ eval value=\"$field\"
|
|
|
|
|
+ value=$(echo "$value"|sed -e 's/"/\\"/g' -e "s/%quote%/'/g")
|
|
|
|
|
+ if [ $i -eq 1 ]; then
|
|
|
|
|
+ (( ++i))
|
|
|
|
|
+ echo -e "\t\"$value\": {"
|
|
|
|
|
+ else
|
|
|
|
|
+ if [ $i -lt $fileds_count ]; then
|
|
|
|
|
+ (( ++i))
|
|
|
|
|
+ echo -e "\t\t\"${field//$/}\": \"${value//,/, }\","
|
|
|
|
|
+ else
|
|
|
|
|
+ echo -e "\t\t\"${field//$/}\": \"${value//,/, }\""
|
|
|
|
|
+ list_data=1
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
|
|
+ done
|
|
|
|
|
+ done < $conf
|
|
|
|
|
+ if [ -n "$list_data" ]; then
|
|
|
|
|
+ echo -e ' }'
|
|
|
|
|
+ fi
|
|
|
|
|
+ echo -e '}'
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+# Shell list function
|
|
|
|
|
+shell_list_search() {
|
|
|
|
|
+ if [ -z "$nohead" ] ; then
|
|
|
|
|
+ echo "${fields//$/}"
|
|
|
|
|
+ for a in $fields; do
|
|
|
|
|
+ echo -e "------ \c"
|
|
|
|
|
+ done
|
|
|
|
|
+ echo
|
|
|
|
|
+ fi
|
|
|
|
|
+ while read line ; do
|
|
|
|
|
+ eval $line
|
|
|
|
|
+ eval echo "$fields" | sed -e "s/%quote%/'/g"
|
|
|
|
|
+ done < $conf
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
#----------------------------------------------------------#
|
|
#----------------------------------------------------------#
|
|
|
# Verifications #
|
|
# Verifications #
|
|
|
#----------------------------------------------------------#
|
|
#----------------------------------------------------------#
|
|
@@ -40,8 +89,11 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
search=$(grep "$object" \
|
|
search=$(grep "$object" \
|
|
|
$VESTA/data/users/$user/web.conf \
|
|
$VESTA/data/users/$user/web.conf \
|
|
|
$VESTA/data/users/$user/dns.conf \
|
|
$VESTA/data/users/$user/dns.conf \
|
|
|
|
|
+ $VESTA/data/users/$user/dns/*.conf \
|
|
|
$VESTA/data/users/$user/mail.conf \
|
|
$VESTA/data/users/$user/mail.conf \
|
|
|
- $VESTA/data/users/$user/db.conf)
|
|
|
|
|
|
|
+ $VESTA/data/users/$user/mail/*.conf \
|
|
|
|
|
+ $VESTA/data/users/$user/db.conf \
|
|
|
|
|
+ $VESTA/data/users/$user/cron.conf 2> /dev/null)
|
|
|
|
|
|
|
|
for row in $search; do
|
|
for row in $search; do
|
|
|
# Initialise variable
|
|
# Initialise variable
|
|
@@ -49,22 +101,23 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
result=''
|
|
result=''
|
|
|
dom_alias=''
|
|
dom_alias=''
|
|
|
suspended=''
|
|
suspended=''
|
|
|
- object_time=''
|
|
|
|
|
|
|
+ object_link=''
|
|
|
|
|
+ object_parent=''
|
|
|
|
|
+ object_time=''
|
|
|
object_date=''
|
|
object_date=''
|
|
|
|
|
|
|
|
# Parsing result
|
|
# Parsing result
|
|
|
- type=$(echo $row |cut -f 1 -d : |cut -f 8 -d / |cut -f 1 -d \.)
|
|
|
|
|
|
|
+ type=$(echo $row |cut -f 1 -d : |cut -f 8 -d /)
|
|
|
data=$(echo $row |cut -f 2,3,4,5 -d :)
|
|
data=$(echo $row |cut -f 2,3,4,5 -d :)
|
|
|
eval "$data"
|
|
eval "$data"
|
|
|
|
|
|
|
|
# Check WEB domain
|
|
# Check WEB domain
|
|
|
- dom_alias=''
|
|
|
|
|
- if [ "$type" = 'web' ]; then
|
|
|
|
|
|
|
+ if [ "$type" = 'web.conf' ]; then
|
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
|
# Check domain alias
|
|
# Check domain alias
|
|
|
- check_dom_alias="$(echo $ALIAS| tr ',' '\n' |grep $object)"
|
|
|
|
|
- if [ ! -z "$check_dom_alias" ];then
|
|
|
|
|
- dom_alias=$(echo $check_dom_alias | tr ' ' ',')
|
|
|
|
|
|
|
+ check_alias="$(echo $ALIAS| tr ',' '\n' |grep $object)"
|
|
|
|
|
+ if [ ! -z "$check_alias" ];then
|
|
|
|
|
+ object_alias=$(echo $check_alias | tr ' ' ',')
|
|
|
fi
|
|
fi
|
|
|
key="DOMAIN"
|
|
key="DOMAIN"
|
|
|
result="$DOMAIN"
|
|
result="$DOMAIN"
|
|
@@ -72,11 +125,23 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
object_time=$TIME
|
|
object_time=$TIME
|
|
|
object_date=$DATE
|
|
object_date=$DATE
|
|
|
((i ++))
|
|
((i ++))
|
|
|
|
|
+ else
|
|
|
|
|
+ check_alias="$(echo $ALIAS| tr ',' '\n' |grep $object)"
|
|
|
|
|
+ if [ ! -z "$check_alias" ];then
|
|
|
|
|
+ key="DOMAIN"
|
|
|
|
|
+ result="$DOMAIN"
|
|
|
|
|
+ object_parent="$DOMAIN"
|
|
|
|
|
+ object_alias=$(echo $check_alias | tr ' ' ',')
|
|
|
|
|
+ suspended=$SUSPENDED
|
|
|
|
|
+ object_time=$TIME
|
|
|
|
|
+ object_date=$DATE
|
|
|
|
|
+ ((i ++))
|
|
|
|
|
+ fi
|
|
|
fi
|
|
fi
|
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
# DNS
|
|
# DNS
|
|
|
- if [ "$type" = 'dns' ]; then
|
|
|
|
|
|
|
+ if [ "$type" = 'dns.conf' ]; then
|
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
|
key="DOMAIN"
|
|
key="DOMAIN"
|
|
|
result="$DOMAIN"
|
|
result="$DOMAIN"
|
|
@@ -87,8 +152,22 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
fi
|
|
fi
|
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
|
|
+ # DNS Records
|
|
|
|
|
+ if [ "$type" = 'dns' ]; then
|
|
|
|
|
+ if [ -n "$(echo $RECORD |grep $object)" ]; then
|
|
|
|
|
+ key="RECORD"
|
|
|
|
|
+ result="$RECORD.$DOMAIN"
|
|
|
|
|
+ suspended=$SUSPENDED
|
|
|
|
|
+ object_link=$ID
|
|
|
|
|
+ object_parent=$DOMAIN
|
|
|
|
|
+ object_time=$TIME
|
|
|
|
|
+ object_date=$DATE
|
|
|
|
|
+ ((i ++))
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
|
|
+
|
|
|
# MAIL
|
|
# MAIL
|
|
|
- if [ "$type" = 'mail' ]; then
|
|
|
|
|
|
|
+ if [ "$type" = 'mail.conf' ]; then
|
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
if [ -n "$(echo $DOMAIN |grep $object)" ]; then
|
|
|
key="DOMAIN"
|
|
key="DOMAIN"
|
|
|
result="$DOMAIN"
|
|
result="$DOMAIN"
|
|
@@ -99,8 +178,24 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
fi
|
|
fi
|
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
|
|
+ # Mail Accounts
|
|
|
|
|
+ if [ "$type" = 'mail' ]; then
|
|
|
|
|
+ type='mail'
|
|
|
|
|
+ if [ -n "$(echo $ACCOUNT |grep $object)" ]; then
|
|
|
|
|
+ key="ACCOUNT"
|
|
|
|
|
+ dom="$(echo $row|cut -f 1 -d :|cut -f 9 -d /|sed -e "s/.conf//")"
|
|
|
|
|
+ result="$ACCOUNT@$dom"
|
|
|
|
|
+ suspended=$SUSPENDED
|
|
|
|
|
+ object_link=$ACCOUNT
|
|
|
|
|
+ object_parent=$dom
|
|
|
|
|
+ object_time=$TIME
|
|
|
|
|
+ object_date=$DATE
|
|
|
|
|
+ ((i ++))
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
|
|
+
|
|
|
# DB
|
|
# DB
|
|
|
- if [ "$type" = 'db' ]; then
|
|
|
|
|
|
|
+ if [ "$type" = 'db.conf' ]; then
|
|
|
if [ -n "$(echo $DB |grep $object)" ]; then
|
|
if [ -n "$(echo $DB |grep $object)" ]; then
|
|
|
key="DATABASE"
|
|
key="DATABASE"
|
|
|
result="$DB"
|
|
result="$DB"
|
|
@@ -111,10 +206,26 @@ for user in $(ls $VESTA/data/users/); do
|
|
|
fi
|
|
fi
|
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
|
|
+ # Cron Jobs
|
|
|
|
|
+ if [ "$type" = 'cron.conf' ]; then
|
|
|
|
|
+ if [ -n "$(echo $CMD |grep $object)" ]; then
|
|
|
|
|
+ key="JOB"
|
|
|
|
|
+ result="$CMD"
|
|
|
|
|
+ suspended=$SUSPENDED
|
|
|
|
|
+ object_link=$JOB
|
|
|
|
|
+ object_parent=$JOB
|
|
|
|
|
+ object_time=$TIME
|
|
|
|
|
+ object_date=$DATE
|
|
|
|
|
+ ((i ++))
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
|
|
+
|
|
|
if [ ! -z "$result" ]; then
|
|
if [ ! -z "$result" ]; then
|
|
|
|
|
+ type=$(echo $type|cut -f1 -d \.)
|
|
|
str="ID='$i' USER='$user' TYPE='$type' KEY='$key'"
|
|
str="ID='$i' USER='$user' TYPE='$type' KEY='$key'"
|
|
|
str="$str RESULT='$result' ALIAS='$dom_alias'"
|
|
str="$str RESULT='$result' ALIAS='$dom_alias'"
|
|
|
- str="$str SUSPENDED='$suspended' TIME='$object_time'"
|
|
|
|
|
|
|
+ str="$str LINK='$object_link' PARENT='$object_parent'"
|
|
|
|
|
+ str="$str SUSPENDED='$suspended' TIME='$object_time'"
|
|
|
str="$str DATE='$object_date'"
|
|
str="$str DATE='$object_date'"
|
|
|
echo $str >> $conf
|
|
echo $str >> $conf
|
|
|
fi
|
|
fi
|
|
@@ -123,14 +234,16 @@ done
|
|
|
IFS=$OLD_IFS
|
|
IFS=$OLD_IFS
|
|
|
|
|
|
|
|
# Defining fileds to select
|
|
# Defining fileds to select
|
|
|
-fields='$ID $USER $TYPE $KEY $RESULT $ALIAS $SUSPENDED $TIME $DATE'
|
|
|
|
|
|
|
+fields='$ID $USER $TYPE $KEY $RESULT $ALIAS $LINK $PARENT $SUSPENDED $TIME'
|
|
|
|
|
+fields="$fields \$DATE"
|
|
|
|
|
|
|
|
# Listing domains
|
|
# Listing domains
|
|
|
-case $format in
|
|
|
|
|
- json) json_list ;;
|
|
|
|
|
- plain) nohead=1; shell_list ;;
|
|
|
|
|
- shell) fields='$USER $TYPE $KEY $RESULT $ALIAS'; shell_list |column -t;;
|
|
|
|
|
- *) check_args '2' '0' 'object [format]'
|
|
|
|
|
|
|
+case $format in
|
|
|
|
|
+ json) json_list_search ;;
|
|
|
|
|
+ plain) nohead=1; shell_list_search ;;
|
|
|
|
|
+ shell) fields='$USER~$TYPE~$KEY~$RESULT~$ALIAS';
|
|
|
|
|
+ shell_list |column -t -s '~' ;;
|
|
|
|
|
+ *) check_args '1' '0' 'object [format]'
|
|
|
esac
|
|
esac
|
|
|
|
|
|
|
|
rm $conf
|
|
rm $conf
|