| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- #!/bin/bash
- # info: list database server
- # options: type host [format]
- #
- # The function for obtaining database server parameters.
- #----------------------------------------------------------#
- # Variable&Function #
- #----------------------------------------------------------#
- # Argument defenition
- type=$1
- host=$2
- format=${3-shell}
- # Includes
- source $VESTA/func/main.sh
- # Json function
- json_list_dbhost() {
- i=1
- fields_count=$(echo "$fields" | wc -w)
- line=$(grep "HOST='$host'" $conf)
- echo '{'
- eval $line
- for field in $fields; do
- eval value=$field
- if [ "$i" -eq 1 ]; then
- echo -e "\t\"$value\": {"
- else
- if [ "$fields_count" -eq "$i" ]; then
- echo -e "\t\t\"${field//$/}\": \"${value//,/, }\""
- else
- echo -e "\t\t\"${field//$/}\": \"${value//,/, }\","
- fi
- fi
- (( ++i))
- done
- if [ -n "$value" ]; then
- echo -e "\t}"
- fi
- echo -e "}"
- }
- # Shell function
- shell_list_dbhost() {
- line=$(grep "HOST='$host'" $conf)
- eval $line
- for field in $fields; do
- eval key="$field"
- echo "${field//$/}: $key"
- done
- }
- #----------------------------------------------------------#
- # Verifications #
- #----------------------------------------------------------#
- check_args '2' "$#" 'type host [format]'
- validate_format 'host'
- is_object_valid "../../conf/$type" 'HOST' "$host"
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Defining fileds to select
- conf=$VESTA/conf/$type.conf
- fields='$HOST $PORT $CHARSETS $MAX_DB $U_SYS_USERS $U_DB_BASES $TPL $SUSPENDED'
- fields="$fields \$TIME \$DATE"
- # Listing database
- case $format in
- json) json_list_dbhost ;;
- plain) nohead=1; shell_list_dbhost ;;
- shell) shell_list_dbhost | column -t;;
- *) check_args '2' '0' 'type host [format]'
- esac
- #----------------------------------------------------------#
- # Vesta #
- #----------------------------------------------------------#
- exit
|