1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-22 23:17:46 +00:00
Files
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

98 خطوط
4.7 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\tests\Fixtures;
use Piwik\Common;
use Piwik\Date;
use Piwik\Db;
use Piwik\Plugins\UsersManager\API;
use Piwik\Plugins\UsersManager\Model as UsersManagerModel;
use Piwik\Tests\Framework\Fixture;
/**
* Generates auth tokens for token notification tests with an optional last_used date
*/
class Tokens extends Fixture
{
public $tokens = [
'user1' => [
[['user1, not expired user token, secure only', '2024-01-01 00:00:00', null, '0', '1'], '2024-09-01 00:00:00'],
[['user1, not expired user token, not secure only', '2025-01-01 00:00:00', null, '0', '0'], '2025-02-01 00:00:00'],
[['user1, not expired system token, secure only', '2024-01-01 00:00:00', null, '1', '1'], null],
[['user1, not expired system token, not secure only', '2025-01-01 00:00:00', null, '1', '0'], null],
[['user1, expired user token, secure only', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '0', '1'], null],
[['user1, expired user token, not secure only', '2025-01-01 00:00:00', '2024-02-01 00:00:00', '0', '0'], null],
[['user1, expired system token, secure only', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '1', '1'], null],
[['user1, expired system token, not secure only', '2025-01-01 00:00:00', '2024-02-01 00:00:00', '1', '0'], null],
],
'user2' => [
[['user2, not expired user token, secure only', '2024-01-01 00:00:00', null, '0', '1'], null],
[['user2, not expired user token, not secure only', '2025-01-01 00:00:00', null, '0', '0'], null],
[['user2, not expired system token, secure only', '2024-01-01 00:00:00', null, '1', '1'], null],
[['user2, not expired system token, not secure only', '2025-01-01 00:00:00', null, '1', '0'], null],
[['user2, expired user token, secure only', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '0', '1'], '2024-01-10 00:00:00'],
[['user2, expired user token, not secure only', '2025-01-01 00:00:00', '2024-02-01 00:00:00', '0', '0'], null],
[['user2, expired system token, secure only', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '1', '1'], null],
[['user2, expired system token, not secure only', '2025-01-01 00:00:00', '2024-02-01 00:00:00', '1', '0'], null],
],
'user3' => [
[['user3, not expired user token, secure only, not used', '2024-01-01 00:00:00', null, '0', '1'], null],
[['user3, not expired user token, secure only, used', '2024-01-01 00:00:00', null, '0', '1'], '2024-09-01 00:00:00'],
[['user3, expired user token, secure only, not used', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '0', '1'], null],
[['user3, expired user token, secure only, used', '2024-01-01 00:00:00', '2024-02-01 00:00:00', '0', '1'], '2024-09-01 00:00:00'],
[['user3, not expired system token, secure only, not used', '2024-01-01 00:00:00', null, '1', '1'], null],
[['user3, not expired system token, secure only, used', '2024-01-01 00:00:00', null, '1', '1'], '2024-09-01 00:00:00'],
]
];
public function setUp(): void
{
Fixture::createWebsite('2020-01-11 00:00:00');
$this->setUpUsersAndTokens();
}
private function setUpUsersAndTokens()
{
Date::$now = Date::factory('2024-01-01')->getTimestamp();
$api = API::getInstance();
$model = new UsersManagerModel();
for ($i = 1; $i <= 5; $i++) {
$api->addUser("user$i", "password$i", "user$i@example.com");
$api->setUserAccess("user$i", 'view', [1]);
}
$model->setSuperUserAccess('user1', true);
$model->setLastSeenDatetime('user2', '2024-09-29 00:00:00');
$model->setLastSeenDatetime('user4', '2024-09-29 00:00:00');
foreach ($this->tokens as $user => $tokens) {
foreach ($tokens as $tokenArray) {
$tokenAuth = $model->generateRandomTokenAuth();
$model->addTokenAuth($user, $tokenAuth, ...$tokenArray[0]);
if ($lastUsed = $tokenArray[1]) {
$model->setTokenAuthWasUsed($tokenAuth, $lastUsed);
}
}
}
}
public function resetTsRotationNotification()
{
Db::get()->query("UPDATE " . Common::prefixTable('user_token_auth') . " SET ts_rotation_notified = NULL");
}
public function resetTsInactivityNotification()
{
Db::get()->query("UPDATE " . Common::prefixTable('user') . " SET ts_inactivity_notified = NULL");
}
}