1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-21 22:47:43 +00:00
Files
matomo/plugins/UsersManager/Tasks.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

83 خطوط
2.6 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;
use Piwik\Access;
use Piwik\Date;
use Piwik\Plugins\UsersManager\TokenNotifications\TokenNotifierTask;
use Piwik\Plugins\UsersManager\UserNotifications\UserNotifierTask;
class Tasks extends \Piwik\Plugin\Tasks
{
/**
* @var Model
*/
private $usersModel;
/**
* @param API
*/
private $usersManagerApi;
public function __construct(Model $usersModel, API $usersManagerApi)
{
$this->usersModel = $usersModel;
$this->usersManagerApi = $usersManagerApi;
}
public function schedule()
{
$this->daily("cleanupExpiredTokens");
$this->daily("setUserDefaultReportPreference");
$this->daily("cleanUpExpiredInvites");
$this->scheduleTask(new TokenNotifierTask());
$this->scheduleTask(new UserNotifierTask());
}
public function cleanupExpiredTokens()
{
$this->usersModel->deleteExpiredTokens(Date::now()->getDatetime());
}
public function cleanUpExpiredInvites()
{
// Expired invites will be removed after 3 days, so there's a chance to resend an invite before it's removed.
$expiredInvites = $this->usersModel->getExpiredInvites(Date::now()->subDay(3)->getDatetime());
foreach ($expiredInvites as $expiredInvite) {
try {
$this->usersModel->deleteUser($expiredInvite['login']);
} catch (\Exception $e) {
// ignore possible errors thrown during delete user event
}
}
}
public function setUserDefaultReportPreference()
{
// We initialize the default report user preference for each user (if it hasn't been inited before) for performance,
// doing this lets us avoid loading all siteIds (which can be 50k or more) when this preference is requested.
// getting the user preference can be called quite often when generating links etc (to get defaultWebsiteId).
$usersModel = $this->usersModel;
$usersManagerApi = $this->usersManagerApi;
/*
* Required to be executed as super user, as the API method used requires super user or the user itself.
*/
Access::getInstance()->doAsSuperUser(function () use ($usersModel, $usersManagerApi) {
$allUsers = $usersModel->getUsers([]);
foreach ($allUsers as $user) {
$usersManagerApi->initUserPreferenceWithDefault($user['login'], API::PREFERENCE_DEFAULT_REPORT);
}
});
}
}