Marius Burkard
2016-04-20 4569cae57f127afd093794310ccd290d2d9fdf36
interface/lib/classes/custom_datasource.inc.php
@@ -29,10 +29,10 @@
*/
class custom_datasource {
   function master_templates($field, $record) {
      global $app, $conf;
      $records = $app->db->queryAllRecords("SELECT template_id,template_name FROM client_template WHERE template_type ='m'");
      $records = $app->db->queryAllRecords("SELECT template_id,template_name FROM client_template WHERE template_type ='m' and ".$app->tform->getAuthSQL('r'));
      $records_new[0] = $app->lng('Custom');
      foreach($records as $rec) {
         $key = $rec['template_id'];
@@ -40,19 +40,19 @@
      }
      return $records_new;
   }
   function dns_servers($field, $record) {
      global $app, $conf;
      if($_SESSION["s"]["user"]["typ"] == 'user') {
         // Get the limits of the client
         $client_group_id = $_SESSION["s"]["user"]["default_group"];
         $client = $app->db->queryOneRecord("SELECT default_dnsserver FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = $client_group_id");
         $sql = "SELECT server_id,server_name FROM server WHERE server_id = ".$client['default_dnsserver'];
         $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
         $client = $app->db->queryOneRecord("SELECT default_dnsserver FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?", $client_group_id);
         $sql = "SELECT server_id,server_name FROM server WHERE server_id = ?";
      } else {
         $sql = "SELECT server_id,server_name FROM server WHERE dns_server = 1 ORDER BY server_name";
         $sql = "SELECT server_id,server_name FROM server WHERE dns_server = 1 ORDER BY server_name AND mirror_server_id = 0";
      }
      $records = $app->db->queryAllRecords($sql);
      $records = $app->db->queryAllRecords($sql, $client['default_dnsserver']);
      $records_new = array();
      if(is_array($records)) {
         foreach($records as $rec) {
@@ -62,9 +62,134 @@
      }
      return $records_new;
   }
   function slave_dns_servers($field, $record) {
      global $app, $conf;
      if($_SESSION["s"]["user"]["typ"] == 'user') {
         // Get the limits of the client
         $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
         $client = $app->db->queryOneRecord("SELECT default_slave_dnsserver FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?", $client_group_id);
         $sql = "SELECT server_id,server_name FROM server WHERE server_id = ?";
      } else {
         $sql = "SELECT server_id,server_name FROM server WHERE dns_server = 1 ORDER BY server_name AND mirror_server_id = 0";
      }
      $records = $app->db->queryAllRecords($sql, $client['default_slave_dnsserver']);
      $records_new = array();
      if(is_array($records)) {
         foreach($records as $rec) {
            $key = $rec['server_id'];
            $records_new[$key] = $rec['server_name'];
         }
      }
      return $records_new;
   }
   function webdav_domains($field, $record) {
      global $app, $conf;
      $servers = $app->db->queryAllRecords("SELECT * FROM server WHERE active = 1 AND mirror_server_id = 0");
      $server_ids = array();
      $app->uses('getconf');
      if(is_array($servers) && !empty($servers)){
         foreach($servers as $server){
            $web_config = $app->getconf->get_server_config($server['server_id'], 'web');
            if($web_config['server_type'] != 'nginx') $server_ids[] = $server['server_id'];
         }
      }
      if(count($server_ids) == 0) return array();
      $server_ids = implode(',', $server_ids);
      $records = $app->db->queryAllRecords("SELECT web_domain.domain_id, CONCAT(web_domain.domain, ' :: ', server.server_name) AS parent_domain FROM web_domain, server WHERE web_domain.type = 'vhost' AND web_domain.server_id IN (?) AND web_domain.server_id = server.server_id AND ".$app->tform->getAuthSQL('r', 'web_domain')." ORDER BY web_domain.domain", $server_ids);
      $records_new = array();
      if(is_array($records)) {
         foreach($records as $rec) {
            $key = $rec['domain_id'];
            $records_new[$key] = $rec['parent_domain'];
         }
      }
      return $records_new;
   }
   function client_servers($field, $record) {
      global $app, $conf;
      $server_type = $field['name'];
      switch($server_type) {
      case 'default_mailserver':
         $field = 'mail_server';
         break;
      case 'default_webserver':
         $field = 'web_server';
         break;
      case 'default_dnsserver':
         $field = 'dns_server';
         break;
      case 'default_slave_dnsserver':
         $field = 'dns_server';
         break;
      case 'default_fileserver':
         $field = 'file_server';
         break;
      case 'default_dbserver':
         $field = 'db_server';
         break;
      case 'default_vserverserver':
         $field = 'vserver_server';
         break;
      case 'mail_servers':
         $field = 'mail_server';
         break;
      case 'web_servers':
         $field = 'web_server';
         break;
      case 'dns_servers':
         $field = 'dns_server';
         break;
      case 'db_servers':
         $field = 'db_server';
         break;
      default:
         $field = 'web_server';
         break;
      }
      if($_SESSION["s"]["user"]["typ"] == 'user') {
         // Get the limits of the client
         $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
         $sql = "SELECT $server_type as server_id FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?";
         $client = $app->db->queryOneRecord($sql, $client_group_id);
         if($client['server_id'] > 0) {
            //* Select the default server for the client
            $sql = "SELECT server_id,server_name FROM server WHERE server_id = ?";
            $records = $app->db->queryAllRecords($sql, $client['server_id']);
         } else {
            //* Not able to find the clients defaults, use this as fallback and add a warning message to the log
            $app->log('Unable to find default server for client in custom_datasource.inc.php', 1);
            $sql = "SELECT server_id,server_name FROM server WHERE ?? = 1 AND mirror_server_id = 0 ORDER BY server_name";
            $records = $app->db->queryAllRecords($sql, $field);
         }
      } else {
         //* The logged in user is admin, so we show him all available servers of a specific type.
         $sql = "SELECT server_id,server_name FROM server WHERE ?? = 1 AND mirror_server_id = 0 ORDER BY server_name";
         $records = $app->db->queryAllRecords($sql, $field);
      }
      $records_new = array();
      if(is_array($records)) {
         foreach($records as $rec) {
            $key = $rec['server_id'];
            $records_new[$key] = $rec['server_name'];
         }
      }
      return $records_new;
   }
}
?>
?>