forked from turnitin/moodle-plagiarism_turnitin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdbexport.php
93 lines (76 loc) · 3.21 KB
/
dbexport.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* View logs page for plagiarism_turnitin component
*
* @package plagiarism_turnitin
* @copyright 2019 Turnitin
* @author 2019 David Winn <[email protected]>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
// Require libs.
require_once(dirname(dirname(dirname(__FILE__))).'/config.php');
require_once($CFG->libdir.'/adminlib.php');
require_once($CFG->libdir.'/dataformatlib.php');
require_once($CFG->dirroot.'/plagiarism/turnitin/classes/turnitin_view.class.php');
$cssurl = new moodle_url('/plagiarism/turnitin/styles.css');
$PAGE->requires->css($cssurl);
// Restrict access to admins only.
require_login();
admin_externalpage_setup('plagiarismturnitin');
$context = context_system::instance();
require_capability('moodle/site:config', $context, $USER->id, true, "nopermissions");
// Get table and dataformat if passed in, otherwise show list of logs.
$table = optional_param('table', null, PARAM_ALPHANUMEXT);
$dataformat = optional_param('dataformat', null, PARAM_ALPHANUMEXT);
$turnitinview = new turnitin_view();
$exportfile = "export_".$table."_".date('Y-m-d_His');
// Use Moodle's dataformatting functions to display a form to download output in different formats.
$tables = array(
'plagiarism_turnitin_files',
'plagiarism_turnitin_config',
'plagiarism_turnitin_users',
'plagiarism_turnitin_courses',
'plagiarism_turnitin_peermark'
);
// If a table has been passed in then export that table data.
if (!is_null($table)) {
if (in_array($table, $tables)) {
raise_memory_limit(MEMORY_EXTRA);
$data = $DB->get_records($table, null, 'id ASC');
// Use Moodle's dataformatting functions to output the data in the desired format.
download_as_dataformat($exportfile, $dataformat, array_keys($DB->get_columns($table)), $data);
exit;
} else {
$output = html_writer::tag('div', get_string('invalidtablename', 'plagiarism_turnitin', $table));
}
} else {
$downloadoptions = "";
foreach ($tables as $table) {
$downloadoptions .= $OUTPUT->download_dataformat_selector(
get_string('dbexporttable', 'plagiarism_turnitin', $table),
'dbexport.php',
'dataformat',
array('table' => $table)
);
}
$output = html_writer::tag('div', $downloadoptions, array('class' => 'turnitin_setup_download_links'));
}
echo $OUTPUT->header();
echo $OUTPUT->heading(get_string('pluginname', 'plagiarism_turnitin'), '2', 'main');
$turnitinview->draw_settings_tab_menu('dbexport');
echo $output;
echo $OUTPUT->footer();