-
Notifications
You must be signed in to change notification settings - Fork 7
/
authorise.php
77 lines (66 loc) · 2.85 KB
/
authorise.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
<?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/>.
/**
* Handles login / logout of the user client.
*
* @package mod_collaborativefolders
* @copyright 2017 Jan Dageförde (Learnweb, University of Münster)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(__DIR__ . '/../../config.php');
require_login();
require_sesskey();
// Parameters.
$cmid = required_param('id', PARAM_INT);
$action = required_param('action', PARAM_TEXT);
// Headers to make it not cacheable.
header('Cache-Control: no-cache, must-revalidate');
header('Expires: Sat, 26 Jul 1997 05:00:00 GMT');
// Wait as long as it takes for this script to finish.
core_php_time_limit::raise();
// Predefine URL used for all redirects.
$nextpage = new \moodle_url('/mod/collaborativefolders/view.php', ['id' => $cmid]);
$userclient = new \mod_collaborativefolders\local\clients\user_folder_access(
new \moodle_url('/mod/collaborativefolders/authorise.php', [
'action' => 'login',
'id' => $cmid,
'sesskey' => sesskey()])
);
$servicename = get_config('collaborativefolders', 'servicename');
// Handle actions.
if ($action === 'logout') {
// Remove access token.
$userclient->log_out();
redirect($nextpage, get_string('logoutsuccess', 'mod_collaborativefolders', $servicename), null,
\core\output\notification::NOTIFY_SUCCESS);
exit;
}
if ($action === 'login') {
// Callback from remote system. Use received authorisation code to convert it into an access token.
if ($userclient->check_login()) {
// Token received! Continuing...
redirect($nextpage, get_string('loginsuccess', 'mod_collaborativefolders', $servicename), null,
\core\output\notification::NOTIFY_SUCCESS);
} else {
// Authorisation failed for some reason.
redirect($nextpage, get_string('loginfailure', 'mod_collaborativefolders', $servicename), null,
\core\output\notification::NOTIFY_ERROR);
}
exit;
}
// We got here with some unknown action. If caused by a script it has to be fixed by a programmer.
// If caused by a human who just likes to mess around with parameters, we don't actually care.
throw new \coding_exception(sprintf('Unsupported action: %s', $action));