Source
<?php declare(strict_types = 0);
/*
** 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 Affero General Public License as published by the Free Software Foundation, version 3.
**
** 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 Affero General Public License for more details.
**
** You should have received a copy of the GNU Affero General Public License along with this program.
** If not, see <https://www.gnu.org/licenses/>.
**/
class CControllerTokenCreate extends CController {
protected function init() {
$this->setPostContentType(self::POST_CONTENT_TYPE_JSON);
}
protected function checkInput() {
$fields = [
'name' => 'db token.name|required|not_empty',
'description' => 'db token.description',
'userid' => 'db users.userid|required',
'expires_state' => 'in 0,1|required',
'expires_at' => 'abs_time',
'status' => 'db token.status|required|in ' . ZBX_AUTH_TOKEN_ENABLED . ',' . ZBX_AUTH_TOKEN_DISABLED,
'admin_mode' => 'required|in 0,1'
];
$ret = $this->validateInput($fields);
if ($ret) {
$fields = [];
if ($this->getInput('expires_state') == 1) {
$fields['expires_at'] = 'required';
}
if ($fields) {
$validator = new CNewValidator($this->getInputAll(), $fields);
foreach ($validator->getAllErrors() as $error) {
info($error);
}
if ($validator->isErrorFatal() || $validator->isError()) {
$ret = false;
}
}
}
if (!$ret) {
$this->setResponse(
new CControllerResponseData(['main_block' => json_encode([
'error' => [
'title' => _('Cannot add API token'),
'messages' => array_column(get_and_clear_messages(), 'message')
]
])])