AutorÃa | Ultima modificación | Ver Log |
<?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/>.
/**
* The mod_hvp event logger, makes it easy to track events throughout
* the H5P system.
*
* @package mod_hvp
* @copyright 2016 Joubel AS
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace mod_hvp;
defined('MOODLE_INTERNAL') || die();
class event extends \H5PEventBase {
private $user;
/**
* @inheritdoc
*/
public function __construct($type, $subtype = null, $contentid = null,
$contenttitle = null, $libraryname = null, $libraryversion = null) {
global $USER;
// Track the who initiated the event.
$this->user = $USER->id;
parent::__construct($type, $subtype, $contentid, $contenttitle, $libraryname, $libraryversion);
}
/**
* Store the event.
*
* @return int Event ID
*/
protected function save() {
global $DB;
// Get data in array format without null values.
$data = $this->getDataArray();
// Add user.
$data['user_id'] = $this->user;
return $DB->insert_record('hvp_events', $data);
}
/**
* @inheritdoc
*/
// @codingStandardsIgnoreLine
protected function saveStats() {
global $DB;
$type = $this->type . ' ' . $this->sub_type;
// Grab current counter to check if it exists.
$id = $DB->get_field_sql(
"SELECT id
FROM {hvp_counters}
WHERE type = ?
AND library_name = ?
AND library_version = ?",
array($type, $this->library_name, $this->library_version)
);
if ($id === false) {
// No counter found, insert new one.
$DB->insert_record('hvp_counters', array(
'type' => $type,
'library_name' => $this->library_name,
'library_version' => $this->library_version,
'num' => 1
));
} else {
// Update num+1.
$DB->execute(
"UPDATE {hvp_counters}
SET num = num + 1
WHERE id = ?",
array($id)
);
}
}
}