Przeglądaj źródła

add dns zones when editing webaliases

Serghey Rodin 13 lat temu
rodzic
commit
530fc3b63d

+ 28 - 22
bin/v_add_dns_on_web_alias

@@ -1,5 +1,5 @@
 #!/bin/bash
-# info: add dns domain or dns record based on web domain alias
+# info: add dns domain or dns record based on web domain alias restart
 # options: user domain
 #
 # The function adds dns domain or dns record based on web domain alias.
@@ -11,8 +11,13 @@
 
 # Argument defenition
 user=$1
-domain=$(echo $domain | sed -e 's/\.*$//g' -e 's/^\.*//g')
+domain=$(echo $2 | sed -e 's/\.*$//g' -e 's/^\.*//g')
 domain_idn=$(idn -t --quiet -a "$domain")
+dom_alias=$(idn -t --quiet -u "$3" )
+dom_alias=$(echo $dom_alias | sed -e 's/\.*$//g' -e 's/^\.*//g')
+dom_alias=$(echo $dom_alias | tr '[:upper:]' '[:lower:]')
+dom_alias_idn=$(idn -t --quiet -a "$dom_alias" )
+restart="$4"
 
 # Includes
 source $VESTA/conf/vesta.conf
@@ -24,7 +29,7 @@ source $VESTA/func/domain.sh
 #                    Verifications                         #
 #----------------------------------------------------------#
 
-check_args '2' "$#" 'user domain'
+check_args '3' "$#" 'user domain alias'
 validate_format 'user' 'domain'
 is_system_enabled "$WEB_SYSTEM"
 is_system_enabled "$DNS_SYSTEM"
@@ -41,34 +46,35 @@ is_object_unsuspended 'web' 'DOMAIN' "$domain"
 # Parsing domain values
 get_domain_values 'web'
 
-OLD_IFS=$IFS
-IFS=','
-for web_alias in $ALIAS; do
-    # Check if parent dns domain exist
-    sub_domain=$(echo $web_alias | cut -f1 -d .)
-    pr_domain=$(echo $web_alias | sed -e "s/^$sub_domain.//" )
-    check_parent=$(grep "DOMAIN='$pr_domain'" $USER_DATA/dns.conf)
-    if [ -z "$check_parent" ]; then
-        check_dom=$(grep "DOMAIN='$web_alias'" $USER_DATA/dns.conf)
-        if [ -z "$check_dom" ]; then
-            $BIN/v_add_dns_domain $user $web_alias $IP
-        fi
+# Check if it a simple domain
+if [ $(echo -e "${dom_alias//\./\n}" | wc -l) -le 2 ]; then
+    if [ ! -e "$USER_DATA/dns/$dom_alias.conf" ]; then
+        $BIN/v_add_dns_domain $user $dom_alias $IP '' '' '' '' '' $restart
+    fi
+else
+    # Check subdomain
+    sub=$(echo "$dom_alias" | cut -f1 -d . -s)
+    dom=$(echo "$dom_alias" | sed -e "s/^$sub.//" )
+    if [ ! -e "$USER_DATA/dns/$dom.conf" ]; then
+        $BIN/v_add_dns_domain $user $dom $IP '' '' '' '' '' $restart
+        $BIN/v_add_dns_domain_record $user $dom "$sub" A $IP '' '' $restart
     else
-        check_rec=$(grep "RECORD='$sub_domain'" $USER_DATA/dns/$pr_domain.conf)
-        if [ -z "$check_rec" ]; then
-            $BIN/v_add_dns_domain_record $user $pr_domain $sub_domain A $IP
+        if [ "$sub" == '*' ]; then
+            rec=$(grep -w "RECORD='\*'" $USER_DATA/dns/$dom.conf)
+        else
+            rec=$(grep -w "RECORD='$sub'" $USER_DATA/dns/$dom.conf)
+        fi
+        if [ -z "$rec" ]; then
+            $BIN/v_add_dns_domain_record $user $dom "$sub" A $IP '' '' $restart
         fi
     fi
-done
+fi
 
 
 #----------------------------------------------------------#
 #                       Vesta                              #
 #----------------------------------------------------------#
 
-# Restart web server
-$BIN/v_restart_dns "$EVENT"
-
 # Logging
 log_history "$EVENT"
 log_event "$OK" "$EVENT"

+ 80 - 0
bin/v_delete_dns_on_web_alias

@@ -0,0 +1,80 @@
+#!/bin/bash
+# info: delete dns domain or dns record based on web domain alias
+# options: user domain
+#
+# The function deletes dns domain or dns record based on web domain alias.
+
+
+#----------------------------------------------------------#
+#                    Variable&Function                     #
+#----------------------------------------------------------#
+
+# Argument defenition
+user=$1
+domain=$(echo $2 | sed -e 's/\.*$//g' -e 's/^\.*//g')
+domain_idn=$(idn -t --quiet -a "$domain")
+dom_alias=$(idn -t --quiet -u "$3" )
+dom_alias=$(echo $dom_alias | sed -e 's/\.*$//g' -e 's/^\.*//g')
+dom_alias=$(echo $dom_alias | tr '[:upper:]' '[:lower:]')
+dom_alias_idn=$(idn -t --quiet -a "$dom_alias" )
+restart="$4"
+
+# Includes
+source $VESTA/conf/vesta.conf
+source $VESTA/func/main.sh
+source $VESTA/func/domain.sh
+
+
+#----------------------------------------------------------#
+#                    Verifications                         #
+#----------------------------------------------------------#
+
+check_args '3' "$#" 'user domain alias'
+validate_format 'user' 'domain'
+is_system_enabled "$WEB_SYSTEM"
+is_system_enabled "$DNS_SYSTEM"
+is_object_valid 'user' 'USER' "$user"
+is_object_unsuspended 'user' 'USER' "$user"
+is_object_valid 'web' 'DOMAIN' "$domain"
+is_object_unsuspended 'web' 'DOMAIN' "$domain"
+
+
+#----------------------------------------------------------#
+#                       Action                             #
+#----------------------------------------------------------#
+
+# Parsing domain values
+get_domain_values 'web'
+
+# Check if it a simple domain
+if [ $(echo -e "${dom_alias//\./\n}" | wc -l) -le 2 ]; then
+    if [ -e "$USER_DATA/dns/$dom_alias.conf" ]; then
+        $BIN/v_delete_dns_domain $user $dom_alias $IP $restart
+    fi
+else
+    # Check subdomain
+    sub=$(echo "$dom_alias" | cut -f1 -d . -s)
+    root=$(echo "$dom_alias" | sed -e "s/^$sub.//" )
+    if [ -e "$USER_DATA/dns/$root.conf" ]; then
+        if [ "$sub" == '*' ]; then
+            rec=$(grep -w "RECORD='\*'" $USER_DATA/dns/$root.conf)
+        else
+            rec=$(grep -w "RECORD='$sub'" $USER_DATA/dns/$root.conf)
+        fi
+        if [ ! -z "$rec" ]; then
+            eval "$rec"
+            $BIN/v_delete_dns_domain_record $user "$root" "$ID"
+        fi
+    fi
+fi
+
+
+#----------------------------------------------------------#
+#                       Vesta                              #
+#----------------------------------------------------------#
+
+# Logging
+log_history "$EVENT"
+log_event "$OK" "$EVENT"
+
+exit

+ 0 - 1
bin/v_update_mail_domains_disk

@@ -58,7 +58,6 @@ done
 recalc_user_disk_usage
 
 # Logging
-log_history "$EVENT"
 log_event "$OK" "$EVENT"
 
 exit

+ 22 - 8
web/add/web/index.php

@@ -100,15 +100,15 @@ top_panel($user,$TAB);
                         }
                     }
                     unset($output);
-                }
-                if (($_POST['v_dns'] == 'on') && (empty($_SESSION['error_msg']))) {
-                    exec (VESTA_CMD."v_add_dns_on_web_alias ".$user." ".$v_domain." 'no'", $output, $return_var);
-                    if ($return_var != 0) {
-                        $error = implode('<br>', $output);
-                        if (empty($error)) $error = 'Error: vesta did not return any output.';
-                        $_SESSION['error_msg'] = $error;
+                    if (($_POST['v_dns'] == 'on') && (empty($_SESSION['error_msg']))) {
+                        exec (VESTA_CMD."v_add_dns_on_web_alias ".$user." ".$v_domain." ".$alias." 'no'", $output, $return_var);
+                        if ($return_var != 0) {
+                            $error = implode('<br>', $output);
+                            if (empty($error)) $error = 'Error: vesta did not return any output.';
+                            $_SESSION['error_msg'] = $error;
+                        }
+                        unset($output);
                     }
-                    unset($output);
                 }
             }
 
@@ -182,6 +182,16 @@ top_panel($user,$TAB);
                 unset($output);
             }
 
+            if (($_POST['v_dns'] == 'on') && (empty($_SESSION['error_msg']))) {
+                exec (VESTA_CMD."v_restart_dns", $output, $return_var);
+                if ($return_var != 0) {
+                    $error = implode('<br>', $output);
+                    if (empty($error)) $error = 'Error: vesta did not return any output.';
+                    $_SESSION['error_msg'] = $error;
+                }
+                unset($output);
+            }
+
             if (empty($_SESSION['error_msg'])) {
                 exec (VESTA_CMD."v_restart_web", $output, $return_var);
                 if ($return_var != 0) {
@@ -205,6 +215,10 @@ top_panel($user,$TAB);
     $ips = json_decode(implode('', $output), true);
     unset($output);
 
+    exec (VESTA_CMD."v_get_user_value ".$user." 'TEMPLATE'", $output, $return_var);
+    $template = $output[0] ;
+    unset($output);
+
     exec (VESTA_CMD."v_list_web_templates json", $output, $return_var);
     $templates = json_decode(implode('', $output), true);
     unset($output);

+ 7 - 8
web/edit/web/index.php

@@ -142,7 +142,7 @@ top_panel($user,$TAB);
             $v_aliases = str_replace(' ', "\n", $waliases);
             $result = array_diff($valiases, $aliases);
             foreach ($result as $alias) {
-                if (empty($_SESSION['error_msg'])) {
+                if ((empty($_SESSION['error_msg'])) && (!empty($alias))) {
                     $restart_web = 'yes';
                     $v_template = escapeshellarg($_POST['v_template']);
                     exec (VESTA_CMD."v_delete_web_domain_alias ".$v_username." ".$v_domain." '".$alias."' 'no'", $output, $return_var);
@@ -152,9 +152,9 @@ top_panel($user,$TAB);
                         $_SESSION['error_msg'] = $error;
                     }
                     unset($output);
-                    exec (VESTA_CMD."v_list_dns_domain ".$v_username." '".$alias."' json", $output, $return_var);
-                    if ((empty($_SESSION['error_msg'])) && ($return_var == 0 )) {
-                        exec (VESTA_CMD."v_delete_dns_domain ".$v_username." '".$alias."'", $output, $return_var);
+
+                    if (empty($_SESSION['error_msg'])) {
+                        exec (VESTA_CMD."v_delete_dns_on_web_alias ".$v_username." ".$v_domain." '".$alias."' 'no'", $output, $return_var);
                         if ($return_var != 0) {
                             $error = implode('<br>', $output);
                             if (empty($error)) $error = 'Error: vesta did not return any output.';
@@ -168,7 +168,7 @@ top_panel($user,$TAB);
 
             $result = array_diff($aliases, $valiases);
             foreach ($result as $alias) {
-                if (empty($_SESSION['error_msg'])) {
+                if ((empty($_SESSION['error_msg'])) && (!empty($alias))) {
                     $restart_web = 'yes';
                     $v_template = escapeshellarg($_POST['v_template']);
                     exec (VESTA_CMD."v_add_web_domain_alias ".$v_username." ".$v_domain." '".$alias."' 'no'", $output, $return_var);
@@ -178,9 +178,8 @@ top_panel($user,$TAB);
                         $_SESSION['error_msg'] = $error;
                     }
                     unset($output);
-                    exec (VESTA_CMD."v_list_dns_domain ".$v_username." '".$alias."' json", $output, $return_var);
-                    if ((empty($_SESSION['error_msg'])) && ($return_var == 0 )) {
-                        exec (VESTA_CMD."v_add_dns_domain ".$v_username." '".$alias."' ".$v_ip, $output, $return_var);
+                    if (empty($_SESSION['error_msg'])) {
+                        exec (VESTA_CMD."v_add_dns_on_web_alias ".$v_username." ".$v_domain." '".$alias."' 'no'", $output, $return_var);
                         if ($return_var != 0) {
                             $error = implode('<br>', $output);
                             if (empty($error)) $error = 'Error: vesta did not return any output.';

+ 5 - 5
web/templates/admin/add_web.html

@@ -41,7 +41,6 @@
 
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">DNS support</td></tr>
             <tr><td><input type="checkbox" size="20" class="add-checkbox" name="v_dns" <?php if (empty($v_dns)) echo "checked=yes"; ?>></tr>
-
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Mail support</td></tr>
             <tr><td><input type="checkbox" size="20" class="add-checkbox" name="v_mail" <?php if (empty($v_mail)) echo "checked=yes"; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;"><a href="javascript:elementHideShow('advtable');" class="add-advanced">Advanced Options ⇢</a></td></tr>
@@ -52,14 +51,15 @@
                     <tr><td class="add-text" style="padding: 10px 0 0 2px;">Apache Template</td></tr>
                     <tr><td><select class="add-list" name="v_template">
                     <?php
-                        echo "<option value=''></option>";
                         foreach ($templates as $key => $value) {
-
                             echo "\t\t\t\t<option value=\"".$value."\"";
-                            if ((!empty($v_template)) && ( $key == $_POST['v_template'])){
+                            if ((!empty($v_template)) && ( $value == $_POST['v_template'])){
                                 echo ' selected' ;
                             }
-                            echo ">".$value."</option>\n";
+                            if ((empty($v_template)) && ( $value == $template)){
+                                echo ' selected' ;
+                            }
+                            echo "> ".$value." </option>\n";
                         }
                     ?>
                         </select></td></tr>