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.
120 lines
3.5 KiB
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
|