Browse Source

edit user package

Serghey Rodin 13 years ago
parent
commit
06c7b42204

+ 8 - 4
bin/v_change_user_package

@@ -1,6 +1,6 @@
 #!/bin/bash
 # info: change user package
-# options: user package
+# options: user package [force]
 #
 # The function changes user's hosting package.
 
@@ -12,6 +12,7 @@
 # Argument defenition
 user=$1
 package=$2
+force=$3
 
 # Includes
 source $VESTA/conf/vesta.conf
@@ -54,7 +55,8 @@ change_user_package() {
     usr_data=$(cat $USER_DATA/user.conf)
     eval $usr_data
 
-    pkg_data=$(cat $VESTA/data/packages/$package.pkg)
+    pkg_data=$(cat $VESTA/data/packages/$package.pkg |grep -v TIME |\
+        grep -v DATE)
     eval $pkg_data
 
     echo "FNAME='$FNAME'
@@ -114,11 +116,13 @@ DATE='$DATE'" > $USER_DATA/user.conf
 #                    Verifications                         #
 #----------------------------------------------------------#
 
-check_args '2' "$#" 'user package'
+check_args '2' "$#" 'user package [force]'
 validate_format 'user' 'package'
 is_object_valid 'user' 'USER' "$user"
 is_package_valid
-is_package_avalable
+if [ "$force" != 'yes' ];then
+    is_package_avalable
+fi
 
 
 #----------------------------------------------------------#

+ 47 - 0
bin/v_update_user_package

@@ -0,0 +1,47 @@
+#!/bin/bash
+# info: update user package
+# options: pacakge
+#
+# The function propogates package to connected users.
+
+
+#----------------------------------------------------------#
+#                    Variable&Function                     #
+#----------------------------------------------------------#
+
+# Argument defenition
+package=$1
+
+# Includes
+source $VESTA/conf/vesta.conf
+source $VESTA/func/main.sh
+
+
+#----------------------------------------------------------#
+#                    Verifications                         #
+#----------------------------------------------------------#
+
+check_args '1' "$#" 'package'
+validate_format 'package'
+is_package_valid
+
+
+#----------------------------------------------------------#
+#                       Action                             #
+#----------------------------------------------------------#
+
+for user in $(ls $VESTA/data/users); do
+    check_package=$(grep "PACKAGE='$package'" $USER_DATA/$user/user.conf)
+    if [ ! -z "$check_package" ]; then
+        $BIN/v_change_user_package $user $package 'yes'
+    fi
+done
+
+#----------------------------------------------------------#
+#                       Vesta                              #
+#----------------------------------------------------------#
+
+# Logging
+log_event "$OK" "$EVENT"
+
+exit

+ 1 - 1
web/add/package/index.php

@@ -114,7 +114,7 @@ if ($_SESSION['user'] == 'admin') {
             }
 
             // Remove tmpdir 
-            exec ('rm -rf '.$tmdir, $output, $return_var);
+            exec ('rm -rf '.$tmpdir, $output, $return_var);
             unset($output);
 
             // Check output

+ 191 - 0
web/edit/package/index.php

@@ -0,0 +1,191 @@
+<?php
+// Init
+error_reporting(NULL);
+ob_start();
+session_start();
+
+$TAB = 'PACKAGE';
+include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
+
+// Header
+include($_SERVER['DOCUMENT_ROOT'].'/templates/header.html');
+
+// Panel
+top_panel($user,$TAB);
+
+// Are you admin?
+if ($_SESSION['user'] == 'admin') {
+
+    // Check user argument?
+    if (empty($_GET['package'])) {
+        header("Location: /list/package/");
+        exit;
+    }
+
+    $v_package = escapeshellarg($_GET['package']);
+    exec (VESTA_CMD."v_list_user_package ".$v_package." 'json'", $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;
+    } else {
+        $data = json_decode(implode('', $output), true);
+        unset($output);
+
+        $v_package = $_GET['package'];
+        $v_template = $data[$v_package]['TEMPLATE'];
+        $v_web_domains = $data[$v_package]['WEB_DOMAINS'];
+        $v_web_aliases = $data[$v_package]['WEB_ALIASES'];
+        $v_dns_domains = $data[$v_package]['DNS_DOMAINS'];
+        $v_dns_records = $data[$v_package]['DNS_RECORDS'];
+        $v_mail_domains = $data[$v_package]['MAIL_DOMAINS'];
+        $v_mail_accounts = $data[$v_package]['MAIL_ACCOUNTS'];
+        $v_databases = $data[$v_package]['DATABASES'];
+        $v_cron_jobs = $data[$v_package]['CRON_JOBS'];
+        $v_disk_quota = $data[$v_package]['DISK_QUOTA'];
+        $v_bandwidth = $data[$v_package]['BANDWIDTH'];
+        $v_shell = $data[$v_package]['SHELL'];
+        $v_ns = $data[$v_package]['NS'];
+        $nameservers = explode(", ", $v_ns);
+        $v_ns1 = $nameservers[0];
+        $v_ns2 = $nameservers[1];
+        $v_ns3 = $nameservers[2];
+        $v_ns4 = $nameservers[3];
+        $v_backups = $data[$v_package]['BACKUPS'];
+        $v_date = $data[$v_package]['DATE'];
+        $v_time = $data[$v_package]['TIME'];
+        $v_status =  'active';
+
+
+        exec (VESTA_CMD."v_list_web_templates json", $output, $return_var);
+        check_error($return_var);
+        $templates = json_decode(implode('', $output), true);
+        unset($output);
+
+        exec (VESTA_CMD."v_list_sys_shells json", $output, $return_var);
+        check_error($return_var);
+        $shells = json_decode(implode('', $output), true);
+        unset($output);
+
+        // Action
+        if (!empty($_POST['save'])) {
+            // Check input
+            if (empty($_POST['v_package'])) $errors[] = 'package';
+            if (empty($_POST['v_template'])) $errors[] = 'template';
+            if (empty($_POST['v_shell'])) $errrors[] = 'shell';
+            if (!isset($_POST['v_web_domains'])) $errors[] = 'web domains';
+            if (!isset($_POST['v_web_aliases'])) $errors[] = 'web aliases';
+            if (!isset($_POST['v_dns_domains'])) $errors[] = 'dns domains';
+            if (!isset($_POST['v_dns_records'])) $errors[] = 'dns records';
+            if (!isset($_POST['v_mail_domains'])) $errors[] = 'mail domains';
+            if (!isset($_POST['v_mail_accounts'])) $errors[] = 'mail accounts';
+            if (!isset($_POST['v_databases'])) $errors[] = 'databases';
+            if (!isset($_POST['v_cron_jobs'])) $errors[] = 'cron jobs';
+            if (!isset($_POST['v_backups'])) $errors[] = 'backups';
+            if (!isset($_POST['v_disk_quota'])) $errors[] = 'quota';
+            if (!isset($_POST['v_bandwidth'])) $errors[] = 'bandwidth';
+            if (empty($_POST['v_ns1'])) $errors[] = 'ns1';
+            if (empty($_POST['v_ns2'])) $errors[] = 'ns2';
+
+            // Protect input
+            $v_package = escapeshellarg($_POST['v_package']);
+            $v_template = escapeshellarg($_POST['v_template']);
+            $v_shell = escapeshellarg($_POST['v_shell']);
+            $v_web_domains = escapeshellarg($_POST['v_web_domains']);
+            $v_web_aliases = escapeshellarg($_POST['v_web_aliases']);
+            $v_dns_domains = escapeshellarg($_POST['v_dns_domains']);
+            $v_dns_records = escapeshellarg($_POST['v_dns_records']);
+            $v_mail_domains = escapeshellarg($_POST['v_mail_domains']);
+            $v_mail_accounts = escapeshellarg($_POST['v_mail_accounts']);
+            $v_databases = escapeshellarg($_POST['v_databases']);
+            $v_cron_jobs = escapeshellarg($_POST['v_cron_jobs']);
+            $v_backups = escapeshellarg($_POST['v_backups']);
+            $v_disk_quota = escapeshellarg($_POST['v_disk_quota']);
+            $v_bandwidth = escapeshellarg($_POST['v_bandwidth']);
+            $v_ns1 = trim($_POST['v_ns1'], '.');
+            $v_ns2 = trim($_POST['v_ns2'], '.');
+            $v_ns3 = trim($_POST['v_ns3'], '.');
+            $v_ns4 = trim($_POST['v_ns4'], '.');
+            $v_ns = $v_ns1.",".$v_ns2;
+            if (!empty($v_ns3)) $v_ns .= ",".$v_ns3;
+            if (!empty($v_ns4)) $v_ns .= ",".$v_ns4;
+            $v_ns = escapeshellarg($v_ns);
+            $v_time = escapeshellarg(date('H:i:s'));
+            $v_date = escapeshellarg(date('Y-m-d'));
+
+            // Check for errors
+            if (!empty($errors[0])) {
+                foreach ($errors as $i => $error) {
+                    if ( $i == 0 ) {
+                        $error_msg = $error;
+                    } else {
+                        $error_msg = $error_msg.", ".$error;
+                    }
+                }
+                $_SESSION['error_msg'] = "Error: field ".$error_msg." can not be blank.";
+            } else {
+                exec ('mktemp -d', $output, $return_var);
+                $tmpdir = $output[0];
+                unset($output);
+
+                // Create package
+                $pkg = "TEMPLATE=".$v_template."\n";
+                $pkg .= "WEB_DOMAINS=".$v_web_domains."\n";
+                $pkg .= "WEB_ALIASES=".$v_web_aliases."\n";
+                $pkg .= "DNS_DOMAINS=".$v_dns_domains."\n";
+                $pkg .= "DNS_RECORDS=".$v_dns_records."\n";
+                $pkg .= "MAIL_DOMAINS=".$v_mail_domains."\n";
+                $pkg .= "MAIL_ACCOUNTS=".$v_mail_accounts."\n";
+                $pkg .= "DATABASES=".$v_databases."\n";
+                $pkg .= "CRON_JOBS=".$v_cron_jobs."\n";
+                $pkg .= "DISK_QUOTA=".$v_disk_quota."\n";
+                $pkg .= "BANDWIDTH=".$v_bandwidth."\n";
+                $pkg .= "NS=".$v_ns."\n";
+                $pkg .= "SHELL=".$v_shell."\n";
+                $pkg .= "BACKUPS=".$v_backups."\n";
+                $pkg .= "TIME=".$v_time."\n";
+                $pkg .= "DATE=".$v_date."\n";
+
+                // Write package
+                $fp = fopen($tmpdir."/".$_POST['v_package'].".pkg", 'w');
+                fwrite($fp, $pkg);
+                fclose($fp);
+
+                // Rewrite package
+                if (empty($_SESSION['error_msg'])) {
+                    exec (VESTA_CMD."v_add_user_package ".$tmpdir." ".$v_package." 'yes'", $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);
+                }
+
+                // Remove tmpdir
+                exec ('rm -rf '.$tmpdir, $output, $return_var);
+                unset($output);
+
+                // Propogate new package
+                exec (VESTA_CMD."v_update_user_package ".$v_package." 'json'", $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 (empty($_SESSION['error_msg'])) {
+                    $_SESSION['ok_msg'] = "OK: changes has been saved.";
+                }
+            }
+        }
+    }
+
+    include($_SERVER['DOCUMENT_ROOT'].'/templates/admin/menu_edit_package.html');
+    include($_SERVER['DOCUMENT_ROOT'].'/templates/admin/edit_package.html');
+    unset($_SESSION['error_msg']);
+    unset($_SESSION['ok_msg']);
+}
+
+// Footer
+include($_SERVER['DOCUMENT_ROOT'].'/templates/footer.html');

+ 15 - 12
web/templates/admin/add_package.html

@@ -19,6 +19,9 @@
             <?php
                 foreach ($templates as $key => $value) {
                     echo "\t\t\t\t<option value=\"".$value."\"";
+                    if ((!empty($v_template)) && ( $value == $v_template)){
+                        echo 'selected' ;
+                    }
                     if ((!empty($v_template)) && ( $value == $_POST['v_template'])){
                         echo 'selected' ;
                     }
@@ -43,27 +46,27 @@
                 </select></td></tr>
 
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Web Domains</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_web_domains" <?php if (!empty($v_web_domains)) echo "value=".$v_web_domains; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_web_domains" <?php if (isset($v_web_domains)) echo "value=".$v_web_domains; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Web Aliases <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_web_aliases" <?php if (!empty($v_web_aliases)) echo "value=".$v_web_aliases; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_web_aliases" <?php if (isset($v_web_aliases)) echo "value=".$v_web_aliases; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">DNS Domains</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_dns_domains" <?php if (!empty($v_dns_domains)) echo "value=".$v_dns_domains; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_dns_domains" <?php if (isset($v_dns_domains)) echo "value=".$v_dns_domains; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">DNS Records <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_dns_records" <?php if (!empty($v_dns_records)) echo "value=".$v_dns_records; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_dns_records" <?php if (isset($v_dns_records)) echo "value=".$v_dns_records; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Mail Domains</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_mail_domains" <?php if (!empty($v_mail_domains)) echo "value=".$v_mail_domains; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_mail_domains" <?php if (isset($v_mail_domains)) echo "value=".$v_mail_domains; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Mail Accounts <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_mail_accounts" <?php if (!empty($v_mail_accounts)) echo "value=".$v_mail_accounts; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_mail_accounts" <?php if (isset($v_mail_accounts)) echo "value=".$v_mail_accounts; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Databases</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_databases" <?php if (!empty($v_databases)) echo "value=".$v_databases; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_databases" <?php if (isset($v_databases)) echo "value=".$v_databases; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Cron Jobs</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_cron_jobs" <?php if (!empty($v_cron_jobs)) echo "value=".$v_cron_jobs; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_cron_jobs" <?php if (isset($v_cron_jobs)) echo "value=".$v_cron_jobs; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Backups</td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_backups" <?php if (!empty($v_backups)) echo "value=".$v_backups; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_backups" <?php if (isset($v_backups)) echo "value=".$v_backups; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Disk Quota <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(in Mb)</span></td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_disk_quota" <?php if (!empty($v_disk_quota)) echo "value=".$v_disk_quota; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_disk_quota" <?php if (isset($v_disk_quota)) echo "value=".$v_disk_quota; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Bandwidth <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(in Mb)</span></td></tr>
-            <tr><td><input type="text" size="20" class="add-input" name="v_bandwidth" <?php if (!empty($v_bandwidth)) echo "value=".$v_bandwidth; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_bandwidth" <?php if (isset($v_bandwidth)) echo "value=".$v_bandwidth; ?>></tr>
             <tr><td class="add-text" style="padding: 10px 0 0 2px;">Name Servers</td></tr>
             <tr><td><input type="text" size="20" class="add-input" name="v_ns1" <?php if (!empty($v_ns1)) echo "value=".$v_ns1; ?>></tr>
             <tr><td><input type="text" size="20" class="add-input" name="v_ns2" <?php if (!empty($v_ns2)) echo "value=".$v_ns2; ?>></tr>
@@ -74,7 +77,7 @@
             <tr><td style="padding: 24px 0 0 0;">
                 <input type="submit" name="ok" value="OK" class="add-button">
                 </form>
-                <input type="button" class="add-button" value="Cancel" onClick="location.href='/list/user/'">
+                <input type="button" class="add-button" value="Cancel" onClick="location.href='/list/package/'">
             </td></tr>
         </table>
     </td>

+ 87 - 0
web/templates/admin/edit_package.html

@@ -0,0 +1,87 @@
+<table class='data'>
+<tr class="data-add">
+    <td class="data-dotted" style="padding: 0px 10px 0px 0px" width="150">
+        <table class="data-col1">
+            <tr><td style="padding: 24px 0 2px 4px;"><a class="data-date" ?><?php echo date("d M Y", strtotime($v_date))?></a></td></tr>
+            <tr><td style="padding: 0 0 6px 4px;"><a class="data-date" ?><?php echo $v_time?></a></td></tr>
+            <tr><td style="padding: 0 0 0 21px;" class="data-<?php echo $v_status ?>"><b><?php echo $v_status ?></b></td></tr>
+        </table>
+    </td>
+    <td class="data-dotted" width="830px" style="vertical-align:top;">
+        <table width="830px"><tr>
+            <td></td>
+        </tr></table>
+
+        <table class="data-col2" width="830px">
+            <form method="post" name="v_add_user">
+            <tr><td class="add-text" style="padding: 10 0 0 2px;">Package Name</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_package" <?php if (!empty($v_package)) echo "value=".$v_package;  ?> ></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Default Template</td></tr>
+            <tr><td><select class="add-list" name="v_template">
+            <?php
+                foreach ($templates as $key => $value) {
+                    echo "\t\t\t\t<option value=\"".$value."\"";
+                    if ((!empty($v_template)) && ( $value == $v_template)){
+                        echo 'selected' ;
+                    }
+                    if ((!empty($v_template)) && ( $value == $_POST['v_template'])){
+                        echo 'selected' ;
+                    }
+                    echo ">".$value."</option>\n";
+                }
+            ?>
+                </select></td></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">System Shell</td></tr>
+            <tr><td><select class="add-list" name="v_shell">
+            <?php
+                foreach ($shells as $key => $value) {
+                    echo "\t\t\t\t<option value=\"".$value."\"";
+                    if ((!empty($v_shell)) && ( $value == $v_shell)){
+                        echo 'selected' ;
+                    }
+                    if ((!empty($v_shell)) && ( $value == $_POST['v_shell'])){
+                        echo 'selected' ;
+                    }
+                    echo ">".$value."</option>\n";
+                }
+            ?>
+                </select></td></tr>
+
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Web Domains</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_web_domains" <?php if (isset($v_web_domains)) echo "value=".$v_web_domains; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Web Aliases <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_web_aliases" <?php if (isset($v_web_aliases)) echo "value=".$v_web_aliases; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">DNS Domains</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_dns_domains" <?php if (isset($v_dns_domains)) echo "value=".$v_dns_domains; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">DNS Records <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_dns_records" <?php if (isset($v_dns_records)) echo "value=".$v_dns_records; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Mail Domains</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_mail_domains" <?php if (isset($v_mail_domains)) echo "value=".$v_mail_domains; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Mail Accounts <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(per domain)</span></td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_mail_accounts" <?php if (isset($v_mail_accounts)) echo "value=".$v_mail_accounts; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Databases</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_databases" <?php if (isset($v_databases)) echo "value=".$v_databases; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Cron Jobs</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_cron_jobs" <?php if (isset($v_cron_jobs)) echo "value=".$v_cron_jobs; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Backups</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_backups" <?php if (isset($v_backups)) echo "value=".$v_backups; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Disk Quota <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(in Mb)</span></td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_disk_quota" <?php if (isset($v_disk_quota)) echo "value=".$v_disk_quota; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Bandwidth <span style="padding:0 0 0 6px; font-size: 10pt; color:#555;">(in Mb)</span></td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_bandwidth" <?php if (isset($v_bandwidth)) echo "value=".$v_bandwidth; ?>></tr>
+            <tr><td class="add-text" style="padding: 10px 0 0 2px;">Name Servers</td></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_ns1" <?php if (!empty($v_ns1)) echo "value=".$v_ns1; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_ns2" <?php if (!empty($v_ns2)) echo "value=".$v_ns2; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_ns3" <?php if (!empty($v_ns3)) echo "value=".$v_ns3; ?>></tr>
+            <tr><td><input type="text" size="20" class="add-input" name="v_ns4" <?php if (!empty($v_ns4)) echo "value=".$v_ns4; ?>></tr>
+
+
+            <tr><td style="padding: 24px 0 0 0;">
+                <input type="submit" name="save" value="Save" class="add-button">
+                </form>
+                <input type="button" class="add-button" value="Cancel" onClick="location.href='/list/package/'">
+            </td></tr>
+        </table>
+    </td>
+</tr>
+</table>

+ 15 - 0
web/templates/admin/menu_edit_package.html

@@ -0,0 +1,15 @@
+<table class="sub-menu">
+<tr>
+    <td style="padding: 14px 0 24px 0;" ><a class="add-name"><b>Editing User Package</b></a>
+    <?php 
+        if (!empty($_SESSION['error_msg'])) {
+            echo "<a class=\"add-error\"> → ".$_SESSION['error_msg']."</a>";
+        } else {
+            if (!empty($_SESSION['ok_msg'])) {
+                echo "<a class=\"add-ok\"> → ".$_SESSION['ok_msg']."</a>";
+            }
+        }
+    ?>
+    </td>
+</tr>
+</table>