mirror of
https://github.com/serghey-rodin/vesta.git
synced 2024-12-11 06:40:47 -08:00
195 lines
5.8 KiB
Bash
Executable File
195 lines
5.8 KiB
Bash
Executable File
#!/bin/bash
|
|
# info: add system ip address
|
|
# options: IP NETMASK [INTERFACE] [USER] [IP_STATUS] [IP_NAME] [NAT_IP]
|
|
#
|
|
# The function adds ip address into a system. It also creates rc scripts. You
|
|
# can specify ip name which will be used as root domain for temporary aliases.
|
|
# For example, if you set a1.myhosting.com as name, each new domain created on
|
|
# this ip will automatically receive alias $domain.a1.myhosting.com. Of course
|
|
# you must have wildcard record *.a1.myhosting.com pointed to ip. This feature
|
|
# is very handy when customer wants to test domain before dns migration.
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Variable&Function #
|
|
#----------------------------------------------------------#
|
|
|
|
# Argument definition
|
|
ip=${1// /}
|
|
netmask=$2
|
|
interface="${3-eth0}"
|
|
user="${4-admin}"
|
|
ip_status="${5-shared}"
|
|
ip_name=$6
|
|
nat_ip=$7
|
|
|
|
# Includes
|
|
source $VESTA/func/main.sh
|
|
source $VESTA/func/ip.sh
|
|
source $VESTA/func/domain.sh
|
|
source $VESTA/conf/vesta.conf
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Verifications #
|
|
#----------------------------------------------------------#
|
|
|
|
check_args '2' "$#" 'IP NETMASK [INTERFACE] [USER] [STATUS] [NAME] [NATED_IP]'
|
|
is_format_valid 'ip' 'netmask' 'interface' 'user' 'ip_status'
|
|
is_ip_free
|
|
is_object_valid 'user' 'USER' "$user"
|
|
is_object_unsuspended 'user' 'USER' "$user"
|
|
if [ ! -z "$ip_name" ] ; then
|
|
is_format_valid 'ip_name'
|
|
fi
|
|
if [ ! -z "$nat_ip" ] ; then
|
|
is_format_valid 'nat_ip'
|
|
fi
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Action #
|
|
#----------------------------------------------------------#
|
|
iface=$(get_ip_iface)
|
|
cidr=$(convert_netmask $netmask)
|
|
broadcast=$(get_broadcast $ip $netmask)
|
|
|
|
sys_ip_check=$(/sbin/ip addr | grep "$ip")
|
|
if [ -z "$sys_ip_check" ]; then
|
|
# Adding sys ip
|
|
/sbin/ip addr add $ip/$cidr dev $interface \
|
|
broadcast $broadcast label $iface
|
|
|
|
# Adding RHEL/CentOS/Fedora/Amazon startup script
|
|
if [ -d "/etc/sysconfig" ]; then
|
|
sys_ip="# Added by vesta"
|
|
sys_ip="$sys_ip\nDEVICE=$iface"
|
|
sys_ip="$sys_ip\nBOOTPROTO=static"
|
|
sys_ip="$sys_ip\nONBOOT=yes"
|
|
sys_ip="$sys_ip\nIPADDR=$ip"
|
|
sys_ip="$sys_ip\nNETMASK=$netmask"
|
|
echo -e $sys_ip > /etc/sysconfig/network-scripts/ifcfg-$iface
|
|
fi
|
|
|
|
# Adding Debian/Ubuntu startup script
|
|
if [ -e "/etc/debian_version" ]; then
|
|
sys_ip="\n# Added by vesta"
|
|
sys_ip="$sys_ip\nauto $iface"
|
|
sys_ip="$sys_ip\niface $iface inet static"
|
|
sys_ip="$sys_ip\naddress $ip"
|
|
sys_ip="$sys_ip\nnetmask $netmask"
|
|
echo -e $sys_ip >> /etc/network/interfaces
|
|
fi
|
|
fi
|
|
|
|
# Generating timestamp
|
|
time_n_date=$(date +'%T %F')
|
|
time=$(echo "$time_n_date" |cut -f 1 -d \ )
|
|
date=$(echo "$time_n_date" |cut -f 2 -d \ )
|
|
|
|
# Adding vesta ip
|
|
echo "OWNER='$user'
|
|
STATUS='$ip_status'
|
|
NAME='$ip_name'
|
|
U_SYS_USERS=''
|
|
U_WEB_DOMAINS='0'
|
|
INTERFACE='$interface'
|
|
NETMASK='$netmask'
|
|
NAT='$nat_ip'
|
|
TIME='$time'
|
|
DATE='$date'" > $VESTA/data/ips/$ip
|
|
chmod 660 $VESTA/data/ips/$ip
|
|
|
|
# WEB support
|
|
if [ ! -z "$WEB_SYSTEM" ]; then
|
|
web_conf="/etc/$WEB_SYSTEM/conf.d/$ip.conf"
|
|
rm -f $web_conf
|
|
|
|
if [ "$WEB_SYSTEM" = 'httpd' ] || [ "$WEB_SYSTEM" = 'apache2' ]; then
|
|
if [ -z "$(/usr/sbin/apachectl -v | grep Apache/2.4)" ]; then
|
|
echo "NameVirtualHost $ip:$WEB_PORT" > $web_conf
|
|
fi
|
|
echo "Listen $ip:$WEB_PORT" >> $web_conf
|
|
fi
|
|
|
|
if [ "$WEB_SSL" = 'mod_ssl' ]; then
|
|
if [ -z "$(/usr/sbin/apachectl -v | grep Apache/2.4)" ]; then
|
|
echo "NameVirtualHost $ip:$WEB_SSL_PORT" >> $web_conf
|
|
fi
|
|
echo "Listen $ip:$WEB_SSL_PORT" >> $web_conf
|
|
fi
|
|
fi
|
|
|
|
# Proxy support
|
|
if [ ! -z "$PROXY_SYSTEM" ]; then
|
|
cat $WEBTPL/$PROXY_SYSTEM/proxy_ip.tpl |\
|
|
sed -e "s/%ip%/$ip/g" \
|
|
-e "s/%web_port%/$WEB_PORT/g" \
|
|
-e "s/%proxy_port%/$PROXY_PORT/g" \
|
|
> /etc/$PROXY_SYSTEM/conf.d/$ip.conf
|
|
|
|
# mod_extract_forwarded
|
|
fw_conf="/etc/$WEB_SYSTEM/conf.d/mod_extract_forwarded.conf"
|
|
if [ -e "$fw_conf" ]; then
|
|
ips=$(grep 'MEFaccept ' $fw_conf | grep -v '#' | head -n1)
|
|
sed -i "s/$ips/$ips $ip/g" $fw_conf
|
|
fi
|
|
|
|
# mod_rpaf
|
|
rpaf_conf="/etc/$WEB_SYSTEM/mods-enabled/rpaf.conf"
|
|
if [ -e "$rpaf_conf" ]; then
|
|
rpaf_str=$(grep RPAFproxy_ips $rpaf_conf)
|
|
rpaf_str="$rpaf_str $ip"
|
|
sed -i "s/.*RPAFproxy_ips.*/$rpaf_str/" $rpaf_conf
|
|
fi
|
|
|
|
#mod_remoteip
|
|
remoteip_conf="/etc/$WEB_SYSTEM/mods-enabled/remoteip.conf"
|
|
if [ -e "$remoteip_conf" ]; then
|
|
if [ $( grep -ic "$ip" $remoteip_conf ) -eq 0 ]; then
|
|
sed -i "s/<\/IfModule>/RemoteIPInternalProxy $ip\n<\/IfModule>/g" $remoteip_conf
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
|
|
#----------------------------------------------------------#
|
|
# Vesta #
|
|
#----------------------------------------------------------#
|
|
|
|
# Updating user counters
|
|
increase_user_value "$user" '$IP_OWNED'
|
|
if [ "$user" = 'admin' ]; then
|
|
if [ "$ip_status" = 'shared' ]; then
|
|
for user in $(ls $VESTA/data/users); do
|
|
increase_user_value "$user" '$IP_AVAIL'
|
|
done
|
|
else
|
|
increase_user_value 'admin' '$IP_AVAIL'
|
|
fi
|
|
else
|
|
increase_user_value "$user" '$IP_AVAIL'
|
|
increase_user_value 'admin' '$IP_AVAIL'
|
|
fi
|
|
|
|
# Restarting web server
|
|
$BIN/v-restart-web
|
|
check_result $? "Web restart failed" >/dev/null
|
|
|
|
# Restarting proxy server
|
|
if [ ! -z "$PROXY_SYSTEM" ]; then
|
|
$BIN/v-restart-proxy
|
|
check_result $? "Proxy restart failed" >/dev/null
|
|
fi
|
|
|
|
# Restarting firewall
|
|
if [ ! -z "$FIREWALL_SYSTEM" ]; then
|
|
$BIN/v-update-firewall
|
|
fi
|
|
|
|
# Logging
|
|
log_history "added system ip address $ip" '' 'admin'
|
|
log_event "$OK" "$ARGUMENTS"
|
|
|
|
exit
|