site-accueil-insa/matomo/plugins/CoreHome/Columns/VisitLastActionTime.php

115 lines
No EOL
4.4 KiB
PHP

<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*
*/
namespace Piwik\Plugins\CoreHome\Columns;
use Piwik\Common;
use Piwik\Date;
use Piwik\Period;
use Piwik\Plugin\Dimension\VisitDimension;
use Piwik\Site;
use Piwik\Tracker\Action;
use Piwik\Tracker\Request;
use Piwik\Tracker\Visitor;
use Piwik\Metrics\Formatter;
require_once PIWIK_INCLUDE_PATH . '/plugins/VisitTime/functions.php';
/**
* This dimension holds the best guess for a visit's end time. It is set the last action
* time for each visit. `ping=1` requests can be sent to update the dimension value so
* it can be a more accurate guess of the time the visitor spent on the site.
*
* Note: though it is named 'visit last action time' it actually refers to the visit's last action's
* end time.
*/
class VisitLastActionTime extends VisitDimension
{
protected $columnName = 'visit_last_action_time';
protected $type = self::TYPE_DATETIME;
protected $nameSingular = 'VisitTime_ColumnVisitEndSiteHour';
protected $sqlSegment = 'HOUR(log_visit.visit_last_action_time)';
protected $segmentName = 'visitServerHour';
protected $acceptValues = '0, 1, 2, 3, ..., 20, 21, 22, 23';
/**
* Converts the hour to the hour depending on the configured site's timezone.
* Only works correct if a date/period is present in the request. Otherwise the result may vary depending on the
* day of the year as it can't know about daylight savings for example. Also if the currently selected date range
* includes multiple days with daylight savings and some without, then it might not be 100% correct as we are
* only looking at the start of the time.
* @param int $hour
* @param int $idSite
* @return int
* @throws \Exception
*/
public static function convertHourToHourInSiteTimezone($hour, $idSite)
{
$date = Date::now();
$dateString = Common::getRequestVar('date', '', 'string');
$periodString = Common::getRequestVar('period', '', 'string');
if (!empty($dateString) && !empty($periodString)) {
try {
$date = Period\Factory::build($periodString, $dateString)->getDateStart();
} catch (\Exception $e) {
// ignore any error eg if values are wrong...
}
}
$timezone = Site::getTimezoneFor($idSite);
$datetime = $date->toString() . ' ' . $hour . ':00:00';
$hourInTz = (int)Date::factory($datetime, $timezone)->toString('H');
return $hourInTz;
}
public function formatValue($value, $idSite, Formatter $formatter)
{
$hourInTz = self::convertHourToHourInSiteTimezone($value, $idSite);
return \Piwik\Plugins\VisitTime\getTimeLabel($hourInTz);
}
// we do not install or define column definition here as we need to create this column when installing as there is
// an index on it. Currently we do not define the index here... although we could overwrite the install() method
// and add column 'visit_last_action_time' and add index. Problem is there is also an index
// INDEX(idsite, config_id, visit_last_action_time) and we maybe not be sure whether idsite already exists at
// installing point (we do not know whether idsite column will be added first).
/**
* @param Request $request
* @param Visitor $visitor
* @param Action|null $action
* @return mixed
*/
public function onNewVisit(Request $request, Visitor $visitor, $action)
{
return Date::getDatetimeFromTimestamp($request->getCurrentTimestamp());
}
/**
* @param Request $request
* @param Visitor $visitor
* @param Action|null $action
* @return mixed
*/
public function onExistingVisit(Request $request, Visitor $visitor, $action)
{
if ($request->getParam('ping') == 1) {
return false;
}
$originalVisitLastActionTime = $visitor->getPreviousVisitColumn('visit_last_action_time');
if (!empty($originalVisitLastActionTime)
&& Date::factory($originalVisitLastActionTime)->getTimestamp() > $request->getCurrentTimestamp()) {
// make sure to not set visit_last_action_time to an earlier time eg if tracking requests aren't sent in order
return $originalVisitLastActionTime;
}
return $this->onNewVisit($request, $visitor, $action);
}
}