X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;ds=sidebyside;f=plugins%2Fadmin%2Fsystems%2Fclass_glpiAccount.inc;h=4323dfa7d439da9fadc91d88e5cc996878b6958f;hb=6cb5be59b017449b99265b7ab8dead4eeab15b19;hp=117aa379252699a08db0270f4e689ce3deb0e490;hpb=3644520502707cc1a35a915bfa358105e86c4818;p=gosa.git diff --git a/plugins/admin/systems/class_glpiAccount.inc b/plugins/admin/systems/class_glpiAccount.inc index 117aa3792..4323dfa7d 100644 --- a/plugins/admin/systems/class_glpiAccount.inc +++ b/plugins/admin/systems/class_glpiAccount.inc @@ -8,44 +8,54 @@ class glpiAccount extends plugin var $cli_parameters= array("eins" => "Eins ist toll", "zwei" => "Zwei ist noch besser"); /* attribute list for save action */ - var $ignore_account= TRUE; + var $ignore_account= FALSE; var $attributes= array("ID","name","contact", - "tech_num","comments","date_mod","os","location","domain","network", + "tech_num","comments","date_mod","os","location","domain","network","contact_num", "model","type","is_template","FK_glpi_enterprise","deleted"); - var $ID ; - var $name =""; - var $contact =""; - - var $tech_num =""; - var $comments =""; - - var $date_mod =""; - var $os =0; - var $location =0; - var $domain =0; - var $network =0; - - var $model =0; - var $type =0; - var $is_template =0; - var $FK_glpi_enterprise =0; - var $deleted ="N"; - + var $ID ; // Is set if this entry is edited + var $name = ""; // This should be the dn of this entry + var $contact = ""; // Empty + + var $comments = ""; // Comment + + var $contact_num = ""; // Contact person + var $tech_num = ""; // Technical responsible person + + var $addUser = ""; // This is used to remember if a dialog was opened for tech_num or contact_num + + var $date_mod = ""; // Modification timestamp + var $os = 0; // Operating system + var $location = 0; // Not used yet + var $domain = 0; // ? Set to 0 + var $network = 0; // ? Set to 0 + + var $model = 0; // ? Can't remember this, it isn't used in GOsa + var $type = 0; // System type id + var $is_template = 0; // Used as template ? + var $FK_glpi_enterprise = 0; // Manufacturer id + var $deleted = "N"; // Deleted entries should have this set to Y + + /* Not necessary, cause we use mysql databse */ var $objectclasses= array("whatever"); + /* Used to remember if this was an account (simply: is this an edited entry) */ var $initialy_was_account = false; - var $edit_type =false; - var $edit_os =false; + /* Remember current dialog */ + var $edit_type = false; + var $edit_os = false; var $data; - var $handle = NULL; + var $handle = NULL; // Glpi class handle used to query database - var $cur_dialog = NULL; + var $cur_dialog = NULL; // This contains the sub dialog handle - var $orig_dn; - var $ui; + var $orig_dn; // To check if dn, has changed + var $ui; // Some GOsa specific user informations + + var $usedDevices = array(); // Which devices are currently selected + var $usedAttachments = array(); // Used Attachments /* Contructor Sets default values and checks if we already have an existing glpi account @@ -55,37 +65,50 @@ class glpiAccount extends plugin plugin::plugin ($config, $dn); $this->ui= get_userinfo(); + /* Abort class construction, if no db is defined */ if(!isset($this->config->data['SERVERS']['GLPI'])){ return; } + // Get informations about databse connection $this->data = $this->config->data['SERVERS']['GLPI']; + // Abort if mysql extension is missing if(!is_callable("mysql_connect")){ return; } + // Create handle of glpi class, and check if database connection is established $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); if(!$this->handle->is_connected){ return; } + // If this dn is already used in database, then get all informations for this entry if($this->handle->is_account($this->dn)){ $this->is_account = true; $tmp = ($this->handle->getComputerInformations($this->dn)); - foreach(array("tech_num","os","FK_glpi_enterprise","type","comments") as $attr){ + foreach(array("tech_num","os","FK_glpi_enterprise","type","comments","contact_num") as $attr){ $this->$attr = $tmp[0][$attr]; } - + $this->usedDevices = $this->handle->getUsedDevices($tmp[0]['ID']); + $atts = $this->handle->getAssignAttachments($tmp[0]['ID']); + foreach($atts as $attachment){ + + $this->usedAttachments[$attachment['FK_doc']]=$attachment['FK_doc']; + } }else{ $this->is_account = false; } - $this->name = $this->dn; - $this->orig_dn = $this->dn; + /* set defaults */ + $this->name = $this->dn; + $this->orig_dn = $this->dn; $this->initialy_was_account = $this->is_account; + + } function execute() @@ -97,20 +120,133 @@ class glpiAccount extends plugin $smarty= get_smarty(); $display= ""; - // #fixme - // Check if mysql a.s.o. is available. + /* Assign smarty defaults + To avoid undefined indexes, if there is an error with the glpi db + */ + foreach(array("SystemTypes","SystemTypeKeys","Manufacturers", + "OSs","TechnicalResponsibles","InstalledDevices","Attachments","AttachmentKeys", + "OSKeys","OSs","ManufacturerKeys","InstalledDeviceKeys") as $attr){ + $smarty->assign($attr,array()); + $smarty->assign($attr."ACL"," disabled "); + } + foreach(array("type","FK_glpi_enterprise","os","tech_num","comments","contact_num") as $attr){ + $smarty->assign($attr,""); + $smarty->assign($attr."ACL"," disabled "); + } + + /* Check if there is a glpi database server defined + */ + if(!isset($this->config->data['SERVERS']['GLPI'])){ + print_red(_("There is no server with valid glpi database service.")); + return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); + } + + $this->data = $this->config->data['SERVERS']['GLPI']; + /* Check if we can call mysql_connect + If we can't, there is no the mysql-php extension + */ + if(!is_callable("mysql_connect")){ + print_red(_("Can't connect to glpi database, the php-mysql extension is missing.")); + return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); + } $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); - $users = ($this->handle->getUsers()); + /* If handle == false, abort + Seems that the server, username and or password is wrong + */ + if(!$this->handle->is_connected){ + print_red(_("Can't connect to glpi database, check configuration twice.")); + return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); + } + + /* All checks are ok + Lets handle Posts, templates etc below ... + */ + + $users = $this->handle->getUsers(); $ldap= $this->config->get_ldap_link(); + + /* Check for Trading button Post + */ + if(isset($_POST['Trading'])){ + print_red(_("This feature is not implemented yet.")); + } + /* Check for Software button Post + */ + if(isset($_POST['Software'])){ + print_red(_("This feature is not implemented yet.")); + } + + /* Check for Contract button Post + */ + if(isset($_POST['Contracts'])){ + print_red(_("This feature is not implemented yet.")); + } + + /* Add Device was requested, open new dialog + */ if(isset($_POST['AddDevice'])){ $this->dialog =true; - $this->cur_dialog = new glpiDeviceManagement($this->config,$this->dn); + $this->cur_dialog = new glpiDeviceManagement($this->config,$this->dn,$this->usedDevices); + } + + /* Attachment pool was closed with use + */ + if(isset($_POST['UseAttachment'])){ + if(count($this->cur_dialog->check())){ + foreach($this->cur_dialog->check() as $msg){ + print_red($msg); + } + }else{ + $this->cur_dialog->save_object(); + $this->usedAttachments = $this->cur_dialog->save(); + $this->cur_dialog = false; + $this->edit_type = false; + } + } + + /* Attachment pool was closed with abort + */ + if(isset($_POST['AbortAttachment'])){ + $this->cur_dialog = false; + $this->edit_type = false; + } + + /* Open Attachment pool to add/edit Attachments + */ + if(isset($_POST['AddAttachment'])){ + $this->cur_dialog = new glpiAttachmentPool($this->config,$this->dn,$this->usedAttachments); + $this->dialog = true; + } + + /* Remove Attachment fro this tab + */ + if((isset($_POST['RemoveAttachment']))&&(isset($_POST['Attachments']))){ + if(isset($this->usedAttachments[$_POST['Attachments']])){ + unset($this->usedAttachments[$_POST['Attachments']]); + } + } + + /* We have selected some devices and pressed use button + */ + if(isset($_POST['SelectDeviceSave'])){ + $this->cur_dialog->save_object(); + $this->usedDevices= ($this->cur_dialog->getSelected()); + $this->cur_dialog = false; + $this->dialog = false; + $this->edit_type=false; } + /* Aborted Device selction + */ + if(isset($_POST['SelectDeviceCancel'])){ + $this->dialog = false; + $this->cur_dialog = false; + $this->edit_type=false; + } /* System type management */ @@ -119,34 +255,41 @@ class glpiAccount extends plugin $this->edit_type=true; } + /* This closes the system type editing dialog + */ if(isset($_POST['close_edit_type'])){ $this->edit_type=false; $this->dialog = false; } + /* This appends a new system to our sytem types + */ if((isset($_POST['add_type']))&&(!empty($_POST['type_string']))){ $this->handle->addSystemType($_POST['type_string']); } + /* Remove selected type from our system types list + */ if((isset($_POST['del_type']))&&(!empty($_POST['select_type']))){ - $this->handle->removeSystemType_byID($_POST['select_type']); + $this->handle->removeSystemType($_POST['select_type']); } + /* Rename selected system type to given string + */ if((isset($_POST['rename_type']))&&(!empty($_POST['select_type']))&&(!empty($_POST['type_string']))){ $this->handle->updateSystemType($_POST['type_string'],$_POST['select_type']); } + /* Someone wants to edit the system types ... + So, lets open a new dialog which provides some buttons to edit the types + */ if($this->edit_type){ $smarty->assign("SystemTypes", $this->handle->getSystemTypes()); $smarty->assign("SystemTypeKeys", array_flip($this->handle->getSystemTypes())); - $display= $smarty->fetch(get_template_path('glpi_edit_type.tpl', TRUE)); return($display); } - /* ENDE, Systemtype management. - */ - /* System os management */ if(isset($_POST['edit_os'])){ @@ -154,50 +297,74 @@ class glpiAccount extends plugin $this->edit_os=true; } + /* Close Operating system dialog + */ if(isset($_POST['close_edit_os'])){ $this->edit_os=false; $this->dialog = false; } + /* Add new os to the db + */ if((isset($_POST['add_os']))&&(!empty($_POST['is_string']))){ $this->handle->addOS($_POST['is_string']); } + /* Delete selected os from list and db + */ if((isset($_POST['del_os']))&&(!empty($_POST['select_os']))){ $this->handle->removeOS_byID($_POST['select_os']); } + /* Rename selected os to given string + */ if((isset($_POST['rename_os']))&&(!empty($_POST['select_os']))&&(!empty($_POST['is_string']))){ $this->handle->updateOS($_POST['is_string'],$_POST['select_os']); } + /* Open dialog to edit os types + */ if($this->edit_os){ $smarty->assign("OSKeys", array_flip($this->handle->getOSTypes())); $smarty->assign("OSs", $this->handle->getOSTypes()); - $display= $smarty->fetch(get_template_path('glpi_edit_os.tpl', TRUE)); return($display); } - /* ENDE, os management. + /* Show dialog to select a new contact person + * Select a contact person */ + if(isset($_POST['SelectContactPerson'])){ + $this->addUser = "contact"; + $this->cur_dialog= new glpiSelectUser($this->config,$this->dn); + } + /* Open dialog which allows to edit the manufacturers + */ if(isset($_POST['edit_manufacturer'])){ $this->cur_dialog = new glpiManufacturer($this->config,$this->dn); $this->dialog = true; } + /* Close manufacturer editing dialog + */ if(isset($_POST['close_edit_manufacturer'])){ $this->dialog = false; $this->cur_dialog = false; } + /* Abort user selection + */ if(isset($_POST['SelectUserCancel'])){ $this->dialog = false; + $this->addUser =""; $this->cur_dialog = false; } + /* Selecte technical responsible person + */ if(isset($_POST['SelectTechPerson'])){ + $this->addUser ="tech"; $this->cur_dialog= new glpiSelectUser($this->config,$this->dn); } @@ -236,54 +403,40 @@ class glpiAccount extends plugin $id=$tmp[$id]; /* Use user id, close dialog */ - $this->tech_num = $id; + if($this->addUser == "tech"){ + $this->tech_num = $id; + }else{ + $this->contact_num = $id; + } $this->cur_dialog = false; $this->dialog= false; } + /* if( cur_dialog != false || cur_dialog != NULL) + * There is a dialog which wants to be displayed + */ if($this->cur_dialog){ $this->cur_dialog->save_object(); $this->dialog=true; $this->cur_dialog->parent = &$this; return($this->cur_dialog->execute()); + }else{ + $this->dialog= false; } /* Assign smarty defaults */ foreach(array("SystemTypes","SystemTypeKeys","Manufacturers","OSs","TechnicalResponsibles","InstalledDevices","Attachments") as $attr){ $smarty->assign($attr,array()); - $smarty->assign($attr."ACL"," disabled "); + $smarty->assign($attr."ACL",chkacl($this->acl,$attr)); } - foreach(array("type","FK_glpi_enterprise","os","tech_num") as $attr){ + /* Assign some vars to smarty + */ + foreach(array("type","FK_glpi_enterprise","os","tech_num","contact_num") as $attr){ $smarty->assign($attr,""); - $smarty->assign($attr."ACL"," disabled "); - } - - /* Perform some checks - * arround the database - */ - if(!isset($this->config->data['SERVERS']['GLPI'])){ - print_red(_("There is no valid configuration for glpi database available.")); - return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); - } - $this->data = $this->config->data['SERVERS']['GLPI']; - - if(!is_callable("mysql_connect")){ - print_red(_("The php mysql extension is missing. Can't perform any queries.")); - return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); - } - - $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); - - if(!$this->handle->is_connected){ - print_red(_("Can't connect to specified database.")); - return($smarty->fetch(get_template_path('glpi.tpl', TRUE))); + $smarty->assign($attr."ACL",chkacl($this->acl,$attr)); } - /* If we reach this this - * the database connection seams to ok - */ - /* Do we need to flip is_account state? */ if (isset($_POST['modify_state'])){ $this->is_account= !$this->is_account; @@ -299,40 +452,61 @@ class glpiAccount extends plugin return ($display); } - + /* Assign ACLs to smarty*/ foreach($this->attributes as $attr){ $smarty->assign($attr."ACL",chkacl($this->acl,$attr)); } - + /* Assign system types + */ $smarty->assign("SystemTypeKeys", array_flip($this->handle->getSystemTypes())); $smarty->assign("SystemTypes", $this->handle->getSystemTypes()); $smarty->assign("type", $this->type); + /* Assign os types + */ $smarty->assign("OSKeys", array_flip($this->handle->getOSTypes())); $smarty->assign("OSs", $this->handle->getOSTypes()); $smarty->assign("os", $this->os); - $smarty->assign("ManufacturerKeys", array_flip($this->handle->getEnterprisesTypes())); - $smarty->assign("Manufacturers", $this->handle->getEnterprisesTypes()); + /* Dispaly installed devices */ + $smarty->assign("InstalledDevices" ,$this->getDevices()); + $smarty->assign("InstalledDeviceKeys" ,array_flip($this->getDevices())); + + /* Append manufacturers + */ + $smarty->assign("ManufacturerKeys", array_flip($this->handle->getEnterprises())); + $smarty->assign("Manufacturers", $this->handle->getEnterprises()); $smarty->assign("FK_glpi_enterprise", $this->FK_glpi_enterprise); + /* Assign used Attachments + */ + $smarty->assign("Attachments", $this->getUsedAttachments()); + $smarty->assign("AttachmentKeys", array_flip($this->getUsedAttachments())); + + /* Handle contact person + Assign name ... to smarty, if set + */ + if(isset($users[$this->contact_num])){ + $tr = $ldap->fetch($ldap->cat($users[$this->contact_num])); + $str = ""; + if(isset($tr['givenName'][0])){ $str .= $tr['givenName'][0]." "; } + if(isset($tr['sn'][0])) { $str .= $tr['sn'][0]." "; } + if(isset($tr['uid'][0])){ $str .= "[".$tr['uid'][0]."]"; } + $smarty->assign("contact_num", $str); + }else{ + $smarty->assign("contact_num", _("N/A")); + } + + /* Handle tech person + Assign name ... to smarty, if set + */ if(isset($users[$this->tech_num])){ $tr = $ldap->fetch($ldap->cat($users[$this->tech_num])); $str = ""; - if(isset($tr['givenName'][0])){ - $str .= $tr['givenName'][0]." "; - } - - if(isset($tr['sn'][0])){ - $str .= $tr['sn'][0]." "; - } - - if(isset($tr['uid'][0])){ - $str .= "[".$tr['uid'][0]."]"; - } - - + if(isset($tr['givenName'][0])){ $str .= $tr['givenName'][0]." "; } + if(isset($tr['sn'][0])) { $str .= $tr['sn'][0]." "; } + if(isset($tr['uid'][0])){ $str .= "[".$tr['uid'][0]."]"; } $smarty->assign("tech_num", $str); }else{ $smarty->assign("tech_num", _("N/A")); @@ -345,6 +519,25 @@ class glpiAccount extends plugin function remove_from_parent() { + $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); + if($this->initialy_was_account){ + $this->handle->removeComputerInformations($this->dn); + } + + } + + function getDevices(){ + $ret = array(); + foreach($this->usedDevices as $type => $entries){ + foreach($entries as $ent){ + if(isset($ent['designation'])){ + $ret[] = $ent['designation']." [".$type."]"; + }else{ + $ret[] = $ent['name']." [".$type."]"; + } + } + } + return($ret); } @@ -375,20 +568,48 @@ class glpiAccount extends plugin /* Save to LDAP */ function save() { - $attrs = array(); - $this->date_mod = date("Y-m-d H:i:s"); - foreach($this->attributes as $attr){ - $attrs[$attr] = $this->$attr; + if($this->is_account){ + $attrs = array(); + $this->date_mod = date("Y-m-d H:i:s"); + foreach($this->attributes as $attr){ + $attrs[$attr] = $this->$attr; + } + $attrs['name'] = $this->dn; + unset($attrs['ID']); + $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); + if($this->initialy_was_account&&$this->is_account){ + $this->handle->updateComputerInformations($attrs,$this->dn); + }elseif($this->is_account){ + $this->handle->addComputerInformations($attrs,$this->dn); + } + $tmp = $this->handle->getComputerInformations($this->dn); + $this->handle->addDevicesToComputer($this->usedDevices,$tmp[0]['ID']); + $this->handle->addAttachmentsToComputer($this->usedAttachments,$tmp[0]['ID']); } - $attrs['name'] = $this->dn; - unset($attrs['ID']); - $this->handle = new glpiDB($this->data['SERVER'],$this->data['LOGIN'],$this->data['PASSWORD'],$this->data['DB']); - if($this->initialy_was_account&&$this->is_account){ - $this->handle->updateComputerInformations($attrs,$this->dn); - }elseif($this->is_account){ - $this->handle->addComputerInformations($attrs,$this->dn); + } + + /* Return used attachments */ + function getUsedAttachments() + { + $atts =$this->handle->getAttachments(); + $ret = array(); + foreach($atts as $entry){ + if(in_array($entry['ID'],$this->usedAttachments)){ + + $cm =""; + if(isset($entry['comment'])){ + $cm=" [".$entry['comment']."]"; + } + if(isset($entry['mime'])){ + $cm.=" -".$entry['mime'].""; + } + + $ret[$entry['ID']]= $entry['name'].$cm; + } } + return($ret); } + }