--- /dev/null
+<?php //$Id$
+/**
+* script for downloading of user lists
+*/
+
+require_once('../../config.php');
+require_once($CFG->libdir.'/adminlib.php');
+
+$format = optional_param('format', '', PARAM_ALPHA);
+
+admin_externalpage_setup('userbulk');
+require_capability('moodle/user:update', get_context_instance(CONTEXT_SYSTEM));
+
+$return = $CFG->wwwroot.'/'.$CFG->admin.'/user/user_bulk.php';
+
+if (empty($SESSION->bulk_users)) {
+ redirect($return);
+}
+
+
+if ($format) {
+ $fields = array('id' => 'id',
+ 'username' => get_string('username'),
+ 'email' => get_string('email'),
+ 'firstname' => get_string('firstname'),
+ 'lastname' => get_string('lastname'),
+ 'idnumber' => get_string('idnumber'),
+ 'city' => get_string('city'),
+ 'country' => get_string('country'));
+
+ switch ($format) {
+ case 'csv' : user_download_csv($fields);
+ case 'ods' : user_download_ods($fields);
+ case 'xls' : user_download_xls($fields);
+
+ }
+ die;
+}
+
+admin_externalpage_print_header();
+print_heading(get_string('download', 'admin'));
+
+print_box_start();
+echo '<ul>';
+echo '<li><a href="user_bulk_download.php?format=csv">'.get_string('downloadtext').'</a></li>';
+echo '<li><a href="user_bulk_download.php?format=ods">'.get_string('downloadods').'</a></li>';
+echo '<li><a href="user_bulk_download.php?format=xls">'.get_string('downloadexcel').'</a></li>';
+echo '</ul>';
+print_box_end();
+
+print_continue($return);
+
+print_footer();
+
+function user_download_ods($fields) {
+ global $CFG, $SESSION;
+
+ require_once("$CFG->libdir/odslib.class.php");
+
+ $filename = clean_filename(get_string('users').'.ods');
+
+ $workbook = new MoodleODSWorkbook('-');
+ $workbook->send($filename);
+
+ $worksheet = array();
+
+ $worksheet[0] =& $workbook->add_worksheet('');
+ $col = 0;
+ foreach ($fields as $fieldname) {
+ $worksheet[0]->write(0, $col, $fieldname);
+ $col++;
+ }
+
+ $row = 1;
+ foreach ($SESSION->bulk_users as $userid) {
+ if (!$user = get_record('user', 'id', $userid)) {
+ continue;
+ }
+ $col = 0;
+ foreach ($fields as $field=>$unused) {
+ $worksheet[0]->write($row, $col, $user->$field);
+ $col++;
+ }
+ $row++;
+ }
+
+ $workbook->close();
+ die;
+}
+
+function user_download_xls($fields) {
+ global $CFG, $SESSION;
+
+ require_once("$CFG->libdir/excellib.class.php");
+
+ $filename = clean_filename(get_string('users').'.xls');
+
+ $workbook = new MoodleExcelWorkbook('-');
+ $workbook->send($filename);
+
+ $worksheet = array();
+
+ $worksheet[0] =& $workbook->add_worksheet('');
+ $col = 0;
+ foreach ($fields as $fieldname) {
+ $worksheet[0]->write(0, $col, $fieldname);
+ $col++;
+ }
+
+ $row = 1;
+ foreach ($SESSION->bulk_users as $userid) {
+ if (!$user = get_record('user', 'id', $userid)) {
+ continue;
+ }
+ $col = 0;
+ foreach ($fields as $field=>$unused) {
+ $worksheet[0]->write($row, $col, $user->$field);
+ $col++;
+ }
+ $row++;
+ }
+
+ $workbook->close();
+ die;
+}
+
+function user_download_csv($fields) {
+ global $CFG, $SESSION;
+
+ $filename = clean_filename(get_string('users').'.csv');
+
+ header("Content-Type: application/download\n");
+ header("Content-Disposition: attachment; filename=$filename");
+ header("Expires: 0");
+ header("Cache-Control: must-revalidate,post-check=0,pre-check=0");
+ header("Pragma: public");
+
+ $delimiter = get_string('listsep');
+ $encdelim = '&#'.ord($delimiter);
+
+ $row = array();
+ foreach ($fields as $fieldname) {
+ $row[] = str_replace($delimiter, $encdelim, $fieldname);
+ }
+ echo implode($delimiter, $row)."\n";
+
+ foreach ($SESSION->bulk_users as $userid) {
+ $row = array();
+ if (!$user = get_record('user', 'id', $userid)) {
+ continue;
+ }
+ foreach ($fields as $field=>$unused) {
+ $row[] = str_replace($delimiter, $encdelim, $user->$field);
+ }
+ echo implode($delimiter, $row)."\n";
+ }
+ die;
+}
+
+?>
$actions[3] = get_string('delete');
}
$actions[4] = get_string('displayonpage');
+ if (has_capability('moodle/user:update', $syscontext)) {
+ $actions[5] = get_string('download', 'admin');
+ }
$objs = array();
$objs[] =& $mform->createElement('select', 'action', null, $actions);
$grp =& $mform->addElement('group', 'usersgrp', get_string('users'), $objs, ' ', false);
- $grp->setHelpButton(array('lists','','bulkusers'));
+ $grp->setHelpButton(array('lists', get_string('users'), 'bulkusers'));
$mform->addElement('static', 'comment');
$objs[] =& $mform->createElement('submit', 'addall', get_string('addall', 'bulkusers'));
$objs[] =& $mform->createElement('submit', 'removeall', get_string('removeall', 'bulkusers'));
$grp =& $mform->addElement('group', 'buttonsgrp', get_string('selectedlist', 'bulkusers'), $objs, array(' ', '<br />'), false);
- $grp->setHelpButton(array('selectedlist','','bulkusers'));
+ $grp->setHelpButton(array('selectedlist', get_string('selectedlist', 'bulkusers'), 'bulkusers'));
$renderer =& $mform->defaultRenderer();
$template = '<label class="qflabel" style="vertical-align:top">{label}</label> {element}';