Source
// Place $timestamp variable value in data provider as the data providers are formed before execution of onBefore.
<?php
/*
** Zabbix
** Copyright (C) 2001-2025 Zabbix SIA
**
** 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.
**/
require_once dirname(__FILE__).'/common/testPageApiTokens.php';
require_once dirname(__FILE__).'/../include/helpers/CDataHelper.php';
/**
* @backup token
* @backup profiles
*
* @onBefore prepareTokenData
*/
class testPageApiTokensUserSettings extends testPageApiTokens {
public static $timestamp;
const STATUS_CHANGE_TOKEN = 'Expired token for admin';
const DELETE_TOKEN = 'Future token for admin';
public static function prepareTokenData() {
self::$timestamp = time() + 172800;
$response = CDataHelper::call('token.create', [
[
'name' => 'Future token for admin',
'userid' => 1,
'description' => 'admin token to be used in update scenarios',
'status' => '0',
'expires_at' => self::$timestamp + 864000
],
[
'name' => 'Expired token for admin',
'userid' => 1,
'description' => 'Token to be deleted in the delete scenario',
'status' => '0',
'expires_at' => '1609452360'
],
[
'name' => 'Aktīvs токен - 頑張って',
'userid' => 1,
'description' => 'Token that is generated for Admin',
'status' => '1'
],
[
'name' => 'Token that will expire in 2 days',
'userid' => 1,
'description' => 'admin token created for filter-create user',
'status' => '1',
'expires_at' => self::$timestamp
]
]);
DBexecute('UPDATE token SET created_at=1609452001');
// Update token "Last accessed" timestamp to be different for each token.
$i = 1;
foreach ($response['tokenids'] as $tokenid) {
DBexecute('UPDATE token SET lastaccess='.(1609452001+$i).' WHERE tokenid='.$tokenid);
$i++;
}
}
public function testPageApiTokensUserSettings_Layout() {
$token_data = [
[
'Name' => 'Aktīvs токен - 頑張って',
'Expires at' => 'Never',
'Created at' => '2021-01-01 00:00:01',
'Last accessed at' => '2021-01-01 00:00:04',
'Status' => 'Disabled'
],
[
'Name' => 'Expired token for admin',