diff --git a/gosa-plugins/systems/admin/systems/class_systemManagement.inc b/gosa-plugins/systems/admin/systems/class_systemManagement.inc
index 20889083ea0d512c281f6a5655b0dab22fc98b34..e6423173c36b632761505afbc960f606f857ac91 100644 (file)
/* Definitions */
var $plHeadline = "Systems";
var $plDescription = "This does something";
+ var $plIcon = "plugins/systems/images/plugin.png";
var $departments = array();
/* Dialog attributes */
var $arp_handling_active = FALSE;
var $last_action = "";
+ var $dns = array();
+
+ var $system_activation_object = ""; // The object to activate (NewDevice)
+ var $fai_activated = FALSE;
+ var $si_active = FALSE;
+
+ var $acl_module = array("incoming","terminal","workstation","server","printer","phone","winworkstation","component");
+
+ var $opsi = NULL;
+
function systems (&$config, $ui)
{
/* Save configuration for internal use */
$this->config= $config;
$this->ui= $ui;
- /* Creat dialog object */
- $this->DivListSystem = new divListSystem($this->config,$this);
+ /* Add FAIstate to attributes if FAI is activated */
+ $tmp = $this->config->search("faiManagement", "CLASS",array('menu','tabs'));
+ if(!empty($tmp)){
+ $this->fai_activated = TRUE;
+ }
/* Copy & Paste enabled ?*/
- if((isset($this->config->data['MAIN']['ENABLECOPYPASTE']))&&(preg_match("/true/i",$this->config->data['MAIN']['ENABLECOPYPASTE']))){
+ if ($this->config->get_cfg_value("copyPaste") == "true"){
$this->CopyPasteHandler = new CopyPasteHandler($this->config);
}
$this->arp_handling_active = TRUE;
}
+ /* Check if we are able to communicate with the GOsa supprot daemon
+ */
+ if(class_available("gosaSupportDaemon")){
+ $o = new gosaSupportDaemon();
+ $this->si_active = $o->connect() && class_available("DaemonEvent");
+ }
+
+ /* Check if we are able to communicate with the GOsa supprot daemon
+ */
+ if(class_available("opsi")){
+ $this->opsi = new opsi($this->config);
+ }
+
+ /* Creat dialog object */
+ $this->DivListSystem = new divListSystem($this->config,$this);
}
}
}
- /* Incoming handling
- * If someone made a systemtype and ogroup selection
- * Display the new requested entry type ... servtab in case of server and so on.
- */
- if(isset($_POST['SystemTypeChoosen'])){
- $SelectedSystemType = session::get('SelectedSystemType');
- $s_action = "SelectedSystemType";
- $s_entry = $_POST['SystemType'];
- $SelectedSystemType['ogroup'] = $_POST['ObjectGroup'];
- $this->systab = NULL;
- session::set('SelectedSystemType',$SelectedSystemType);
- }
-
/* remove image tags from posted entry (posts looks like this 'name_x')*/
$s_entry = preg_replace("/_.$/","",$s_entry);
}
}
+ /* Activate multiple machines */
+ if(isset($_POST['menu_action']) && preg_match("/^activate_multiple/",$_POST['menu_action'])){
+ $s_action = "activate_multiple";
+ }
+
/* Check for exeeded sizelimit */
if (($message= check_sizelimit()) != ""){
return($message);
return ($smarty->fetch(get_template_path('chooser.tpl', TRUE)));
}
+ /* Incoming handling
+ * If someone made a systemtype and ogroup selection
+ * Display the new requested entry type ... servtab in case of server and so on.
+ */
+ if(isset($_POST['SystemTypeChoosen'])){
+ $s_action = "SelectedSystemType";
+ }
/********************
Copy & Paste Handling ...
********************/
if ($s_action=="gen_cd"){
$this->dn= $this->terminals[$s_entry]['dn'];
- session::set('objectinfo',$this->dn);
+ set_object_info($this->dn);
return ($smarty->fetch(get_template_path('gencd.tpl', TRUE)));
}
$dsc = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));
/* Get and check command */
- $command= $this->config->search("workgeneric", "ISOCMD",array('tabs'));
+ $command= $this->config->search("workgeneric", "SYSTEMISOHOOK",array('tabs'));
if (check_command($command)){
@DEBUG (DEBUG_SHELL, __LINE__, __FUNCTION__, __FILE__, $command, "Execute");
/********************
- Create new system ...
+ New Device handling (Ogroup/System select dialog.)
********************/
- /* Create new default terminal
- * Or create specified object of selected system type, from given incoming object
+
+ /* All objects that have to be activated are listed in
+ $this->system_activation_object[] = "dn";
+
+ If there is an object group selected we simply adopt all
+ settings from these group and then directly save the entry again.
+ If no object group was selected, then we keep the "edit" dialog of
+ the target system opened to allow to edit the objects attributes.
*/
+
+ if($s_action == "SelectedSystemType"){
+
+ /* Possible destination system types
+ */
+ $tabs = $this->get_tab_defs();
+
+ /* Remember dialog selection.
+ */
+ $selected_group = $_POST['ObjectGroup'];
+ $selected_system = $_POST['SystemType'];
+
+ $this->systab = NULL;
+
+ /* Check if system type exists. It should! */
+ if(isset($tabs[$selected_system])){
+
+ /* Get tab informations */
+ $class = $tabs[$selected_system]["CLASS"];
+ $tabname = $tabs[$selected_system]["TABNAME"];
+ $tabclass = $tabs[$selected_system]["TABCLASS"];
+ $acl_cat = $tabs[$selected_system]["ACLC"];
+
+
+ if(!class_available($tabclass)){
+ msg_dialog::display(_("Error"), msgPool::class_not_found($tabclass), ERROR_DIALOG);
+ }else{
+
+ /* Go through all objects that should be activated
+ Contains alls object dns that have to be activated ("New Devices" not unknown)
+ */
+ foreach($this->system_activation_object as $key => $dn){
+
+ /* Remove entry from list, to avoid page-reload problems */
+ unset($this->system_activation_object[$key]);
+
+ /* Load permissions for selected 'dn' and check if
+ we're allowed to create this 'dn' */
+ $this->dn = $dn;
+ $ui = get_userinfo();
+ $tabacl = $ui->get_permissions($this->dn,$acl_cat."/".$tabname);
+
+ /* We are allowed to create the requested system type */
+ if(preg_match("/c/",$tabacl)){
+ $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn,$selected_system);
+ $this->systab->set_acl_base($this->DivListSystem->selectedBase);
+ $this->systab->by_object[$tabname]->base = $this->DivListSystem->selectedBase;
+ $this->systab->base = $this->DivListSystem->selectedBase;
+
+ /* This will be used when the object is saved, to set FAIstate to 'install'
+ and to preset maybe other attributes.
+ */
+ $this->systab->was_activated = TRUE;
+
+ /* Assign some default values for opsi hosts
+ */
+ if($this->systab instanceOf opsi_tabs){
+ $ldap = $this->config->get_ldap_link();
+ $ldap->cat($dn);
+ $source_attrs = $ldap->fetch();
+ foreach(array("macAddress" => "mac" ,"cn" => "hostId","description","description") as $src => $attr){
+ if(isset($source_attrs[$src][0])){
+ $this->systab->by_object['opsiGeneric']->$attr = $source_attrs[$src][0];
+ }
+ }
+ }
+
+ if($selected_group != "none"){
+
+ /*******
+ * Set gotoMode to active if there was an ogroup selected.
+ */
+ $found = false;
+ foreach(array("workgeneric"=>"active","servgeneric"=>"active","termgeneric"=>"active") as $tab => $value){
+ if(isset($this->systab->by_object[$tab]->gotoMode)) {
+ $found = true;
+ $this->systab->by_object[$tab]->gotoMode = $value;
+ }
+ }
+ if(!$found){
+ msg_dialog::display(_("Internal error"), _("Cannot set mode to 'active'!"), ERROR_DIALOG);
+ }
+
+ /*******
+ * Update object group membership
+ */
+ $og = new ogroup($this->config,$selected_group);
+ if($og){
+ $og->AddDelMembership($this->systab->dn);
+ $og->save();
+ }
+
+ /*******
+ * Set default system specific attributes
+ */
+ foreach (array("workservice", "termservice") as $cls){
+ if (isset($this->systab->by_object[$cls])){
+ $this->systab->by_object[$cls]->gotoXMouseport= "";
+ $this->systab->by_object[$cls]->gotoXMouseType= "";
+ $this->systab->by_object[$cls]->gotoXResolution= "";
+ $this->systab->by_object[$cls]->gotoXColordepth= "";
+ }
+ }
- $save_object_directly = false;
- if(($s_action == "SelectedSystemType") && (isset($_POST['ObjectGroup']) && ($_POST['ObjectGroup'] != "none"))){
- $save_object_directly = true;
+ // Enable activation
+ foreach (array("servgeneric", "workgeneric", "termgeneric") as $cls){
+ if (isset($this->systab->by_object[$cls])){
+ $this->systab->by_object[$cls]->auto_activate= TRUE;
+ }
+ }
+
+ // Enable sending of LDAP events
+ if (isset($this->systab->by_object["workstartup"])){
+ $this->systab->by_object["workstartup"]->gotoLdap_inherit= TRUE;
+ }
+ }
+
+ /* Don't save directly if there is no objectGroup selected.
+ The user will then be able to configure the missing attributes
+ on his own.
+ */
+ if($selected_group != "none"){
+ $this->systab->save();
+
+ /* Post handling for activated new devices
+ */
+ $this->activate_new_device($this->systab->dn);
+ $this->systab = NULL;
+
+ if(!isset($ldap)){
+ $ldap = $this->config->get_ldap_link();
+ }
+ $ldap->cd ($this->dn);
+ $ldap->cat($this->dn, array('dn'));
+ if(count($ldap->fetch())){
+ $ldap->cd($this->dn);
+ $ldap->rmDir($this->dn);
+ }
+ }
+ }else{
+ msg_dialog::display(_("Error"), msgPool::permCreate(), ERROR_DIALOG);
+ }
+ }
+ }
+ }
}
- if (isset($_POST['create_system'])||$s_action=="newsystem"||$s_action == "SelectedSystemType") {
+ if (isset($_POST['create_system'])||$s_action=="newsystem") {
+
+ $this->last_action = "";
+
/* If the current entry is an incoming object
* $sw = System type as posted in new incoming handling dialog
*/
- if($s_action == "SelectedSystemType") {
- $sw = $s_entry;
+ if(isset($_POST['system'])){
+ $sw = $_POST['system'];
}else{
- if(isset($_POST['system'])){
- $sw = $_POST['system'];
- }else{
- $sw = $s_entry;
- }
- $this->dn= "new";
+ $sw = $s_entry;
}
+ $this->dn= "new";
- $tabs = array(
- "terminal" => array("CLASS"=>"TERMTABS", "TABNAME"=>"termgeneric", "TABCLASS" =>"termtabs", "ACL"=> "terminal"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABNAME"=>"workgeneric", "TABCLASS" =>"worktabs", "ACL"=> "workstation"),
- "server" => array("CLASS"=>"SERVTABS", "TABNAME"=>"servgeneric", "TABCLASS" =>"servtabs", "ACL"=> "server"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABNAME"=>"printgeneric", "TABCLASS" =>"printtabs", "ACL"=> "printer"),
- "phone" => array("CLASS"=>"PHONETABS", "TABNAME"=>"phoneGeneric", "TABCLASS" =>"phonetabs", "ACL"=> "phone"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABNAME"=>"componentGeneric","TABCLASS" =>"componenttabs", "ACL"=> "component"));
-
+ $tabs = $this->get_tab_defs();
+
if(isset($tabs[$sw])){
$class = $tabs[$sw]["CLASS"];
$tabname = $tabs[$sw]["TABNAME"];
$tabclass = $tabs[$sw]["TABCLASS"];
- $acl_cat = $tabs[$sw]["ACL"];
+ $acl_cat = $tabs[$sw]["ACLC"];
/* Load permissions for selected 'dn' and check if
we're allowed to remove this 'dn' */
$ui = get_userinfo();
$tabacl = $ui->get_permissions($this->DivListSystem->selectedBase,$acl_cat."/".$tabname);
if(preg_match("/c/",$tabacl)){
- $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn,$sw);
- $this->systab->set_acl_base($this->DivListSystem->selectedBase);
- $this->systab->by_object[$tabname]->base = $this->DivListSystem->selectedBase;
- $this->systab->base = $this->DivListSystem->selectedBase;
+
+ if(!class_available($tabclass)){
+ msg_dialog::display(_("Error"), msgPool::class_not_found($tabclass), ERROR_DIALOG);
+ }else{
+ $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn,$sw);
+ $this->systab->set_acl_base($this->DivListSystem->selectedBase);
+ $this->systab->by_object[$tabname]->base = $this->DivListSystem->selectedBase;
+ $this->systab->base = $this->DivListSystem->selectedBase;
+ }
}else{
msg_dialog::display(_("Error"), msgPool::permCreate(), ERROR_DIALOG);
}
}
}
+ /********************
+ System activation
+ ********************/
+
+ /* User wants to edit data? */
+ if (($s_action == "activate_multiple") && (!isset($this->systab->config))){
+ $this->system_activation_object = array();
+ foreach($this->list_get_selected_items() as $id) {
+ $obj = $this->terminals[$id];
+ $type= $this->get_system_type($obj);
+ if($type == "NewDevice"){
+ $this->system_activation_object[] = $obj['dn'];
+ }
+ }
+ if(count($this->system_activation_object)){
+ $this->systab = new SelectDeviceType($this->config,$this->system_activation_object) ;
+ }
+ }
+
+
/********************
Edit system ...
********************/
/* User wants to edit data? */
if (($s_action == "edit") && (!isset($this->systab->config))){
-
+ $this->last_action = "";
$this->dn= $this->terminals[$s_entry]['dn'];
/* Check locking, save current plugin in 'back_plugin', so
the dialog knows where to return. */
if (($user= get_lock($this->dn)) != ""){
- return(gen_locked_message ($user, $this->dn));
+ return(gen_locked_message ($user, $this->dn,TRUE));
}
/* Find out more about the object type */
- $ldap= $this->config->get_ldap_link();
- $ldap->cat($this->dn, array('objectClass','gotoMode'));
- $attrs= $ldap->fetch();
+ $attrs = $this->terminals[$s_entry];
$type= $this->get_system_type($attrs);
-
+
/* Lock the current entry, so everyone will get the
above dialog */
- $tabs = array(
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs", "ACL"=> "printer"),
- "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs", "ACL"=> "phone"),
- "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs", "ACL"=> "winworkstation"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component"));
-
+ $tabs = $this->get_tab_defs();
if($type == "ArpNewDevice"){
- $this->systab = new ArpNewDeviceTabs($this->config,$this->config->data['TABS']['ARPNEWDEVICETABS'],$this->dn);
+ if(!class_available("ArpNewDeviceTabs")){
+ msg_dialog::display(_("Error"), msgPool::class_not_found("ArpNewDevice"), ERROR_DIALOG);
+ }else{
+ add_lock ($this->dn, $this->ui->dn);
+ $this->systab = new ArpNewDeviceTabs($this->config,$this->config->data['TABS']['ARPNEWDEVICETABS'],$this->dn);
+ }
}elseif($type == "NewDevice"){
- $this->systab = new SelectDeviceType($this->config,$this->dn) ;
+ if(!class_available("SelectDeviceType")){
+ msg_dialog::display(_("Error"), msgPool::class_not_found("SelectDeviceType"), ERROR_DIALOG);
+ }else{
+ add_lock ($this->dn, $this->ui->dn);
+ $this->system_activation_object= array($this->dn);
+ $this->systab = new SelectDeviceType($this->config,$this->dn) ;
+
+ // see condition -$s_action == "SelectedSystemType"- for further handling
+ }
}elseif(isset($tabs[$type])){
$class = $tabs[$type]["CLASS"];
- $acl_cat = $tabs[$type]["ACL"];
+ $acl_cat = $tabs[$type]["ACLC"];
$tabclass = $tabs[$type]["TABCLASS"];
- $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn,$acl_cat);
- $this->systab->set_acl_base($this->dn);
- session::set('objectinfo',$this->dn);
- add_lock ($this->dn, $this->ui->dn);
+ if(!class_available($tabclass)){
+ msg_dialog::display(_("Error"), msgPool::class_not_found($tabclass), ERROR_DIALOG);
+ }else{
+ add_lock ($this->dn, $this->ui->dn);
+ $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn,$acl_cat);
+ $this->systab->set_acl_base($this->dn);
+ set_object_info($this->dn);
+ }
}else{
msg_dialog::display(_("Error"), _("Editing this type of object is not supported yet!"), ERROR_DIALOG);
- del_lock($this->dn);
+ $this->remove_lock();
}
}
/* Set terminals root password */
if ($s_action=="change_pw"){
- $tabs = array(
- "ArpNewDevice"=> array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "NewDevice" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal/termgeneric"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation/workgeneric"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server/servgeneric"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs", "ACL"=> "printer/printgeneric"),
- "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs", "ACL"=> "phone/phoneGeneric"),
- "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs", "ACL"=> "winworkstation/wingeneric"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component/componentGeneric"));
+ $tabs = $this->get_tab_defs();
$dn = $this->terminals[$s_entry]['dn'];
$type = $this->get_system_type($this->terminals[$s_entry]);
$tabacl = $ui->get_permissions($dn,$acl,"userPassword");
if(preg_match("/w/",$tabacl)){
$this->dn= $this->terminals[$s_entry]['dn'];
- session::set('objectinfo',$this->dn);
+ set_object_info($this->dn);
return ($smarty->fetch(get_template_path('password.tpl', TRUE)));
}else{
msg_dialog::display(_("Permission error"), _("You have no permission to change this password!"), ERROR_DIALOG);
$_POST['new_password'] == $_POST['repeated_password']){
/* Check if user is allowed to set password */
- $tabs = array(
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal/termgeneric" ,"PLUG"=>"termgeneric"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation/workgeneric" ,"PLUG"=>"workgeneric"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server/servgeneric" ,"PLUG"=>"servgeneric"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component/componentGeneric","PLUG"=>"componentGeneric"));
+ $tabs = $this->get_tab_defs();
- /* Detect object type */
$type = "";
foreach($this->terminals as $terminal){
if($terminal['dn'] == $this->dn){
if(!empty($type) && in_array($type,$allow_for)){
/* Get infos */
- $plug = $tabs[$type]["PLUG"];
- $class = $tabs[$type]["CLASS"];
+ $plug = $tabs[$type]["TABNAME"];
$acl = $tabs[$type]["ACL"];
$tabclass = $tabs[$type]["TABCLASS"];
-
+
/* Get acls */
$ui = get_userinfo();
$tabacl = $ui->get_permissions($this->dn,$acl,"userPassword");
}
$ldap->modify($attrs);
if (!$ldap->success()){
- msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, LDAP_MOD, get_class()));
+ msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, LDAP_MOD, $type));
}else{
- if(class_available($plug)){
+ if(class_available($plug)){
$p = new $plug($this->config,$this->dn);
$p->handle_post_events("modify");
}
}else{
msg_dialog::display(_("Error"), _("Cannot determine object to change password!"), ERROR_DIALOG);
}
- session::un_set('objectinfo');
+ set_object_info();
}
/* Delete terminal canceled? */
if (isset($_POST['delete_cancel']) || isset($_POST['password_cancel'])){
- del_lock ($this->dn);
- session::un_set('objectinfo');
+ $this->remove_lock();
+ set_object_info();
}
$this->dns = array();
$ids = $this->list_get_selected_items();
- if(count($ids)){
+ /* Handle opsi actions */
+ if($s_action == "trigger_event_DaemonEvent_reinstall"){
+ foreach($ids as $key => $id){
+ if($this->terminals[$id]['type'] == "O"){
+ $obj = $this->terminals[$id];
+ $this->opsi->job_opsi_install_client($obj['cn'][0],$obj['macAddress'][0]);
+ unset($ids[$key]);
+ }
+ }
+ }
+
+ if(count($ids) && class_available("DaemonEvent")){
$mac= array();
+ /* Collect target mac addresses */
$ldap = $this->config->get_ldap_link();
foreach($ids as $id){
- $ldap->cat ($this->terminals[$id]['dn'], array("macAddress"));
- $attrs= $ldap->fetch();
- if (isset($attrs['macAddress'][0])){
- $mac[]= $attrs['macAddress'][0];
+ $type = $this->get_system_type($this->terminals[$id]);
+ if(!in_array($type,array("terminal","server","workstation","opsi_client","winstation "))) continue;
+ if(isset($this->terminals[$id]['macAddress'][0])){
+ $mac[] = $this->terminals[$id]['macAddress'][0];
+ }else{
+ $ldap->cat ($this->terminals[$id]['dn'], array("macAddress"));
+ $attrs= $ldap->fetch();
+ if (isset($attrs['macAddress'][0])){
+ $mac[]= $attrs['macAddress'][0];
+ }
}
}
$events = DaemonEvent::get_event_types(SYSTEM_EVENT);
}
/* Insert scheduled events into queue */
- if($this->systab instanceof DaemonEvent){
+ if(class_available("DaemonEvent") && $this->systab instanceof DaemonEvent){
$this->systab->save_object();
/* Save event
Delete MULTIPLE entries requested, display confirm dialog
********************/
- if ($s_action=="del_multiple"){
+ if ($s_action=="del_multiple" || $s_action == "del"){
$this->dns = array();
- $ids = $this->list_get_selected_items();
+
+ if($s_action == "del_multiple"){
+ $ids = $this->list_get_selected_items();
+ }else{
+ $ids = array($s_entry);
+ }
+
+ $ui = get_userinfo();
+ $tabs = $this->get_tab_defs();
if(count($ids)){
+ $disallowed = array();
foreach($ids as $id){
- $dn = $this->terminals[$id]['dn'];
- $this->dns[$id] = $dn;
- }
- if ($user= get_multiple_locks($this->dns)){
- return(gen_locked_message($user,$this->dns));
+
+ /* Get 'dn' from posted termlinst */
+ $attrs = $this->terminals[$id];
+ $type = $this->get_system_type($attrs);
+ $dn = $attrs['dn'];
+ $acl = $this->ui->get_permissions($dn, $tabs[$type]['ACL']);
+ if(preg_match("/d/",$acl)){
+ $this->dns[$id] = $dn;
+ }else{
+ $disallowed[] = $dn;
+ }
}
- $dns_names = array();
- foreach($this->dns as $dn){
- add_lock ($dn, $this->ui->dn);
- $dns_names[] = @LDAP::fix($dn);
+ if(count($disallowed)){
+ msg_dialog::display(_("Permission"),msgPool::permDelete($disallowed),INFO_DIALOG);
}
- /* Lock the current entry, so nobody will edit it during deletion */
- $smarty->assign("warning", msgPool::deleteInfo($dns_names));
- $smarty->assign("multiple", true);
- return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+ if(count($this->dns)){
+
+ if ($user= get_multiple_locks($this->dns)){
+ return(gen_locked_message($user,$this->dns));
+ }
+
+ $dns_names = array();
+ foreach($this->dns as $dn){
+ add_lock ($dn, $this->ui->dn);
+ $dns_names[] = LDAP::fix($dn);
+ }
+
+ /* Lock the current entry, so nobody will edit it during deletion */
+ $smarty->assign("warning", msgPool::deleteInfo($dns_names));
+ $smarty->assign("multiple", true);
+ return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+ }
}
}
if (isset($_POST['delete_multiple_system_confirm'])){
$ui = get_userinfo();
- $tabs = array(
- "ArpNewDevice"=> array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "NewDevice" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal/termgeneric"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation/workgeneric"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server/servgeneric"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs", "ACL"=> "printer/printgeneric"),
- "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs", "ACL"=> "phone/phoneGeneric"),
- "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs", "ACL"=> "winworkstation/wingeneric"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component/componentGeneric"));
-
+ $tabs = $this->get_tab_defs();
/* Remove user by user and check acls before removeing them */
foreach($this->dns as $key => $dn){
msg_dialog::display(_("Permission error"), msgPool::permDelete(), ERROR_DIALOG);
new log("security","systems/".get_class($this),$dn,array(),"Tried to trick deletion.");
}
- /* Remove lock file after successfull deletion */
- del_lock ($dn);
- unset($this->dns[$key]);
}
+
+ /* Remove lock file after successfull deletion */
+ $this->remove_lock();
+ $this->dns = array();
}
}
/* Remove lock */
if(isset($_POST['delete_multiple_system_cancel'])){
- foreach($this->dns as $key => $dn){
- del_lock ($dn);
- unset($this->dns[$key]);
- }
- }
-
- /********************
- Delete system, confirm dialog
- ********************/
-
- /* Remove terminal was requested */
- if ($s_action=="del"){
-
- /* Get 'dn' from posted termlinst */
- $this->dn = $this->terminals[$s_entry]['dn'];
- $attrs = $this->terminals[$s_entry];
-
-
-
- $type= $this->get_system_type($attrs);
- $ui = get_userinfo();
- $tabs = array(
- "ArpNewDevice"=> array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "NewDevice" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal/termgeneric"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation/workgeneric"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server/servgeneric"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs", "ACL"=> "printer/printgeneric"),
- "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs", "ACL"=> "phone/phoneGeneric"),
- "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs", "ACL"=> "winworkstation/wingeneric"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component/componentGeneric"));
-
- /* get object type */
- $tabtype = "termtabs";
- $tabobj = "TERMTABS";
- $tabacl = "";
- if(isset($tabs[$type])){
- $tabtype = $tabs[$type]['TABCLASS'];
- $tabobj = $tabs[$type]['CLASS'];
- $tabacl = $ui->get_permissions($this->dn,$tabs[$type]['ACL']);
- }
-
- /* Load permissions for selected 'dn' and check if
- we're allowed to remove this 'dn' */
- if(preg_match("/d/",$tabacl)){
-
- /* Check locking, save current plugin in 'back_plugin', so
- the dialog knows where to return. */
- if (($user= get_lock($this->dn)) != ""){
- return(gen_locked_message ($user, $this->dn));
- }
-
- /* Lock the current entry, so nobody will edit it during deletion */
- add_lock ($this->dn, $this->ui->dn);
- $smarty->assign("warning", msgPool::deleteInfo(@LDAP::fix($this->dn)));
- $smarty->assign("multiple", false);
- return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
- } else {
-
- /* Obviously the user isn't allowed to delete. Show message and
- clean session. */
- msg_dialog::display(_("Permission error"), msgPool::permDelete(), ERROR_DIALOG);
- }
- }
-
-
- /********************
- Delete system, confirmed
- ********************/
- /* Confirmation for deletion has been passed. Terminal should be deleted. */
- if (isset($_POST['delete_terminal_confirm'])){
-
- /* Find out more about the object type */
- $ldap= $this->config->get_ldap_link();
- $ldap->cat($this->dn, array('objectClass'));
- $attrs= $ldap->fetch();
- $type= $this->get_system_type($attrs);
-
- $ui = get_userinfo();
-
- $tabs = array(
- "ArpNewDevice"=> array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "NewDevice" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "incoming/systems"),
- "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs", "ACL"=> "terminal/termgeneric"),
- "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs", "ACL"=> "workstation/workgeneric"),
- "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs", "ACL"=> "server/servgeneric"),
- "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs", "ACL"=> "printer/printgeneric"),
- "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs", "ACL"=> "phone/phoneGeneric"),
- "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs", "ACL"=> "winworkstation/wingeneric"),
- "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs", "ACL"=> "component/componentGeneric"));
-
- /* get object type */
- $tabtype = "termtabs";
- $tabobj = "TERMTABS";
- $tabacl = "";
- if(isset($tabs[$type])){
- $tabtype = $tabs[$type]['TABCLASS'];
- $tabobj = $tabs[$type]['CLASS'];
- $tabacl = $ui->get_permissions($this->dn,$tabs[$type]['ACL']);
- }
-
- /* Check if we are allowed to remove this object */
- if(preg_match("/d/",$tabacl)){
-
- /* Delete request is permitted, perform LDAP action */
- if(in_array($type,array("ArpNewDevice","NewDevice")) && class_available("termgeneric")){
- $this->systab= new termgeneric($this->config, $this->dn);
- $this->systab->set_acl_base($this->dn);
- $this->systab->remove_from_parent();
- }elseif($tabtype=="phonetabs"){
- $this->systab= new $tabtype($this->config, $this->config->data['TABS'][$tabobj], $this->dn,$type);
- $this->systab->set_acl_base($this->dn);
- $this->systab->by_object['phoneGeneric']->remove_from_parent ();
- }else{
- $this->systab= new $tabtype($this->config,$this->config->data['TABS'][$tabobj], $this->dn,$type);
- $this->systab->set_acl_base($this->dn);
- $this->systab->delete();
- }
- unset ($this->systab);
- $this->systab= NULL;
-
- /* Terminal list has changed, reload it. */
- } else {
-
- /* Normally this shouldn't be reached, send some extra
- logs to notify the administrator */
- msg_dialog::display(_("Permission error"), msgPool::permDelete(), ERROR_DIALOG);
- new log("security","systems/".get_class($this),$dn,array(),"Tried to trick deletion.");
- }
-
- /* Remove lock file after successfull deletion */
- del_lock ($this->dn);
- }
+ /* Remove lock file after successfull deletion */
+ $this->remove_lock();
+ $this->dns = array();
+ }
/********************
}
}
- if ((isset($_POST['edit_finish']) || isset($_POST['edit_apply'])) && (isset($this->systab->config)) || $save_object_directly){
+ if ((isset($_POST['edit_finish']) || isset($_POST['edit_apply'])) && (isset($this->systab->config))){
/* If the save routine gets interrupted by a confirm dialog,
store last action so we can trigger it again after 'Ok' was pressed.
}
/* Check tabs, will feed message array */
- $message = array();
- if(!$save_object_directly){
- $message = $this->systab->check();
- }else{
- $found = false;
-
- /* Set gotoMode to active if we there was an ogroup selected . (save_object_directly) */
- foreach(array("workgeneric"=>"active","servgeneric"=>"active","termgeneric"=>"active") as $tab => $value){
- if(isset($this->systab->by_object[$tab]->gotoMode)) {
- $found = true;
- $this->systab->by_object[$tab]->gotoMode = $value;
- }
- }
- if(!$found){
- msg_dialog::display(_("Internal error"), _("Cannot set mode to 'active'!"), ERROR_DIALOG);
- }
+ $message = $this->systab->check();
- }
/* Save, or display error message? */
if (count($message) == 0){
-
- /* Incoming behavior; you can select a system type and an ogroup membership.
- * If this object is an Incoming object, session::get('SelectedSystemType') isset.
- * Check if we must add the new object to an object group.
- *
- * If this is done, delete the old incoming entry... it is still there, because this is a new
- * entry and not an edited one, so we will delete it.
- *
- */
- if(session::is_set('SelectedSystemType')){
- $SelectedSystemType = session::get('SelectedSystemType');
- if($SelectedSystemType['ogroup'] != "none"){
- $og = new ogroup($this->config,$SelectedSystemType['ogroup']);
- if($og){
- $og->AddDelMembership($this->systab->dn);
- $og->save();
- }
- }
- }
-
- /* Save terminal data to ldap */
- $SelectedSystemType = session::get('SelectedSystemType');
- if(isset($SelectedSystemType['ogroup']) && $SelectedSystemType['ogroup'] != 'none'){
- foreach (array("workservice", "termservice") as $cls){
- if (isset($this->systab->by_object[$cls])){
- $this->systab->by_object[$cls]->gotoXMouseport= "";
- $this->systab->by_object[$cls]->gotoXMouseType= "";
- $this->systab->by_object[$cls]->gotoXResolution= "";
- $this->systab->by_object[$cls]->gotoXColordepth= "";
- }
- }
-
- # Enable activation
- foreach (array("servgeneric", "workgeneric", "termgeneric") as $cls){
- if (isset($this->systab->by_object[$cls])){
- $this->systab->by_object["workstartup"]->auto_activate= TRUE;
- }
- }
-
- # Enable sending of LDAP events
- if (isset($this->systab->by_object["workstartup"])){
- $this->systab->by_object["workstartup"]->gotoLdap_inherit= TRUE;
- }
- }
-
$this->systab->save();
- if(session::is_set('SelectedSystemType')){
- session::un_set('SelectedSystemType');
- if(!isset($ldap)){
- $ldap = $this->config->get_ldap_link();
- }
- $ldap->cd ($this->dn);
- $ldap->cat($this->dn, array('dn'));
- if(count($ldap->fetch())){
- $ldap->cd($this->dn);
- $ldap->rmDir($this->dn);
- }
+ /* Post handling for activated systems
+ target opsi -> Remove source.
+ target gosa -> Activate system.
+ */
+ if($this->systab instanceOf opsi_tabs && $this->systab->was_activated){
+ $ldap = $this->config->get_ldap_link();
$ldap->cd($this->config->current['BASE']);
+ $ldap->rmdir ($this->systab->dn);
+ @DEBUG(DEBUG_LDAP,__LINE__, __FUNCTION__, __FILE__,"Source removed: ".$this->systab->dn,"Opsi host activated.");
+ }elseif(isset($this->systab->was_activated) && $this->systab->was_activated){
+ $this->activate_new_device($this->systab->dn);
}
/* Terminal has been saved successfully, remove lock from LDAP. */
if (!isset($_POST['edit_apply'])){
if ($this->dn != "new"){
- del_lock ($this->dn);
+ $this->remove_lock();
}
unset ($this->systab);
$this->systab= NULL;
- session::un_set('objectinfo');
+ set_object_info();
}else{
/* Reinitialize tab */
/* Cancel dialogs */
if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel']) || isset($_POST['SystemTypeAborted'])){
if (isset($this->systab)){
- del_lock ($this->systab->dn);
+ $this->remove_lock();
unset ($this->systab);
}
$this->systab= NULL;
- session::un_set('objectinfo');
-
- /* Remove ogroup selection, which was set while editing a new incoming entry */
- if(session::is_set('SelectedSystemType')){
- session::un_set('SelectedSystemType');
- }
+ set_object_info();
}
/********************
/* Show tab dialog if object is present */
if (isset($this->systab->config)){
+
+ if($this->systab instanceOf plugin && !($this->systab instanceOf tabs)){
+ $this->systab->save_object();
+ }
+
$display= $this->systab->execute();
/* Don't show buttons if tab dialog requests this */
$dialog = FALSE;
$hide_apply = $this->dn == "new";
- $hide_apply = ($this->dn == "new") || (preg_match("/".normalizePreg(get_ou("incomingou"))."/",$this->dn));
+ $hide_apply = ($this->dn == "new") || (preg_match("/".preg_quote(get_ou("systemIncomingRDN"), '/')."/",$this->dn));
if(is_object($this->systab) && !isset($this->systab->by_object)){
$dialog = TRUE;
$hide_apply = TRUE;
$dialog = TRUE;
}
- if (!$dialog){
+ if(($this->systab instanceOf tabs || $this->systab instanceOf plugin) && $this->systab->read_only == TRUE){
+ $display.= "<p style=\"text-align:right\">
+ <input type=submit name=\"edit_cancel\" value=\"".msgPool::cancelButton()."\">
+ </p>";
+ }elseif (!$dialog){
$display.= "<p style=\"text-align:right\">\n";
$display.= "<input type=\"submit\" name=\"edit_finish\" style=\"width:80px\" value=\"".msgPool::okButton()."\">\n";
$display.= " \n";
/* Check if there is a snapshot dialog open */
$base = $this->DivListSystem->selectedBase;
- if($str = $this->showSnapshotDialog($base,$this->get_used_snapshot_bases())){
+ if($str = $this->showSnapshotDialog($base,$this->get_used_snapshot_bases(),$this)){
return($str);
}
/* Add departments if subsearch is disabled */
if(!$this->DivListSystem->SubSearch){
- $this->DivListSystem->AddDepartments($this->DivListSystem->selectedBase,3,1);
+
+ /* Add FAIstate to attributes if FAI is activated */
+ if($this->fai_activated){
+ $this->DivListSystem->AddDepartments($this->DivListSystem->selectedBase,4,1);
+ }else{
+ $this->DivListSystem->AddDepartments($this->DivListSystem->selectedBase,3,1);
+ }
}
$this->reload();
$this->DivListSystem->setEntries($this->terminals);
/* Check acls, if we are not allowed to create and write each plugin tab, skip this object */
$tabs = array(
- "terminal" => get_ou('terminalou'),
- "workstation" => get_ou('workstationou'),
- "incoming" => get_ou('incomingou'),
- "server" => get_ou('serverou'),
- "printer" => get_ou('printerou'),
- "phone" => get_ou('phoneou'),
+ "terminal" => get_ou('terminalRDN'),
+ "workstation" => get_ou('workstationRDN'),
+ "incoming" => get_ou('systemIncomingRDN'),
+ "server" => get_ou('serverRDN'),
+ "printer" => get_ou('printerRDN'),
+ "phone" => get_ou('phoneRDN'),
"winworkstation" => get_winstations_ou(),
- "component" => get_ou('componentou')
+ "component" => get_ou('componentRDN')
);
foreach($tabs as $acl_cat => $dn){
$res = array();
$this->terminals = array();
$userregex = "";
+ $opsi_clients = array();
/* Set base for all searches */
$base= $this->DivListSystem->selectedBase;
/* Prepare samba class name */
$samba ="";
if ($this->DivListSystem->ShowWinWorkstations){
- if ($this->config->current['SAMBAVERSION'] == "3"){
+ if ($this->config->get_cfg_value("sambaversion") == "3"){
$samba= "sambaSamAccount";
} else {
$samba= "sambaAccount";
/* This array represents the combination between checkboxes and search filters */
$objs = array(
- "ShowServers" => array("CLASS" => "goServer" ,"TREE" => get_ou('serverou')),
- "ShowTerminals" => array("CLASS" => "gotoTerminal" ,"TREE" => get_ou('terminalou')),
- "ShowPrinters" => array("CLASS" => "gotoPrinter" ,"TREE" => get_ou('printerou')),
- "ShowDevices" => array("CLASS" => "ieee802Device" ,"TREE" => get_ou('componentou')),
- "ShowPhones" => array("CLASS" => "goFonHardware" ,"TREE" => get_ou('phoneou')),
- "ShowWorkstations" => array("CLASS" => "gotoWorkstation" ,"TREE" => get_ou('workstationou')),
- "ShowWinWorkstations"=> array("CLASS" => $samba ,"TREE" => get_winstations_ou() ));
+ "ShowServers" => array("TAB" => "servtabs", "CLASS" => "goServer" ,"TREE" => get_ou('serverRDN')),
+ "ShowTerminals" => array("TAB" => "termtabs", "CLASS" => "gotoTerminal" ,"TREE" => get_ou('terminalRDN')),
+ "ShowPrinters" => array("TAB" => "printtabs", "CLASS" => "gotoPrinter" ,"TREE" => get_ou('printerRDN')),
+ "ShowDevices" => array("TAB" => "componenttabs", "CLASS" => "ieee802Device" ,"TREE" => get_ou('componentRDN')),
+ "ShowPhones" => array("TAB" => "phonetabs", "CLASS" => "goFonHardware" ,"TREE" => get_ou('phoneRDN')),
+ "ShowWorkstations" => array("TAB" => "worktabs", "CLASS" => "gotoWorkstation" ,"TREE" => get_ou('workstationRDN')),
+ "ShowWinWorkstations"=> array("TAB" => "wintabs", "CLASS" => $samba ,"TREE" => get_winstations_ou() ));
/* Include the 'Display Systems of user' attribute */
if ((!empty($this->DivListSystem->UserRegex)) && ($this->DivListSystem->UserRegex!= "*")){
}
/* Attributes to fetch */
- $sys_attrs = array("cn", "description", "macAddress", "objectClass", "sambaDomainName","gotoMode");
- $sys_categories = array("terminal", "workstation", "server", "phone" ,"printer","incoming");
+ $sys_attrs = array("cn", "description", "macAddress", "objectClass", "sambaDomainName","gotoMode","FAIclass");
+ $sys_categories = array("terminal", "workstation", "server", "phone" ,"printer","incoming","winworkstation","component");
/* Add FAIstate to attributes if FAI is activated */
$tmp = $this->config->search("faiManagement", "CLASS",array('menu','tabs'));
/* Walk through all possible search combinations, and search for some objects if the checkbox is enabled */
foreach($objs as $checkBox => $oc){
- if($this->DivListSystem->$checkBox){
+
+ if($this->DivListSystem->$checkBox && class_available($oc['TAB'])){
if($this->DivListSystem->SubSearch){
if($oc['CLASS'] != ""){
$filter = "(&".$userregex."(objectClass=".$oc['CLASS'].")(cn=".$this->DivListSystem->Regex."))";
/* Search for incoming objects */
$filter = "(|(&".$userregex."(objectClass=goHard)(cn=".$this->DivListSystem->Regex.")))";
- $res = array_merge($res,get_list($filter,$sys_categories, get_ou('incomingou').$base,$sys_attrs, GL_SIZELIMIT));
+ $res = array_merge($res,get_list($filter,$sys_categories, get_ou('systemIncomingRDN').$base,$sys_attrs, GL_SIZELIMIT));
+ /* Append opsi systems, the opsi extension have to installed.
+ (Only, if we are allowed to view opsi hosts)
+ */
+ if($this->opsi instanceof opsi && $this->opsi->enabled() && $this->DivListSystem->ShowOpsiHosts){
+ $o_acl = $this->ui->get_permissions($base,"opsi/opsiGeneric","");
+ if(preg_match("/r/",$o_acl)){
+ $opsi_clients = $this->opsi->get_hosts_for_system_management();
+ if($this->opsi->is_error()){
+ msg_dialog::display(_("Error"),msgPool::siError($this->opsi->get_error()),ERROR_DIALOG);
+ }
+ }
+ }
+
/* Get all gotoTerminal's */
+ $t_id = 0;
+ $opsi_map = array();
foreach ($res as $value){
$tmp= $value['dn'];
}
/* Create a string containing the last part of the department. */
- $dn_name = preg_replace("#^([^/]+/)*#","",convert_department_dn(@LDAP::fix($tmp)));
+ $dn_name = preg_replace("#^([^/]+/)*#","",convert_department_dn(LDAP::fix($tmp)));
if(empty($dn_name)){
$dn_name = "/";
}
/* check if current object is a new one */
- if (preg_match ("/,".get_ou('incomingou')."/i", $tmp)){
+ if (preg_match ("/,".get_ou('systemIncomingRDN')."/i", $tmp)){
if (in_array_ics('gotoTerminal', $value['objectClass'])){
$add= "- "._("New terminal");
}elseif (in_array_ics('gotoWorkstation', $value['objectClass'])){
/* Detect type of object and create an entry for $this->terminals */
$terminal = array();
- if (in_array_ics('gotoTerminal', $value["objectClass"])){
+
+ if (0 && in_array_ics('gosa_opsi_client', $value["objectClass"])){
+
+ /* check acl */
+ $terminal = $value;
+ $terminal['type'] = "O";
+
+ } elseif (in_array_ics('gotoTerminal', $value["objectClass"])){
/* check acl */
$acl = $ui->get_permissions($value['dn'],"terminal/termgeneric");
$terminal['type'] = "Q";
$terminal['is_new'] = $add;
}
- } elseif (in_array_ics('ieee802Device', $value["objectClass"])){
-
+ } elseif (in_array_ics('ieee802Device', $value["objectClass"]) &&
+ !( in_array_ics('sambaAccount', $value["objectClass"]) || in_array_ics('sambaSamAccount', $value["objectClass"]))){
+ $type= "winstation";
$acl = $ui->get_permissions($value['dn'],"component/componentGeneric");
if($add != "" || preg_match("/r/",$acl)) {
} else {
$domain= "";
}
- $terminal=$value;
- $terminal['type'] ="W";
- $terminal['domain'] = $name.$domain;
+ $acl = $ui->get_permissions($value['dn'],"winworkstation/wingeneric");
+ if($add != "" || preg_match("/r/",$acl)) {
+ $terminal=$value;
+ $terminal['type'] ="W";
+ $terminal['domain'] = $name.$domain;
+ }
}
+ /* Append collected data to the host list.
+ */
if(count($terminal)){
- $this->terminals[]=$terminal;
+ $t_id ++ ;
+ $this->terminals[$t_id]=$terminal;
+ $opsi_map[preg_replace('/\$$/',"",$value['cn'][0])] = $t_id;
}
}
+
+ /* Merge real hosts with opsi hosts.
+ If there is a samba host, then merge it with the opsi host,
+ to avoid duplicate entries.
+ */
+ foreach($opsi_clients as $entry){
+ if(isset($opsi_map[$entry['cn'][0]])){
+ continue;
+ }
+ $terminal = $entry;
+ $terminal['type'] = "O";
+ $this->terminals[] = $terminal;
+ }
+
$tmp =array();
$tmp2 =array();
foreach($this->terminals as $tkey => $val ){
{
if (isset($this->systab->dn)){
del_lock ($this->systab->dn);
+ }elseif(isset($this->dn) && !empty($this->dn) && $this->dn != "new"){
+ del_lock($this->dn);
+ }
+ if(isset($this->dns) && is_array($this->dns) && count($this->dns)){
+ del_lock($this->dns);
}
}
return("");
}
-
- $tabs = array(
- "terminal" => array( "CLASS" =>"TERMTABS", "TABNAME" =>"termgeneric",
- "TABCLASS" =>"termtabs", "ACL" =>"terminal"),
- "workstation" => array( "CLASS" =>"WORKTABS", "TABNAME" =>"workgeneric",
- "TABCLASS" =>"worktabs", "ACL" =>"workstation"),
- "server" => array( "CLASS" =>"SERVTABS", "TABNAME" =>"servgeneric",
- "TABCLASS" =>"servtabs", "ACL" =>"server"),
- "printer" => array( "CLASS" =>"PRINTTABS", "TABNAME" =>"printgeneric",
- "TABCLASS" =>"printtabs", "ACL" =>"printer"),
- "phone" => array( "CLASS" =>"PHONETABS", "TABNAME" =>"phoneGeneric",
- "TABCLASS" =>"phonetabs", "ACL" =>"phone"),
- "component" => array( "CLASS" =>"COMPONENTTABS","TABNAME" =>"componentGeneric",
- "TABCLASS" =>"componenttabs","ACL" =>"component"));
+ $ui = get_userinfo();
+
+ $tabs = $this->get_tab_defs();
/* Add a single entry to queue */
if($s_action == "cut" || $s_action == "copy"){
$tab_o = $tabs[$type]['CLASS'];
$tab_c = $tabs[$type]['TABCLASS'];
- $acl = $tabs[$type]['ACL'];
+ $acl_c = $tabs[$type]['TABNAME'];
+ $acl = $tabs[$type]['ACLC'];
- $this->CopyPasteHandler->add_to_queue($dn,$s_action,$tab_c,$tab_o,$acl);
+ if($s_action == "copy" && $ui->is_copyable($dn,$acl,$acl_c)){
+ $this->CopyPasteHandler->add_to_queue($dn,$s_action,$tab_c,$tab_o,$acl);
+ }
+ if($s_action == "cut" && $ui->is_cutable($dn,$acl,$acl_c)){
+ $this->CopyPasteHandler->add_to_queue($dn,$s_action,$tab_c,$tab_o,$acl);
+ }
}
/* Add entries to queue */
if(isset($tabs[$type])){
$tab_o = $tabs[$type]['CLASS'];
$tab_c = $tabs[$type]['TABCLASS'];
- $acl = $tabs[$type]['ACL'];
+ $acl_c = $tabs[$type]['TABNAME'];
+ $acl = $tabs[$type]['ACLC'];
- if($s_action == "copy_multiple"){
+ if($s_action == "copy_multiple" && $ui->is_copyable($dn,$acl,$acl_c)){
$this->CopyPasteHandler->add_to_queue($dn,"copy",$tab_c,$tab_o,$acl);
}
- if($s_action == "cut_multiple"){
+ if($s_action == "cut_multiple" && $ui->is_cutable($dn,$acl,$acl_c)){
$this->CopyPasteHandler->add_to_queue($dn,"cut",$tab_c,$tab_o,$acl);
}
}
if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){
/* Get dialog */
- $data = $this->CopyPasteHandler->execute();
$this->CopyPasteHandler->SetVar("base",$this->DivListSystem->selectedBase);
+ $data = $this->CopyPasteHandler->execute();
/* Return dialog data */
if(!empty($data)){
$classes = $attrs['objectClass'];
$type= "";
- if (in_array_ics('ieee802Device', $classes)){
+ if (in_array_ics('gosa_opsi_client', $classes)){
+ $type= "opsi_client";
+ }elseif (in_array_ics('sambaAccount', $classes) ||
+ in_array_ics('sambaSamAccount', $classes)){
+ $type= "winstation";
+ }elseif (in_array_ics('ieee802Device', $classes)){
$type= "component";
}elseif (in_array_ics('gotoTerminal', $classes)){
$type= "terminal";
$type= "ArpNewDevice";
}elseif (in_array_ics('GOhard', $classes)){
$type= "NewDevice";
- }elseif (in_array_ics('sambaAccount', $classes) ||
- in_array_ics('sambaSamAccount', $classes)){
- $type= "winstation";
}
return ($type);
}
$temp= "";
$conv= array(
- "D" => array("select_default.png",_("Template")),
- "F" => array("select_phone.png",_("Phone")),
- "C" => array("select_component.png",_("Network device")),
- "P" => array("select_printer.png",_("Printer")),
+ "D" => array("plugins/systems/images/select_default.png",_("Template")),
+ "F" => array("plugins/systems/images/select_phone.png",_("Phone")),
+ "C" => array("plugins/systems/images/select_component.png",_("Network device")),
+ "P" => array("plugins/systems/images/select_printer.png",_("Printer")),
+
+ "W" => array("plugins/systems/images/select_winstation.png",_("Windows workstation")),
- "W" => array("select_winstation.png",_("Win workstation")),
+ "L" => array("plugins/systems/images/select_workstation.png",_("Workstation")),
+ "S" => array("plugins/systems/images/select_server.png",_("Server")),
+ "T" => array("plugins/systems/images/select_terminal.png",_("Terminal")),
- "L" => array("select_workstation.png",_("Workstation")),
- "S" => array("select_server.png",_("Server")),
- "T" => array("select_terminal.png",_("Terminal")),
+ "LX" => array("plugins/systems/images/workstation_locked.png",_("Locked workstation")),
+ "SX" => array("plugins/systems/images/server_locked.png",_("Locked server")),
+ "TX" => array("plugins/systems/images/terminal_locked.png",_("Locked terminal")),
- "LX" => array("workstation_locked.png",_("Locked workstation")),
- "SX" => array("server_locked.png",_("Locked server")),
- "TX" => array("terminal_locked.png",_("Locked terminal")),
+ "LE" => array("plugins/systems/images/workstation_error.png",_("Workstation error")),
+ "SE" => array("plugins/systems/images/server_error.png",_("Server error")),
+ "TE" => array("plugins/systems/images/terminal_error.png",_("Terminal error")),
- "LE" => array("workstation_error.png",_("Workstation error")),
- "SE" => array("server_error.png",_("Server error")),
- "TE" => array("terminal_error.png",_("Terminal error")),
+ "LB" => array("plugins/systems/images/workstation_busy.png",_("Workstation busy")),
+ "SB" => array("plugins/systems/images/server_busy.png",_("Server busy")),
- "LB" => array("workstation_busy.png",_("Workstation busy")),
- "SB" => array("server_busy.png",_("Server busy")),
+ "NQ" => array("plugins/systems/images/select_newsystem.png",_("New system from incoming")),
+ "NT" => array("plugins/systems/images/select_new_terminal.png",_("New terminal")),
+ "NL" => array("plugins/systems/images/select_new_workstation.png",_("New workstation")));
- "NQ" => array("select_newsystem.png",_("New system from incoming")),
- "NT"=> array("select_new_terminal.png",_("New terminal")),
- "NL"=> array("select_new_workstation.png",_("New workstation")));
+ /* Add opsi client to system types */
+ if($this->opsi != NULL){
+ $conv["O"] = array("plugins/systems/images/select_winstation.png",_("Opsi client"));
+ }
/* Use locked icons
*/
/* Add FAI state icons
*/
+ $type= "";
switch (preg_replace('/:.*$/', '', $input['FAIstate'][0])) {
- case 'installing':
- $type= 'O';
- break;
case 'error':
$type= 'E';
break;
+ case 'installing':
case 'install':
case 'sysinfo':
case 'softupdate':
if(!preg_match("/".$key[$i]."/",$input['type'])){
$found = FALSE;
}
- }
+ }
if($found){
- $tmp['img'] ="<img class='center' src='images/".$value[0]."' alt='".$key."' title='".$value['1']."'>";
+ $tmp['img'] ="<img class='center' src='".$value[0]."' alt='".$key."' title='".$value['1']."'>";
$tmp['class']=$key;
return $tmp;
}
}
+ public function get_tab_defs()
+ {
+ $tabs = array(
+ "incoming" => array(
+ "CLASS" => "",
+ "TABNAME" => "",
+ "TABCLASS" => "",
+ "ACLC" => "incoming",
+ "ACL" => "incoming/systems"),
+
+ "ArpNewDevice"=> array(
+ "CLASS" => "TERMTABS",
+ "TABNAME" => "termgeneric" ,
+ "TABCLASS" => "termtabs",
+ "ACLC" => "incoming",
+ "ACL" => "incoming/systems"),
+
+ "NewDevice" => array(
+ "CLASS" => "TERMTABS",
+ "TABNAME" => "termgeneric",
+ "TABCLASS" => "termtabs",
+ "ACLC" => "incoming",
+ "ACL" => "incoming/systems"),
+
+ "terminal" => array(
+ "CLASS" => "TERMTABS",
+ "TABNAME" => "termgeneric",
+ "TABCLASS" => "termtabs",
+ "ACLC" => "terminal",
+ "ACL" => "terminal/termgeneric"),
+
+ "workstation" => array(
+ "CLASS" => "WORKTABS",
+ "TABNAME" => "workgeneric",
+ "TABCLASS"=> "worktabs",
+ "ACLC" => "workstation",
+ "ACL" => "workstation/workgeneric" ),
+
+ "server" => array(
+ "CLASS" => "SERVTABS",
+ "TABNAME" => "servgeneric",
+ "TABCLASS"=> "servtabs",
+ "ACLC" => "server",
+ "ACL" => "server/servgeneric"),
+
+ "printer" => array(
+ "CLASS" => "PRINTTABS",
+ "TABNAME" => "printgeneric",
+ "TABCLASS"=> "printtabs",
+ "ACLC" => "printer",
+ "ACL" => "printer/printgeneric"),
+
+ "phone" => array(
+ "CLASS" => "PHONETABS",
+ "TABNAME" => "phoneGeneric",
+ "TABCLASS"=> "phonetabs",
+ "ACLC" => "phone",
+ "ACL" => "phone/phoneGeneric"),
+
+ "winstation" => array(
+ "CLASS" => "WINTABS",
+ "TABNAME" => "wingeneric",
+ "TABCLASS"=> "wintabs",
+ "ACLC" => "winworkstation",
+ "ACL" => "winworkstation/wingeneric"),
+
+ "component" => array(
+ "CLASS" => "COMPONENTTABS",
+ "TABNAME" => "componentGeneric",
+ "TABCLASS"=> "componenttabs",
+ "ACLC" => "component",
+ "ACL" => "component/componentGeneric"));
+
+ if($this->opsi != NULL){
+ $tabs["opsi_client"] = array(
+ "CLASS" => "OPSITABS",
+ "TABNAME" => "opsiGeneric" ,
+ "TABCLASS"=> "opsi_tabs",
+ "ACLC" => "opsi" ,
+ "ACL" => "opsi/opsiGeneric");
+ }
+
+ return($tabs);
+ }
+
+
+ /*! \brief Sets FAIstate to "install" for "New Devices".
+ This function is some kind of "Post handler" for activated systems,
+ it is called directly after the object (workstabs,servtabs) gets saved.
+ @param String $dn The dn of the newly activated object.
+ @return Boolean TRUE if activated else FALSE
+ */
+ function activate_new_device($dn)
+ {
+ $ldap = $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+ $ldap->cat($dn);
+ if($ldap->count()){
+ $attrs = $ldap->fetch();
+ $type = $this->get_system_type($attrs);
+ if(!in_array($type,array("workstation","server"))) {
+ $ocs = $attrs['objectClass'];
+ unset($ocs['count']);
+ $new_attrs = array();
+ if(!in_array("FAIobject",$ocs)){
+ $ocs[] = "FAIobject";
+ $new_attrs['objectClass'] = $ocs;
+ }
+ $new_attrs['FAIstate'] = "install";
+ $ldap->cd($dn);
+ $ldap->modify($new_attrs);
+ if (!$ldap->success()){
+ msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn,
+ LDAP_MOD, "activate_new_device($dn)"));
+ }else{
+ return(TRUE);
+ }
+ }
+ }
+ return(FALSE);
+ }
+
+
/* !! Incoming dummy acls, required to defined acls for incoming objects
*/
static function plInfo()
));
}
-
-
-
-
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: