| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- #!/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 startup script
- if [ -e "/etc/redhat-release" ]; 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
|