From 35a68db64451d951fe35a3bbb22dfaf06a20109c Mon Sep 17 00:00:00 2001 From: florian030 <florian@schaal-24.de> Date: Tue, 18 Feb 2014 00:33:30 -0500 Subject: [PATCH] Merge branch 'master' of http://git.ispconfig.org/ispconfig/ispconfig3 --- interface/lib/classes/remote.d/server.inc.php | 46 ++++++++++++++++++++++++++++++++++++++++------ interface/lib/classes/tform_base.inc.php | 5 ++++- 2 files changed, 44 insertions(+), 7 deletions(-) diff --git a/interface/lib/classes/remote.d/server.inc.php b/interface/lib/classes/remote.d/server.inc.php index 61bf92a..4035302 100644 --- a/interface/lib/classes/remote.d/server.inc.php +++ b/interface/lib/classes/remote.d/server.inc.php @@ -115,21 +115,55 @@ */ - public function server_get($session_id, $server_id, $section ='') { + public function server_get($session_id, $server_id = null, $section ='') { + global $app; + if(!$this->checkPerm($session_id, 'server_get')) { + $this->server->fault('permission_denied', 'You do not have the permissions to access this function.'); + return false; + } + if (!empty($session_id)) { + $app->uses('remoting_lib , getconf'); + if(!empty($server_id)) { + $section_config = $app->getconf->get_server_config($server_id, $section); + return $section_config; + } else { + $servers = array(); + $sql = "SELECT server_id FROM server WHERE 1"; + $all = $app->db->queryAllRecords($sql); + foreach($all as $s) { + $servers[$s['server_id']] = $app->getconf->get_server_config($s['server_id'], $section); + } + unset($all); + unset($s); + return $servers; + } + } else { + return false; + } + } + + /** + Gets a list of all servers + @param int session_id + @param int server_name + @author Marius Cramer <m.cramer@pixcept.de> 2014 + */ + public function server_get_all($session_id) + { global $app; if(!$this->checkPerm($session_id, 'server_get')) { $this->server->fault('permission_denied', 'You do not have the permissions to access this function.'); return false; } - if (!empty($session_id) && !empty($server_id)) { - $app->uses('remoting_lib , getconf'); - $section_config = $app->getconf->get_server_config($server_id, $section); - return $section_config; + if (!empty($session_id)) { + $sql = "SELECT server_id, server_name FROM server WHERE 1"; + $servers = $app->db->queryAllRecords($sql); + return $servers; } else { return false; } } - + /** Gets the server_id by server_name @param int session_id diff --git a/interface/lib/classes/tform_base.inc.php b/interface/lib/classes/tform_base.inc.php index e295d55..329f1ef 100644 --- a/interface/lib/classes/tform_base.inc.php +++ b/interface/lib/classes/tform_base.inc.php @@ -270,7 +270,7 @@ unset($tmp_recordid); $querystring = str_replace("{AUTHSQL}", $this->getAuthSQL('r'), $querystring); - $querystring = preg_replace_callback('@{AUTHSQL::(.+?)}@', "self::table_auth_sql", $querystring); + $querystring = preg_replace_callback('@{AUTHSQL::(.+?)}@', array($this, 'table_auth_sql'), $querystring); // Getting the records $tmp_records = $app->db->queryAllRecords($querystring); @@ -312,6 +312,9 @@ } + function table_auth_sql($matches){ + return $this->getAuthSQL('r', $matches[1]); + } /** * Get the key => value array of a form filled from a datasource definitiom -- Gitblit v1.9.1