-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathruns.php
100 lines (84 loc) · 3.37 KB
/
runs.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
94
95
96
97
98
99
100
<?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/>.
/**
* Runs (list) for a dataflow page
*
* @package tool_dataflows
* @author Kevin Pham <[email protected]>
* @copyright Catalyst IT, 2022
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
use tool_dataflows\visualiser;
use tool_dataflows\dataflow;
use tool_dataflows\runs_table;
require_once(dirname(__FILE__) . '/../../../config.php');
require_once($CFG->libdir . '/adminlib.php');
require_once($CFG->libdir . '/tablelib.php');
defined('MOODLE_INTERNAL') || die();
require_login();
$id = required_param('id', PARAM_INT);
$url = new moodle_url('/admin/tool/dataflows/runs.php', ['id' => $id]);
$context = context_system::instance();
$PAGE->set_context($context);
$PAGE->set_url($url);
// Check for caps.
require_capability('tool/dataflows:managedataflows', $context);
// Configure any table specifics.
$table = new runs_table('dataflow_runs_table');
$ufields = \core_user\fields::for_name()->get_sql('usr', false, '', '', false)->selects;
$sqlfields = 'run.id,'
// Cast the name as a real number so it can be correctly sorted.
. $DB->sql_cast_char2real('run.name') . ' as name,'
// Fetch user name fields (for display purposes).
. $ufields . ',
run.dataflowid,
run.userid,
run.status,
run.timestarted,
run.timepaused,
run.timefinished,
run.startstate,
run.currentstate,
run.endstate';
$sqlfrom = '{tool_dataflows_runs} run
LEFT JOIN {user} usr
ON usr.id = run.userid';
$sqlwhere = 'dataflowid = :dataflowid';
$sqlparams = ['dataflowid' => $id];
$table->set_sql($sqlfields, $sqlfrom, $sqlwhere, $sqlparams);
$table->make_columns();
// Configure the breadcrumb navigation.
$dataflow = new dataflow($id);
visualiser::breadcrumb_navigation([
// Dataflows > Manage Flows > :dataflow->name (details page).
[get_string('pluginmanage', 'tool_dataflows'), new moodle_url('/admin/tool/dataflows/index.php')],
[$dataflow->name, new moodle_url('/admin/tool/dataflows/view.php', ['id' => $id])],
[get_string('all_runs', 'tool_dataflows'), $url],
]);
// Page basic setup.
$output = $PAGE->get_renderer('tool_dataflows');
$pluginname = get_string('pluginname', 'tool_dataflows');
$table->define_baseurl($url);
$pageheading = get_string('all_runs', 'tool_dataflows');
$dataflow = new dataflow($dataflow->id);
$PAGE->set_title($dataflow->name . ': ' . $pageheading);
$PAGE->set_pagelayout('admin');
$PAGE->set_heading($dataflow->name . ': ' . $pageheading);
echo $output->header();
// No hide/show links under each column.
$table->attributes['class'] = 'table-sm w-auto';
$table->build();
echo $output->footer();