diff --git a/interface/web/vm/ajax_get_ip.php b/interface/web/vm/ajax_get_ip.php new file mode 100644 index 0000000000000000000000000000000000000000..b6963ade9be5f36fefc0ab02b863dffb5b58dc89 --- /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 3d75e8464b154c52b91c65188031b3550bab9172..280473a0eb21f61a68dc0c947fcac844a8379ee6 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 eefe4f0e6fea633f50593ff663b9ceca9da22591..e5bd2111bd894980aacca244983c106e7941645d 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 c6615709c5bd1714786a74ea218f7b4afbb2217d..9ffea3e9adf5001ed51eb2431bc9a0d0abc8ef18 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'}