Marius Burkard
2016-01-04 d22277878254cf33fd63ca1bf12b215f4e030a27
install/lib/installer_base.lib.php
@@ -36,6 +36,7 @@
   public $conf;
   public $install_ispconfig_interface = true;
   public $is_update = false; // true if it is an update, falsi if it is a new install
   public $min_php = '5.3.3'; // minimal php-version for update / install
   protected $mailman_group = 'list';
@@ -130,6 +131,12 @@
   }
   */
   //** Detect PHP-Version
   public function get_php_version() {
      if(version_compare(PHP_VERSION, $this->min_php, '<')) return false;
      else return true;
   }
   //** Detect installed applications
   public function find_installed_apps() {
      global $conf;
@@ -175,6 +182,19 @@
      return $force;
    }
   public function reconfigure_app($service, $reconfigure_services_answer) {
      $reconfigure = false;
      if ($reconfigure_services_answer != 'selected') {
         $reconfigure = true;
      } else {
         if(strtolower($this->simple_query("Reconfigure $service", array('y', 'n'), 'y') ) == 'y') {
            $reconfigure = true;
         } else {
            swriteln("Skip reconfigure $service\n");
         }
      }
      return $reconfigure;
   }
   /** Create the database for ISPConfig */
@@ -333,7 +353,7 @@
         $conf['server_id'] = $conf['server_id'];
         //* Insert the same record in the local DB
         $sql = "INSERT INTO `server` (`server_id`, `sys_userid`, `sys_groupid`, `sys_perm_user`, `sys_perm_group`, `sys_perm_other`, `server_name`, `mail_server`, `web_server`, `dns_server`, `file_server`, `db_server`, `vserver_server`, `config`, `updated`, `active`, `dbversion`,`firewall_server`,`proxy_server`) VALUES (?,1, 1, 'riud', 'riud', 'r', ?, ?, ?, ?, ?, ?, ?, 0, 1, ?, ?, ?);";
         $sql = "INSERT INTO `server` (`server_id`, `sys_userid`, `sys_groupid`, `sys_perm_user`, `sys_perm_group`, `sys_perm_other`, `server_name`, `mail_server`, `web_server`, `dns_server`, `file_server`, `db_server`, `vserver_server`, `config`, `updated`, `active`, `dbversion`,`firewall_server`,`proxy_server`) VALUES (?,1, 1, 'riud', 'riud', 'r', ?, ?, ?, ?, ?, ?, ?, ?, 0, 1, ?, ?, ?);";
         $this->db->query($sql, $conf['server_id'], $conf['hostname'], $mail_server_enabled, $web_server_enabled, $dns_server_enabled, $file_server_enabled, $db_server_enabled, $vserver_server_enabled, $server_ini_content, $current_db_version, $proxy_server_enabled, $firewall_server_enabled);
         //* username for the ispconfig user
@@ -350,6 +370,84 @@
      }
   }
   public function detect_ips(){
      global $conf;
      exec("ip addr show | awk '/global/ { print $2 }' | cut -d '/' -f 1", $output, $retval);
      if($retval == 0){
         if(is_array($output) && !empty($output)){
            foreach($output as $line){
               $line = trim($line);
               $ip_type = '';
               if (filter_var($line, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
                  $ip_type = 'IPv4';
               }
               if (filter_var($line, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6)) {
                  $ip_type = 'IPv6';
               }
               if($ip_type == '') continue;
               if($this->db->dbHost != $this->dbmaster->dbHost){
                  $this->dbmaster->query('INSERT INTO server_ip (
                     sys_userid, sys_groupid, sys_perm_user, sys_perm_group,
                     sys_perm_other, server_id, client_id, ip_type, ip_address,
                     virtualhost, virtualhost_port
                  ) VALUES (
                     1,
                     1,
                     "riud",
                     "riud",
                     "",
                     ' . $conf['server_id'] . ',
                     0,
                     "'.$ip_type.'",
                     "'.$line.'",
                     "y",
                     "80,443"
                  )');
                  $server_ip_id = $this->dbmaster->insertID();
                  $this->db->query('INSERT INTO server_ip (
                     server_php_id, sys_userid, sys_groupid, sys_perm_user, sys_perm_group,
                     sys_perm_other, server_id, client_id, ip_type, ip_address,
                     virtualhost, virtualhost_port
                  ) VALUES (
                     '.$server_ip_id.',
                     1,
                     1,
                     "riud",
                     "riud",
                     "",
                     ' . $conf['server_id'] . ',
                     0,
                     "'.$ip_type.'",
                     "'.$line.'",
                     "y",
                     "80,443"
                  )');
               } else {
                  $this->db->query('INSERT INTO server_ip (
                     sys_userid, sys_groupid, sys_perm_user, sys_perm_group,
                     sys_perm_other, server_id, client_id, ip_type, ip_address,
                     virtualhost, virtualhost_port
                  ) VALUES (
                     1,
                     1,
                     "riud",
                     "riud",
                     "",
                     ' . $conf['server_id'] . ',
                     0,
                     "'.$ip_type.'",
                     "'.$line.'",
                     "y",
                     "80,443"
                  )');
               }
            }
         }
      }
   }
   public function grant_master_database_rights($verbose = false) {
@@ -855,7 +953,7 @@
      $regex = "/^maildrop   unix.*pipe flags=DRhu user=vmail argv=\\/usr\\/bin\\/maildrop -d ".$cf['vmail_username']." \\$\{extension} \\$\{recipient} \\$\{user} \\$\{nexthop} \\$\{sender}/";
      $configfile = $config_dir.'/master.cf';
      if ($this->postfix_master()) {
         exec ("postconf -M maildrop.unix", $out, $ret);
         exec ("postconf -M maildrop.unix &> /dev/null", $out, $ret);
         $change_maildrop_flags = @(preg_match($regex, $out[0]) && $out[0] !='')?false:true;
      } else { //* fallback - postfix < 2.9
         $change_maildrop_flags = @(preg_match($regex, $configfile))?false:true;
@@ -1035,7 +1133,7 @@
      $config_dir = $conf['postfix']['config_dir'];
      //* Configure master.cf and add a line for deliver
      if ($this->postfix_master()) {
         exec ("postconf -M dovecot.unix", $out, $ret);
         exec ("postconf -M dovecot.unix &> /dev/null", $out, $ret);
         $add_dovecot_service = @($out[0]=='')?true:false;
       } else { //* fallback - postfix < 2.9
         $content = rf($config_dir.'/master.cf');
@@ -1177,13 +1275,13 @@
      // Adding amavis-services to the master.cf file if the service does not already exists
      if ($this->postfix_master()) {
          exec ("postconf -M amavis.unix", $out, $ret);
          exec ("postconf -M amavis.unix &> /dev/null", $out, $ret);
          $add_amavis = @($out[0]=='')?true:false;
          unset($out);
          exec ("postconf -M 127.0.0.1:10025.inet", $out, $ret);
          exec ("postconf -M 127.0.0.1:10025.inet &> /dev/null", $out, $ret);
          $add_amavis_10025 = @($out[0]=='')?true:false;
          unset($out);
          exec ("postconf -M 127.0.0.1:10027.inet", $out, $ret);
          exec ("postconf -M 127.0.0.1:10027.inet &> /dev/null", $out, $ret);
          $add_amavis_10027 = @($out[0]=='')?true:false;
          unset($out);
      } else { //* fallback - postfix < 2.9
@@ -2724,4 +2822,4 @@
}
?>
?>