Code

Added GOsa version to Feedback formular
authorhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 27 May 2010 08:22:15 +0000 (08:22 +0000)
committerhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 27 May 2010 08:22:15 +0000 (08:22 +0000)
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@18758 594d385d-05f5-0310-b6e9-bd551577e9d8

gosa-core/setup/class_setupStep_Feedback.inc
gosa-core/setup/setup_feedback.tpl

index 7b8b3570a3a409d9519943c895078e124db80be8..99055a3c3d62cf6c5914c73eb5491f03b80f2a2a 100644 (file)
    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
-*/
+ */
 
 
 class Step_Feedback  extends setup_step
 {
-  var $languages      = array();
-  var $header_image   = "images/setup/welcome.png";
-
-  var $organization       = "";
-  var $eMail              = "";
-  var $name               = "";
-  var $subscribe          = FALSE;
-  var $use_gosa_announce  = FALSE;
-
-  var $feedback_url         = "http://oss.gonicus.de/gosa-feedback/";
-  var $get_started          = TRUE;
-  var $problems_encountered = "";
-  
-  var $first_use            = TRUE;
-  var $use_since            = "";
-
-  var $distribution         = "";
-  var $web_server           = "";
-  var $php_version          = "";
-
-  var $ldap_server          = "";
-  var $object_count         = "";
-    
-  var $want_to_see_next     = "";
-
-  var $features_used        = array();  
-  var $initialized          = FALSE; 
-  var $feedback_send        = FALSE;
-  var $attributes = array("organization","eMail","name","subscribe","use_gosa_announce","get_started","problems_encountered","features_used",
-                          "first_use","use_since","distribution","web_server","php_version","ldap_server","object_count","want_to_see_next");
-  
-
-  function Step_Feedback()
-  {
-    $this->is_enabled     = TRUE;
-    $this->is_active      = TRUE;
-    $this->update_strings(); 
-  }
-
-
-  function init()
-  {
-    $cv = $this->parent->captured_values;
-
-    /* Initialize values */
-    $this->use_since      = date("Y");
-    $this->organization   = preg_replace("/^[^=]*+=(.*),.*$/","\\1",$cv['base']);
-    $this->distribution   = "";
-    $this->web_server     = $_SERVER['SERVER_SOFTWARE'];
-    $this->php_version    = PHP_VERSION;
-
-    /* Establish ldap connection */
-    $cv = $this->parent->captured_values;
-    $ldap_l = new LDAP($cv['admin'],
-        $cv['password'],
-        $cv['connection'],
-        FALSE,
-        $cv['tls']);
-
-    $this->object_count= "";
-    $ldap = new ldapMultiplexer($ldap_l);
-    $ldap->cd($cv['base']);
-
-    /* Preselect used features */
-    $oc = $ldap->get_objectclasses();
-    $this->features_used                = array();
-    $this->features_used['posix']       = array("USED" => isset($oc['posixAccount']) , 
-                                                "NAME" => _("UNIX accounts/groups"));
-    $this->features_used['samba']       = array("USED" => isset($oc['sambaSamAccount']) || isset($oc['sambaAccount']) , 
-                                                "NAME" => _("Samba management"));
-    $this->features_used['mail']        = array("USED" => FALSE,
-                                                "NAME" => _("Mailsystem management"));
-    $this->features_used['fax']         = array("USED" => isset($oc['goFaxAccount']) , 
-                                                "NAME" => _("FAX system administration"));
-    $this->features_used['asterisk']    = array("USED" => isset($oc['goFonAccount']), 
-                                                "NAME" => _("Asterisk administration"));
-    $this->features_used['inventory']   = array("USED" => isset($oc['glpiAccount']) , 
-                                                "NAME" => _("System inventory"));
-    $this->features_used['system']      = array("USED" => FALSE , 
-                                                "NAME" => _("System-/Configmanagement"));
-    $this->features_used['addressbook'] = array("USED" => FALSE , 
-                                                "NAME" => _("Addressbook"));
-  }
-
-
-  function update_strings()
-  {
-    $this->s_title      = _("Feedback");
-    $this->s_info       = _("Get notifications or send feedback");
-    $this->s_title_long = _("Notification and feedback");
-  }
-
-  
-  function execute()
-  {
-    if(!$this->initialized){
-      $this->initialized = TRUE;
-      $this->init();
-    }
+    var $languages      = array();
+    var $header_image   = "images/setup/welcome.png";
 
-    $additional_info ="";
-    if(isset($_POST['send_feedback'])){
+    var $organization       = "";
+    var $eMail              = "";
+    var $name               = "";
+    var $subscribe          = FALSE;
+    var $use_gosa_announce  = FALSE;
 
-      $msgs = $this->check_feedback();
-      if(count($msgs)){
-        foreach($msgs as $msg){
-          msg_dialog::display(_("Setup error"), $msg, ERROR_DIALOG);
-        }
-      }else{
-        $str = $this->create_serialise_data_string(); 
-        $feedback_url = $this->feedback_url."?data=".base64_encode($str);
-
-        $ret = @fopen($feedback_url,"r");
-
-        if(!$ret){
-          msg_dialog::display(_("Feedback error"), sprintf(_("Cannot send feedback to '%s': %s"), $this->feedback_url, $ret), ERROR_DIALOG);
-        }else{
-          $ret_value="";
-          while($ret && !feof($ret)){
-            $ret_value.= fgets($ret,256);
-          }
-          if(!preg_match("/successful/i",$ret_value)){
-            msg_dialog::display(_("Feedback error"), _("Cannot send feedback: service temporarily unavailable"), ERROR_DIALOG);
-          }else{
-            $this->feedback_send = TRUE;
-          }
-        }
-        @fclose($ret);
-      }
-    }
+    var $feedback_url         = "http://oss.gonicus.de/gosa-feedback/";
+    var $get_started          = TRUE;
+    var $problems_encountered = "";
 
-    $years = array();
-    for($i = date("Y") ; $i >= 2001; $i--){
-      $years[$i] = $i;
-    }
+    var $first_use            = TRUE;
+    var $use_since            = "";
+
+    var $distribution         = "";
+    var $web_server           = "";
+    var $php_version          = "";
+    var $gosa_version          = "";
+
+    var $ldap_server          = "";
+    var $object_count         = "";
+
+    var $want_to_see_next     = "";
 
-    $this->is_completed=TRUE;
-    $smarty = get_smarty();
+    var $features_used        = array();  
+    var $initialized          = FALSE; 
+    var $feedback_send        = FALSE;
+    var $attributes = array("organization","eMail","name","subscribe","use_gosa_announce","get_started","problems_encountered","features_used",
+            "first_use","use_since","distribution","web_server","php_version","ldap_server","object_count","want_to_see_next","gosa_version");
 
-    foreach($this->attributes as $attr){
-      $smarty->assign($attr,   reverse_html_entities($this->$attr));
+
+    function Step_Feedback()
+    {
+        $this->is_enabled     = TRUE;
+        $this->is_active      = TRUE;
+        $this->update_strings(); 
     }
-    $smarty->assign("feedback_send",$this->feedback_send);
-    $smarty->assign("years",$years);
-    $smarty->assign("features_used",$this->features_used);
-    $smarty->assign("additional_info", reverse_html_entities($additional_info));
-    $smarty->assign ("must", "<font class=\"must\">*</font>");
-    return($smarty->fetch(get_template_path("setup_feedback.tpl",TRUE,dirname(__FILE__))));
-  }
-
-
-  function check_feedback()
-  {
-    $msgs = array();
-    if($this->subscribe && (!tests::is_email($this->eMail) || empty($this->eMail))){
-      $msgs[] = _("Please specify a valid email address.");
+
+
+    function init()
+    {
+        $cv = $this->parent->captured_values;
+
+        /* Initialize values */
+        $this->use_since      = date("Y");
+        $this->organization   = preg_replace("/^[^=]*+=(.*),.*$/","\\1",$cv['base']);
+        $this->distribution   = "";
+        $this->web_server     = $_SERVER['SERVER_SOFTWARE'];
+        $this->php_version    = PHP_VERSION;
+        $this->gosa_version   = get_gosa_version(FALSE);
+
+        /* Establish ldap connection */
+        $cv = $this->parent->captured_values;
+        $ldap_l = new LDAP($cv['admin'],
+                $cv['password'],
+                $cv['connection'],
+                FALSE,
+                $cv['tls']);
+
+        $this->object_count= "";
+        $ldap = new ldapMultiplexer($ldap_l);
+        $ldap->cd($cv['base']);
+
+        /* Preselect used features */
+        $oc = $ldap->get_objectclasses();
+        $this->features_used                = array();
+        $this->features_used['posix']       = array("USED" => isset($oc['posixAccount']) , 
+                "NAME" => _("UNIX accounts/groups"));
+        $this->features_used['samba']       = array("USED" => isset($oc['sambaSamAccount']) || isset($oc['sambaAccount']) , 
+                "NAME" => _("Samba management"));
+        $this->features_used['mail']        = array("USED" => FALSE,
+                "NAME" => _("Mailsystem management"));
+        $this->features_used['fax']         = array("USED" => isset($oc['goFaxAccount']) , 
+                "NAME" => _("FAX system administration"));
+        $this->features_used['asterisk']    = array("USED" => isset($oc['goFonAccount']), 
+                "NAME" => _("Asterisk administration"));
+        $this->features_used['inventory']   = array("USED" => isset($oc['glpiAccount']) , 
+                "NAME" => _("System inventory"));
+        $this->features_used['system']      = array("USED" => FALSE , 
+                "NAME" => _("System-/Configmanagement"));
+        $this->features_used['addressbook'] = array("USED" => FALSE , 
+                "NAME" => _("Addressbook"));
     }
 
-    if(!$this->subscribe && !$this->use_gosa_announce){
-      $msgs[] = _("You have to select at least one of both options, subscribe or send feedback.");
+
+    function update_strings()
+    {
+        $this->s_title      = _("Feedback");
+        $this->s_info       = _("Get notifications or send feedback");
+        $this->s_title_long = _("Notification and feedback");
     }
 
-    return($msgs);
-  }
-  
 
-  function save_object()
-  {
-    if(isset($_POST['step_feedback'])){
-      foreach($this->attributes as $attr){
-        if(isset($_POST[$attr])){
-          $this->$attr = get_post($attr);
+    function execute()
+    {
+        if(!$this->initialized){
+            $this->initialized = TRUE;
+            $this->init();
         }
-      }
-
-      if(isset($_POST['subscribe'])){
-        $this->subscribe = TRUE;
-      }else{
-        $this->subscribe = FALSE;
-      }
-
-      if(isset($_POST['use_gosa_announce'])){
-        $this->use_gosa_announce = TRUE;
-      }else{
-        $this->use_gosa_announce = FALSE;
-      }
-    
-      foreach($this->features_used as $key => $data){
-        if(isset($_POST['feature_'.$key])){
-          $this->features_used[$key]['USED'] = TRUE;
-        }else{
-          $this->features_used[$key]['USED'] = FALSE;
+        $additional_info ="";
+        if(isset($_POST['send_feedback'])){
+
+            $msgs = $this->check_feedback();
+            if(count($msgs)){
+                foreach($msgs as $msg){
+                    msg_dialog::display(_("Setup error"), $msg, ERROR_DIALOG);
+                }
+            }else{
+                $str = $this->create_serialise_data_string(); 
+                $feedback_url = $this->feedback_url."?data=".urlencode(base64_encode($str));
+                $ret = @fopen($feedback_url,"r");
+
+                if(!$ret){
+                    msg_dialog::display(_("Feedback error"), sprintf(_("Cannot send feedback to '%s': %s"), $this->feedback_url, $ret), ERROR_DIALOG);
+                }else{
+                    $ret_value="";
+                    while($ret && !feof($ret)){
+                        $ret_value.= fgets($ret,256);
+                    }
+                    if(!preg_match("/successful/i",$ret_value)){
+                        msg_dialog::display(_("Feedback error"), _("Cannot send feedback: service temporarily unavailable"), ERROR_DIALOG);
+                    }else{
+                        $this->feedback_send = TRUE;
+                    }
+                }
+                @fclose($ret);
+            }
         }
-      }
-    }
-  }
 
+        $years = array();
+        for($i = date("Y") ; $i >= 2001; $i--){
+            $years[$i] = $i;
+        }
 
-  function create_serialise_data_string()
-  {
-    $str = "#FEEDBACK ".date("H:i:s d:m:Y");
-    if($this->subscribe){
+        $this->is_completed=TRUE;
+        $smarty = get_smarty();
 
-      $str.= "\n\nSubscribe";
-      $str .= "\nOrganization: ".$this->organization; 
-      $str .= "\nName: ".$this->name;
-      $str .= "\neMail: ".$this->eMail;
+        foreach($this->attributes as $attr){
+            $smarty->assign($attr,   reverse_html_entities($this->$attr));
+        }
+        $smarty->assign("gosa_version",$this->gosa_version);
+        $smarty->assign("feedback_send",$this->feedback_send);
+        $smarty->assign("years",$years);
+        $smarty->assign("features_used",$this->features_used);
+        $smarty->assign("additional_info", reverse_html_entities($additional_info));
+        $smarty->assign ("must", "<font class=\"must\">*</font>");
+        return($smarty->fetch(get_template_path("setup_feedback.tpl",TRUE,dirname(__FILE__))));
     }
-  
-    if($this->use_gosa_announce){
-
-      $str.= "\n\nFeedback";    
-  
-      if($this->get_started) {
-        $str .= "\nGet started: TRUE";
-      }else{
-        $str .= "\nGet started: FALSE";
-      }
-      $str .= "\nProblems : ".($this->problems_encountered);
-
-      if($this->first_use){
-        $str .= "\nFirst use: TRUE";
-      }else{
-        $str .= "\nFirst use: FALSE";
-      }
-      $str .= "\nUsing GOsa since: ".$this->use_since;
-
-      $str .="\nDistribution: ".$this->distribution;
-      $str .="\nWeb Server: ".$this->web_server;
-      $str .="\nPHP_Version: ".$this->php_version;
-      $str .="\nLDAP Server: ".$this->ldap_server;
-      $str .="\nObject count: ".$this->object_count;
-      $str .="\nMissing features: ".($this->want_to_see_next);
+
+
+    function check_feedback()
+    {
+        $msgs = array();
+        if($this->subscribe && (!tests::is_email($this->eMail) || empty($this->eMail))){
+            $msgs[] = _("Please specify a valid email address.");
+        }
+
+        if(!$this->subscribe && !$this->use_gosa_announce){
+            $msgs[] = _("You have to select at least one of both options, subscribe or send feedback.");
+        }
+
+        return($msgs);
     }
 
-    $str .= "\n\nFeatures used";
-    foreach($this->features_used as $name => $data){
-      $str.="\n".$name.": ";
-      if($data['USED']){
-        $str .= "TRUE";
-      }else{
-        $str .= "FALSE";
-      }
+
+    function save_object()
+    {
+        if(isset($_POST['step_feedback'])){
+            foreach($this->attributes as $attr){
+                if(isset($_POST[$attr])){
+                    $this->$attr = get_post($attr);
+                }
+            }
+
+            if(isset($_POST['subscribe'])){
+                $this->subscribe = TRUE;
+            }else{
+                $this->subscribe = FALSE;
+            }
+
+            if(isset($_POST['use_gosa_announce'])){
+                $this->use_gosa_announce = TRUE;
+            }else{
+                $this->use_gosa_announce = FALSE;
+            }
+
+            foreach($this->features_used as $key => $data){
+                if(isset($_POST['feature_'.$key])){
+                    $this->features_used[$key]['USED'] = TRUE;
+                }else{
+                    $this->features_used[$key]['USED'] = FALSE;
+                }
+            }
+        }
     }
 
-    return($str);  
-  }
+
+    function create_serialise_data_string()
+    {
+        $str = "#FEEDBACK ".date("H:i:s d:m:Y");
+        if($this->subscribe){
+
+            $str.= "\n\nSubscribe";
+            $str .= "\nOrganization: ".$this->organization; 
+            $str .= "\nName: ".$this->name;
+            $str .= "\neMail: ".$this->eMail;
+        }
+
+        if($this->use_gosa_announce){
+
+            $str.= "\n\nFeedback";    
+
+            if($this->get_started) {
+                $str .= "\nGet started: TRUE";
+            }else{
+                $str .= "\nGet started: FALSE";
+            }
+            $str .= "\nProblems : ".($this->problems_encountered);
+
+            if($this->first_use){
+                $str .= "\nFirst use: TRUE";
+            }else{
+                $str .= "\nFirst use: FALSE";
+            }
+            $str .= "\nUsing GOsa since: ".$this->use_since;
+
+            $str .="\nDistribution: ".$this->distribution;
+            $str .="\nWeb Server: ".$this->web_server;
+            $str .="\nPHP_Version: ".$this->php_version;
+            $str .="\nGOsa_Version: ".strip_tags($this->gosa_version);
+            $str .="\nLDAP Server: ".$this->ldap_server;
+            $str .="\nObject count: ".$this->object_count;
+            $str .="\nMissing features: ".($this->want_to_see_next);
+        }
+
+        $str .= "\n\nFeatures used";
+        foreach($this->features_used as $name => $data){
+            $str.="\n".$name.": ";
+            if($data['USED']){
+                $str .= "TRUE";
+            }else{
+                $str .= "FALSE";
+            }
+        }
+
+        return($str);  
+    }
 }
 
 // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
index 14ff80b1f2e658e30df220b5906ea75f0995ed29..5fdebc253aa93adb9dd86b75de080c86a47f5c03 100644 (file)
                        <td>{t}What PHP version do you use?{/t}</td>
                        <td><input type='text' size=50 name='php_version' value='{$php_version}'></td>
                </tr>
+               <tr>
+                       <td>{t}GOsa version{/t}</td>
+                       <td>{$gosa_version}</td>
+               </tr>
        </table>
 
        <hr>