See Release Notes
Long Term Support Release
Differences Between: [Versions 39 and 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]
1 <?php 2 // This file is part of Moodle - http://moodle.org/ 3 // 4 // Moodle is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // Moodle is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU General Public License for more details. 13 // 14 // You should have received a copy of the GNU General Public License 15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>. 16 17 /** 18 * Public Profile -- a user's public profile page 19 * 20 * - each user can currently have their own page (cloned from system and then customised) 21 * - users can add any blocks they want 22 * - the administrators can define a default site public profile for users who have 23 * not created their own public profile 24 * 25 * This script implements the user's view of the public profile, and allows editing 26 * of the public profile. 27 * 28 * @package core_user 29 * @copyright 2010 Remote-Learner.net 30 * @author Hubert Chathi <hubert@remote-learner.net> 31 * @author Olav Jordan <olav.jordan@remote-learner.net> 32 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 33 */ 34 35 require_once(__DIR__ . '/../config.php'); 36 require_once($CFG->dirroot . '/my/lib.php'); 37 require_once($CFG->dirroot . '/user/profile/lib.php'); 38 require_once($CFG->dirroot . '/user/lib.php'); 39 require_once($CFG->libdir.'/filelib.php'); 40 41 $userid = optional_param('id', 0, PARAM_INT); 42 $edit = optional_param('edit', null, PARAM_BOOL); // Turn editing on and off. 43 $reset = optional_param('reset', null, PARAM_BOOL); 44 45 $PAGE->set_url('/user/profile.php', array('id' => $userid)); 46 47 if (!empty($CFG->forceloginforprofiles)) { 48 require_login(); 49 if (isguestuser()) { 50 $PAGE->set_context(context_system::instance()); 51 echo $OUTPUT->header(); 52 echo $OUTPUT->confirm(get_string('guestcantaccessprofiles', 'error'), 53 get_login_url(), 54 $CFG->wwwroot); 55 echo $OUTPUT->footer(); 56 die; 57 } 58 } else if (!empty($CFG->forcelogin)) { 59 require_login(); 60 } 61 62 $userid = $userid ? $userid : $USER->id; // Owner of the page. 63 if ((!$user = $DB->get_record('user', array('id' => $userid))) || ($user->deleted)) { 64 $PAGE->set_context(context_system::instance()); 65 echo $OUTPUT->header(); 66 if (!$user) { 67 echo $OUTPUT->notification(get_string('invaliduser', 'error')); 68 } else { 69 echo $OUTPUT->notification(get_string('userdeleted')); 70 } 71 echo $OUTPUT->footer(); 72 die; 73 } 74 75 $currentuser = ($user->id == $USER->id); 76 $context = $usercontext = context_user::instance($userid, MUST_EXIST); 77 78 if (!user_can_view_profile($user, null, $context)) { 79 80 // Course managers can be browsed at site level. If not forceloginforprofiles, allow access (bug #4366). 81 $struser = get_string('user'); 82 $PAGE->set_context(context_system::instance()); 83 $PAGE->set_title("$SITE->shortname: $struser"); // Do not leak the name. 84 $PAGE->set_heading($struser); 85 $PAGE->set_pagelayout('mypublic'); 86 $PAGE->set_url('/user/profile.php', array('id' => $userid)); 87 $PAGE->navbar->add($struser); 88 echo $OUTPUT->header(); 89 echo $OUTPUT->notification(get_string('usernotavailable', 'error')); 90 echo $OUTPUT->footer(); 91 exit; 92 } 93 94 // Get the profile page. Should always return something unless the database is broken. 95 if (!$currentpage = my_get_page($userid, MY_PAGE_PUBLIC)) { 96 print_error('mymoodlesetup'); 97 } 98 99 $PAGE->set_context($context); 100 $PAGE->set_pagelayout('mypublic'); 101 $PAGE->set_pagetype('user-profile'); 102 103 // Set up block editing capabilities. 104 if (isguestuser()) { // Guests can never edit their profile. 105 $USER->editing = $edit = 0; // Just in case. 106 $PAGE->set_blocks_editing_capability('moodle/my:configsyspages'); // unlikely :). 107 } else { 108 if ($currentuser) { 109 $PAGE->set_blocks_editing_capability('moodle/user:manageownblocks'); 110 } else { 111 $PAGE->set_blocks_editing_capability('moodle/user:manageblocks'); 112 } 113 } 114 115 // Start setting up the page. 116 $strpublicprofile = get_string('publicprofile'); 117 118 $PAGE->blocks->add_region('content'); 119 $PAGE->set_subpage($currentpage->id); 120 $PAGE->set_title(fullname($user).": $strpublicprofile"); 121 $PAGE->set_heading(fullname($user)); 122 123 if (!$currentuser) { 124 $PAGE->navigation->extend_for_user($user); 125 if ($node = $PAGE->settingsnav->get('userviewingsettings'.$user->id)) { 126 $node->forceopen = true; 127 } 128 } else if ($node = $PAGE->settingsnav->get('dashboard', navigation_node::TYPE_CONTAINER)) { 129 $node->forceopen = true; 130 } 131 if ($node = $PAGE->settingsnav->get('root')) { 132 $node->forceopen = false; 133 } 134 135 136 // Toggle the editing state and switches. 137 if ($PAGE->user_allowed_editing()) { 138 if ($reset !== null) { 139 if (!is_null($userid)) { 140 if (!$currentpage = my_reset_page($userid, MY_PAGE_PUBLIC, 'user-profile')) { 141 print_error('reseterror', 'my'); 142 } 143 redirect(new moodle_url('/user/profile.php', array('id' => $userid))); 144 } 145 } else if ($edit !== null) { // Editing state was specified. 146 $USER->editing = $edit; // Change editing state. 147 } else { // Editing state is in session. 148 if ($currentpage->userid) { // It's a page we can edit, so load from session. 149 if (!empty($USER->editing)) { 150 $edit = 1; 151 } else { 152 $edit = 0; 153 } 154 } else { 155 // For the page to display properly with the user context header the page blocks need to 156 // be copied over to the user context. 157 if (!$currentpage = my_copy_page($userid, MY_PAGE_PUBLIC, 'user-profile')) { 158 print_error('mymoodlesetup'); 159 } 160 $PAGE->set_context($usercontext); 161 $PAGE->set_subpage($currentpage->id); 162 // It's a system page and they are not allowed to edit system pages. 163 $USER->editing = $edit = 0; // Disable editing completely, just to be safe. 164 } 165 } 166 167 // Add button for editing page. 168 $params = array('edit' => !$edit, 'id' => $userid); 169 170 $resetbutton = ''; 171 $resetstring = get_string('resetpage', 'my'); 172 $reseturl = new moodle_url("$CFG->wwwroot/user/profile.php", array('edit' => 1, 'reset' => 1, 'id' => $userid)); 173 174 if (!$currentpage->userid) { 175 // Viewing a system page -- let the user customise it. 176 $editstring = get_string('updatemymoodleon'); 177 $params['edit'] = 1; 178 } else if (empty($edit)) { 179 $editstring = get_string('updatemymoodleon'); 180 $resetbutton = $OUTPUT->single_button($reseturl, $resetstring); 181 } else { 182 $editstring = get_string('updatemymoodleoff'); 183 $resetbutton = $OUTPUT->single_button($reseturl, $resetstring); 184 } 185 186 $url = new moodle_url("$CFG->wwwroot/user/profile.php", $params); 187 $button = $OUTPUT->single_button($url, $editstring); 188 $PAGE->set_button($resetbutton . $button); 189 190 } else { 191 $USER->editing = $edit = 0; 192 } 193 194 // Trigger a user profile viewed event. 195 profile_view($user, $usercontext); 196 197 // TODO WORK OUT WHERE THE NAV BAR IS! 198 echo $OUTPUT->header(); 199 echo '<div class="userprofile">'; 200 201 $hiddenfields = []; 202 if (!has_capability('moodle/user:viewhiddendetails', $usercontext)) { 203 $hiddenfields = array_flip(explode(',', $CFG->hiddenuserfields)); 204 } 205 if ($user->description && !isset($hiddenfields['description'])) { 206 echo '<div class="description">'; 207 if (!empty($CFG->profilesforenrolledusersonly) && !$currentuser && 208 !$DB->record_exists('role_assignments', array('userid' => $user->id))) { 209 echo get_string('profilenotshown', 'moodle'); 210 } else { 211 $user->description = file_rewrite_pluginfile_urls($user->description, 'pluginfile.php', $usercontext->id, 'user', 212 'profile', null); 213 echo format_text($user->description, $user->descriptionformat); 214 } 215 echo '</div>'; 216 } 217 218 echo $OUTPUT->custom_block_region('content'); 219 220 // Render custom blocks. 221 $renderer = $PAGE->get_renderer('core_user', 'myprofile'); 222 $tree = core_user\output\myprofile\manager::build_tree($user, $currentuser); 223 echo $renderer->render($tree); 224 225 echo '</div>'; // Userprofile class. 226 227 echo $OUTPUT->footer();
title
Description
Body
title
Description
Body
title
Description
Body
title
Body