mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
110 lines
3.9 KiB
PHP
110 lines
3.9 KiB
PHP
<?php
|
|
|
|
require_once(dirname(__FILE__).'/../../../config.php');
|
|
require_once($CFG->libdir.'/adminlib.php');
|
|
|
|
// page parameters
|
|
$page = optional_param('page', 0, PARAM_INT);
|
|
$perpage = optional_param('perpage', 30, PARAM_INT); // how many per page
|
|
$sort = optional_param('sort', 'timemodified', PARAM_ALPHA);
|
|
$dir = optional_param('dir', 'DESC', PARAM_ALPHA);
|
|
|
|
admin_externalpage_setup('reportconfiglog');
|
|
admin_externalpage_print_header();
|
|
|
|
echo $OUTPUT->heading(get_string('configlog', 'report_configlog'));
|
|
|
|
$changescount = $DB->count_records('config_log');
|
|
|
|
$columns = array('firstname' => get_string('firstname'),
|
|
'lastname' => get_string('lastname'),
|
|
'timemodified' => get_string('timemodified', 'report_configlog'),
|
|
'plugin' => get_string('plugin', 'report_configlog'),
|
|
'name' => get_string('setting', 'report_configlog'),
|
|
'value' => get_string('value', 'report_configlog'),
|
|
'oldvalue' => get_string('oldvalue', 'report_configlog'),
|
|
);
|
|
$hcolumns = array();
|
|
|
|
|
|
if (!isset($columns[$sort])) {
|
|
$sort = 'lastname';
|
|
}
|
|
|
|
foreach ($columns as $column=>$strcolumn) {
|
|
if ($sort != $column) {
|
|
$columnicon = '';
|
|
if ($column == 'lastaccess') {
|
|
$columndir = 'DESC';
|
|
} else {
|
|
$columndir = 'ASC';
|
|
}
|
|
} else {
|
|
$columndir = $dir == 'ASC' ? 'DESC':'ASC';
|
|
if ($column == 'lastaccess') {
|
|
$columnicon = $dir == 'ASC' ? 'up':'down';
|
|
} else {
|
|
$columnicon = $dir == 'ASC' ? 'down':'up';
|
|
}
|
|
$columnicon = " <img src=\"" . $OUTPUT->pix_url('t/' . $columnicon) . "\" alt=\"\" />";
|
|
|
|
}
|
|
$hcolumns[$column] = "<a href=\"index.php?sort=$column&dir=$columndir&page=$page&perpage=$perpage\">".$strcolumn."</a>$columnicon";
|
|
}
|
|
|
|
$baseurl = new moodle_url('index.php', array('sort' => $sort, 'dir' => $dir, 'perpage' => $perpage));
|
|
echo $OUTPUT->paging_bar($changescount, $page, $perpage, $baseurl);
|
|
|
|
$override = new object();
|
|
$override->firstname = 'firstname';
|
|
$override->lastname = 'lastname';
|
|
$fullnamelanguage = get_string('fullnamedisplay', '', $override);
|
|
if (($CFG->fullnamedisplay == 'firstname lastname') or
|
|
($CFG->fullnamedisplay == 'firstname') or
|
|
($CFG->fullnamedisplay == 'language' and $fullnamelanguage == 'firstname lastname' )) {
|
|
$fullnamedisplay = $hcolumns['firstname'].' / '.$hcolumns['lastname'];
|
|
} else { // ($CFG->fullnamedisplay == 'language' and $fullnamelanguage == 'lastname firstname')
|
|
$fullnamedisplay = $hcolumns['lastname'].' / '.$hcolumns['firstname'];
|
|
}
|
|
|
|
$table = new html_table();
|
|
$table->head = array($hcolumns['timemodified'], $fullnamedisplay, $hcolumns['plugin'], $hcolumns['name'], $hcolumns['value'], $hcolumns['oldvalue']);
|
|
$table->align = array('left', 'left', 'left', 'left', 'left', 'left');
|
|
$table->size = array('30%', '10%', '10%', '10%', '20%', '20%');
|
|
$table->width = '95%';
|
|
$table->data = array();
|
|
|
|
if ($sort == 'firstname' or $sort == 'lastname') {
|
|
$orderby = "u.$sort $dir";
|
|
} else {
|
|
$orderby = "cl.$sort $dir";
|
|
}
|
|
|
|
$sql = "SELECT u.id, u.firstname, u.lastname, u.picture, u.imagealt,
|
|
cl.timemodified, cl.plugin, cl.name, cl.value, cl.oldvalue
|
|
FROM {config_log} cl
|
|
JOIN {user} u ON u.id = cl.userid
|
|
ORDER BY $orderby";
|
|
|
|
$rs = $DB->get_recordset_sql($sql, array(), $page*$perpage, $perpage);
|
|
foreach ($rs as $log) {
|
|
$row = array();
|
|
$row[] = userdate($log->timemodified);
|
|
$row[] = fullname($log);
|
|
if (is_null($log->plugin)) {
|
|
$row[] = 'core';
|
|
} else {
|
|
$row[] = $log->plugin;
|
|
}
|
|
$row[] = $log->name;
|
|
$row[] = s($log->value);
|
|
$row[] = s($log->oldvalue);
|
|
|
|
$table->data[] = $row;
|
|
}
|
|
$rs->close();
|
|
|
|
echo $OUTPUT->table($table);
|
|
|
|
echo $OUTPUT->footer();
|