X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fsystems%2Fclass_systemManagement.inc;h=b19b57cb3dac446345303acab36a502602351dbe;hb=408dda1f13eaab930b68d47cca237d2c866d9aa1;hp=b64fb5e777f8984cbf0b389d3edb690b0eba7a44;hpb=82c9653059b3ef6e214f5bfa181ed99b270b3776;p=gosa.git
diff --git a/plugins/admin/systems/class_systemManagement.inc b/plugins/admin/systems/class_systemManagement.inc
index b64fb5e77..b19b57cb3 100644
--- a/plugins/admin/systems/class_systemManagement.inc
+++ b/plugins/admin/systems/class_systemManagement.inc
@@ -38,6 +38,8 @@ class systems extends plugin
var $terminals= array();
var $ui= NULL;
var $acl= "";
+ var $DivListSystem;
+ var $image_creation_log ="";
function systems ($config, $ui)
{
@@ -45,67 +47,25 @@ class systems extends plugin
$this->config= $config;
$this->ui= $ui;
- /* Get global filter config */
- if (!is_global("terminalfilter")){
- $ui= get_userinfo();
- $base= get_base_from_people($ui->dn);
- $terminalfilter= array("workstations" => "checked",
- "thins" => "checked",
- "winstations" => "checked",
- "servers" => "checked",
- "printers" => "checked",
- "phones" => "checked",
- "netdev" => "checked",
- "user" => "*",
- "depselect" => $base,
- "regex" => "*");
- register_global("terminalfilter", $terminalfilter);
- }
+ /* Creat dialog object */
+ $this->DivListSystem = new divListSystem($this->config,$this);
}
function execute()
{
- /* Call parent execute */
- plugin::execute();
-
- /* Save data */
- $terminalfilter= get_global("terminalfilter");
- foreach( array("depselect", "user", "regex") as $type){
- if (isset($_POST[$type])){
- $terminalfilter[$type]= $_POST[$type];
- }
- }
- if (isset($_POST['depselect'])){
- foreach( array("workstations", "thins", "winstations", "printers", "phones", "servers", "netdev") as $type){
+ /* Call parent execute */
+ plugin::execute();
- if (isset($_POST[$type])) {
- $terminalfilter[$type]= "checked";
- } else {
- $terminalfilter[$type]= "";
- }
- }
- }
- if (isset($_GET['search'])){
- $s= mb_substr($_GET['search'], 0, 1, "UTF8")."*";
- if ($s == "**"){
- $s= "*";
- }
- $terminalfilter['regex']= $s;
- }
+ $_SESSION['LOCK_VARS_TO_USE'] = array("/^user_edit_/i","/^user_del_/","/^act/","/^id/");
+ /********************
+ Check for functional posts, edit|delete|add|... system devices
+ ********************/
$s_action = ""; // Contains the action to proceed
$s_entry = ""; // The value for s_action
$base_back = ""; // The Link for Backbutton
$smarty = get_smarty();
- /* Start for New List Managment */
- if(isset($_GET['act'])&&($_GET['act']=="dep_open")){
- $s_action="open";
- $s_entry = base64_decode($_GET['dep_id']);
- $terminalfilter['depselect']= "".$this->config->departments[trim($s_entry)];
- $this->reload();
- }
-
/* Test Posts */
foreach($_POST as $key => $val){
// Post for delete
@@ -117,63 +77,42 @@ class systems extends plugin
$s_action="edit";
$s_entry = preg_replace("/user_".$s_action."_/i","",$key);
// Post for new
- }elseif(preg_match("/dep_back.*/i",$key)){
- $s_action="back";
}elseif(preg_match("/user_new.*/",$key)){
$s_action="new";
- }elseif(preg_match("/dep_home.*/i",$key)){
- $s_action="home";
}elseif(preg_match("/user_tplnew.*/i",$key)){
$s_action="new_tpl";
}elseif(preg_match("/user_setpwd_.*/i",$key)){
$s_action="change_pw";
$s_entry = preg_replace("/user_setpwd_/i","",$key);
- }elseif(preg_match("/dep_root.*/i",$key)){
- $s_action="root";
+ }elseif(preg_match("/gen_cd_.*/i",$key)){
+ $s_action="gen_cd";
+ $s_entry = preg_replace("/gen_cd_/i","",$key);
}elseif(preg_match("/newsystem_.*/i",$key)){
$s_action="newsystem";
$s_entry = preg_replace("/newsystem_/i","",$key);
}
}
- if((isset($_GET['act']))&&($_GET['act']=="edit_entry")){
- $s_action ="edit";
- $s_entry = $_GET['id'];
+ /* 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";
+ $s_entry = $_POST['SystemType'];
+ $_SESSION['SelectedSystemType']['ogroup'] = $_POST['ObjectGroup'];
+ $this->systab = NULL;
}
+ /* remove image tags from posted entry (posts looks like this 'name_x')*/
$s_entry = preg_replace("/_.$/","",$s_entry);
- /* Department changed? */
- if(isset($_POST['depselect']) && $_POST['depselect']){
- $terminalfilter['depselect']= $_POST['depselect'];
- }
-
- /* Homebutton is posted */
- if($s_action=="home"){
- $terminalfilter['depselect']=(preg_replace("/^[^,]+,/","",$this->ui->dn));
- $terminalfilter['depselect']=(preg_replace("/^[^,]+,/","",$terminalfilter['depselect']));
- }
-
- if($s_action=="root"){
- $terminalfilter['depselect']=($this->config->current['BASE']);
- }
-
-
- /* If Backbutton is Posted */
- if($s_action=="back"){
- $base_back = preg_replace("/^[^,]+,/","",$terminalfilter['depselect']);
- $base_back = convert_department_dn($base_back);
-
- if(isset($this->config->departments[trim($base_back)])){
- $terminalfilter['depselect']= $this->config->departments[trim($base_back)];
- }else{
- $terminalfilter['depselect']= $this->config->departments["/"];
- }
+ /* Edit was requested by pressing the name(link) of an item */
+ if((isset($_GET['act']))&&($_GET['act']=="edit_entry")){
+ $s_action ="edit";
+ $s_entry = $_GET['id'];
}
- register_global("terminalfilter", $terminalfilter);
- $this->reload();
-
/* Check for exeeded sizelimit */
if (($message= check_sizelimit()) != ""){
return($message);
@@ -184,73 +123,60 @@ class systems extends plugin
return ($smarty->fetch(get_template_path('chooser.tpl', TRUE)));
}
- /* Create new default terminal */
- if (isset($_POST['create_system'])||$s_action=="newsystem") {
- $this->dn= "new";
- $this->acl= array(":all");
+ /********************
+ Create new system ...
+ ********************/
+ /* Create new default terminal
+ * Or create specified object of selected system type, from given incoming object
+ */
+
+ $save_object_directly = false;
+ if(($s_action == "SelectedSystemType") && (isset($_POST['ObjectGroup']) && ($_POST['ObjectGroup'] != "none"))){
+ $save_object_directly = true;
+ }
+
+ if (isset($_POST['create_system'])||$s_action=="newsystem"||$s_action == "SelectedSystemType") {
- if(isset($_POST['system'])){
- $sw = $_POST['system'];
+ /* 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;
}else{
- $sw = $s_entry;
+ if(isset($_POST['system'])){
+ $sw = $_POST['system'];
+ }else{
+ $sw = $s_entry;
+ }
+ $this->dn= "new";
}
+ $this->acl= array(":all");
+ $tabs = array(
+ "terminal" => array("CLASS"=>"TERMTABS", "TABNAME"=>"termgeneric", "TABCLASS" =>"termtabs"),
+ "workstation" => array("CLASS"=>"WORKTABS", "TABNAME"=>"workgeneric", "TABCLASS" =>"worktabs"),
+ "server" => array("CLASS"=>"SERVTABS", "TABNAME"=>"servgeneric", "TABCLASS" =>"servtabs"),
+ "printer" => array("CLASS"=>"PRINTTABS", "TABNAME"=>"printgeneric", "TABCLASS" =>"printtabs"),
+ "phone" => array("CLASS"=>"PHONETABS", "TABNAME"=>"phonegeneric", "TABCLASS" =>"phonetabs"),
+ "component" => array("CLASS"=>"COMPONENTTABS","TABNAME"=>"componentgeneric","TABCLASS" =>"componenttabs"));
- switch ($sw){
- case 'terminal':
- $this->systab= new termtabs($this->config,
- $this->config->data['TABS']['TERMTABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['termgeneric']->cn= "default";
- $this->systab->by_object['termservice']->cn= "default";
- $this->systab->by_object['termgeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
-
- case 'workstation':
- $this->systab= new worktabs($this->config,
- $this->config->data['TABS']['WORKTABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['workgeneric']->cn= "wdefault";
- $this->systab->by_object['workservice']->cn= "default";
- $this->systab->by_object['workgeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
-
- case 'server':
- $this->systab= new servtabs($this->config,
- $this->config->data['TABS']['SERVTABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['servgeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
-
- case 'printer':
- $this->systab= new printtabs($this->config,
- $this->config->data['TABS']['PRINTTABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['printgeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
-
- case 'phone':
- $this->systab= new phonetabs($this->config,
- $this->config->data['TABS']['PHONETABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['phonegeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
-
- case 'component':
- $this->systab= new componenttabs($this->config,
- $this->config->data['TABS']['COMPONENTTABS'], $this->dn);
- $this->systab->set_acl ($this->acl);
- $this->systab->by_object['componentgeneric']->base = $_SESSION['terminalfilter']['depselect'];
- break;
+ if(isset($tabs[$sw])){
+ $class = $tabs[$sw]["CLASS"];
+ $tabname = $tabs[$sw]["TABNAME"];
+ $tabclass = $tabs[$sw]["TABCLASS"];
+ $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn);
+ $this->systab->set_acl ($this->acl);
+ $this->systab->by_object[$tabname]->base = $this->DivListSystem->selectedBase;
+ $this->systab->base = $this->DivListSystem->selectedBase;
}
-
- $this->systab->base = $_SESSION['terminalfilter']['depselect'];
}
+ /********************
+ Edit system ...
+ ********************/
/* User wants to edit data? */
- if ($s_action == "edit"){
+ if (($s_action == "edit") && (!isset($this->systab->config))){
- /* Get 'dn' from posted 'cn', must be unique */
$this->dn= $this->terminals[$s_entry]['dn'];
/* Check locking, save current plugin in 'back_plugin', so
@@ -264,78 +190,160 @@ class systems extends plugin
/* Find out more about the object type */
$ldap= $this->config->get_ldap_link();
- $ldap->cat($this->dn);
+ $ldap->cat($this->dn, array('objectClass'));
$attrs= $ldap->fetch();
$type= $this->get_system_type($attrs['objectClass']);
/* Lock the current entry, so everyone will get the
above dialog */
- add_lock ($this->dn, $this->ui->dn);
-
- switch ($type){
- case "terminal":
- /* Register systab to trigger edit dialog */
- $this->systab= new termtabs($this->config,
- $this->config->data['TABS']['TERMTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "server":
- /* Register systab to trigger edit dialog */
- $this->systab= new servtabs($this->config,
- $this->config->data['TABS']['SERVTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "workstation":
- /* Register systab to trigger edit dialog */
- $this->systab= new worktabs($this->config,
- $this->config->data['TABS']['WORKTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "printer":
- /* Register systab to trigger edit dialog */
- $this->systab= new printtabs($this->config,
- $this->config->data['TABS']['PRINTTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "phone":
- /* Register systab to trigger edit dialog */
- $this->systab= new phonetabs($this->config,
- $this->config->data['TABS']['PHONETABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "component":
- /* Register systab to trigger edit dialog */
- $this->systab= new componenttabs($this->config,
- $this->config->data['TABS']['COMPONENTTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
- case "winstation":
- /* Register systab to trigger edit dialog */
- $this->systab= new wintabs($this->config,
- $this->config->data['TABS']['WINTABS'], $this->dn);
- $this->systab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- break;
-
-
- default:
- print_red (_("You can't edit this object type yet!"));
- del_lock($this->dn);
- break;
+ $tabs = array(
+ "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs"),
+ "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs"),
+ "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs"),
+ "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs"),
+ "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs"),
+ "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs"),
+ "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs"));
+
+
+ if($type == "NewDevice"){
+ $this->systab = new SelectDeviceType($this->config,$this->dn) ;
+ }elseif(isset($tabs[$type])){
+
+ $class = $tabs[$type]["CLASS"];
+ $tabclass = $tabs[$type]["TABCLASS"];
+
+ $this->systab= new $tabclass($this->config, $this->config->data['TABS'][$class], $this->dn);
+ $this->systab->set_acl($acl);
+ $_SESSION['objectinfo']= $this->dn;
+ add_lock ($this->dn, $this->ui->dn);
+ }else{
+ print_red (_("You can't edit this object type yet!"));
+ del_lock($this->dn);
+ }
+ }
+
+ /********************
+ Create FAI CD ...
+ ********************/
+ if ($s_action=="gen_cd"){
+ $this->dn= $this->terminals[$s_entry]['dn'];
+ $_SESSION['objectinfo']= $this->dn;
+ return ($smarty->fetch(get_template_path('gencd.tpl', TRUE)));
+ }
+
+ /* Start CD-Creation */
+ if (isset($_POST["cd_create"])){
+ $smarty->assign("src", "?plug=".$_GET['plug']."&PerformIsoCreation");
+ return ($smarty->fetch(get_template_path('gencd_frame.tpl', TRUE)));
+ }
+
+ if ($this->dn != "" && isset($_GET['PerformIsoCreation'])){
+
+ /* Initialize some attributes */
+ $this->image_creation_log = "";
+ $download_button = ""._("Download")."";
+ $return_button = ""._("Back to work")."";
+ $dsc = array(0 => array("pipe", "r"), 1 => array("pipe", "w"), 2 => array("pipe", "w"));
+
+ /* Get and check command */
+ $command= search_config($this->config->data['TABS'], "workgeneric", "ISOCMD");
+ $command = "/bin/sh /home/hickert/gen_stuff.sh";
+ if (check_command($command)){
+ @DEBUG (DEBUG_SHELL, __LINE__, __FUNCTION__, __FILE__, $command, "Execute");
+
+ /* Print out html introduction */
+ echo "
";
+ echo "";
+ echo "";
+ echo "
+
+
";
+
+ /* Open process handle and check if it is a valid process */
+ $process= proc_open($command, $dsc, $pipes, '/tmp');
+ if (is_resource($process)) {
+ fclose($pipes[0]);
+
+ /* Print out returned lines && write JS to scroll down each line */
+ while (!feof($pipes[1])){
+ $cur_dat = fgets($pipes[1], 1024);
+ $this->image_creation_log .= $cur_dat;
+ echo $cur_dat;
+ echo "" ;
+ flush();
+ }
+ }
+
+ /* Get error string && close streams */
+ $buffer= stream_get_contents($pipes[2]);
+ fclose($pipes[1]);
+ fclose($pipes[2]);
+ echo "
".sprintf(_("Command '%s', specified for ISO creation doesn't seem to exist."), $command)."
";
+ echo $tmp;
+ }
+
+ /* Scroll down completly */
+ echo "" ;
+ echo "";
+ flush();
+ exit;
+ }
+
+
+ /******************
+ FAI Image creation logfile requested
+ ******************/
+ if(isset($_GET['download_image_log'])){
+
+ /* force download dialog */
+ header("Content-type: application/tiff\n");
+ if (preg_match('/MSIE 5.5/', $HTTP_USER_AGENT) ||
+ preg_match('/MSIE 6.0/', $HTTP_USER_AGENT)) {
+ header('Content-Disposition: filename="image.log"');
+ } else {
+ header('Content-Disposition: attachment; filename="image.log"');
}
+ header("Content-transfer-encoding: binary\n");
+ header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
+ header("Last-Modified: ".gmdate("D, d M Y H:i:s")." GMT");
+ header("Cache-Control: no-cache");
+ header("Pragma: no-cache");
+ header("Cache-Control: post-check=0, pre-check=0");
+
+ echo $this->image_creation_log;
+
+ exit();
}
+
+
+
+ /********************
+ Change password ...
+ ********************/
/* Set terminals root password */
if ($s_action=="change_pw"){
@@ -344,6 +352,11 @@ class systems extends plugin
return ($smarty->fetch(get_template_path('password.tpl', TRUE)));
}
+
+ /********************
+ Password cahnge finish, but check if entered data is ok
+ ********************/
+
/* Correctly specified? */
if (isset($_POST['password_finish'])){
if ($_POST['new_password'] != $_POST['repeated_password']){
@@ -352,6 +365,10 @@ class systems extends plugin
}
}
+ /********************
+ Password change finish
+ ********************/
+
/* Change terminal password */
if (isset($_POST['password_finish']) &&
$_POST['new_password'] == $_POST['repeated_password']){
@@ -378,12 +395,22 @@ class systems extends plugin
unset($_SESSION['objectinfo']);
}
+
+ /********************
+ Delete system cancel
+ ********************/
+
/* Delete terminal canceled? */
if (isset($_POST['delete_cancel']) || isset($_POST['password_cancel'])){
del_lock ($this->dn);
unset($_SESSION['objectinfo']);
}
+
+ /********************
+ Delete system, confirm dialog
+ ********************/
+
/* Remove terminal was requested */
if ($s_action=="del"){
@@ -404,7 +431,7 @@ class systems extends plugin
/* Lock the current entry, so nobody will edit it during deletion */
add_lock ($this->dn, $this->ui->dn);
- $smarty->assign("warning", sprintf(_("You're about to delete all information about the component at '%s'."), $this->dn));
+ $smarty->assign("warning", sprintf(_("You're about to delete all information about the component at '%s'."), @LDAP::fix($this->dn)));
return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
} else {
@@ -414,6 +441,10 @@ class systems extends plugin
}
}
+
+ /********************
+ Delete system, confirmed
+ ********************/
/* Confirmation for deletion has been passed. Terminal should be deleted. */
if (isset($_POST['delete_terminal_confirm'])){
@@ -423,54 +454,45 @@ class systems extends plugin
/* Find out more about the object type */
$ldap= $this->config->get_ldap_link();
- $ldap->cat($this->dn);
+ $ldap->cat($this->dn, array('objectClass'));
$attrs= $ldap->fetch();
$type= $this->get_system_type($attrs['objectClass']);
- switch ($type){
- case "terminal":
- $tabtype= "termtabs";
- break;
-
- case "workstation":
- $tabtype= "worktabs";
- break;
-
- case "phone":
- $tabtype= "phonetabs";
- break;
-
- case "server":
- $tabtype= "servtabs";
- break;
-
- default:
-#print_red (_("You can't remove this object type yet!"));
-#del_lock($this->dn);
-#return;
- $tabtype= "termtabs";
- break;
+ $tabs = array(
+ "terminal" => array("CLASS"=>"TERMTABS", "TABCLASS" =>"termtabs"),
+ "workstation" => array("CLASS"=>"WORKTABS", "TABCLASS" =>"worktabs"),
+ "server" => array("CLASS"=>"SERVTABS", "TABCLASS" =>"servtabs"),
+ "printer" => array("CLASS"=>"PRINTTABS", "TABCLASS" =>"printtabs"),
+ "phone" => array("CLASS"=>"PHONETABS", "TABCLASS" =>"phonetabs"),
+ "winstation" => array("CLASS"=>"WINTABS", "TABCLASS" =>"wintabs"),
+ "component" => array("CLASS"=>"COMPONENTTABS","TABCLASS" =>"componenttabs"));
+
+ /* get object type */
+ $tabtype = "termtabs";
+ $tabobj = "TERMTABS";
+ if(isset($tabs[$type])){
+ $tabtype = $tabs[$type]['TABCLASS'];
+ $tabobj = $tabs[$type]['CLASS'];
}
/* Delete request is permitted, perform LDAP action */
if($tabtype=="phonetabs"){
$this->systab= new $tabtype($this->config,
- $this->config->data['TABS']['PHONETABS'], $this->dn);
+ $this->config->data['TABS'][$tabobj], $this->dn);
$this->systab->set_acl(array($this->acl));
$this->systab->by_object['phonegeneric']->remove_from_parent ();
}else{
$this->systab= new $tabtype($this->config,
- $this->config->data['TABS']['TERMTABS'], $this->dn);
+ $this->config->data['TABS'][$tabobj], $this->dn);
$this->systab->set_acl(array($this->acl));
$this->systab->delete();
- #$this->systab->by_object['termgeneric']->remove_from_parent ();
+#$this->systab->by_object['termgeneric']->remove_from_parent ();
}
unset ($this->systab);
gosa_log ("System object'".$this->dn."' has been removed");
$this->systab= NULL;
/* Terminal list has changed, reload it. */
- $this->reload ();
} else {
/* Normally this shouldn't be reached, send some extra
@@ -484,20 +506,81 @@ class systems extends plugin
del_lock ($this->dn);
}
+
+ /********************
+ Edit system type finished, check if everything went ok
+ ********************/
/* Finish user edit is triggered by the tabulator dialog, so
the user wants to save edited data. Check and save at this
point. */
- if (isset($_POST['edit_finish'])){
+ if ((isset($_POST['edit_finish'])) && (isset($this->systab->config)) || $save_object_directly){
/* Check tabs, will feed message array */
- $message= $this->systab->check();
+ $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"=>"graphic") as $tab => $value){
+ if(isset($this->systab->by_object[$tab]->gotoMode)) {
+ $found = true;
+ $this->systab->by_object[$tab]->gotoMode = $value;
+ }
+ }
+ if(!$found){
+ print_red(sprintf(_("Can't set gotoMode to status 'avtice', the current object couldn't be identified.")));
+ }
+ }
/* Save, or display error message? */
if (count($message) == 0){
/* Save terminal data to ldap */
- gosa_log ("System object'".$this->dn."' has been saved");
+ if(isset($_SESSION['SelectedSystemType']['ogroup']) && $_SESSION['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= "";
+ }
+ }
+ }
+
$this->systab->save();
+ gosa_log ("System object'".$this->dn."' has been saved");
+
+ /* Incoming behavior; you can select a system type and an ogroup membership.
+ * If this object is an Incoming object, $_SESSION['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(isset($_SESSION['SelectedSystemType'])){
+ $SelectedSystemType= $_SESSION['SelectedSystemType'];
+ unset($_SESSION['SelectedSystemType']);
+ if($SelectedSystemType['ogroup'] != "none"){
+ $og = new ogroup($this->config,$SelectedSystemType['ogroup']);
+ if($og){
+ $og->AddDelMembership($this->systab->dn);
+ $og->save();
+ }
+ }
+ 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);
+ }
+ $ldap->cd($this->config->current['BASE']);
+ }
/* Terminal has been saved successfully, remove lock from
LDAP. */
@@ -505,39 +588,46 @@ class systems extends plugin
del_lock ($this->dn);
}
- /* There's no page reload so we have to read new terminals at
- this point. */
- $this->reload ();
unset ($this->systab);
$this->systab= NULL;
unset($_SESSION['objectinfo']);
-
} else {
/* Ok. There seem to be errors regarding to the tab data,
show message and continue as usual. */
show_errors($message);
}
-
}
+ /********************
+ Edit system was canceled
+ ********************/
/* Cancel dialogs */
- if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel'])){
+ if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel']) || isset($_POST['SystemTypeAborted'])){
if (isset($this->systab)){
del_lock ($this->systab->dn);
unset ($this->systab);
}
$this->systab= NULL;
unset($_SESSION['objectinfo']);
+
+ /* Remove ogroup selection, which was set while editing a new incoming entry */
+ if(isset($_SESSION['SelectedSystemType'])){
+ unset($_SESSION['SelectedSystemType']);
+ }
}
+ /********************
+ Display edit dialog, or some other
+ ********************/
+
/* Show tab dialog if object is present */
- if ($this->systab){
+ if (isset($this->systab->config)){
$display= $this->systab->execute();
/* Don't show buttons if tab dialog requests this */
- if (!$this->systab->by_object[$this->systab->current]->dialog){
+ if ((isset($this->systab->by_object))&&(!$this->systab->by_object[$this->systab->current]->dialog)){
$display.= "