disableCsrfValidation(); } protected function checkInput() { $fields = [ 'name' => 'db dashboard_page.name', 'dashboard_display_period' => 'required|db dashboard.display_period|in '.implode(',', DASHBOARD_DISPLAY_PERIODS), 'display_period' => 'db dashboard_page.display_period|in '.implode(',', array_merge([0], DASHBOARD_DISPLAY_PERIODS)), 'unique_id' => 'string' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse( (new CControllerResponseData(['main_block' => json_encode([ 'error' => [ 'messages' => array_column(get_and_clear_messages(), 'message') ] ])]))->disableView() ); } return $ret; } protected function checkPermissions() { if ($this->hasInput('template')) { return $this->getUserType() >= USER_TYPE_ZABBIX_ADMIN; } else { return $this->checkAccess(CRoleHelper::UI_MONITORING_DASHBOARD) && $this->checkAccess(CRoleHelper::ACTIONS_EDIT_DASHBOARDS); } } protected function doAction() { $data = [ 'dashboard' => [ 'display_period' => (int) $this->getInput('dashboard_display_period') ], 'dashboard_page' => [ 'name' => $this->getInput('name', DB::getDefault('dashboard_page', 'name')), 'display_period' => (int) $this->getInput('display_period', DB::getDefault('dashboard_page', 'display_period') ), 'unique_id' => $this->hasInput('unique_id') ? $this->getInput('unique_id') : null ], 'user' => [ 'debug_mode' => $this->getDebugMode() ] ]; $this->setResponse(new CControllerResponseData($data)); } }