mirror of
https://github.com/DanielSiepmann/tracking.git
synced 2025-01-08 05:56:10 +01:00
Daniel Siepmann
33685d1735
Allow Integrator to define rules to track views of records. This allows to add tracking to extensions like tx_news. Integrators are able to define matching rules on current request. If a request matches, the record is stored as individual view beside existing pageview. Relates: #14
101 lines
3 KiB
PHP
101 lines
3 KiB
PHP
<?php
|
|
|
|
namespace DanielSiepmann\Tracking\Domain\Repository;
|
|
|
|
/*
|
|
* Copyright (C) 2020 Daniel Siepmann <coding@daniel-siepmann.de>
|
|
*
|
|
* This program 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 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program 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 this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301, USA.
|
|
*/
|
|
|
|
use DanielSiepmann\Tracking\Domain\Model\Pageview as Model;
|
|
use DanielSiepmann\Tracking\Domain\Pageview\Factory;
|
|
use TYPO3\CMS\Core\Database\Connection;
|
|
|
|
class Pageview
|
|
{
|
|
/**
|
|
* @var Connection
|
|
*/
|
|
private $connection;
|
|
|
|
/**
|
|
* @var Factory
|
|
*/
|
|
private $factory;
|
|
|
|
public function __construct(
|
|
Connection $connection,
|
|
Factory $factory
|
|
) {
|
|
$this->connection = $connection;
|
|
$this->factory = $factory;
|
|
}
|
|
|
|
public function countAll(): int
|
|
{
|
|
return $this->connection->createQueryBuilder()
|
|
->count('uid')
|
|
->from('tx_tracking_pageview')
|
|
->execute()
|
|
->fetchColumn();
|
|
}
|
|
|
|
public function findAll(): \Generator
|
|
{
|
|
$queryBuilder = $this->connection->createQueryBuilder();
|
|
$pageViews = $queryBuilder->select('*')->from('tx_tracking_pageview')->execute();
|
|
|
|
while ($pageView = $pageViews->fetch()) {
|
|
yield $this->factory->fromDbRow($pageView);
|
|
}
|
|
}
|
|
|
|
public function update(Model $pageview): void
|
|
{
|
|
if ($pageview->getUid() === 0) {
|
|
throw new \InvalidArgumentException('Can not update pageview if uid is 0.', 1585770573);
|
|
}
|
|
|
|
$this->connection->update(
|
|
'tx_tracking_pageview',
|
|
$this->getFieldsFromModel($pageview),
|
|
['uid' => $pageview->getUid()]
|
|
);
|
|
}
|
|
|
|
public function add(Model $pageview): void
|
|
{
|
|
$this->connection->insert(
|
|
'tx_tracking_pageview',
|
|
$this->getFieldsFromModel($pageview)
|
|
);
|
|
}
|
|
|
|
private function getFieldsFromModel(Model $pageview): array
|
|
{
|
|
return [
|
|
'pid' => $pageview->getPageUid(),
|
|
'crdate' => $pageview->getCrdate()->format('U'),
|
|
'tstamp' => $pageview->getCrdate()->format('U'),
|
|
'type' => $pageview->getPageType(),
|
|
'sys_language_uid' => $pageview->getLanguage()->getLanguageId(),
|
|
'url' => $pageview->getUrl(),
|
|
'user_agent' => $pageview->getUserAgent(),
|
|
'operating_system' => $pageview->getOperatingSystem(),
|
|
];
|
|
}
|
|
}
|