1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-22 06:57:53 +00:00
Files
matomo/plugins/UsersManager/TokenNotifications/TokenNotifierTask.php
Michal Kleiner 7cc8a70b3d Add mechanism to send inactive users notification (#23425)
* Add new setting for enabling inactive user notifications (#23393)
* Migrate 'last seen' from options table to users table (#23388)
* Create scheduled task to send inactive users security notification (#23403)
* Simplify enrich user and remove surplus methods
* Create a language helper to run code using given user's preferred language
* Update UI test screenshots

---------

Co-authored-by: Nathan Gavin <nathangavin987@gmail.com>
2025-08-05 13:54:58 +12:00

90 خطوط
2.9 KiB
PHP

<?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\Plugins\UsersManager\TokenNotifications;
use Exception;
use Piwik\Container\StaticContainer;
use Piwik\Date;
use Piwik\Log\LoggerInterface;
use Piwik\Option;
use Piwik\Plugin\Manager as PluginManager;
use Piwik\Scheduler\Schedule\Daily;
use Piwik\Scheduler\Task;
/**
* Send token notifications for each provider
*/
class TokenNotifierTask extends Task
{
public const LAST_RUN_TIME_OPTION_NAME = 'TokenNotifier.lastRunTime';
public function __construct()
{
parent::__construct($this, 'dispatchNotifications', null, new Daily());
}
/**
* Get a list of providers (class names) that may provide token notifications to be dispatched
*
* @return array
*/
private function getTokenProviderClasses(): array
{
return PluginManager::getInstance()->findMultipleComponents(
'TokenNotifications',
TokenNotificationProviderInterface::class
);
}
/**
* Dispatch notifications for each provider and its tokens
*/
public function dispatchNotifications()
{
$container = StaticContainer::getContainer();
$logger = $container->get(LoggerInterface::class);
try {
Option::set(self::LAST_RUN_TIME_OPTION_NAME, Date::factory('today')->getTimestamp());
$notificationsToDispatchCount = 0;
$notificationsDispatchedCount = 0;
foreach ($this->getTokenProviderClasses() as $providerClass) {
/** @var TokenNotificationProviderInterface $provider */
$provider = $container->get($providerClass);
$providerTokenNotificationsForDispatch = $provider->getTokenNotificationsForDispatch();
$notificationsToDispatchCount += count($providerTokenNotificationsForDispatch);
foreach ($providerTokenNotificationsForDispatch as $tokenNotification) {
$dispatched = $tokenNotification->dispatch();
if ($dispatched) {
$provider->setTokenNotificationDispatched($tokenNotification->getTokenId());
$notificationsDispatchedCount++;
}
}
}
if ($notificationsToDispatchCount) {
$logger->info(
"Number of token notifications dispatched: {number} of {total}.",
['number' => $notificationsDispatchedCount, 'total' => $notificationsToDispatchCount]
);
} else {
$logger->info("No token notifications to dispatch, task rescheduled.");
}
} catch (Exception $ex) {
$container->get(LoggerInterface::class)->error($ex);
throw $ex;
}
}
}