芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/.trash/cepali/lib/classes/analytics/indicator/any_write_action.php
. /** * Write actions indicator. * * @package core * @copyright 2016 David Monllao {@link http://www.davidmonllao.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core\analytics\indicator; defined('MOODLE_INTERNAL') || die(); /** * Write actions indicator. * * @package core * @copyright 2016 David Monllao {@link http://www.davidmonllao.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class any_write_action extends \core_analytics\local\indicator\binary { /** * Returns the name. * * If there is a corresponding '_help' string this will be shown as well. * * @return \lang_string */ public static function get_name() : \lang_string { return new \lang_string('indicator:anywrite'); } /** * required_sample_data * * @return string[] */ public static function required_sample_data() { // User is not required, calculate_sample can handle its absence. return array('context'); } /** * calculate_sample * * @param int $sampleid * @param string $sampleorigin * @param int $starttime * @param int $endtime * @return float */ protected function calculate_sample($sampleid, $sampleorigin, $starttime = false, $endtime = false) { global $DB; $select = ''; $params = array(); if ($user = $this->retrieve('user', $sampleid)) { $select .= "userid = :userid AND "; $params = $params + array('userid' => $user->id); } if (!$logstore = \core_analytics\manager::get_analytics_logstore()) { throw new \coding_exception('No available log stores'); } // Filter by context to use the logstore_standard_log db table index. $context = $this->retrieve('context', $sampleid); $select .= "contextlevel = :contextlevel AND contextinstanceid = :contextinstanceid AND " . "(crud = 'c' OR crud = 'u')"; $params = $params + array('contextlevel' => $context->contextlevel, 'contextinstanceid' => $context->instanceid); if ($starttime) { $select .= " AND timecreated > :starttime"; $params['starttime'] = $starttime; } if ($endtime) { $select .= " AND timecreated <= :endtime"; $params['endtime'] = $endtime; } $nlogs = $logstore->get_events_select_count($select, $params); if ($nlogs) { return self::get_max_value(); } else { return self::get_min_value(); } } }