Marius Cramer
2015-08-06 37b29231e47a0c4458dc1c15d98588f16f07e1e2
interface/web/sites/ajax_get_json.php
@@ -28,100 +28,218 @@
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
require_once('../../lib/config.inc.php');
require_once('../../lib/app.inc.php');
require_once '../../lib/config.inc.php';
require_once '../../lib/app.inc.php';
//* Check permissions for module
$app->auth->check_module_permissions('sites');
$app->uses('getconf');
$app->uses('getconf,tform');
$server_id = intval($_GET["server_id"]);
$web_id = intval($_GET["web_id"]);
$server_id = $app->functions->intval($_GET["server_id"]);
$web_id = $app->functions->intval($_GET["web_id"]);
$php_type = $_GET["php_type"];
$client_group_id = $app->functions->intval($_GET['client_group_id']);
$type = $_GET["type"];
//if($_SESSION["s"]["user"]["typ"] == 'admin') {
   if($type == 'getservertype'){
      $json = '{"servertype":"';
      $server_type = 'apache';
      $web_config = $app->getconf->get_server_config($server_id, 'web');
      if(!empty($web_config['server_type'])) $server_type = $web_config['server_type'];
      $json .= $server_type;
      unset($webconfig);
      $json .= '"}';
if($type == 'getservertype'){
   $json = '{"servertype":"';
   $server_type = 'apache';
   $web_config = $app->getconf->get_server_config($server_id, 'web');
   if(!empty($web_config['server_type'])) $server_type = $web_config['server_type'];
   $json .= $server_type;
   unset($webconfig);
   $json .= '"}';
}
if($type == 'getserverid'){
   $json = '{"serverid":"';
   $sql = "SELECT server_id FROM web_domain WHERE domain_id = ? AND ".$app->tform->getAuthSQL('r');
   $server = $app->db->queryOneRecord($sql, $web_id);
   $json .= $server['server_id'];
   unset($server);
   $json .= '"}';
}
if($type == 'getphpfastcgi'){
   $json = '{';
   $server_type = 'apache';
   $web_config = $app->getconf->get_server_config($server_id, 'web');
   if(!empty($web_config['server_type'])) $server_type = $web_config['server_type'];
   if($server_type == 'nginx' && $php_type == 'fast-cgi') $php_type = 'php-fpm';
   $sql_where = '';
   //* Client: If the logged in user is not admin and has no sub clients (no reseller)
   if($_SESSION["s"]["user"]["typ"] != 'admin' && !$app->auth->has_clients($_SESSION['s']['user']['userid'])) {
      $sql_where = " AND (client_id = 0 OR client_id = ".$app->functions->intval($_SESSION["s"]["user"]["client_id"]) . ")";
      //* Reseller: If the logged in user is not admin and has sub clients (is a reseller)
   } elseif ($_SESSION["s"]["user"]["typ"] != 'admin' && $app->auth->has_clients($_SESSION['s']['user']['userid'])) {
      $client = $app->db->queryOneRecord("SELECT client_id FROM sys_group WHERE groupid = ?", $client_group_id);
      //$sql_where = " AND (client_id = 0 OR client_id = ".$_SESSION["s"]["user"]["client_id"];
      $sql_where = " AND (client_id = 0";
      if($app->functions->intval($client['client_id']) > 0) $sql_where .= " OR client_id = ".$app->functions->intval($client['client_id']);
      $sql_where .= ")";
      //* Admin: If the logged in user is admin
   } else {
      //$sql_where = '';
      $client = $app->db->queryOneRecord("SELECT client_id FROM sys_group WHERE groupid = ?", $client_group_id);
      //$sql_where = " AND (client_id = 0 OR client_id = ".$_SESSION["s"]["user"]["client_id"];
      $sql_where = " AND (client_id = 0";
      if($app->functions->intval($client['client_id']) > 0) $sql_where .= " OR client_id = ".$app->functions->intval($client['client_id']);
      $sql_where .= ")";
   }
   if($type == 'getserverid'){
      $json = '{"serverid":"';
      $sql = "SELECT server_id FROM web_domain WHERE domain_id = $web_id";
      $server = $app->db->queryOneRecord($sql);
      $json .= $server['server_id'];
      unset($server);
      $json .= '"}';
   if($php_type == 'php-fpm'){
      $php_records = $app->db->queryAllRecords("SELECT * FROM server_php WHERE php_fpm_init_script != '' AND php_fpm_ini_dir != '' AND php_fpm_pool_dir != '' AND server_id = ?".$sql_where, $server_id);
   } elseif($php_type == 'fast-cgi'){
      $php_records = $app->db->queryAllRecords("SELECT * FROM server_php WHERE php_fastcgi_binary != '' AND php_fastcgi_ini_dir != '' AND server_id = ?".$sql_where, $server_id);
   }
   if($type == 'getphpfastcgi'){
      $json = '{';
   $php_select = "";
   if(is_array($php_records) && !empty($php_records)) {
      foreach( $php_records as $php_record) {
         if($php_type == 'php-fpm'){
            $php_version = $php_record['name'].':'.$php_record['php_fpm_init_script'].':'.$php_record['php_fpm_ini_dir'].':'.$php_record['php_fpm_pool_dir'];
         } else {
            $php_version = $php_record['name'].':'.$php_record['php_fastcgi_binary'].':'.$php_record['php_fastcgi_ini_dir'];
         }
         $json .= '"'.$php_version.'": "'.$php_record['name'].'",';
      }
   }
   unset($php_records);
   if(substr($json, -1) == ',') $json = substr($json, 0, -1);
   $json .= '}';
}
if($type == 'getphptype'){
   $json = '{"phptype":"';
   $sql = "SELECT php FROM web_domain WHERE domain_id = ? AND ".$app->tform->getAuthSQL('r');
   $php = $app->db->queryOneRecord($sql, $web_id);
   $json .= $php['php'];
   unset($php);
   $json .= '"}';
}
if($type == 'getredirecttype'){
   $json = '{"redirecttype":"';
   $sql = "SELECT redirect_type FROM web_domain WHERE domain_id = ? AND ".$app->tform->getAuthSQL('r');
   $redirect = $app->db->queryOneRecord($sql, $web_id);
   $json .= $redirect['redirect_type'];
   unset($redirect);
   $json .= '"}';
}
if($type == 'get_ipv4'){
   $result = array();
   // ipv4
   //$result[] = _search('admin', 'server_ip', "AND ip_type = 'IPv4' AND (client_id = 0 OR client_id=".$app->functions->intval($_SESSION['s']['user']['client_id']).")");
   $result[] = $app->functions->suggest_ips('IPv4');
   $json = $app->functions->json_encode($result);
}
if($type == 'get_ipv6'){
   $result = array();
   // ipv6
   //$result[] = _search('admin', 'server_ip', "AND ip_type = 'IPv6' AND (client_id = 0 OR client_id=".$app->functions->intval($_SESSION['s']['user']['client_id']).")");
   $result[] = $app->functions->suggest_ips('IPv6');
   $json = $app->functions->json_encode($result);
}
if($type == 'getdatabaseusers') {
   $json = '{}';
   $sql = "SELECT sys_groupid FROM web_domain WHERE domain_id = ? AND ".$app->tform->getAuthSQL('r');
   $group = $app->db->queryOneRecord($sql, $web_id);
   if($group) {
      $sql = "SELECT database_user_id, database_user FROM web_database_user WHERE sys_groupid = ?";
      $records = $app->db->queryAllRecords($sql, $group['sys_groupid']);
      $tmp_array = array();
      foreach($records as $record) {
         $tmp_array[$record['database_user_id']] = $record['database_user'];
      }
      $json = $app->functions->json_encode($tmp_array);
      unset($records, $group, $tmp_array);
   }
}
if($type == 'get_use_combobox'){
   $json = '{"usecombobox":"';
   $use_combobox = 'y';
   $server_config_array = $app->getconf->get_global_config();
   if($server_config_array['misc']['use_combobox'] != 'y') $use_combobox = 'n';
   $json .= $use_combobox;
   unset($server_config_array);
   $json .= '"}';
}
if($type == 'get_use_loadindicator'){
   $json = '{"useloadindicator":"';
   $use_loadindicator = 'y';
   $server_config_array = $app->getconf->get_global_config();
   if($server_config_array['misc']['use_loadindicator'] != 'y') $use_loadindicator = 'n';
   $json .= $use_loadindicator;
   unset($server_config_array);
   $json .= '"}';
}
if ($type == 'getdirectivesnippet') {
   $server_type = 'apache';
   $web_config = $app->getconf->get_server_config($server_id, 'web');
   if (!empty($web_config['server_type']))
      $server_type = $web_config['server_type'];
   $snippets = $app->db->queryAllRecords("SELECT directive_snippets_id, name FROM directive_snippets WHERE customer_viewable = 'y' AND type = ? ORDER BY name ASC", $server_type);
   $json = json_encode($snippets);
}
if($type == 'getclientssldata'){
   $web = $app->db->queryOneRecord("SELECT * FROM web_domain WHERE domain_id = ?", $web_id);
   $sys_group = $app->db->queryOneRecord("SELECT * FROM sys_group WHERE groupid = ?", $web['sys_groupid']);
   $client = $app->db->queryOneRecord("SELECT * FROM client WHERE client_id = ?", $sys_group['client_id']);
   if(is_array($client) && !empty($client)){
      if($client['telephone'] == '' && $client['mobile'] != '') $client['telephone'] = $client['mobile'];
      
      $server_type = 'apache';
      $web_config = $app->getconf->get_server_config($server_id, 'web');
      if(!empty($web_config['server_type'])) $server_type = $web_config['server_type'];
      if($server_type == 'nginx' && $php_type == 'fast-cgi') $php_type = 'php-fpm';
      if($php_type == 'php-fpm'){
         $php_records = $app->db->queryAllRecords("SELECT * FROM server_php WHERE php_fpm_init_script != '' AND php_fpm_ini_dir != '' AND php_fpm_pool_dir != '' AND server_id = $server_id");
      $fname = '';
      $lname = '';
      $parts = preg_split("/\s+/", $client['contact_name']);
      if(sizeof($parts) == 2){
         $fname = $parts[0];
         $lname = $parts[1];
      }
      if($php_type == 'fast-cgi'){
         $php_records = $app->db->queryAllRecords("SELECT * FROM server_php WHERE php_fastcgi_binary != '' AND php_fastcgi_ini_dir != '' AND server_id = $server_id");
      }
      $php_select = "";
      if(is_array($php_records) && !empty($php_records)) {
         foreach( $php_records as $php_record) {
            if($php_type == 'php-fpm'){
               $php_version = $php_record['name'].':'.$php_record['php_fpm_init_script'].':'.$php_record['php_fpm_ini_dir'].':'.$php_record['php_fpm_pool_dir'];
      if(sizeof($parts) > 2){
         $fname = $parts[0].' ';
         for($i=1;$i<sizeof($parts);$i++){
            if($i == (sizeof($parts) - 1)){
               $lname .= $parts[$i];
            } else {
               $php_version = $php_record['name'].':'.$php_record['php_fastcgi_binary'].':'.$php_record['php_fastcgi_ini_dir'];
               if(preg_match('@^(von|van|ten|ter|zur|zu|auf|sieber)$@i', $parts[$i])){
                  $lname .= implode(' ', array_slice($parts, $i));
                  break;
               } else {
                  $fname .= $parts[$i].' ';
               }
            }
            $json .= '"'.$php_version.'": "'.$php_record['name'].'",';
         }
      }
      unset($php_records);
      if(substr($json,-1) == ',') $json = substr($json,0,-1);
      $json .= '}';
      $fname = trim($fname);
      $lname = trim($lname);
      $client['fname'] = $fname;
      $client['lname'] = $lname;
      if(trim($client['company_name']) == '') $client['company_name'] = $fname.' '.$lname;
   }
   if($type == 'getphptype'){
      $json = '{"phptype":"';
      $sql = "SELECT php FROM web_domain WHERE domain_id = $web_id";
      $php = $app->db->queryOneRecord($sql);
      $json .= $php['php'];
      unset($php);
      $json .= '"}';
   }
   if($type == 'get_ipv4'){
      $result = array();
      // ipv4
      //$result[] = _search('admin', 'server_ip', "AND ip_type = 'IPv4' AND (client_id = 0 OR client_id=".intval($_SESSION['s']['user']['client_id']).")");
      $result[] = $app->functions->suggest_ips('IPv4');
      $json = $app->functions->json_encode($result);
   }
   if($type == 'get_ipv6'){
      $result = array();
      // ipv6
      //$result[] = _search('admin', 'server_ip', "AND ip_type = 'IPv6' AND (client_id = 0 OR client_id=".intval($_SESSION['s']['user']['client_id']).")");
      $result[] = $app->functions->suggest_ips('IPv6');
      $json = $app->functions->json_encode($result);
   }
   $json = $app->functions->json_encode($client);
}
//}
header('Content-type: application/json');
echo $json;
?>
?>