From d03323d167435f14e65b20475ce4d6e257c7ce43 Mon Sep 17 00:00:00 2001 From: tbrehm Date: Wed, 6 Jun 2012 12:08:47 +0000 Subject: [PATCH] Fixed: FS#2118 - IP addresses dont get loaded into list of openvz container when the server is changed --- interface/web/vm/ajax_get_ip.php | 55 +++++++++++++++++++ interface/web/vm/form/openvz_vm.tform.php | 2 + interface/web/vm/openvz_vm_edit.php | 21 +++++++ interface/web/vm/templates/openvz_vm_edit.htm | 2 +- 4 files changed, 79 insertions(+), 1 deletion(-) create mode 100644 interface/web/vm/ajax_get_ip.php diff --git a/interface/web/vm/ajax_get_ip.php b/interface/web/vm/ajax_get_ip.php new file mode 100644 index 000000000..b6963ade9 --- /dev/null +++ b/interface/web/vm/ajax_get_ip.php @@ -0,0 +1,55 @@ +auth->check_module_permissions('vm'); + +$server_id = intval($_GET["server_id"]); + +if($_SESSION["s"]["user"]["typ"] == 'admin' or $app->auth->has_clients($_SESSION['s']['user']['userid'])) { + + $sql = "SELECT ip_address FROM openvz_ip WHERE reserved = 'n' AND server_id = $server_id"; + $ips = $app->db->queryAllRecords($sql); + $ip_select = ""; + if(is_array($ips)) { + foreach( $ips as $ip) { + //$selected = ($ip["ip_address"] == $this->dataRecord["ip_address"])?'SELECTED':''; + $ip_select .= "$ip[ip_address]#"; + } + } + unset($tmp); + unset($ips); +} +$ip_select = substr($ip_select,0,-1); +echo $ip_select; +?> \ No newline at end of file diff --git a/interface/web/vm/form/openvz_vm.tform.php b/interface/web/vm/form/openvz_vm.tform.php index 3d75e8464..280473a0e 100644 --- a/interface/web/vm/form/openvz_vm.tform.php +++ b/interface/web/vm/form/openvz_vm.tform.php @@ -100,11 +100,13 @@ $form["tabs"]['main'] = array ( 'errmsg'=> 'ip_address_error_empty'), ), 'default' => '', + /* 'datasource' => array ( 'type' => 'SQL', 'querystring' => "SELECT ip_address FROM openvz_ip WHERE reserved = 'n' AND (vm_id = 0 or vm_id = '{RECORDID}') ORDER BY ip_address", 'keyfield'=> 'ip_address', 'valuefield'=> 'ip_address' ), + */ 'value' => '' ), 'hostname' => array ( diff --git a/interface/web/vm/openvz_vm_edit.php b/interface/web/vm/openvz_vm_edit.php index eefe4f0e6..e5bd2111b 100644 --- a/interface/web/vm/openvz_vm_edit.php +++ b/interface/web/vm/openvz_vm_edit.php @@ -157,6 +157,27 @@ class page_action extends tform_actions { } + //* Fill the IPv4 select field with the IP addresses that are allowed for this client + //$sql = "SELECT ip_address FROM server_ip WHERE server_id = ".$client['default_webserver']." AND ip_type = 'IPv4' AND (client_id = 0 OR client_id=".$_SESSION['s']['user']['client_id'].")"; + if(isset($this->dataRecord["server_id"])) { + $vm_server_id = intval($this->dataRecord["server_id"]); + } else { + $tmp = $app->db->queryOneRecord('SELECT server_id FROM server WHERE vserver_server = 1 AND mirror_server_id = 0 ORDER BY server_name LIMIT 0,1'); + $vm_server_id = $tmp['server_id']; + } + $sql = "SELECT ip_address FROM openvz_ip WHERE reserved = 'n' AND (vm_id = 0 or vm_id = '".$this->id."') AND server_id = ".$vm_server_id." ORDER BY ip_address"; + $ips = $app->db->queryAllRecords($sql); + $ip_select = ""; + if(is_array($ips)) { + foreach( $ips as $ip) { + $selected = ($ip["ip_address"] == $this->dataRecord["ip_address"])?'SELECTED':''; + $ip_select .= "\r\n"; + } + } + $app->tpl->setVar("ip_address",$ip_select); + unset($tmp); + unset($ips); + if($this->id > 0) { //* we are editing a existing record $app->tpl->setVar("edit_disabled", 1); diff --git a/interface/web/vm/templates/openvz_vm_edit.htm b/interface/web/vm/templates/openvz_vm_edit.htm index c6615709c..9ffea3e9a 100644 --- a/interface/web/vm/templates/openvz_vm_edit.htm +++ b/interface/web/vm/templates/openvz_vm_edit.htm @@ -15,7 +15,7 @@ - {tmpl_var name='server_id'} -- GitLab