X-Git-Url: http://git.pk910.de/?p=ZNCAdmin.git;a=blobdiff_plain;f=zncadmin%2FZNCServerV1.class.php;fp=zncadmin%2FZNCServerV1.class.php;h=a40f0c6658125d5424139f5b2766e35c6cb2cb44;hp=674d612cfa091988d5f30a7cd21f6284b96a7bbd;hb=5d0acf341f782d1b99a571a88334dda3259e9d36;hpb=20cd7f168efc290245a261ce8f916d4619897998 diff --git a/zncadmin/ZNCServerV1.class.php b/zncadmin/ZNCServerV1.class.php index 674d612..a40f0c6 100644 --- a/zncadmin/ZNCServerV1.class.php +++ b/zncadmin/ZNCServerV1.class.php @@ -183,52 +183,34 @@ class ZNCServerV1 { } private function parseHTMLFields($html, &$post) { - preg_match_all("]*)>", $html, $matches); - foreach($matches[0] as $input) { - $fields = array(0 => ""); - $esc = false; $str = false; - $fieldid = 0; - for($i = 0; $i < strlen($input); $i++) { - if($esc) { - $esc = false; - $fields[$fieldid] .= $input[$i]; - continue; - } - if($input[$i] == "\\") { - $esc = true; - } - if($input[$i] == "\"") { - $str = !$str; - continue; - } - if($input[$i] == " " && !$str) { - $fields[++$fieldid] = ""; - continue; - } - $fields[$fieldid] .= $input[$i]; - } - $cfields = array(); - foreach($fields as $field) { - $fieldexp = explode("=", $field, 2); - if(count($fieldexp) != 2) continue; - $cfields[$fieldexp[0]] = $fieldexp[1]; - } - $name = $cfields['name']; - switch($cfields['type']) { + preg_match_all("##", $html, $matches); + foreach($matches[1] as $input) { + if(preg_match("#name=\"(.*?)\"#", $input, $match)) + $name = $match[1]; + else + $name = null; + if(preg_match("#type=\"(.*?)\"#", $input, $match)) + $type = $match[1]; + else + $type = null; + if(preg_match("#value=\"(.*?)\"#", $input, $match)) + $value = $match[1]; + else + $value= null; + switch($type) { case "text": case "hidden": - $value = $cfields['value']; break; case "checkbox": - if($cfields['checked']) { - $value = ($cfields['value'] ? $cfields['value'] : "1"); + if(preg_match("# checked=#", $input, $match)) { + $value = ($value ? $value : "1"); } else $value = null; break; default: $value = null; } - if($name && $value) { + if($name && $value !== null) { if(array_key_exists($name, $post)) { if(!is_array($post[$name])) { $cvalue = $post[$name]; @@ -336,9 +318,6 @@ class ZNCServerV1 { public function blockZNC($username, $block) { $html = $this->connector->get("http://".$this->host.":".$this->port."/mods/global/webadmin/edituser?user=".$username); - $handle = fopen('/home/srvx/neonserv/log.txt', 'a'); - fwrite($handle, "$html\r\n"); - fclose($handle); if(preg_match("/No such username/i", $html)) return ERR_USER_NOT_FOUND; $post = array(); $post['user'] = $username; @@ -399,6 +378,45 @@ class ZNCServerV1 { $this->connector->post("http://".$this->host.":".$this->port."/mods/global/webadmin/addchan?user=".$username.'&network=default', $post); } + public function getUserInfo($username, $loadNetInfos = false) { + $html = $this->connector->get("http://".$this->host.":".$this->port."/mods/global/webadmin/edituser?user=".$username); + if(preg_match("/No such username/i", $html)) return false; + $info = array(); + $info['loadmod'] = array(); + $this->parseHTMLFields($html, $info); + + { // parse network list + $info['networks'] = array(); + $netlist = explode("

Networks

", $html); + $netlist = explode("", $netlist[1], 2); + $netlist = explode("", $netlist[1], 2); + $netlist = explode("", $netlist[0]); + foreach($netlist as $net) { + if(preg_match_all("#(.*?)#sm", $net, $matches)) { + $network = array(); + $network['name'] = $matches[1][1]; + $network['clients'] = $matches[1][2]; + $network['server'] = $matches[1][3]; + $network['nick'] = $matches[1][4]; + + if($loadNetInfos) { + $html2 = $this->connector->get("http://".$this->host.":".$this->port."/mods/global/webadmin/editnetwork?user=".$username."&network=".$network['name']); + if(!preg_match("/No such username/i", $html2)) { + $settings = array(); + $settings['loadmod'] = array(); + $this->parseHTMLFields($html2, $settings); + $network['settings'] = $settings; + } + } + + $info['networks'][] = $network; + } + } + } + + return $info; + } + } ?> \ No newline at end of file