. */ namespace SP\Modules\Web\Controllers; use SP\Core\Acl\ActionsInterface; use SP\Core\Acl\UnauthorizedPageException; use SP\Core\Events\Event; use SP\Core\Exceptions\SPException; use SP\Http\JsonResponse; use SP\Http\Request; use SP\Modules\Web\Controllers\Traits\ConfigTrait; /** * Class ConfigLdapController * * @package SP\Modules\Web\Controllers */ class ConfigLdapController extends SimpleControllerBase { use ConfigTrait; /** * @throws \SP\Core\Exceptions\InvalidArgumentException */ public function saveAction() { $messages = []; $configData = clone $this->config->getConfigData(); // LDAP $ldapEnabled = Request::analyze('ldap_enabled', false, false, true); $ldapADSEnabled = Request::analyze('ldap_ads', false, false, true); $ldapServer = Request::analyze('ldap_server'); $ldapBase = Request::analyze('ldap_base'); $ldapGroup = Request::analyze('ldap_group'); $ldapDefaultGroup = Request::analyze('ldap_defaultgroup', 0); $ldapDefaultProfile = Request::analyze('ldap_defaultprofile', 0); $ldapBindUser = Request::analyze('ldap_binduser'); $ldapBindPass = Request::analyzeEncrypted('ldap_bindpass'); // Valores para la configuración de LDAP if ($ldapEnabled && (!$ldapServer || !$ldapBase || !$ldapBindUser)) { $this->returnJsonResponse(JsonResponse::JSON_ERROR, __u('Faltan parámetros de LDAP')); } if ($ldapEnabled) { $configData->setLdapEnabled(true); $configData->setLdapAds($ldapADSEnabled); $configData->setLdapServer($ldapServer); $configData->setLdapBase($ldapBase); $configData->setLdapGroup($ldapGroup); $configData->setLdapDefaultGroup($ldapDefaultGroup); $configData->setLdapDefaultProfile($ldapDefaultProfile); $configData->setLdapBindUser($ldapBindUser); $configData->setLdapBindPass($ldapBindPass); $messages[] = __u('LDAP habiltado'); } elseif ($configData->isLdapEnabled()) { $configData->setLdapEnabled(false); $messages[] = __u('LDAP deshabilitado'); } $this->eventDispatcher->notifyEvent('save.config.ldap', new Event($this, $messages)); $this->saveConfig($configData, $this->config); } protected function initialize() { try { if (!$this->checkAccess(ActionsInterface::LDAP_CONFIG)) { throw new UnauthorizedPageException(SPException::INFO); } } catch (UnauthorizedPageException $e) { $this->returnJsonResponseException($e); } } }