dn); } } /* Remove this plugin from session */ if ( $cleanup ){ session::un_set('user'); session::un_set('edit'); }else{ /* Reset requested? */ if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel'])|| isset($_POST['password_changed'])){ session::un_set ('edit'); session::un_set ('user'); } /* Create user object on demand */ if (!session::is_set('user') || (isset($_GET['reset']) && $_GET['reset'] == 1)){ $user= new user ($config, $ui->dn); $user->enable_CSN_check(); $user->set_acl_base($ui->dn); $user->set_acl_category("users"); session::set('user',$user); } $user = session::get('user'); /* save changes back to object */ if (session::is_set('edit')){ $user->save_object (); } /* Enter edit mode? */ if ((isset($_POST['edit'])) && (!session::is_set('edit')) &&preg_match("/w/",$ui->get_permissions($ui->dn,"users/user"))){ /* 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('dn',$ui->dn); session::set('edit',TRUE); } } /* save changes to LDAP and disable edit mode */ $info = ""; if (isset($_POST['edit_finish'])){ /* Perform checks */ $message= $user->check (); /* No errors, save object */ if (count ($message) == 0){ $user->save (); del_lock ($ui->dn); session::un_set ('edit'); /* Need to reset the password? */ if($user->password_change_needed()){ $user->passwordClass= new password($config, $ui->dn); $user->passwordClass->forceHash($user->pw_storage); session::set('user',$user); $display.=$user->passwordClass->execute(); } else { session::un_set ('user'); } } else { /* Errors found, show message */ msg_dialog::displayChecks($message); } }elseif(isset($user->passwordClass)){ $display.=$user->passwordClass->execute(); }else{ /* Execute formular */ if($lock_msg){ $display.= $lock_msg; }else{ $display.= $user->execute (); } /* Store changes in session */ if (session::is_set('edit')){ session::set('user',$user); } /* Show page footer depending on the mode */ if (!$user->cert_dialog && !$user->picture_dialog && !$user->dialog && $user->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 { /* 'viewid' may be set by i.e. the phonelist plugin. This means that we want to go back... */ if (isset ($viewid)){ $str= msgPool::backButton(); $fn = "back"; } else { $str= msgPool::editButton(); $fn = "edit"; $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/user"))){ if ($fn == "edit"){ $info.= "\"\" ". msgPool::clickEditToChange(); $display.= "\n"; } } $display.= "\n"; } $display.= "

\n"; } } /* Page header*/ $display= print_header(get_template_path('plugins/generic/images/plugin.png'), _("Generic user information"), $info).$display; } // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: ?>