. /** * ILB Enrol Confirmation reports * * @package report * @subpackage ilbenrol * @copyright 2008 Sam Marshall * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require('../../config.php'); require("{$CFG->dirroot}/enrol/locallib.php"); require_once('report_form.php'); require_once("$CFG->dirroot/user/profile/lib.php"); define('ILBENROL_REPORT_PAGE', 25); // Get course $id = required_param('course',PARAM_INT); $course = $DB->get_record('course',array('id'=>$id)); if (!$course) { print_error('invalidcourseid'); } $context = context_course::instance($course->id); // Sort (default lastname, optionally firstname) $sort = optional_param('sort','timecreated',PARAM_ALPHA); // CSV format $format = optional_param('format','',PARAM_ALPHA); $excel = $format == 'excelcsv'; $csv = $format == 'csv' || $excel; // Paging $start = optional_param('start', 0, PARAM_INT); $sifirst = optional_param('sifirst', 'all', PARAM_ALPHA); $silast = optional_param('silast', 'all', PARAM_ALPHA); // User profile fields to filter $filterfields = explode(',', get_config(null, 'report_ilbenrol_filterfields')); $filterfields = $DB->get_records_list('user_info_field', 'shortname', $filterfields); function csv_quote($value) { global $excel; if ($excel) { return textlib::convert('"'.str_replace('"',"'",$value).'"','UTF-8','UTF-16LE'); } else { return '"'.str_replace('"',"'",$value).'"'; } } $url = new moodle_url('/report/ilbenrol/index.php', array('course'=>$id)); if ($sort !== '') { $url->param('sort', $sort); } if ($format !== '') { $url->param('format', $format); } if ($start !== 0) { $url->param('start', $start); } $PAGE->set_url($url); $PAGE->set_pagelayout('report'); require_login($course); // Check basic permission require_capability('report/ilbenrol:view',$context); // Get group mode $group = groups_get_course_group($course,true); // Supposed to verify group if ($group===0 && $course->groupmode==SEPARATEGROUPS) { require_capability('moodle/site:accessallgroups',$context); } // Get data for user filtering $manager = new course_enrolment_manager($PAGE, $course); $mform = new filter_form($course->id, $filterfields); $instances = $manager->get_enrolment_instances(); $contextids = $context->get_parent_context_ids(true); // Roles $allroles = $manager->get_all_roles(); $role_confirmed = get_config(null, 'report_ilbenrol_confirmed'); $role_revoked = get_config(null, 'report_ilbenrol_revoked'); if (!$role_confirmed or !$role_revoked) { print_error('invalidargorconf'); } $roles = array($role_confirmed=>$allroles[$role_confirmed], $role_revoked=>$allroles[$role_revoked]); // Generate where clause $where = array(); $where_params = array(); if ($sifirst !== 'all') { $where[] = $DB->sql_like('u.firstname', ':sifirst', false); $where_params['sifirst'] = $sifirst.'%'; } if ($silast !== 'all') { $where[] = $DB->sql_like('u.lastname', ':silast', false); $where_params['silast'] = $silast.'%'; } $whereors = array(); if ($formdata = $mform->get_data()) { foreach ($filterfields as $field) { $shortname = $field->shortname; if (array_key_exists($shortname, $formdata)) { list($in_options, $param_options) = $DB->get_in_or_equal(array_keys($formdata->$shortname), SQL_PARAMS_NAMED); $whereors[] = "(uid.fieldid = {$field->id} AND uid.data {$in_options})"; $where_params = $where_params + $param_options; } } } list($in_instances, $param_instances) = $DB->get_in_or_equal(array_keys($instances), SQL_PARAMS_NAMED); list($in_contexts, $param_contexts) = $DB->get_in_or_equal($contextids, SQL_PARAMS_NAMED); list($in_fields, $param_fields) = $DB->get_in_or_equal(array_keys($filterfields), SQL_PARAMS_NAMED); $params = $param_instances + $param_contexts + $param_fields; // Get data to summary table $dados = $DB->get_records_sql_menu("SELECT uid.fieldid||'-'||ra.roleid||'-'||uid.data, count(distinct u.id) FROM {user} u JOIN {user_enrolments} ue ON (ue.userid = u.id AND ue.enrolid {$in_instances}) JOIN {role_assignments} ra ON (ra.userid = u.id AND ra.contextid {$in_contexts}) LEFT JOIN {user_info_data} uid ON (uid.userid = u.id AND uid.fieldid {$in_fields}) GROUP BY uid.fieldid, ra.roleid, uid.data", $params); // Get data to User List table $whereorstr = implode(' OR ', $whereors); if ($whereorstr) { $where[] = "({$whereorstr})"; } $wherestr = implode(' AND ', $where); $sql = "SELECT DISTINCT u.id, u.firstname, u.lastname, u.email, ue.timecreated FROM {user} u JOIN {user_enrolments} ue ON (ue.userid = u.id AND ue.enrolid {$in_instances}) JOIN {role_assignments} ra ON (ra.userid = u.id AND ra.contextid {$in_contexts}) LEFT JOIN {user_info_data} uid ON (uid.userid = u.id AND uid.fieldid {$in_fields})"; if ($wherestr) { $sql .= " WHERE {$wherestr}"; } if ($sort == 'timecreated') { $sql .= ' ORDER BY ue.timecreated'; } else { $sql .= " ORDER BY u.{$sort}"; } $total = $DB->count_records_sql($sql, $params + $where_params); $userlist = $DB->get_records_sql($sql, $params + $where_params, $start); if ($csv && $userlist) { // Only show CSV if there are some users $shortname = format_string($course->shortname, true, array('context' => $context)); header('Content-Disposition: attachment; filename=ilbenrol.'. preg_replace('/[^a-z0-9-]/','_',textlib::strtolower(strip_tags($shortname))).'.csv'); // Unicode byte-order mark for Excel if ($excel) { header('Content-Type: text/csv; charset=UTF-16LE'); print chr(0xFF).chr(0xFE); $sep="\t".chr(0); $line="\n".chr(0); } else { header('Content-Type: text/csv; charset=UTF-8'); $sep=","; $line="\n"; } } else { // Navigation and header $PAGE->set_title(get_string('title','report_ilbenrol')); $PAGE->set_heading($course->fullname); echo $OUTPUT->header(); // $PAGE->requires->js('/report/ilbenrol/textrotate.js'); // $PAGE->requires->js_function_call('textrotate_init', null, true); // Handle groups (if enabled) groups_print_course_menu($course,$CFG->wwwroot.'/report/ilbenrol/?course='.$course->id); // Print filter form $mform->display(); // Print summary table $thead = array(''); $talign = array('left'); foreach ($roles as $role) { $thead[] = $role->localname; $talign[] = 'right'; } foreach ($filterfields as $field) { $options = explode("\n", $field->param1); $data = array(); foreach($options as $option) { $row = array($option); foreach ($roles as $role) { if (isset($dados["{$field->id}-{$role->id}-{$option}"])) { $row[] = $dados["{$field->id}-{$role->id}-{$option}"]; } else { $row[] = ""; } } $data[] = $row; } $thead[0] = $field->name; $table = new html_table(); $table->align = $talign; $table->head = $thead; $table->data = $data; echo html_writer::table($table); } } // If no users in this filter if (!$userlist) { echo $OUTPUT->container(get_string('err_nousers', 'completion'), 'errorbox errorboxcontent'); echo $OUTPUT->footer(); exit; } // Build link for paging $link = $CFG->wwwroot.'/report/ilbenrol/?course='.$course->id; if (strlen($sort)) { $link .= '&sort='.$sort; } // Add filterform fields if ($formdata) { $formvar = '&_qf__filter_form=1&mform_isexpanded_id_filter=1&sesskey='.sesskey(); foreach ($formdata as $key=>$value) { if (is_array($value)) { foreach ($value as $k=>$v) { $formvar .= "&{$key}[{$k}]={$v}"; } } else { $formvar .= "&{$key}={$value}"; } } $link .= $formvar; } $link .= '&start='; // Build the the page by Initial bar $initials = array('first', 'last'); $alphabet = explode(',', get_string('alphabet', 'langconfig')); $pagingbar = ''; foreach ($initials as $initial) { $var = 'si'.$initial; $othervar = $initial == 'first' ? 'silast' : 'sifirst'; $othervar = $$othervar != 'all' ? "&{$othervar}={$$othervar}" : ''; $pagingbar .= '
'; } // Do we need a paging bar? if ($total > ILBENROL_REPORT_PAGE) { // Paging bar $pagingbar .= '