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.
		
		
		
		
		
			
		
			
				
					
					
						
							167 lines
						
					
					
						
							4.9 KiB
						
					
					
				
			
		
		
	
	
							167 lines
						
					
					
						
							4.9 KiB
						
					
					
				#!/bin/bash
 | 
						|
# info: list web domain parameters
 | 
						|
# options: USER DOMAIN [FORMAT]
 | 
						|
#
 | 
						|
# example: v-list-web-domain admin example.com
 | 
						|
#
 | 
						|
# This function to obtain web domain parameters.
 | 
						|
 | 
						|
#----------------------------------------------------------#
 | 
						|
#                Variables & Functions                     #
 | 
						|
#----------------------------------------------------------#
 | 
						|
 | 
						|
# Argument definition
 | 
						|
user=$1
 | 
						|
domain=$2
 | 
						|
format=${3-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() {
 | 
						|
	echo '{'
 | 
						|
	echo '    "'$DOMAIN'": {
 | 
						|
        "IP": "'$IP'",
 | 
						|
        "IP6": "'$IP6'",
 | 
						|
        "DOCUMENT_ROOT": "'$DOCROOT'",
 | 
						|
        "U_DISK": "'$U_DISK'",
 | 
						|
        "U_BANDWIDTH": "'$U_BANDWIDTH'",
 | 
						|
        "TPL": "'$TPL'",
 | 
						|
        "ALIAS": "'$ALIAS'",
 | 
						|
        "STATS": "'$STATS'",
 | 
						|
        "STATS_USER": "'$STATS_USER'",
 | 
						|
        "SSL": "'$SSL'",
 | 
						|
        "SSL_FORCE": "'$SSL_FORCE'",
 | 
						|
        "SSL_HSTS": "'$SSL_HSTS'",
 | 
						|
        "SSL_HOME": "'$SSL_HOME'",
 | 
						|
        "LETSENCRYPT": "'$LETSENCRYPT'",
 | 
						|
        "FTP_USER": "'$FTP_USER'",
 | 
						|
        "FTP_PATH": "'$FTP_PATH'",
 | 
						|
        "AUTH_USER": "'$AUTH_USER'",
 | 
						|
        "BACKEND": "'$BACKEND'",
 | 
						|
        "PROXY": "'$PROXY'",
 | 
						|
        "PROXY_EXT": "'$PROXY_EXT'",
 | 
						|
        "FASTCGI_CACHE": "'$FASTCGI_CACHE'",
 | 
						|
        "FASTCGI_DURATION": "'$FASTCGI_DURATION'",
 | 
						|
        "REDIRECT": "'$REDIRECT'",
 | 
						|
        "REDIRECT_CODE": "'$REDIRECT_CODE'",
 | 
						|
        "CUSTOM_DOCROOT": "'$CUSTOM_DOCROOT'",
 | 
						|
        "SUSPENDED": "'$SUSPENDED'",
 | 
						|
        "TIME": "'$TIME'",
 | 
						|
        "DATE": "'$DATE'",
 | 
						|
		"PROXY_PORT_INTERNAL": "'$PROXY_PORT_INTERNAL'"
 | 
						|
    }'
 | 
						|
	echo '}'
 | 
						|
}
 | 
						|
 | 
						|
# SHELL list function
 | 
						|
shell_list() {
 | 
						|
	echo "DOMAIN:         $DOMAIN"
 | 
						|
	echo "ALIAS:          ${ALIAS//,/ }"
 | 
						|
	echo "IP:             $IP"
 | 
						|
	echo "DOCUMENT_ROOT:  $DOCROOT"
 | 
						|
	if [ -n "$IP6" ]; then
 | 
						|
		echo "IP6:            $IP6"
 | 
						|
	fi
 | 
						|
	if [ -n "$SSL" ] && [ "$SSL" != 'no' ]; then
 | 
						|
		echo "SSL:            $SSL / $SSL_HOME"
 | 
						|
		if [ -n "$LETSENCRYPT" ] && [ "$LETSENCRYPT" != 'no' ]; then
 | 
						|
			echo "LETSENCRYPT:    $LETSENCRYPT"
 | 
						|
		fi
 | 
						|
		if [ -n "$SSL_FORCE" ]; then
 | 
						|
			echo "SSL_FORCE:       $SSL_FORCE"
 | 
						|
		fi
 | 
						|
		if [ -n "$SSL_HSTS" ]; then
 | 
						|
			echo "SSL_HSTS:       $SSL_HSTS"
 | 
						|
		fi
 | 
						|
	fi
 | 
						|
	echo "TEMPLATE:       $TPL"
 | 
						|
	if [ -n "$WEB_BACKEND" ]; then
 | 
						|
		echo "BACKEND:        $BACKEND"
 | 
						|
	fi
 | 
						|
	if [ -n "$PROXY_SYSTEM" ]; then
 | 
						|
		echo "PROXY:          $PROXY"
 | 
						|
		echo "PROXY_PORT_INTERNAL:     $PROXY_PORT_INTERNAL"
 | 
						|
		echo "PROXY EXT:      ${PROXY_EXT//,/ }"
 | 
						|
	fi
 | 
						|
	if [ -n "$STATS" ]; then
 | 
						|
		echo "STATS:          $STATS"
 | 
						|
	fi
 | 
						|
	if [ -n "$FTP_USER" ]; then
 | 
						|
		echo "FTP_USER:       ${FTP_USER//,/, }"
 | 
						|
	fi
 | 
						|
	if [ -n "$AUTH_USER" ]; then
 | 
						|
		echo "HTTP_AUTH:      $AUTH_USER"
 | 
						|
	fi
 | 
						|
	echo "DISK:           $U_DISK"
 | 
						|
	echo "BW:             $U_BANDWIDTH"
 | 
						|
	echo "SUSPENDED:      $SUSPENDED"
 | 
						|
	echo "TIME:           $TIME"
 | 
						|
	echo "DATE:           $DATE"
 | 
						|
}
 | 
						|
 | 
						|
# PLAIN list function
 | 
						|
plain_list() {
 | 
						|
	echo -ne "$DOMAIN\t$IP\t$IP6\t$DOCROOT\t$U_DISK\t$U_BANDWIDTH\t$TPL\t"
 | 
						|
	echo -ne "$ALIAS\t$STATS\t$STATS_USER\t$SSL\t$SSL_FORCE\t$SSL_HSTS\t$SSL_HOME\t,$LETSENCRYPT"
 | 
						|
	echo -ne "$FTP_USER\t$FTP_PATH\t$AUTH_USER\t$BACKEND\t$PROXY\t"
 | 
						|
	echo -e "$PROXY_EXT\t$SUSPENDED\t$TIME\t$DATE\t$PROXY_PORT_INTERNAL"
 | 
						|
}
 | 
						|
 | 
						|
# CSV list function
 | 
						|
csv_list() {
 | 
						|
	echo -n "DOMAIN,IP,IP6,DOCROOT,U_DISK,U_BANDWIDTH,TPL,ALIAS,STATS,STATS_USER,SSL,"
 | 
						|
	echo -n "SSL_FORCE,SSL_HSTS,SSL_HOME,LETSENCRYPT,FTP_USER,FTP_PATH,AUTH_USER,BACKEND,PROXY,PROXY_EXT,"
 | 
						|
	echo "SUSPENDED,TIME,DATE,PROXY_PORT_INTERNAL"
 | 
						|
	echo -n "$DOMAIN,$IP,$IP6,$DOCROOT,$U_DISK,$U_BANDWIDTH,$TPL,\"$ALIAS\",$STATS"
 | 
						|
	echo -n "\"$STATS_USER\",$SSL,$SSL_FORCE,$SSL_HSTS,$SSL_HOME,$LETSENCRYPT,\"$FTP_USER\",\"$FTP_PATH\","
 | 
						|
	echo -n "\"$AUTH_USER\",$BACKEND,$PROXY,\"$PROXY_EXT\",$SUSPENDED,$TIME,$DATE,"
 | 
						|
	echo "\"$PROXY_PORT_INTERNAL\""
 | 
						|
}
 | 
						|
 | 
						|
#----------------------------------------------------------#
 | 
						|
#                    Verifications                         #
 | 
						|
#----------------------------------------------------------#
 | 
						|
 | 
						|
check_args '2' "$#" 'USER DOMAIN [FORMAT]'
 | 
						|
is_format_valid 'user' 'domain'
 | 
						|
is_object_valid 'user' 'USER' "$user"
 | 
						|
is_object_valid 'web' 'DOMAIN' "$domain"
 | 
						|
 | 
						|
#----------------------------------------------------------#
 | 
						|
#                       Action                             #
 | 
						|
#----------------------------------------------------------#
 | 
						|
 | 
						|
# Parsing domain
 | 
						|
parse_object_kv_list $(grep "DOMAIN='$domain'" $USER_DATA/web.conf)
 | 
						|
 | 
						|
if [ -n "$CUSTOM_DOCROOT" ]; then
 | 
						|
	DOCROOT="$CUSTOM_DOCROOT"
 | 
						|
else
 | 
						|
	DOCROOT="$HOMEDIR/$user/web/$DOMAIN/public_html/"
 | 
						|
fi
 | 
						|
 | 
						|
if [ -z "$PROXY_PORT_INTERNAL" ];then
 | 
						|
	PROXY_PORT_INTERNAL="0"
 | 
						|
fi
 | 
						|
 | 
						|
# Listing data
 | 
						|
case $format in
 | 
						|
	json) json_list ;;
 | 
						|
	plain) plain_list ;;
 | 
						|
	csv) csv_list ;;
 | 
						|
	shell) shell_list ;;
 | 
						|
esac
 | 
						|
 | 
						|
#----------------------------------------------------------#
 | 
						|
#                       Hestia                             #
 | 
						|
#----------------------------------------------------------#
 | 
						|
 | 
						|
exit
 |