require_once('../config.php');
require_once($CFG->libdir.'/gdlib.php');
require_once($CFG->dirroot.'/user/edit_form.php');
+ require_once($CFG->dirroot.'/user/editlib.php');
require_once($CFG->dirroot.'/user/profile/lib.php');
$course = optional_param('course', SITEID, PARAM_INT); // course id (defaults to Site)
redirect($CFG->wwwroot . "/user/view.php?course={$course->id}");
}
- //load preferences
- if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
- foreach($preferences as $name=>$value) {
- $user->{'preference_'.$name} = $value;
- }
- }
- //TODO: Load the custom profile fields
+ //load user preferences
+ useredit_load_preferences($user);
+
+ //Load custom profile fields data
+ profile_load_data($user);
//create form
$userform = new user_edit_form();
}
//update preferences
- $ua = (array)$usernew;
- foreach($ua as $key=>$value) {
- if (strpos($key, 'preference_') === 0) {
- $name = substr($key, strlen('preference_'));
- set_user_preference($name, $value, $usernew->id);
- }
- }
+ useredit_update_user_preference($usernew);
+ //update user picture
if (!empty($CFG->gdversion) and empty($CFG->disableuserimages)) {
- //update user picture
- if ($usernew->deletepicture) {
- //TODO - delete the files
- set_field('user', 'picture', 0, 'id', $usernew->id);
- } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
- set_field('user', 'picture', 1, 'id', $usernew->id);
- }
+ useredit_update_picture($usernew, $userform);
}
// update mail bounces
- if ($user->email !== $usernew->email) {
- set_bounce_count($usernew,true);
- set_send_count($usernew,true);
- }
+ useredit_update_bounces($user, $usernew);
- /// Update forum track preference.
- if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
- require_once($CFG->dirroot.'/mod/forum/lib.php');
- forum_tp_delete_read_records($usernew->id);
- }
+ /// update forum track preference
+ useredit_update_trackforums($user, $usernew);
- //TODO: Save the custom profile fields
+ // save custom profile fields data
+ profile_save_data($usernew);
// Override old $USER session variable
$usernew = (array)get_record('user', 'id', $newuser->id); // reload from db
/// Print the required moodle fields first
$mform->addElement('header', 'moodle', $strrequired);
- require('edit_form_common.php');
+ /// shared fields
+ useredit_shared_definition($mform);
/// extra settigs
$mform->addRule('description', $strrequired, 'required', null, 'client');
} else if (($usernew->email !== $user->email) and record_exists('user', 'email', $usernew->email, 'mnethostid', $CFG->mnet_localhost_id)) {
$err['email'] = get_string('emailexists');
}
-
+
if ($usernew->email === $user->email and over_bounce_threshold($user)) {
$err['email'] = get_string('toomanybounces');
}
require_once($CFG->libdir.'/gdlib.php');
require_once($CFG->libdir.'/adminlib.php');
require_once($CFG->dirroot.'/user/editadvanced_form.php');
+ require_once($CFG->dirroot.'/user/editlib.php');
require_once($CFG->dirroot.'/user/profile/lib.php');
$id = optional_param('id', $USER->id, PARAM_INT); // user id; -1 if creating new user
print_error('guestnoeditprofileother');
}
- //load preferences
- if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
- foreach($preferences as $name=>$value) {
- $user->{'preference_'.$name} = $value;
- }
- }
-
+ //load user preferences
+ useredit_load_preferences($user);
+
//Load custom profile fields data
profile_load_data($user);
if (empty($usernew->auth)) {
//user editing self
$authplugin = get_auth_plugin($user->auth);
- unset($usernew->auth);
+ unset($usernew->auth); //can not change/remove
} else {
$authplugin = get_auth_plugin($usernew->auth);
}
$usernew->timemodified = time();
if ($usernew->id == -1) {
- //TODO check out that it makes sense to create account with this auth plugin and what to do with the password
+ //TODO check out if it makes sense to create account with this auth plugin and what to do with the password
unset($usernew->id);
$usernew->mnethostid = $CFG->mnet_localhost_id; // always local user
$usernew->confirmed = 1;
}
}
-
//update preferences
- $ua = (array)$usernew;
- foreach($ua as $key=>$value) {
- if (strpos($key, 'preference_') === 0) {
- $name = substr($key, strlen('preference_'));
- set_user_preference($name, $value, $usernew->id);
- }
- }
+ useredit_update_user_preference($usernew);
//update user picture
if (!empty($CFG->gdversion)) {
- if ($usernew->deletepicture) {
- //TODO - delete the files
- set_field('user', 'picture', 0, 'id', $usernew->id);
- } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
- set_field('user', 'picture', 1, 'id', $usernew->id);
- }
+ useredit_update_picture($usernew, $userform);
}
// update mail bounces
- if ($user->email !== $usernew->email) {
- set_bounce_count($usernew,true);
- set_send_count($usernew,true);
- }
+ useredit_update_bounces($user, $usernew);
- /// Update forum track preference.
- if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
- require_once($CFG->dirroot.'/mod/forum/lib.php');
- forum_tp_delete_read_records($usernew->id);
- }
+ /// update forum track preference
+ useredit_update_trackforums($user, $usernew);
// save custom profile fields data
profile_save_data($usernew);
unset($USER->newadminuser);
// redirect to admin/ to continue with installation
redirect("$CFG->wwwroot/$CFG->admin/");
- } else {
+ } else {
redirect("$CFG->wwwroot/user/view.php?id=$USER->id&course=$course->id");
}
} else {
$mform->addElement('checkbox', 'preference_auth_forcepasswordchange', get_string('forcepasswordchange'));
//TODO: add missing help - user will be forced to change password
- require('edit_form_common.php');
+ /// shared fields
+ useredit_shared_definition($mform);
/// Next the customisable profile fields
profile_definition($mform);
<?php //$Id$
- if (!defined('MOODLE_INTERNAL')) {
- die('Direct access to this script is forbidden.'); /// It must be included from a Moodle page
+
+function useredit_load_preferences(&$user) {
+ if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
+ foreach($preferences as $name=>$value) {
+ $user->{'preference_'.$name} = $value;
+ }
+ }
+}
+
+function useredit_update_user_preference($usernew) {
+ $ua = (array)$usernew;
+ foreach($ua as $key=>$value) {
+ if (strpos($key, 'preference_') === 0) {
+ $name = substr($key, strlen('preference_'));
+ set_user_preference($name, $value, $usernew->id);
+ }
+ }
+}
+
+function useredit_update_picture(&$usernew, &$userform) {
+ if (isset($usernew->deletepicture) and $usernew->deletepicture) {
+ //TODO - delete the file
+ set_field('user', 'picture', 0, 'id', $usernew->id);
+ } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
+ set_field('user', 'picture', 1, 'id', $usernew->id);
+ }
+}
+
+function useredit_update_bounces($user, $usernew) {
+ if (!isset($usernew->email)) {
+ //locked field
+ return;
}
+ if ($user->email !== $usernew->email) {
+ set_bounce_count($usernew,true);
+ set_send_count($usernew,true);
+ }
+}
+
+function useredit_update_trackforums($user, $usernew) {
+ global $CFG;
+ if (!isset($usernew->trackforums)) {
+ //locked field
+ return;
+ }
+ if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
+ require_once($CFG->dirroot.'/mod/forum/lib.php');
+ forum_tp_delete_read_records($usernew->id);
+ }
+}
+
+function useredit_shared_definition(&$mform) {
+ global $CFG;
+
+ $strrequired = get_string('required');
$mform->addElement('text', 'firstname', get_string('firstname'), 'maxlength="100" size="30"');
$mform->addRule('firstname', $strrequired, 'required', null, 'client');
$mform->addElement('text', 'address', get_string('address'), 'maxlength="70" size="25"');
$mform->setType('address', PARAM_MULTILANG);
-
+}
?>
\ No newline at end of file