mirror of
https://github.com/moodle/moodle.git
synced 2025-02-26 21:13:33 +01:00
161 lines
4.1 KiB
PHP
Executable File
161 lines
4.1 KiB
PHP
Executable File
<?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;
|
|
}
|
|
|
|
?>
|