dn); } } /* Remove this plugin from session */ if ( $cleanup ){ session::un_set('posixAccount'); session::un_set('edit'); }else{ /* Reset requested? */ if (isset($_POST['edit_cancel'])){ session::un_set ('edit'); session::un_set ('posixAccount'); } /* Create posixAccount object on demand */ if (!session::is_set('posixAccount') || (isset($_GET['reset']) && $_GET['reset'] == 1)){ $posixAccount= new posixAccount ($config, $ui->dn); $posixAccount->enable_CSN_check(); $posixAccount->set_acl_base($ui->dn); $posixAccount->set_acl_category("users"); session::set('posixAccount',$posixAccount); } $posixAccount = session::get('posixAccount'); /* save changes back to object */ if (session::is_set('edit')){ $posixAccount->save_object (); } /* Enter edit mode? */ if ((isset($_POST['edit'])) && (!session::is_set('edit'))){ /* Check locking */ if (($username= get_lock($ui->dn)) != ""){ session::set('back_plugin',$plug); session::set('LOCK_VARS_TO_USE',array("/^edit$/","/^plug$/")); $lock_msg = gen_locked_message ($username, $ui->dn); }else{ /* Lock the current entry */ add_lock ($ui->dn, $ui->dn); session::set('edit',TRUE); } } /* save changes to LDAP and disable edit mode */ $info= ""; if (isset($_POST['edit_finish'])){ /* Perform checks */ $message= $posixAccount->check (); /* No errors, save object */ if (count ($message) == 0){ $posixAccount->save (); del_lock ($ui->dn); session::un_set ('edit'); /* Remove from session */ session::un_set ('posixAccount'); } else { /* Errors found, show message */ msg_dialog::displayChecks($message); } } /* Execute formular */ if($lock_msg){ $display = $lock_msg; }else{ $display.= $posixAccount->execute (); } /* Store changes in session */ if (session::is_set('edit')){ session::set('posixAccount',$posixAccount); } /* Show page footer depending on the mode */ if (!$posixAccount->groupSelect && !$posixAccount->trustSelect && $posixAccount->is_account && empty($lock_msg)){ $display.= "
";
/* Are we in edit mode? */
if (session::is_set('edit')){
$display.= "\n";
$display.= " ";
$display.= "\n";
$info= " ".$ui->dn." ";
} else {
$info= "
".$ui->dn." ";
/* Only display edit button if there is at least one attribute editable */
if(preg_match("/r/",$ui->get_permissions($ui->dn,"users/posixAccount"))){
$info.= "
".
msgPool::clickEditToChange();
$display.= "\n";
}
$display.= "\n";
}
$display.= "