Merge branch 'MDL-48679-master' of git://github.com/lameze/moodle
[moodle.git] / grade / export / xls / dump.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
18 define('NO_MOODLE_COOKIES', true); // session not used here
19 require_once '../../../config.php';
20 require_once($CFG->dirroot.'/grade/export/xls/grade_export_xls.php');
22 $id                 = required_param('id', PARAM_INT);
23 $groupid            = optional_param('groupid', 0, PARAM_INT);
24 $itemids            = required_param('itemids', PARAM_RAW);
25 $exportfeedback     = optional_param('export_feedback', 0, PARAM_BOOL);
26 $displaytype        = optional_param('displaytype', $CFG->grade_export_displaytype, PARAM_RAW);
27 $decimalpoints      = optional_param('decimalpoints', $CFG->grade_export_decimalpoints, PARAM_INT);
28 $onlyactive         = optional_param('export_onlyactive', 0, PARAM_BOOL);
30 if (!$course = $DB->get_record('course', array('id'=>$id))) {
31     print_error('nocourseid');
32 }
34 require_user_key_login('grade/export', $id); // we want different keys for each course
36 if (empty($CFG->gradepublishing)) {
37     print_error('gradepubdisable');
38 }
40 $context = context_course::instance($id);
41 require_capability('moodle/grade:export', $context);
42 require_capability('gradeexport/xls:view', $context);
43 require_capability('gradeexport/xls:publish', $context);
45 if (!groups_group_visible($groupid, $COURSE)) {
46     print_error('cannotaccessgroup', 'grades');
47 }
49 // Get all url parameters and create an object to simulate a form submission.
50 $formdata = grade_export::export_bulk_export_data($id, $itemids, $exportfeedback, $onlyactive, $displaytype,
51         $decimalpoints);
53 $export = new grade_export_xls($course, $groupid, $formdata);
54 $export->print_grades();