. **/ class CControllerMfaEdit extends CController { protected function init(): void { $this->disableCsrfValidation(); } protected function checkInput(): bool { $fields = [ 'mfaid' => 'db mfa.mfaid', 'type' => 'in '.MFA_TYPE_TOTP.','.MFA_TYPE_DUO, 'name' => 'db mfa.name', 'hash_function' => 'in '.TOTP_HASH_SHA1.','.TOTP_HASH_SHA256.','.TOTP_HASH_SHA512, 'code_length' => 'in '.TOTP_CODE_LENGTH_6.','.TOTP_CODE_LENGTH_8, 'api_hostname' => 'db mfa.api_hostname', 'clientid' => 'db mfa.clientid', 'client_secret' => 'db mfa.client_secret', 'add_mfa_method' => 'in 0,1' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse( (new CControllerResponseData([ 'main_block' => json_encode([ 'error' => [ 'title' => _('Invalid MFA configuration'), 'messages' => array_column(get_and_clear_messages(), 'message') ] ]) ]))->disableView() ); } return $ret; } protected function checkPermissions(): bool { return $this->checkAccess(CRoleHelper::UI_ADMINISTRATION_AUTHENTICATION); } protected function doAction(): void { $data = [ 'type' => MFA_TYPE_TOTP, 'name' => '', 'hash_function' => TOTP_HASH_SHA1, 'code_length' => TOTP_CODE_LENGTH_6, 'api_hostname' => '', 'clientid' => '', 'user' => [ 'debug_mode' => $this->getDebugMode() ], 'add_mfa_method' => 1 ]; $this->getInputs($data, array_keys($data)); if ($this->hasInput('client_secret')) { $data['client_secret'] = $this->getInput('client_secret'); } if ($this->hasInput('mfaid')) { $data['mfaid'] = $this->getInput('mfaid'); } $curl_status = (new CFrontendSetup())->checkPhpCurlModule(); $data['curl_error'] = ($curl_status['result'] == CFrontendSetup::CHECK_WARNING); $this->setResponse(new CControllerResponseData($data)); } }