'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() { $tokenids = $this->getInput('tokenids'); $result = API::Token()->delete($tokenids); $deleted = count($tokenids); $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 deleted', 'API tokens deleted', $deleted)); } else { CMessageHelper::setErrorTitle(_n('Cannot delete API token', 'Cannot delete API tokens', $deleted)); } $this->setResponse($response); } }