2 // This file is part of Moodle - http://moodle.org/
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.
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.
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/>.
18 * This file processes AJAX enrolment actions and returns JSON for the manual enrolments plugin
20 * The general idea behind this file is that any errors should throw exceptions
21 * which will be returned and acted upon by the calling AJAX script.
23 * @package enrol_manual
24 * @copyright 2010 Sam Hemelryk
25 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
28 define('AJAX_SCRIPT', true);
30 require('../../config.php');
31 require_once($CFG->dirroot
.'/enrol/locallib.php');
32 require_once($CFG->dirroot
.'/group/lib.php');
34 $id = required_param('id', PARAM_INT
); // Course id.
35 $action = required_param('action', PARAM_ALPHANUMEXT
);
37 $PAGE->set_url(new moodle_url('/enrol/ajax.php', array('id'=>$id, 'action'=>$action)));
39 $course = $DB->get_record('course', array('id'=>$id), '*', MUST_EXIST
);
40 $context = context_course
::instance($course->id
, MUST_EXIST
);
42 if ($course->id
== SITEID
) {
43 throw new moodle_exception('invalidcourse');
46 require_login($course);
47 require_capability('moodle/course:enrolreview', $context);
50 echo $OUTPUT->header(); // Send headers.
52 $manager = new course_enrolment_manager($PAGE, $course);
54 $outcome = new stdClass();
55 $outcome->success
= true;
56 $outcome->response
= new stdClass();
59 $searchanywhere = get_user_preferences('userselector_searchanywhere', false);
63 $otheruserroles = optional_param('otherusers', false, PARAM_BOOL
);
64 $outcome->response
= array_reverse($manager->get_assignable_roles($otheruserroles), true);
67 $enrolid = required_param('enrolid', PARAM_INT
);
68 $search = optional_param('search', '', PARAM_RAW
);
69 $page = optional_param('page', 0, PARAM_INT
);
70 $addedenrollment = optional_param('enrolcount', 0, PARAM_INT
);
71 $perpage = optional_param('perpage', 25, PARAM_INT
); // This value is hard-coded to 25 in quickenrolment.js
72 $outcome->response
= $manager->get_potential_users($enrolid, $search, $searchanywhere, $page, $perpage, $addedenrollment);
73 $extrafields = get_extra_user_fields($context);
74 foreach ($outcome->response
['users'] as &$user) {
75 $user->picture
= $OUTPUT->user_picture($user);
76 $user->fullname
= fullname($user);
77 $fieldvalues = array();
78 foreach ($extrafields as $field) {
79 $fieldvalues[] = s($user->{$field});
80 unset($user->{$field});
82 $user->extrafields
= implode(', ', $fieldvalues);
84 // Chrome will display users in the order of the array keys, so we need
85 // to ensure that the results ordered array keys. Fortunately, the JavaScript
86 // does not care what the array keys are. It uses user.id where necessary.
87 $outcome->response
['users'] = array_values($outcome->response
['users']);
88 $outcome->success
= true;
91 $enrolid = required_param('enrolid', PARAM_INT
);
92 $userid = required_param('userid', PARAM_INT
);
94 $roleid = optional_param('role', null, PARAM_INT
);
95 $duration = optional_param('duration', 0, PARAM_INT
);
96 $startdate = optional_param('startdate', 0, PARAM_INT
);
97 $recovergrades = optional_param('recovergrades', 0, PARAM_INT
);
105 $timestart = $course->startdate
;
110 $today = make_timestamp(date('Y', $today), date('m', $today), date('d', $today), 0, 0, 0);
114 if ($duration <= 0) {
117 $timeend = $timestart +
($duration*24*60*60);
120 $user = $DB->get_record('user', array('id'=>$userid), '*', MUST_EXIST
);
121 $instances = $manager->get_enrolment_instances();
122 $plugins = $manager->get_enrolment_plugins(true); // Do not allow actions on disabled plugins.
123 if (!array_key_exists($enrolid, $instances)) {
124 throw new enrol_ajax_exception('invalidenrolinstance');
126 $instance = $instances[$enrolid];
127 if (!isset($plugins[$instance->enrol
])) {
128 throw new enrol_ajax_exception('enrolnotpermitted');
130 $plugin = $plugins[$instance->enrol
];
131 if ($plugin->allow_enrol($instance) && has_capability('enrol/'.$plugin->get_name().':enrol', $context)) {
132 $plugin->enrol_user($instance, $user->id
, $roleid, $timestart, $timeend);
133 if ($recovergrades) {
134 require_once($CFG->libdir
.'/gradelib.php');
135 grade_recover_history_grades($user->id
, $instance->courseid
);
138 throw new enrol_ajax_exception('enrolnotpermitted');
140 $outcome->success
= true;
144 throw new enrol_ajax_exception('unknowajaxaction');
147 echo json_encode($outcome);