-
Notifications
You must be signed in to change notification settings - Fork 86
/
Copy pathhandler.php
86 lines (79 loc) · 3.2 KB
/
handler.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
<?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/>.
/**
* Transformer handler.
*
* @package logstore_xapi
* @copyright Jerret Fowler <jerrett.fowler@gmail.com>
* Ryan Smith <https://www.linkedin.com/in/ryan-smith-uk/>
* David Pesce <david.pesce@exputo.com>
* Milt Reder <milt@yetanalytics.com>
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace src\transformer;
use src\transformer\utils as utils;
/**
* Generic handler for the transformer.
*
* @param array $config The transformer config settings.
* @param array $events The event to be transformed.
* @return array
*/
function handler(array $config, array $events) {
$eventfunctionmap = get_event_function_map();
$transformedevents = array_map(function ($event) use ($config, $eventfunctionmap) {
$eventobj = (object) $event;
try {
$eventname = $eventobj->eventname;
if (isset($eventfunctionmap[$eventname])) {
$eventfunctionname = $eventfunctionmap[$eventname];
$eventfunction = '\src\transformer\events\\' . $eventfunctionname;
$eventconfig = array_merge([
'event_function' => $eventfunction,
], $config);
$eventstatements = utils\apply_statement_defaults(
$eventconfig,
$eventobj,
$eventfunction($eventconfig, $eventobj)
);
} else {
$eventstatements = [];
}
// Returns successfully transformed event with its statements.
$transformedevent = [
'event' => $eventobj,
'statements' => $eventstatements,
'transformed' => true,
];
return $transformedevent;
} catch (\Exception $e) {
$logerror = $config['log_error'];
$id=property_exists($eventobj,'id') ? $eventobj->id : ' (id not present on event object) ';
$errormessage = "Failed transform for event id #" . $id . ": " . $e->getMessage();
$logerror($errormessage);
$logerror($e->getTraceAsString());
$eventobj->response = json_encode(['transfromerror' => $errormessage]);
// Returns unsuccessfully transformed event without statements.
$transformedevent = [
'event' => $eventobj,
'statements' => [],
'transformed' => false,
];
return $transformedevent;
}
}, $events);
return $transformedevents;
}