You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							98 lines
						
					
					
						
							4.1 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							98 lines
						
					
					
						
							4.1 KiB
						
					
					
				| <?php | |
| /** | |
|  * ************************************************************************* | |
|  * *                  Apply	Enrol   				                      ** | |
|  * ************************************************************************* | |
|  * @copyright   emeneo.com                                                ** | |
|  * @link        emeneo.com                                                ** | |
|  * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later  ** | |
|  * ************************************************************************* | |
|  * ************************************************************************ | |
| */ | |
| /** | |
|  * Unenrol a user who was enrolled through a self enrolment. | |
|  * | |
|  * @package    enrol | |
|  * @subpackage self | |
|  * @copyright  2011 Sam Hemelryk | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| 
 | |
| require('../../config.php'); | |
| require_once("$CFG->dirroot/enrol/locallib.php"); | |
| require_once("$CFG->dirroot/enrol/renderer.php"); | |
| 
 | |
| $ueid    = required_param('ue', PARAM_INT); // user enrolment id | |
| $filter  = optional_param('ifilter', 0, PARAM_INT); | |
| $confirm = optional_param('confirm', false, PARAM_BOOL); | |
| 
 | |
| // Get the user enrolment object | |
| $ue     = $DB->get_record('user_enrolments', array('id' => $ueid), '*', MUST_EXIST); | |
| // Get the user for whom the enrolment is | |
| $user   = $DB->get_record('user', array('id'=>$ue->userid), '*', MUST_EXIST); | |
| // Get the course the enrolment is to | |
| //list($ctxsql, $ctxjoin) = context_instance_preload_sql('c.id', CONTEXT_COURSE, 'ctx'); | |
| $ctxsql = context_helper::get_preload_record_columns_sql('ctx'); | |
| $sql = "SELECT c.*, $ctxsql | |
|           FROM {course} c | |
|      LEFT JOIN {enrol} e ON e.courseid = c.id | |
| 		 LEFT JOIN {context} ctx ON (ctx.instanceid = c.id AND ctx.contextlevel = :contextcourse) | |
|          WHERE e.id = :enrolid"; | |
| $params = array('enrolid' => $ue->enrolid, 'contextcourse' => CONTEXT_COURSE); | |
| $course = $DB->get_record_sql($sql, $params, MUST_EXIST); | |
| context_helper::preload_from_record($course); | |
| 
 | |
| 
 | |
| // Make sure it's not the front page | |
| if ($course->id == SITEID) { | |
|     redirect(new moodle_url('/')); | |
| } | |
| 
 | |
| // Obviously | |
| require_login($course); | |
| // Make sure the user can unenrol self enrolled users. | |
| require_capability("enrol/self:unenrol", context_course::instance($course->id)); | |
| 
 | |
| // Get the enrolment manager for this course | |
| $manager = new course_enrolment_manager($PAGE, $course, $filter); | |
| // Get an enrolment users table object. Doign this will automatically retrieve the the URL params | |
| // relating to table the user was viewing before coming here, and allows us to return the user to the | |
| // exact page of the users screen they can from. | |
| $table = new course_enrolment_users_table($manager, $PAGE); | |
| 
 | |
| // The URL of the enrolled users page for the course. | |
| $usersurl = new moodle_url('/enrol/users.php', array('id' => $course->id)); | |
| // The URl to return the user too after this screen. | |
| $returnurl = new moodle_url($usersurl, $manager->get_url_params()+$table->get_url_params()); | |
| // The URL of this page | |
| $url = new moodle_url('/enrol/apply/unenroluser.php', $returnurl->params()); | |
| $url->param('ue', $ueid); | |
| 
 | |
| $PAGE->set_url($url); | |
| $PAGE->set_pagelayout('admin'); | |
| navigation_node::override_active_url($usersurl); | |
| 
 | |
| list($instance, $plugin) = $manager->get_user_enrolment_components($ue); | |
| if (!$plugin->allow_unenrol($instance) || $instance->enrol != 'apply' || !($plugin instanceof enrol_apply_plugin)) { | |
|     print_error('erroreditenrolment', 'enrol'); | |
| } | |
| 
 | |
| // If the unenrolment has been confirmed and the sesskey is valid unenrol the user. | |
| if ($confirm && confirm_sesskey() && $manager->unenrol_user($ue)) { | |
|     redirect($returnurl); | |
| } | |
| 
 | |
| $yesurl = new moodle_url($PAGE->url, array('confirm'=>1, 'sesskey'=>sesskey())); | |
| $message = get_string('unenroluser', 'enrol_self', array('user' => fullname($user, true), 'course' => format_string($course->fullname))); | |
| $fullname = fullname($user); | |
| $title = get_string('unenrol', 'enrol_self'); | |
| 
 | |
| $PAGE->set_title($title); | |
| $PAGE->set_heading($title); | |
| $PAGE->navbar->add($title); | |
| $PAGE->navbar->add($fullname); | |
| 
 | |
| echo $OUTPUT->header(); | |
| echo $OUTPUT->heading($fullname); | |
| echo $OUTPUT->confirm($message, $yesurl, $returnurl); | |
| echo $OUTPUT->footer();
 | |
| 
 |