disableSIDValidation(); } protected function checkInput() { $fields = [ 'proxyid' => 'db hosts.hostid', 'host' => 'db hosts.host', 'status' => 'db hosts.status |in '.HOST_STATUS_PROXY_ACTIVE.','.HOST_STATUS_PROXY_PASSIVE, 'interfaceid' => 'db interface.interfaceid', 'dns' => 'db interface.dns', 'ip' => 'db interface.ip', 'useip' => 'db interface.useip |in 0,1', 'port' => 'db interface.port', 'proxy_address' => 'db hosts.proxy_address', 'description' => 'db hosts.description', 'tls_connect' => 'db hosts.tls_connect |in '.HOST_ENCRYPTION_NONE.','.HOST_ENCRYPTION_PSK.','. HOST_ENCRYPTION_CERTIFICATE, 'tls_accept' => 'db hosts.tls_accept |in 0,'.HOST_ENCRYPTION_NONE.','.HOST_ENCRYPTION_PSK.','. (HOST_ENCRYPTION_NONE | HOST_ENCRYPTION_PSK).','. HOST_ENCRYPTION_CERTIFICATE.','. (HOST_ENCRYPTION_NONE | HOST_ENCRYPTION_CERTIFICATE).','. (HOST_ENCRYPTION_PSK | HOST_ENCRYPTION_CERTIFICATE).','. (HOST_ENCRYPTION_NONE | HOST_ENCRYPTION_PSK | HOST_ENCRYPTION_CERTIFICATE), 'tls_psk' => 'db hosts.tls_psk', 'tls_psk_identity'=>'db hosts.tls_psk_identity', 'psk_edit_mode' => 'in 0,1', 'tls_issuer' => 'db hosts.tls_issuer', 'tls_subject' => 'db hosts.tls_subject', 'clone_proxyid' => 'db hosts.hostid', 'form_refresh' => 'int32' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse(new CControllerResponseFatal()); } return $ret; } protected function checkPermissions() { if (!$this->checkAccess(CRoleHelper::UI_ADMINISTRATION_PROXIES)) { return false; } if ($this->getInput('proxyid', 0)) { return (bool) API::Proxy()->get([ 'output' => [], 'proxyids' => $this->getInput('proxyid'), 'editable' => true ]); } return true; } protected function doAction() { // default values $data = [ 'sid' => $this->getUserSID(), 'proxyid' => 0, 'host' => '', 'status' => HOST_STATUS_PROXY_ACTIVE, 'dns' => 'localhost', 'ip' => '127.0.0.1', 'useip' => '1', 'port' => '10051', 'proxy_address' => '', 'description' => '', 'tls_accept' => HOST_ENCRYPTION_NONE, 'tls_connect' => HOST_ENCRYPTION_NONE, 'tls_psk' => '', 'tls_psk_identity' => '', 'psk_edit_mode' => 1, 'tls_issuer' => '', 'tls_subject' => '', 'form_refresh' => 0 ]; // get values from the dabatase if ($this->getInput('proxyid', 0)) { $data['proxyid'] = $this->getInput('proxyid'); $proxies = API::Proxy()->get([ 'output' => ['host', 'status', 'proxy_address', 'description', 'tls_connect', 'tls_accept', 'tls_issuer', 'tls_subject' ], 'selectInterface' => ['interfaceid', 'dns', 'ip', 'useip', 'port'], 'proxyids' => $data['proxyid'] ]); $proxy = $proxies[0]; $data['host'] = $proxy['host']; $data['status'] = $proxy['status']; $data['proxy_address'] = $proxy['proxy_address']; $data['description'] = $proxy['description']; $data['tls_accept'] = $proxy['tls_accept']; $data['tls_connect'] = $proxy['tls_connect']; $data['tls_issuer'] = $proxy['tls_issuer']; $data['tls_subject'] = $proxy['tls_subject']; if ($data['status'] == HOST_STATUS_PROXY_PASSIVE) { $data['interfaceid'] = $proxy['interface']['interfaceid']; $data['dns'] = $proxy['interface']['dns']; $data['ip'] = $proxy['interface']['ip']; $data['useip'] = $proxy['interface']['useip']; $data['port'] = $proxy['interface']['port']; } if ($proxy['tls_connect'] == HOST_ENCRYPTION_PSK || ($proxy['tls_accept'] & HOST_ENCRYPTION_PSK)) { $data['psk_edit_mode'] = 0; } } // overwrite with input variables $data['host'] = $this->getInput('host', $data['host']); $data['status'] = $this->getInput('status', $data['status']); $data['dns'] = $this->getInput('dns', $data['dns']); $data['ip'] = $this->getInput('ip', $data['ip']); $data['useip'] = $this->getInput('useip', $data['useip']); $data['port'] = $this->getInput('port', $data['port']); $data['proxy_address'] = $this->getInput('proxy_address', $data['proxy_address']); $data['description'] = $this->getInput('description', $data['description']); $data['tls_accept'] = $this->getInput('tls_accept', $data['tls_accept']); $data['tls_connect'] = $this->getInput('tls_connect', $data['tls_connect']); $data['tls_psk_identity'] = $this->getInput('tls_psk_identity', ''); $data['tls_psk'] = $this->getInput('tls_psk', ''); $data['psk_edit_mode'] = $this->getInput('psk_edit_mode', $data['psk_edit_mode']); $data['tls_issuer'] = $this->getInput('tls_issuer', $data['tls_issuer']); $data['tls_subject'] = $this->getInput('tls_subject', $data['tls_subject']); $data['form_refresh'] = $this->getInput('form_refresh', $data['form_refresh']); if ($data['status'] == HOST_STATUS_PROXY_PASSIVE && $this->hasInput('interfaceid')) { $data['interfaceid'] = $this->getInput('interfaceid'); } if (!$data['proxyid'] && $this->hasInput('clone_proxyid')) { $data['clone_proxyid'] = $this->getInput('clone_proxyid'); } $response = new CControllerResponseData($data); $response->setTitle(_('Configuration of proxies')); $this->setResponse($response); } }