setPostContentType(self::POST_CONTENT_TYPE_JSON); } protected function checkInput() { $fields = [ 'tokenids' => 'required|array_db token.tokenid' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse( new CControllerResponseData(['main_block' => json_encode([ 'error' => [ 'messages' => array_column(get_and_clear_messages(), 'message') ] ])]) ); } 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); $output = []; if ($result) { $output['success']['title'] = _n('API token deleted', 'API tokens deleted', count($tokenids)); if ($messages = get_and_clear_messages()) { $output['success']['messages'] = array_column($messages, 'message'); } } else { $output['error'] = [ 'title' => _n('Cannot delete API token', 'Cannot delete API tokens', count($tokenids)), 'messages' => array_column(get_and_clear_messages(), 'message') ]; $tokens = API::Token()->get([ 'output' => [], 'tokenids' => $tokenids, 'preservekeys' => true ]); $output['keepids'] = array_keys($tokens); } $this->setResponse(new CControllerResponseData(['main_block' => json_encode($output)])); } }