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 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Changes;
use Piwik\Container\StaticContainer;
use Piwik\Date;
use Piwik\Plugins\UsersManager\Model as UsersModel;
/**
* CoreHome user changes class
*/
class UserChanges
{
private $user;
private $changesModel;
/**
* @param array $user
*/
public function __construct(array $user)
{
$this->user = $user;
$this->changesModel = StaticContainer::get(\Piwik\Changes\Model::class);
}
/**
* Return a value indicating if there are any changes available to show the user
*
* @return int Changes\Model::NO_CHANGES_EXIST, Changes\Model::CHANGES_EXIST or Changes\Model::NEW_CHANGES_EXIST
* @throws \Exception
*/
public function getNewChangesStatus(): int
{
return $this->changesModel->doChangesExist($this->getIdchangeLastViewed());
}
/**
* Return the count of new changes unseen by the user
*
* @return int Change count
* @throws \Exception
*/
public function getNewChangesCount(): int
{
return $this->changesModel->getNewChangesCount($this->getIdchangeLastViewed());
}
/**
* Return the key of the last viewed change for the user, if any
*
*/
private function getIdchangeLastViewed(): ?int
{
return (isset($this->user['idchange_last_viewed']) ? intval($this->user['idchange_last_viewed']) : null);
}
/**
* Return true if the changes popup is snoozed
*
* @return bool If changes were shown to the user in the last 24hrs then this will be true, otherwise false
*/
public function shownRecently(): bool
{
$lastShown = (isset($this->user['ts_changes_shown']) ? $this->user['ts_changes_shown'] : null);
if (!$lastShown) {
return false; // Never shown
}
// Less than 24hrs since last shown
return ((Date::factory('now')->getTimestamp() - Date::factory($lastShown)->getTimestamp()) < 86400);
}
/**
* Return an array of changes and update the user's popup last shown timestamp
*
* @return array
*/
public function getChanges(): array
{
$usersModel = new UsersModel();
$usersModel->updateUserFields($this->user['login'], ['ts_changes_shown' => Date::now()->getDatetime()]);
return $this->changesModel->getChangeItems();
}
/**
* Record all changes as read
*
* @throws \Piwik\Tracker\Db\DbException
*/
public function markChangesAsRead(): void
{
$changes = $this->changesModel->getChangeItems();
$maxId = null;
foreach ($changes as $k => $change) {
if ($maxId < $change['idchange']) {
$maxId = $change['idchange'];
}
}
if ($maxId) {
$usersModel = new UsersModel();
$usersModel->updateUserFields($this->user['login'], ['idchange_last_viewed' => $maxId]);
}
}
}
|