#!/bin/bash # info: list database # options: USER DATABASE [FORMAT] # # example: v-list-database wp_db # # This function for obtaining of all database's parameters. #----------------------------------------------------------# # Variables & Functions # #----------------------------------------------------------# # Argument definition user=$1 database=$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 ' "'$database'": { "DATABASE": "'$DB'", "DBUSER": "'$DBUSER'", "HOST": "'$HOST'", "TYPE": "'$TYPE'", "CHARSET": "'$CHARSET'", "U_DISK": "'$U_DISK'", "SUSPENDED": "'$SUSPENDED'", "TIME": "'$TIME'", "DATE": "'$DATE'" }' echo '}' } # SHELL list function shell_list() { echo "DATABASE: $DB" echo "DB USER: $DBUSER" echo "HOST: $HOST" echo "TYPE: $TYPE" echo "CHARSET: $CHARSET" echo "DISK: $U_DISK" echo "SUSPENDED: $SUSPENDED" echo "TIME: $TIME" echo "DATE: $DATE" } # PLAIN list function plain_list() { echo -ne "$DB\t$DBUSER\t$HOST\t$TYPE\t$CHARSET\t$U_DISK\t" echo -e "$SUSPENDED\t$TIME\t$DATE" } # CSV list function csv_list() { echo "DATABASE,DBUSER,HOST,TYPE,CHARSET,U_DISK,SUSPENDED,TIME,DATE" echo "$DB,$DBUSER,$HOST,$TYPE,$CHARSET,$U_DISK,$SUSPENDED,$TIME,$DATE" } #----------------------------------------------------------# # Verifications # #----------------------------------------------------------# check_args '2' "$#" 'USER DATABASE [FORMAT]' is_format_valid 'user' 'database' is_object_valid 'user' 'USER' "$user" is_object_valid 'db' 'DB' "$database" #----------------------------------------------------------# # Action # #----------------------------------------------------------# # Parsing database parse_object_kv_list $(grep "DB='$database'" $USER_DATA/db.conf) # Listing data case $format in json) json_list ;; plain) plain_list ;; csv) csv_list ;; shell) shell_list ;; esac #----------------------------------------------------------# # Hestia # #----------------------------------------------------------# exit