. */ namespace SP\Modules\Web\Controllers; use SP\Config\ConfigUtil; use SP\Core\Acl\Acl; use SP\Core\Acl\UnauthorizedPageException; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Http\JsonResponse; use SP\Modules\Web\Controllers\Traits\ConfigTrait; /** * Class ConfigGeneral * * @package SP\Modules\Web\Controllers */ final class ConfigGeneralController extends SimpleControllerBase { use ConfigTrait; /** * saveAction */ public function saveAction() { $configData = $this->config->getConfigData(); $eventMessage = EventMessage::factory(); // General $siteLang = $this->request->analyzeString('sitelang'); $siteTheme = $this->request->analyzeString('sitetheme', 'material-blue'); $sessionTimeout = $this->request->analyzeInt('session_timeout', 300); $httpsEnabled = $this->request->analyzeBool('https_enabled', false); $debugEnabled = $this->request->analyzeBool('debug_enabled', false); $maintenanceEnabled = $this->request->analyzeBool('maintenance_enabled', false); $checkUpdatesEnabled = $this->request->analyzeBool('check_updates_enabled', false); $checkNoticesEnabled = $this->request->analyzeBool('check_notices_enabled', false); $encryptSessionEnabled = $this->request->analyzeBool('encrypt_session_enabled', false); $configData->setSiteLang($siteLang); $configData->setSiteTheme($siteTheme); $configData->setSessionTimeout($sessionTimeout); $configData->setHttpsEnabled($httpsEnabled); $configData->setDebug($debugEnabled); $configData->setMaintenance($maintenanceEnabled); $configData->setCheckUpdates($checkUpdatesEnabled); $configData->setChecknotices($checkNoticesEnabled); $configData->setEncryptSession($encryptSessionEnabled); // Events $logEnabled = $this->request->analyzeBool('log_enabled', false); $syslogEnabled = $this->request->analyzeBool('syslog_enabled', false); $remoteSyslogEnabled = $this->request->analyzeBool('remotesyslog_enabled', false); $syslogServer = $this->request->analyzeString('remotesyslog_server'); $syslogPort = $this->request->analyzeInt('remotesyslog_port', 0); $configData->setLogEnabled($logEnabled); $configData->setLogEvents($this->request->analyzeArray('log_events', function ($items) { return ConfigUtil::eventsAdapter($items); }, [])); $configData->setSyslogEnabled($syslogEnabled); if ($remoteSyslogEnabled) { if (!$syslogServer || !$syslogPort) { return $this->returnJsonResponse(JsonResponse::JSON_ERROR, __u('Faltan parámetros de syslog remoto')); } $configData->setSyslogRemoteEnabled(true); $configData->setSyslogServer($syslogServer); $configData->setSyslogPort($syslogPort); if ($configData->isSyslogRemoteEnabled() === false) { $eventMessage->addDescription(__u('Syslog remoto habilitado')); } } elseif ($remoteSyslogEnabled === false && $configData->isSyslogEnabled()) { $configData->setSyslogRemoteEnabled(false); $eventMessage->addDescription(__u('Syslog remoto deshabilitado')); } // Proxy $proxyEnabled = $this->request->analyzeBool('proxy_enabled', false); $proxyServer = $this->request->analyzeString('proxy_server'); $proxyPort = $this->request->analyzeInt('proxy_port', 8080); $proxyUser = $this->request->analyzeString('proxy_user'); $proxyPass = $this->request->analyzeEncrypted('proxy_pass'); // Valores para Proxy if ($proxyEnabled && (!$proxyServer || !$proxyPort)) { return $this->returnJsonResponse(JsonResponse::JSON_ERROR, __u('Faltan parámetros de Proxy')); } if ($proxyEnabled) { $configData->setProxyEnabled(true); $configData->setProxyServer($proxyServer); $configData->setProxyPort($proxyPort); $configData->setProxyUser($proxyUser); if ($proxyPass !== '***') { $configData->setProxyPass($proxyPass); } if ($configData->isProxyEnabled() === false) { $eventMessage->addDescription(__u('Proxy habiltado')); } } elseif ($proxyEnabled === false && $configData->isProxyEnabled()) { $configData->setProxyEnabled(false); $eventMessage->addDescription(__u('Proxy deshabilitado')); } // Autentificación $authBasicEnabled = $this->request->analyzeBool('authbasic_enabled', false); $authBasicAutologinEnabled = $this->request->analyzeBool('authbasicautologin_enabled', false); $authBasicDomain = $this->request->analyzeString('authbasic_domain'); $authSsoDefaultGroup = $this->request->analyzeInt('sso_defaultgroup'); $authSsoDefaultProfile = $this->request->analyzeInt('sso_defaultprofile'); // Valores para Autentificación if ($authBasicEnabled) { $configData->setAuthBasicEnabled(true); $configData->setAuthBasicAutoLoginEnabled($authBasicAutologinEnabled); $configData->setAuthBasicDomain($authBasicDomain); $configData->setSsoDefaultGroup($authSsoDefaultGroup); $configData->setSsoDefaultProfile($authSsoDefaultProfile); if ($configData->isAuthBasicEnabled() === false) { $eventMessage->addDescription(__u('Auth Basic habilitada')); } } elseif ($authBasicEnabled === false && $configData->isAuthBasicEnabled()) { $configData->setAuthBasicEnabled(false); $configData->setAuthBasicAutoLoginEnabled(false); $eventMessage->addDescription(__u('Auth Basic deshabiltada')); } return $this->saveConfig($configData, $this->config, function () use ($eventMessage) { $this->eventDispatcher->notifyEvent('save.config.general', new Event($this, $eventMessage)); }); } /** * @return bool */ protected function initialize() { try { $this->checks(); $this->checkAccess(Acl::CONFIG_GENERAL); } catch (UnauthorizedPageException $e) { $this->eventDispatcher->notifyEvent('exception', new Event($e)); return $this->returnJsonResponseException($e); } } }