diff --git a/install/sql/incremental/upd_dev_collection.sql b/install/sql/incremental/upd_dev_collection.sql index bbf80e6952342b29aa69537a15eb369b6b74289f..f03448687ad23aa2d75af585d70918737abe3aeb 100644 --- a/install/sql/incremental/upd_dev_collection.sql +++ b/install/sql/incremental/upd_dev_collection.sql @@ -168,3 +168,7 @@ CREATE TABLE `server_ip_map` ( ALTER TABLE `web_domain` ADD COLUMN `rewrite_to_https` ENUM('y','n') NOT NULL DEFAULT 'n' AFTER `seo_redirect`; ALTER TABLE openvz_ip ADD COLUMN `additional` VARCHAR(255) NOT NULL DEFAULT 'n'; + +ALTER TABLE openvz_template ADD COLUMN `custom` text; +ALTER TABLE openvz_vm ADD COLUMN `custom` text; + diff --git a/install/sql/ispconfig3.sql b/install/sql/ispconfig3.sql index 6089f3f7454bed945ce8112f11038edc6c99e6ad..ece5558289f45b5a19fccc6bcbb9cafca19d475e 100644 --- a/install/sql/ispconfig3.sql +++ b/install/sql/ispconfig3.sql @@ -1093,6 +1093,7 @@ CREATE TABLE IF NOT EXISTS `openvz_template` ( `capability` varchar(255) DEFAULT NULL, `features` varchar(255) DEFAULT NULL, `iptables` varchar(255) DEFAULT NULL, + `custom` text, PRIMARY KEY (`template_id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 ; @@ -1100,7 +1101,7 @@ CREATE TABLE IF NOT EXISTS `openvz_template` ( -- Dumping data for table `openvz_template` -- -INSERT INTO `openvz_template` (`template_id`, `sys_userid`, `sys_groupid`, `sys_perm_user`, `sys_perm_group`, `sys_perm_other`, `template_name`, `diskspace`, `traffic`, `bandwidth`, `ram`, `ram_burst`, `cpu_units`, `cpu_num`, `cpu_limit`, `io_priority`, `active`, `description`, `numproc`, `numtcpsock`, `numothersock`, `vmguarpages`, `kmemsize`, `tcpsndbuf`, `tcprcvbuf`, `othersockbuf`, `dgramrcvbuf`, `oomguarpages`, `privvmpages`, `lockedpages`, `shmpages`, `physpages`, `numfile`, `avnumproc`, `numflock`, `numpty`, `numsiginfo`, `dcachesize`, `numiptent`, `swappages`, `hostname`, `nameserver`, `create_dns`, `capability`, `features`, `iptables`) VALUES(1, 1, 1, 'riud', 'riud', '', 'small', 10, -1, -1, 256, 512, 1000, 4, 400, 4, 'y', '', '999999:999999', '7999992:7999992', '7999992:7999992', '65536:65536', '2147483646:2147483646', '214748160:396774400', '214748160:396774400', '214748160:396774400', '214748160:396774400', '65536:65536', '131072:131072', '999999:999999', '65536:65536', '0:2147483647', '23999976:23999976', '180:180', '999999:999999', '500000:500000', '999999:999999', '2147483646:2147483646', '999999:999999', '256000:256000', 'v{VEID}.test.tld', '8.8.8.8 8.8.4.4', 'n', '', '', ''); +INSERT INTO `openvz_template` (`template_id`, `sys_userid`, `sys_groupid`, `sys_perm_user`, `sys_perm_group`, `sys_perm_other`, `template_name`, `diskspace`, `traffic`, `bandwidth`, `ram`, `ram_burst`, `cpu_units`, `cpu_num`, `cpu_limit`, `io_priority`, `active`, `description`, `numproc`, `numtcpsock`, `numothersock`, `vmguarpages`, `kmemsize`, `tcpsndbuf`, `tcprcvbuf`, `othersockbuf`, `dgramrcvbuf`, `oomguarpages`, `privvmpages`, `lockedpages`, `shmpages`, `physpages`, `numfile`, `avnumproc`, `numflock`, `numpty`, `numsiginfo`, `dcachesize`, `numiptent`, `swappages`, `hostname`, `nameserver`, `create_dns`, `capability`, `features`, `iptables`) VALUES(1, 1, 1, 'riud', 'riud', '', 'small', 10, -1, -1, 256, 512, 1000, 4, 400, 4, 'y', '', '999999:999999', '7999992:7999992', '7999992:7999992', '65536:65536', '2147483646:2147483646', '214748160:396774400', '214748160:396774400', '214748160:396774400', '214748160:396774400', '65536:65536', '131072:131072', '999999:999999', '65536:65536', '0:2147483647', '23999976:23999976', '180:180', '999999:999999', '500000:500000', '999999:999999', '2147483646:2147483646', '999999:999999', '256000:256000', 'v{VEID}.test.tld', '8.8.8.8 8.8.4.4', 'n', '', '', '', ''); -- -------------------------------------------------------- @@ -1159,6 +1160,7 @@ CREATE TABLE IF NOT EXISTS `openvz_vm` ( `features` text, `iptabless` text, `config` mediumtext, + `custom` text, PRIMARY KEY (`vm_id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 ; diff --git a/interface/lib/classes/validate_openvz.inc.php b/interface/lib/classes/validate_openvz.inc.php new file mode 100644 index 0000000000000000000000000000000000000000..75e41fe65fe485c138a24dcaccf31f3dbaab9eeb --- /dev/null +++ b/interface/lib/classes/validate_openvz.inc.php @@ -0,0 +1,66 @@ +<?php + +/** + Copyright (c) 2015, Florian Schaal, schaal @it + All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, + are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + * Neither the name of ISPConfig nor the names of its contributors + may be used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY + OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, + EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + @author Florian Schaal, info@schaal-24.de + @copyrighth Florian Schaal, info@schaal-24.de + */ + +class validate_openvz { + + function get_error($errmsg, $additional='') { + global $app; + if(isset($app->tform->wordbook[$errmsg])) { + return $app->tform->wordbook[$errmsg].$additional."<br>\r\n"; + } else { + return $errmsg."<br>".$additional."<br>\r\n"; + } + } + + function check_custom($field_name, $field_value, $validator) { + $template = file('../vm/templates/openvz.conf.tpl', FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES); + $custom_array = explode("\n", $field_value); + $used_parameters = array(); + foreach ($template as $line) { + $line = trim ($line); + if (preg_match('/^[^#].*=\".*\"/', $line)) { + $line = explode('=', $line, 2); + $used_parameters[] = $line[0]; + } + } + foreach ($custom_array as $check) { + $check = trim(strtoupper($check)); + $check = explode('=', trim($check), 2); + $check = trim($check[0]); + if (in_array($check, $used_parameters)) { + return $this->get_error($validator['errmsg'], $check); + } + } + } + +} diff --git a/interface/lib/plugins/vm_openvz_plugin.inc.php b/interface/lib/plugins/vm_openvz_plugin.inc.php index 5f6e3bbe800365a05b372a6f92e06f181d6c5c3a..aae645c4f30e7ad4372884e8f88fb91f2956f99f 100644 --- a/interface/lib/plugins/vm_openvz_plugin.inc.php +++ b/interface/lib/plugins/vm_openvz_plugin.inc.php @@ -156,8 +156,9 @@ class vm_openvz_plugin { $sql .= "capability = ?, "; $sql .= "features = ?, "; $sql .= "iptables = ? "; + $sql .= "custom = ? "; $sql .= "WHERE vm_id = ?"; - $app->db->query($sql, $tpl['diskspace'], $tpl['ram'], $tpl['ram_burst'], $tpl['cpu_units'], $tpl['cpu_num'], $tpl['cpu_limit'], $tpl['io_priority'], $tpl['nameserver'], $tpl['create_dns'], $tpl['capability'], $tpl['features'], $tpl['iptables'], $this->id); + $app->db->query($sql, $tpl['diskspace'], $tpl['ram'], $tpl['ram_burst'], $tpl['cpu_units'], $tpl['cpu_num'], $tpl['cpu_limit'], $tpl['io_priority'], $tpl['nameserver'], $tpl['create_dns'], $tpl['capability'], $tpl['features'], $tpl['iptables'], $tpl['custom'], $this->id); } @@ -230,6 +231,8 @@ class vm_openvz_plugin { $tpl->setVar('features', $vm['features']); $tpl->setVar('iptables', $vm['iptables']); + $tpl->setVar('custom', $vm['custom']); + $tmp = $app->db->queryOneRecord("SELECT template_file FROM openvz_ostemplate WHERE ostemplate_id = ?", $app->functions->intval($vm['ostemplate_id'])); $tpl->setVar('ostemplate', $tmp['template_file']); unset($tmp); diff --git a/interface/web/vm/form/openvz_template.tform.php b/interface/web/vm/form/openvz_template.tform.php index fd67c99179837855f5e65ca16bcf9c32cdcb9dae..8279ce085c8566a0b41096b2800f1b5013d0d919 100644 --- a/interface/web/vm/form/openvz_template.tform.php +++ b/interface/web/vm/form/openvz_template.tform.php @@ -475,6 +475,22 @@ $form["tabs"]['advanced'] = array ( 'width' => '30', 'maxlength' => '255' ), + 'custom' => array ( + 'datatype' => 'TEXT', + 'formtype' => 'TEXTAREA', + 'default' => '', + 'value' => '', + 'separator' => '', + 'width' => '', + 'maxlength' => '', + 'rows' => '10', + 'cols' => '30', + 'validators' => array ( 0 => array ('type' => 'CUSTOM', + 'class' => 'validate_openvz', + 'function' => 'check_custom', + 'errmsg'=> 'custom_error'), + ), + ), //################################# // ENDE Datatable fields //################################# diff --git a/interface/web/vm/form/openvz_vm.tform.php b/interface/web/vm/form/openvz_vm.tform.php index d6911ccfda4910dd45a4f0705499dc4de79b21c3..37bf86975edc552aeb21f251f8b4d12a411a9894 100644 --- a/interface/web/vm/form/openvz_vm.tform.php +++ b/interface/web/vm/form/openvz_vm.tform.php @@ -322,6 +322,23 @@ if($_SESSION["s"]["user"]["typ"] == 'admin') { 'width' => '30', 'maxlength' => '255' ), + 'custom' => array ( + 'datatype' => 'TEXT', + 'formtype' => 'TEXTAREA', + 'default' => '', + 'value' => '', + 'separator' => '', + 'width' => '', + 'maxlength' => '', + 'rows' => '10', + 'cols' => '30', + 'searchable' => 2, + 'validators' => array ( 0 => array ('type' => 'CUSTOM', + 'class' => 'validate_openvz', + 'function' => 'check_custom', + 'errmsg'=> 'custom_error'), + ), + ), //################################# // ENDE Datatable fields //################################# diff --git a/interface/web/vm/lib/lang/ar_openvz_template.lng b/interface/web/vm/lib/lang/ar_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/ar_openvz_template.lng +++ b/interface/web/vm/lib/lang/ar_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/ar_openvz_vm.lng b/interface/web/vm/lib/lang/ar_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/ar_openvz_vm.lng +++ b/interface/web/vm/lib/lang/ar_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/bg_openvz_template.lng b/interface/web/vm/lib/lang/bg_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/bg_openvz_template.lng +++ b/interface/web/vm/lib/lang/bg_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/bg_openvz_vm.lng b/interface/web/vm/lib/lang/bg_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/bg_openvz_vm.lng +++ b/interface/web/vm/lib/lang/bg_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/br_openvz_template.lng b/interface/web/vm/lib/lang/br_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/br_openvz_template.lng +++ b/interface/web/vm/lib/lang/br_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/br_openvz_vm.lng b/interface/web/vm/lib/lang/br_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/br_openvz_vm.lng +++ b/interface/web/vm/lib/lang/br_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/cz_openvz_template.lng b/interface/web/vm/lib/lang/cz_openvz_template.lng index 3abd8167dc709ba7259c5f9bbe314e06b0ee3abb..26434be3b91312277a78da4637342fc70028fb26 100644 --- a/interface/web/vm/lib/lang/cz_openvz_template.lng +++ b/interface/web/vm/lib/lang/cz_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Å ablona'; $wb['Advanced'] = 'PokroÄilý'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/cz_openvz_vm.lng b/interface/web/vm/lib/lang/cz_openvz_vm.lng index eaf12b75576efc915e07765926bad49cfa09bcd9..9d20c9be862a51f4cd80f7a86cf60d76e7e8db84 100644 --- a/interface/web/vm/lib/lang/cz_openvz_vm.lng +++ b/interface/web/vm/lib/lang/cz_openvz_vm.lng @@ -39,5 +39,6 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'PokroÄilý'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/de_openvz_template.lng b/interface/web/vm/lib/lang/de_openvz_template.lng index c86e878b75db6b359c15993fb8d0a69f2939ec70..776e14a5e1aab9b605f7b460371d0d71833be283 100644 --- a/interface/web/vm/lib/lang/de_openvz_template.lng +++ b/interface/web/vm/lib/lang/de_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Erweitert'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/de_openvz_vm.lng b/interface/web/vm/lib/lang/de_openvz_vm.lng index edce4b733b1477cc52485ee839ac2144c642f14c..467af85dbd50fccaf508ca44c3b31cb541374266 100644 --- a/interface/web/vm/lib/lang/de_openvz_vm.lng +++ b/interface/web/vm/lib/lang/de_openvz_vm.lng @@ -38,4 +38,5 @@ $wb['template_nameserver_error_empty'] = 'Nameserver ist leer.'; $wb['Virtual server'] = 'Virtueller Server'; $wb['Advanced'] = 'Erweitert'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/el_openvz_template.lng b/interface/web/vm/lib/lang/el_openvz_template.lng index b8c654372351e19e6a53689f4e0cc9532c6b93fb..75b2d7f2f174a051b7861b7f7e52fbddb3d3422e 100644 --- a/interface/web/vm/lib/lang/el_openvz_template.lng +++ b/interface/web/vm/lib/lang/el_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/el_openvz_vm.lng b/interface/web/vm/lib/lang/el_openvz_vm.lng index c74b1029232f8cdd8523be6a48db330e8a269567..24b6e26d20528d360066673850a7e19e3c52f09d 100644 --- a/interface/web/vm/lib/lang/el_openvz_vm.lng +++ b/interface/web/vm/lib/lang/el_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Εικονικός server'; $wb['Advanced'] = 'Για Ï€ÏοχωÏημÎνους'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/en_openvz_template.lng b/interface/web/vm/lib/lang/en_openvz_template.lng index a2b7f8db966feac079f8752917ab24fb1eae6c52..cb648cbd6aab68f5249f7b72bbbb06a2674ef197 100644 --- a/interface/web/vm/lib/lang/en_openvz_template.lng +++ b/interface/web/vm/lib/lang/en_openvz_template.lng @@ -92,4 +92,6 @@ $wb["Template"] = 'Template'; $wb["Advanced"] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/en_openvz_vm.lng b/interface/web/vm/lib/lang/en_openvz_vm.lng index 67cdbfd6f5d05eb7338f354601fb4fc02c961632..213e3ad25d5d71fb89fe5970650c55bf435e00d5 100644 --- a/interface/web/vm/lib/lang/en_openvz_vm.lng +++ b/interface/web/vm/lib/lang/en_openvz_vm.lng @@ -39,4 +39,5 @@ $wb["Virtual server"] = 'Virtual server'; $wb["Advanced"] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/es_openvz_template.lng b/interface/web/vm/lib/lang/es_openvz_template.lng index cad093304b699820fb8675925eafe3dd51abe934..bffc71705735fddc1ec037e6c34cfe898336bd24 100644 --- a/interface/web/vm/lib/lang/es_openvz_template.lng +++ b/interface/web/vm/lib/lang/es_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Plantilla'; $wb['Advanced'] = 'Avanzado'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/es_openvz_vm.lng b/interface/web/vm/lib/lang/es_openvz_vm.lng index 6a88f4f441ba82d125555dc216aa3a39d26a43b6..2982a9af8bedb4b8cacc78a996a1fb5955015b06 100644 --- a/interface/web/vm/lib/lang/es_openvz_vm.lng +++ b/interface/web/vm/lib/lang/es_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Servidor virtual'; $wb['Advanced'] = 'Avanzado'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/fi_openvz_template.lng b/interface/web/vm/lib/lang/fi_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/fi_openvz_template.lng +++ b/interface/web/vm/lib/lang/fi_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/fi_openvz_vm.lng b/interface/web/vm/lib/lang/fi_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/fi_openvz_vm.lng +++ b/interface/web/vm/lib/lang/fi_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/fr_openvz_template.lng b/interface/web/vm/lib/lang/fr_openvz_template.lng index 66db26534dad061c2e2b72f663588b44513e7189..c2554a0b76f45b6d60eccde471a262cb189578e6 100644 --- a/interface/web/vm/lib/lang/fr_openvz_template.lng +++ b/interface/web/vm/lib/lang/fr_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Modèle'; $wb['Advanced'] = 'Avancé'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/fr_openvz_vm.lng b/interface/web/vm/lib/lang/fr_openvz_vm.lng index 26d21a06346f2c62ad4a1de938ea23d9bd04ee2e..d01f6248f914b2dd51010d7d35f8ba86ab8d8b74 100644 --- a/interface/web/vm/lib/lang/fr_openvz_vm.lng +++ b/interface/web/vm/lib/lang/fr_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Serveur virtuel'; $wb['Advanced'] = 'Avancé'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/hr_openvz_template.lng b/interface/web/vm/lib/lang/hr_openvz_template.lng index 69b36b92026105395278dcc7847a99d5f3a64d9b..622274bc4dee0fa3b9467f3da48bcdc908e8ab7e 100644 --- a/interface/web/vm/lib/lang/hr_openvz_template.lng +++ b/interface/web/vm/lib/lang/hr_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Predložak'; $wb['Advanced'] = 'Napredno'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/hr_openvz_vm.lng b/interface/web/vm/lib/lang/hr_openvz_vm.lng index 6ae18e105d1b59604440a782d8cf2b7aed01ef5a..5169eb95554a629167cc872a498a3e23deb4d875 100644 --- a/interface/web/vm/lib/lang/hr_openvz_vm.lng +++ b/interface/web/vm/lib/lang/hr_openvz_vm.lng @@ -39,6 +39,7 @@ $wb['Virtual server'] = 'Virtualni server'; $wb['Advanced'] = 'Napredno'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/hu_openvz_template.lng b/interface/web/vm/lib/lang/hu_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/hu_openvz_template.lng +++ b/interface/web/vm/lib/lang/hu_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/hu_openvz_vm.lng b/interface/web/vm/lib/lang/hu_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/hu_openvz_vm.lng +++ b/interface/web/vm/lib/lang/hu_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/id_openvz_template.lng b/interface/web/vm/lib/lang/id_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/id_openvz_template.lng +++ b/interface/web/vm/lib/lang/id_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/id_openvz_vm.lng b/interface/web/vm/lib/lang/id_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/id_openvz_vm.lng +++ b/interface/web/vm/lib/lang/id_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/it_openvz_template.lng b/interface/web/vm/lib/lang/it_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/it_openvz_template.lng +++ b/interface/web/vm/lib/lang/it_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/it_openvz_vm.lng b/interface/web/vm/lib/lang/it_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/it_openvz_vm.lng +++ b/interface/web/vm/lib/lang/it_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/ja_openvz_template.lng b/interface/web/vm/lib/lang/ja_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/ja_openvz_template.lng +++ b/interface/web/vm/lib/lang/ja_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/ja_openvz_vm.lng b/interface/web/vm/lib/lang/ja_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/ja_openvz_vm.lng +++ b/interface/web/vm/lib/lang/ja_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/nl_openvz_template.lng b/interface/web/vm/lib/lang/nl_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/nl_openvz_template.lng +++ b/interface/web/vm/lib/lang/nl_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/nl_openvz_vm.lng b/interface/web/vm/lib/lang/nl_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/nl_openvz_vm.lng +++ b/interface/web/vm/lib/lang/nl_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/pl_openvz_template.lng b/interface/web/vm/lib/lang/pl_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/pl_openvz_template.lng +++ b/interface/web/vm/lib/lang/pl_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/pl_openvz_vm.lng b/interface/web/vm/lib/lang/pl_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/pl_openvz_vm.lng +++ b/interface/web/vm/lib/lang/pl_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/pt_openvz_template.lng b/interface/web/vm/lib/lang/pt_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/pt_openvz_template.lng +++ b/interface/web/vm/lib/lang/pt_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/pt_openvz_vm.lng b/interface/web/vm/lib/lang/pt_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/pt_openvz_vm.lng +++ b/interface/web/vm/lib/lang/pt_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/ro_openvz_template.lng b/interface/web/vm/lib/lang/ro_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/ro_openvz_template.lng +++ b/interface/web/vm/lib/lang/ro_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/ro_openvz_vm.lng b/interface/web/vm/lib/lang/ro_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/ro_openvz_vm.lng +++ b/interface/web/vm/lib/lang/ro_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/ru_openvz_template.lng b/interface/web/vm/lib/lang/ru_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/ru_openvz_template.lng +++ b/interface/web/vm/lib/lang/ru_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/ru_openvz_vm.lng b/interface/web/vm/lib/lang/ru_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/ru_openvz_vm.lng +++ b/interface/web/vm/lib/lang/ru_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/se_openvz_template.lng b/interface/web/vm/lib/lang/se_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/se_openvz_template.lng +++ b/interface/web/vm/lib/lang/se_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/se_openvz_vm.lng b/interface/web/vm/lib/lang/se_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/se_openvz_vm.lng +++ b/interface/web/vm/lib/lang/se_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/sk_openvz_template.lng b/interface/web/vm/lib/lang/sk_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/sk_openvz_template.lng +++ b/interface/web/vm/lib/lang/sk_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/sk_openvz_vm.lng b/interface/web/vm/lib/lang/sk_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/sk_openvz_vm.lng +++ b/interface/web/vm/lib/lang/sk_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/lib/lang/tr_openvz_template.lng b/interface/web/vm/lib/lang/tr_openvz_template.lng index 262cad0dab88af8bf1d89b98b5bfb021a6089220..27dfbbb7b5d51c3beb773a7112020838f305b587 100644 --- a/interface/web/vm/lib/lang/tr_openvz_template.lng +++ b/interface/web/vm/lib/lang/tr_openvz_template.lng @@ -92,4 +92,6 @@ $wb['Template'] = 'Template'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; +$wb["custom_error"] = "Not allowed in Custom settings: "; ?> diff --git a/interface/web/vm/lib/lang/tr_openvz_vm.lng b/interface/web/vm/lib/lang/tr_openvz_vm.lng index 3f4e1c1ee1d2a76cbf5d17347673f845e14ccb76..bbf388a875dcea73df2e41a924118ef287304dc3 100644 --- a/interface/web/vm/lib/lang/tr_openvz_vm.lng +++ b/interface/web/vm/lib/lang/tr_openvz_vm.lng @@ -39,4 +39,5 @@ $wb['Virtual server'] = 'Virtual server'; $wb['Advanced'] = 'Advanced'; $wb['features_txt'] = 'Features'; $wb["iptables_txt"] = "IP Tables"; +$wb["custom_txt"] = "Custom settings"; ?> diff --git a/interface/web/vm/templates/openvz.conf.tpl b/interface/web/vm/templates/openvz.conf.tpl index 1cb4dc06198ec0ea84cf8d72dd87578a6b547764..a2b061a06fcf56d968eaf6dead34901e6d92c4d6 100644 --- a/interface/web/vm/templates/openvz.conf.tpl +++ b/interface/web/vm/templates/openvz.conf.tpl @@ -50,3 +50,4 @@ MEMINFO="privvmpages:1" CAPABILITY="{tmpl_var name='capability'}" FEATURES="{tmpl_var name='features'}" IPTABLES="{tmpl_var name='iptables'}" +{tmpl_var name='custom'} diff --git a/interface/web/vm/templates/openvz_template_advanced_edit.htm b/interface/web/vm/templates/openvz_template_advanced_edit.htm index d3dee9a281a1afe800724566c0a87e21553d5a29..3712906ed0ce11b84e51b7d66f1a4a945109f19a 100644 --- a/interface/web/vm/templates/openvz_template_advanced_edit.htm +++ b/interface/web/vm/templates/openvz_template_advanced_edit.htm @@ -80,7 +80,9 @@ <div class="form-group"> <label for="iptables" class="col-sm-3 control-label">{tmpl_var name='iptables_txt'}</label> <div class="col-sm-9"><input type="text" name="iptables" id="iptables" value="{tmpl_var name='iptables'}" class="form-control" /></div></div> - + <div class="form-group"> + <label for="custom" class="col-sm-3 control-label">{tmpl_var name='custom_txt'}</label> + <div class="col-sm-9"><textarea class="form-control" name="custom" id="custom" rows='10' cols='30'>{tmpl_var name='custom'}</textarea></div></div> <input type="hidden" name="id" value="{tmpl_var name='id'}"> diff --git a/interface/web/vm/templates/openvz_vm_advanced_edit.htm b/interface/web/vm/templates/openvz_vm_advanced_edit.htm index 83bbb3d5198de864ba4755140936ef5fc5d4a3e4..a25d715e575fdc7fd92117aea208fc0fe0c9a85a 100644 --- a/interface/web/vm/templates/openvz_vm_advanced_edit.htm +++ b/interface/web/vm/templates/openvz_vm_advanced_edit.htm @@ -58,6 +58,10 @@ <label for="iptables" class="col-sm-3 control-label">{tmpl_var name='iptables_txt'}</label> <div class="col-sm-9"><input type="text" name="iptables" id="iptables" value="{tmpl_var name='iptables'}" class="form-control" /> </div></div> + <div class="form-group"> + <label for="custom" class="col-sm-3 control-label">{tmpl_var name='custom_txt'}</label> + <div class="col-sm-9"><textarea class="form-control" name="custom" id="custom" rows='10' cols='30'>{tmpl_var name='custom'}</textarea></div> + </div> <input type="hidden" name="id" value="{tmpl_var name='id'}">