moodle/user/edit.php

336 lines
12 KiB
PHP
Raw Normal View History

2001-11-22 06:23:56 +00:00
<?PHP // $Id$
require_once("../config.php");
require_once("$CFG->libdir/gdlib.php");
2001-11-22 06:23:56 +00:00
require_variable($id); // user id
require_variable($course); // course id
2004-09-07 10:18:52 +00:00
2001-11-22 06:23:56 +00:00
if (! $user = get_record("user", "id", $id)) {
error("User ID was incorrect");
}
if (! $course = get_record("course", "id", $course)) {
2002-08-08 16:02:39 +00:00
error("Course ID was incorrect");
2001-11-22 06:23:56 +00:00
}
if ($user->confirmed and user_not_fully_set_up($user)) {
// Special case which can only occur when a new account
// has just been created by EXTERNAL authentication
// This is the only page in Moodle that has the exception
// so that users can set up their accounts
$newaccount = true;
2004-01-03 15:41:15 +00:00
if (empty($USER)) {
error("Sessions don't seem to be working on this server!");
}
} else {
$newaccount = false;
require_login($course->id);
}
2001-11-22 06:23:56 +00:00
if ($USER->id <> $user->id and !isadmin()) {
2001-11-22 06:23:56 +00:00
error("You can only edit your own information");
}
2002-06-10 04:33:46 +00:00
if (isguest()) {
error("The guest user cannot edit their profile.");
}
if (isguest($user->id)) {
error("Sorry, the guest user cannot be edited.");
}
// load the relevant auth libraries
if ($user->auth) {
$auth = $user->auth;
if (!file_exists("$CFG->dirroot/auth/$auth/lib.php")) {
$auth = "manual"; // Can't find auth module, default to internal
}
require_once("$CFG->dirroot/auth/$auth/lib.php");
}
2001-11-22 06:23:56 +00:00
2001-11-22 06:23:56 +00:00
/// If data submitted, then process and store.
if ($usernew = data_submitted()) {
2004-01-14 13:31:28 +00:00
if (isset($USER->username)) {
check_for_restricted_user($USER->username, "$CFG->wwwroot/course/view.php?id=$course->id");
}
2004-01-14 13:31:28 +00:00
foreach ($usernew as $key => $data) {
$usernew->$key = addslashes(clean_text(stripslashes($usernew->$key), FORMAT_MOODLE));
2004-01-14 13:31:28 +00:00
}
$usernew->firstname = trim(strip_tags($usernew->firstname));
$usernew->lastname = trim(strip_tags($usernew->lastname));
2004-01-14 13:31:28 +00:00
if (isset($usernew->username)) {
$usernew->username = trim(moodle_strtolower($usernew->username));
}
require_once($CFG->dirroot.'/lib/uploadlib.php');
Small bug fixes for upload class. These patches are maintained in an publicly accessible Arch repository, see: http://lists.eduforge.org/cgi-bin/archzoom.cgi/arch-eduforge@catalyst.net.nz--2004-MIRROR/moodle--eduforge--1.3.3 Index of arch patches in this commit: arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-75 2004-09-17 03:19:50 GMT Penny Leach <penny@catalyst.net.nz> bug fix for upload class related to optional file uploads (like in user/edit.php) arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-76 2004-09-17 03:23:17 GMT Penny Leach <penny@catalyst.net.nz> bug fix for upload class related to optional file uploads (like in user/edit.php) arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-77 2004-09-17 03:42:10 GMT Penny Leach <penny@catalyst.net.nz> more fixes for upload class Full logs: Revision: moodle--eduforge--1.3.3--patch-75 Archive: arch-eduforge@catalyst.net.nz--2004 Creator: Penny Leach <penny@catalyst.net.nz> Date: Fri Sep 17 15:19:50 NZST 2004 Standard-date: 2004-09-17 03:19:50 GMT Modified-files: lib/uploadlib.php user/edit.php New-patches: arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-75 Summary: bug fix for upload class related to optional file uploads (like in user/edit.php) Keywords: Revision: moodle--eduforge--1.3.3--patch-76 Archive: arch-eduforge@catalyst.net.nz--2004 Creator: Penny Leach <penny@catalyst.net.nz> Date: Fri Sep 17 15:23:17 NZST 2004 Standard-date: 2004-09-17 03:23:17 GMT Modified-files: lib/uploadlib.php New-patches: arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-76 Summary: bug fix for upload class related to optional file uploads (like in user/edit.php) Keywords: Revision: moodle--eduforge--1.3.3--patch-77 Archive: arch-eduforge@catalyst.net.nz--2004 Creator: Penny Leach <penny@catalyst.net.nz> Date: Fri Sep 17 15:42:10 NZST 2004 Standard-date: 2004-09-17 03:42:10 GMT Modified-files: lang/en/moodle.php lib/uploadlib.php New-patches: arch-eduforge@catalyst.net.nz--2004/moodle--eduforge--1.3.3--patch-77 Summary: more fixes for upload class Keywords:
2004-09-17 04:21:41 +00:00
$um = new upload_manager('imagefile',false,false,null,false,0,true,true);
if (find_form_errors($user, $usernew, $err, $um)) {
if (empty($err['imagefile']) && $usernew->picture = save_profile_image($user->id, $um,'users')) {
set_field('user', 'picture', $usernew->picture, 'id', $user->id); /// Note picture in DB
} else {
if (!empty($usernew->deletepicture)) {
set_field('user', 'picture', 0, 'id', $user->id); /// Delete picture
$usernew->picture = 0;
}
}
$user = $usernew;
} else {
$timenow = time();
if (!$usernew->picture = save_profile_image($user->id,$um,'users')) {
if (!empty($usernew->deletepicture)) {
set_field('user', 'picture', 0, 'id', $user->id); /// Delete picture
$usernew->picture = 0;
} else {
$usernew->picture = $user->picture;
}
2001-11-22 06:23:56 +00:00
}
2001-11-22 06:23:56 +00:00
$usernew->timemodified = time();
if (isadmin()) {
if (!empty($usernew->newpassword)) {
$usernew->password = md5($usernew->newpassword);
// update external passwords
if (!empty($CFG->{'auth_'. $user->auth.'_stdchangepassword'})) {
if (function_exists('auth_user_update_password')){
if (!auth_user_update_password($user->username, $usernew->newpassword)){
error('Failed to update password on external auth: ' . $user->auth .
'. See the server logs for more details.');
}
} else {
error('Your external authentication module is misconfigued!');
}
}
}
// store forcepasswordchange in user's preferences
2004-09-23 04:15:19 +00:00
if (!empty($usernew->forcepasswordchange)){
set_user_preference('auth_forcepasswordchange', 1, $user->id);
} else {
2004-09-23 04:15:19 +00:00
unset_user_preference('auth_forcepasswordchange', $user->id);
}
} else {
if (isset($usernew->newpassword)) {
error("You can not change the password like that");
}
}
if ($usernew->url and !(substr($usernew->url, 0, 4) == "http")) {
$usernew->url = "http://".$usernew->url;
}
2001-11-22 06:23:56 +00:00
if (update_record("user", $usernew)) {
if (function_exists("auth_user_update")){
auth_user_update($user, $usernew);
}
add_to_log($course->id, "user", "update", "view.php?id=$user->id&course=$course->id", "");
if ($user->id == $USER->id) {
// Copy data into $USER session variable
$usernew = (array)$usernew;
foreach ($usernew as $variable => $value) {
$USER->$variable = stripslashes($value);
}
if (isset($USER->newadminuser)) {
unset($USER->newadminuser);
2003-07-30 05:21:24 +00:00
redirect("$CFG->wwwroot/", get_string("changessaved"));
}
redirect("$CFG->wwwroot/user/view.php?id=$user->id&course=$course->id", get_string("changessaved"));
} else {
2003-12-16 05:31:52 +00:00
redirect("$CFG->wwwroot/$CFG->admin/user.php", get_string("changessaved"));
}
2001-11-22 06:23:56 +00:00
} else {
error("Could not update the user record ($user->id)");
}
}
2001-11-22 06:23:56 +00:00
}
2001-11-22 06:23:56 +00:00
/// Otherwise fill and print the form.
$streditmyprofile = get_string("editmyprofile");
$strparticipants = get_string("participants");
$strnewuser = get_string("newuser");
if (($user->firstname and $user->lastname) or $newaccount) {
if ($newaccount) {
$userfullname = $strnewuser;
} else {
2003-11-19 16:15:56 +00:00
$userfullname = fullname($user, isteacher($course->id));
}
2002-08-14 01:51:58 +00:00
if ($course->category) {
print_header("$course->shortname: $streditmyprofile", "$course->fullname: $streditmyprofile",
"<a href=\"$CFG->wwwroot/course/view.php?id=$course->id\">$course->shortname</a>
2004-09-07 08:05:25 +00:00
-> <a href=\"index.php?id=$course->id\">$strparticipants</a>
-> <a href=\"view.php?id=$user->id&amp;course=$course->id\">$userfullname</a>
-> $streditmyprofile", "");
2002-08-14 01:51:58 +00:00
} else {
if (isset($USER->newadminuser)) {
print_header();
} else {
print_header("$course->shortname: $streditmyprofile", "$course->fullname",
"<a href=\"view.php?id=$user->id&amp;course=$course->id\">$userfullname</a>
-> $streditmyprofile", "");
}
2002-08-14 01:51:58 +00:00
}
2001-11-22 06:23:56 +00:00
} else {
$userfullname = $strnewuser;
2002-08-14 01:51:58 +00:00
$straddnewuser = get_string("addnewuser");
$stradministration = get_string("administration");
print_header("$course->shortname: $streditmyprofile", "$course->fullname",
"<a href=\"$CFG->wwwroot/$CFG->admin/\">$stradministration</a> -> ".
"<a href=\"$CFG->wwwroot/$CFG->admin/users.php\">$strusers</a> -> $straddnewuser", "");
2001-11-22 06:23:56 +00:00
}
$teacher = strtolower($course->teacher);
if (!isadmin()) {
$teacheronly = "(".get_string("teacheronly", "", $teacher).")";
} else {
$teacheronly = "";
}
2002-08-14 01:51:58 +00:00
print_heading( get_string("userprofilefor", "", "$userfullname") );
if (isset($USER->newadminuser)) {
print_simple_box(get_string("configintroadmin"), "center", "50%");
echo "<br />";
}
print_simple_box_start("center", "", "$THEME->cellheading");
if (!empty($err)) {
echo "<center>";
notify(get_string("someerrorswerefound"));
echo "</center>";
}
include("edit.html");
if (!isadmin()) { /// Lock all the locked fields using Javascript
$fields = get_user_fieldnames();
echo '<script type="text/javascript">'."\n";
echo '<!--'."\n";
foreach ($fields as $field) {
$configvariable = 'auth_user_'.$field.'_editlock';
if (!empty($CFG->$configvariable)) {
echo "eval('document.form.$field.disabled=true');\n";
}
}
echo '-->'."\n";
echo '</script>'."\n";
}
2001-11-22 06:23:56 +00:00
print_simple_box_end();
if (!isset($USER->newadminuser)) {
print_footer($course);
}
exit;
2001-11-22 06:23:56 +00:00
/// FUNCTIONS ////////////////////
function find_form_errors(&$user, &$usernew, &$err, &$um) {
global $CFG;
2001-11-22 06:23:56 +00:00
if (isadmin()) {
if (empty($usernew->username)) {
$err["username"] = get_string("missingusername");
} else if (record_exists("user", "username", $usernew->username) and $user->username == "changeme") {
$err["username"] = get_string("usernameexists");
} else {
if (empty($CFG->extendedusernamechars)) {
$string = eregi_replace("[^(-\.[:alnum:])]", "", $usernew->username);
if (strcmp($usernew->username, $string)) {
$err["username"] = get_string("alphanumerical");
}
}
}
2003-09-22 14:01:45 +00:00
if (empty($usernew->newpassword) and empty($user->password) and is_internal_auth() )
$err["newpassword"] = get_string("missingpassword");
if (($usernew->newpassword == "admin") or ($user->password == md5("admin") and empty($usernew->newpassword)) ) {
$err["newpassword"] = get_string("unsafepassword");
}
}
2001-11-22 06:23:56 +00:00
if (empty($usernew->email))
$err["email"] = get_string("missingemail");
2001-11-22 06:23:56 +00:00
if (empty($usernew->description) and !isadmin())
$err["description"] = get_string("missingdescription");
if (empty($usernew->city))
$err["city"] = get_string("missingcity");
if (empty($usernew->firstname))
$err["firstname"] = get_string("missingfirstname");
if (empty($usernew->lastname))
$err["lastname"] = get_string("missinglastname");
if (empty($usernew->country))
$err["country"] = get_string("missingcountry");
if (! validate_email($usernew->email)) {
$err["email"] = get_string("invalidemail");
2001-11-22 06:23:56 +00:00
} else if ($otheruser = get_record("user", "email", $usernew->email)) {
2001-11-22 06:23:56 +00:00
if ($otheruser->id <> $user->id) {
$err["email"] = get_string("emailexists");
2001-11-22 06:23:56 +00:00
}
}
if (empty($err["email"]) and !isadmin()) {
if ($error = email_is_not_allowed($usernew->email)) {
$err["email"] = $error;
}
}
if (!$um->preprocess_files()) {
$err['imagefile'] = $um->notify;
}
2001-11-22 06:23:56 +00:00
if (!isadmin()) { /// Make sure that locked fields are not being edited
$fields = get_user_fieldnames();
foreach ($fields as $field) {
$configvariable = 'auth_user_'.$field.'_editlock';
if (!empty($CFG->$configvariable)) {
if ($user->$field !== $usernew->$field) {
$err[$field] = get_string("editlock");
}
}
}
}
2001-11-22 06:23:56 +00:00
$user->email = $usernew->email;
return count($err);
}
?>