1
0

remote.sh 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. #!/bin/bash
  2. #===========================================================================#
  3. # #
  4. # Hestia Control Panel - API Function Library #
  5. # #
  6. #===========================================================================#
  7. # Check if script already running or not
  8. is_procces_running() {
  9. SCRIPT=$(basename $0)
  10. for pid in $(pidof -x $SCRIPT); do
  11. if [ $pid != $$ ]; then
  12. check_result "$E_INUSE" "$SCRIPT is already running"
  13. fi
  14. done
  15. }
  16. send_api_cmd() {
  17. if [ -n "$PASSWORD" ]; then
  18. answer=$(curl -s -k \
  19. --data-urlencode "user=$USER" \
  20. --data-urlencode "password=$PASSWORD" \
  21. --data-urlencode "returncode=yes" \
  22. --data-urlencode "cmd=$1" \
  23. --data-urlencode "arg1=$2" \
  24. --data-urlencode "arg2=$3" \
  25. --data-urlencode "arg3=$4" \
  26. --data-urlencode "arg4=$5" \
  27. --data-urlencode "arg5=$6" \
  28. --data-urlencode "arg6=$7" \
  29. --data-urlencode "arg7=$8" \
  30. --data-urlencode "arg8=$9" \
  31. https://$HOST:$PORT/api/)
  32. else
  33. answer=$(curl -s -k \
  34. --data-urlencode "hash=$HASH" \
  35. --data-urlencode "returncode=yes" \
  36. --data-urlencode "cmd=$1" \
  37. --data-urlencode "arg1=$2" \
  38. --data-urlencode "arg2=$3" \
  39. --data-urlencode "arg3=$4" \
  40. --data-urlencode "arg4=$5" \
  41. --data-urlencode "arg5=$6" \
  42. --data-urlencode "arg6=$7" \
  43. --data-urlencode "arg7=$8" \
  44. --data-urlencode "arg8=$9" \
  45. https://$HOST:$PORT/api/)
  46. fi
  47. if [ "$DEBUG_MODE" = "yes" ]; then
  48. # log out going request if wanted for debugging
  49. echo "$1 $2 $3 $4 $5 $6 $7 $8 $9" >> /var/log/hestia/api_out.log
  50. fi
  51. return $answer
  52. }
  53. send_api_file() {
  54. if [ -n "$PASSWORD" ]; then
  55. answer=$(curl -s -k \
  56. --data-urlencode "user=$USER" \
  57. --data-urlencode "password=$PASSWORD" \
  58. --data-urlencode "returncode=yes" \
  59. --data-urlencode "cmd=v-make-tmp-file" \
  60. --data-urlencode "arg1=$(cat $1)" \
  61. --data-urlencode "arg2=$2" \
  62. https://$HOST:$PORT/api/)
  63. else
  64. answer=$(curl -s -k \
  65. --data-urlencode "hash=$HASH" \
  66. --data-urlencode "returncode=yes" \
  67. --data-urlencode "cmd=v-make-tmp-file" \
  68. --data-urlencode "arg1=$(cat $1)" \
  69. --data-urlencode "arg2=$2" \
  70. https://$HOST:$PORT/api/)
  71. fi
  72. return $answer
  73. }
  74. send_ssh_cmd() {
  75. if [ -z "$IDENTITY_FILE" ] && [ "$USER" = 'root' ]; then
  76. IDENTITY_FILE="/root/.ssh/id_rsa"
  77. fi
  78. if [ -z "$IDENTITY_FILE" ]; then
  79. IDENTITY_FILE="/home/$USER/.ssh/id_rsa"
  80. fi
  81. if [ "$USER" = 'root' ]; then
  82. args="$BIN/$1 \"$2\" \"$3\" \"$4\" \"$5\""
  83. else
  84. args="sudo $BIN/$1 \"$2\" \"$3\" \"$4\" \"$5\""
  85. fi
  86. ssh -i $IDENTITY_FILE $USER@$HOST -p $PORT "$args" > /dev/null 2>&1
  87. if [ "$?" -ne '0' ]; then
  88. return 1
  89. else
  90. return 0
  91. fi
  92. }
  93. send_scp_file() {
  94. if [ -z "$IDENTITY_FILE" ]; then
  95. IDENTITY_FILE="/home/admin/.ssh/id_rsa"
  96. fi
  97. scp -P $PORT -i $IDENTITY_FILE $1 $USER@$HOST:$2 > /dev/null 2>&1
  98. if [ "$?" -ne '0' ]; then
  99. return 1
  100. else
  101. return 0
  102. fi
  103. }
  104. is_dnshost_new() {
  105. if [ -e "$HESTIA/conf/dns-cluster.conf" ]; then
  106. check_host=$(grep "HOST='$host'" $HESTIA/conf/dns-cluster.conf)
  107. if [ -n "$check_host" ]; then
  108. check_result $E_EXISTS "remote dns host $host exists"
  109. fi
  110. fi
  111. }
  112. is_dnshost_alive() {
  113. cluster_cmd v-list-sys-config
  114. check_result $? "$type connection to $HOST failed" "$E_CONNECT"
  115. cluster_cmd v-list-user "$DNS_USER"
  116. check_result $? "$DNS_USER doesn't exist" "$E_CONNECT"
  117. }
  118. remote_dns_health_check() {
  119. OLD_IFS="$IFS"
  120. IFS=$'\n'
  121. # Starting health-check
  122. for str in $(grep "SUSPENDED='no'" $HESTIA/conf/dns-cluster.conf); do
  123. # Reset user, password and hash vars
  124. clear_dns_cluster_settings
  125. # Parsing host values
  126. parse_object_kv_list "$str"
  127. # Checking host connection
  128. cluster_cmd v-list-user "$DNS_USER"
  129. if [ $? -ne 0 ]; then
  130. # Creating error report
  131. tmpfile=$(mktemp)
  132. echo "$(basename $0) $*" > $tmpfile
  133. echo -e "Error: $TYPE connection to $HOST failed.\n" >> $tmpfile
  134. echo -n "Remote dns host has been suspended." >> $tmpfile
  135. echo -n "After resolving issue run " >> $tmpfile
  136. echo -e "following commands:\n" >> $tmpfile
  137. echo "v-unsuspend-remote-dns-host $HOST" >> $tmpfile
  138. echo "v-sync-dns-cluster $HOST" >> $tmpfile
  139. echo -e "\n\n--\nHestia Control Panel\n$(hostname)" >> $tmpfile
  140. if [ "$1" = 'no_email' ]; then
  141. cat $tmpfile
  142. else
  143. subj="DNS sync failed"
  144. email=$($BIN/v-get-user-value admin CONTACT)
  145. cat $tmpfile | $SENDMAIL -s "$subj" $email
  146. fi
  147. # Deleting tmp file
  148. rm -f $tmpfile
  149. log_event "$E_CONNECT" "$ARGUMENTS"
  150. # Suspending remote host
  151. dconf="../../conf/dns-cluster"
  152. update_object_value "$dconf" 'HOST' "$HOST" '$SUSPENDED' 'yes'
  153. fi
  154. done
  155. IFS="$OLD_IFS"
  156. }
  157. cluster_cmd() {
  158. case $TYPE in
  159. ssh) send_ssh_cmd $* ;;
  160. api) send_api_cmd $* ;;
  161. esac
  162. }
  163. cluster_file() {
  164. case $TYPE in
  165. ssh) send_scp_file $* ;;
  166. api) send_api_file $* ;;
  167. esac
  168. }
  169. clear_dns_cluster_settings() {
  170. unset USER
  171. unset PASSWORD
  172. unset HASH
  173. }