. */ namespace SP\Modules\Web\Controllers; use SP\Core\Acl\ActionsInterface; use SP\Core\Acl\UnauthorizedPageException; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Http\JsonResponse; use SP\Http\Request; use SP\Modules\Web\Controllers\Traits\ConfigTrait; /** * Class ConfigGeneral * * @package SP\Modules\Web\Controllers */ class ConfigGeneralController extends SimpleControllerBase { use ConfigTrait; /** * saveAction */ public function saveAction() { $configData = $this->config->getConfigData(); $eventMessage = EventMessage::factory(); // General $siteLang = Request::analyze('sitelang'); $siteTheme = Request::analyze('sitetheme', 'material-blue'); $sessionTimeout = Request::analyze('session_timeout', 300); $httpsEnabled = Request::analyze('https_enabled', false, false, true); $debugEnabled = Request::analyze('debug', false, false, true); $maintenanceEnabled = Request::analyze('maintenance', false, false, true); $checkUpdatesEnabled = Request::analyze('updates', false, false, true); $checkNoticesEnabled = Request::analyze('notices', false, false, true); $encryptSessionEnabled = Request::analyze('encryptsession', false, false, true); $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 = Request::analyze('log_enabled', false, false, true); $syslogEnabled = Request::analyze('syslog_enabled', false, false, true); $remoteSyslogEnabled = Request::analyze('remotesyslog_enabled', false, false, true); $syslogServer = Request::analyze('remotesyslog_server'); $syslogPort = Request::analyze('remotesyslog_port', 0); $configData->setLogEnabled($logEnabled); $configData->setSyslogEnabled($syslogEnabled); if ($remoteSyslogEnabled) { if (!$syslogServer || !$syslogPort) { $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 = Request::analyze('proxy_enabled', false, false, true); $proxyServer = Request::analyze('proxy_server'); $proxyPort = Request::analyze('proxy_port', 0); $proxyUser = Request::analyze('proxy_user'); $proxyPass = Request::analyzeEncrypted('proxy_pass'); // Valores para Proxy if ($proxyEnabled && (!$proxyServer || !$proxyPort)) { $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); $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 = Request::analyze('authbasic_enabled', false, false, true); $authBasicAutologinEnabled = Request::analyze('authbasicautologin_enabled', false, false, true); $authBasicDomain = Request::analyze('authbasic_domain'); $authSsoDefaultGroup = Request::analyze('sso_defaultgroup', false, false, true); $authSsoDefaultProfile = Request::analyze('sso_defaultprofile', false, false, true); // 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')); } $this->saveConfig($configData, $this->config, function () use ($eventMessage) { $this->eventDispatcher->notifyEvent('save.config.general', new Event($this, $eventMessage)); }); } protected function initialize() { try { $this->checkAccess(ActionsInterface::CONFIG_GENERAL); } catch (UnauthorizedPageException $e) { $this->eventDispatcher->notifyEvent('exception', new Event($e)); $this->returnJsonResponseException($e); } } }