'required|array_db token.tokenid', 'action_src' => 'required|in token.list,user.token.list' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse(new CControllerResponseFatal()); } return $ret; } protected function checkPermissions() { if (CWebUser::isGuest()) { return false; } return $this->checkAccess(CRoleHelper::ACTIONS_MANAGE_API_TOKENS); } protected function doAction() { $tokens = []; foreach ($this->getInput('tokenids') as $tokenid) { $tokens[] = ['tokenid' => $tokenid, 'status' => ZBX_AUTH_TOKEN_DISABLED]; } $result = API::Token()->update($tokens); $updated = count($tokens); $response = new CControllerResponseRedirect((new CUrl('zabbix.php')) ->setArgument('action', $this->getInput('action_src')) ->setArgument('page', CPagerHelper::loadPage($this->getInput('action_src'), null)) ); if ($result) { $response->setFormData(['uncheck' => '1']); CMessageHelper::setSuccessTitle(_n('API token disabled', 'API tokens disabled', $updated)); } else { CMessageHelper::setErrorTitle(_n('Cannot disable API token', 'Cannot disable API tokens', $updated)); } $this->setResponse($response); } }