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.
hestiacp/bin/v-change-sys-ip-nat

120 lines
3.5 KiB

#!/bin/bash
# info: change NAT IP address
# options: IP NAT_IP [RESTART]
#
# example: v-change-sys-ip-nat 10.0.0.1 203.0.113.1
#
# This function for changing NAT IP associated with IP.
#----------------------------------------------------------#
# Variables & Functions #
#----------------------------------------------------------#
# Argument definition
ip="$1"
nat_ip="$2"
restart="$3"
# 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
# shellcheck source=/usr/local/hestia/func/ip.sh
source $HESTIA/func/ip.sh
# load config file
source_conf "$HESTIA/conf/hestia.conf"
#----------------------------------------------------------#
# Verifications #
#----------------------------------------------------------#
check_args '2' "$#" 'IP NAT_IP [RESTART]'
is_format_valid 'ip'
is_format_valid 'nat_ip'
is_ip_valid "$ip"
# Perform verification if read-only mode is enabled
check_hestia_demo_mode
#----------------------------------------------------------#
# Action #
#----------------------------------------------------------#
# Updating IP
if [ -z "$(grep NAT= $HESTIA/data/ips/$ip)" ]; then
sed -i "s/^TIME/NAT='$nat_ip'\nTIME/g" $HESTIA/data/ips/$ip
old=''
new="$nat_ip"
else
old="$(get_ip_value '$NAT')"
new="$nat_ip"
sed -i "s/NAT=.*/NAT='$new'/" $HESTIA/data/ips/$ip
if [ -z "$nat_ip" ]; then
new="$ip"
fi
fi
# Updating WEB configs
if [ -n "$old" ] && [ -n "$WEB_SYSTEM" ]; then
for user in $($BIN/v-list-sys-users plain); do
sed -i "s/$old/$new/" $HESTIA/data/users/$user/web.conf
$BIN/v-rebuild-web-domains "$user" no
done
$BIN/v-restart-dns "$restart"
fi
# Updating DNS configs
if [ -n "$old" ] && [ -n "$DNS_SYSTEM" ]; then
for user in $($BIN/v-list-sys-users plain); do
sed -i "s/$old/$new/" "$HESTIA/data/users/$user/dns.conf"
if ls $HESTIA/data/users/$user/dns/*.conf > /dev/null 2>&1; then
sed -i "s/$old/$new/" $HESTIA/data/users/$user/dns/*.conf
fi
$BIN/v-rebuild-dns-domains "$user" no
done
$BIN/v-restart-dns "$restart"
fi
# Updating FTP
if [ -n "$old" ] && [ -n "$FTP_SYSTEM" ]; then
ftp_conf="$(find /etc -maxdepth 2 -name "$FTP_SYSTEM.conf")"
if [ -e "$ftp_conf" ]; then
sed -i "s/$old/$new/g" "$ftp_conf"
if [ "$FTP_SYSTEM" = 'vsftpd' ]; then
check_pasv="$(grep pasv_address "$ftp_conf")"
if [ -z "$check_pasv" ] && [ -n "$nat_ip" ]; then
echo "pasv_address=$nat_ip" >> "$ftp_conf"
fi
if [ -n "$check_pasv" ] && [ -z "$nat_ip" ]; then
sed -i "/pasv_address/d" "$ftp_conf"
fi
if [ -n "$check_pasv" ] && [ -n "$nat_ip" ]; then
sed -i "s/pasv_address=.*/pasv_address='$nat_ip'/g" "$ftp_conf"
fi
fi
fi
if [ "$FTP_SYSTEM" = 'proftpd' ]; then
ext_ip_conf="/etc/$FTP_SYSTEM/conf.d/external_ip.conf"
content="MasqueradeAddress ${nat_ip}"
echo "$content" > "$ext_ip_conf"
fi
$BIN/v-restart-ftp "$restart"
fi
# Updating firewall
if [ -n "$old" ] && [ -n "$FIREWALL_SYSTEM" ]; then
sed -i "s/$old/$new/g" $HESTIA/data/firewall/*.conf
$BIN/v-update-firewall
fi
#----------------------------------------------------------#
# Hestia #
#----------------------------------------------------------#
# Logging
$BIN/v-log-action "system" "Info" "System" "IP NAT address changed (IP: $ip, NAT IP: $nat_ip)."
log_event "$OK" "$ARGUMENTS"
exit