X-Git-Url: http://git.pk910.de/?p=PHP-P10.git;a=blobdiff_plain;f=Bots%2FPHPGod.class.php;h=e0ee13ef4709d1969a283549e59811d5e2639d0f;hp=5fc4b873a81436721892bd1afb32a90b7f9d3f15;hb=7f51193ddac01b0540000c756c50167ff015e02a;hpb=5cb4a51d7eee716c108e7071e0de392b4c512a57 diff --git a/Bots/PHPGod.class.php b/Bots/PHPGod.class.php index 5fc4b87..e0ee13e 100644 --- a/Bots/PHPGod.class.php +++ b/Bots/PHPGod.class.php @@ -1,12 +1,10 @@ . * * * ************************************************************************ - * + * * Bots/PHPGod.class.php * * simple PHP debugger... @@ -28,8 +25,8 @@ class {$_NAME} extends Bot { private $uplink; - private $php, $phpcache; - + private $php, $phpcache = array(); + public function load($uplink, $old = false) { $this->uplink = $uplink; if(!$old) { @@ -43,17 +40,18 @@ class {$_NAME} extends Bot { if(is_a($this->php, "P10_User")) { $this->uplink->join($this->php, "#php", (P10_Channel::USERPRIV_OPED | P10_Channel::USERPRIV_VOICE)); $this->uplink->join($this->php, "#dev", P10_Channel::USERPRIV_VOICE); + $this->uplink->join($this->php, "#CoderCom", P10_Channel::USERPRIV_VOICE); } } else { $this->php = $old; } - + ModCMD::bind($this, BIND_CHANMSG, "recive_privmsg"); ModCMD::bind($this, BIND_QUIT, "recive_quit"); } - + public function unload($rehash = false) { - foreach($this->phpcache as $id => &$php) { + foreach($this->phpcache as $id => $php) { fclose($php['pipes'][1]); fclose($php['pipes'][2]); proc_terminate($php['proc'],9); @@ -65,15 +63,15 @@ class {$_NAME} extends Bot { $this->uplink->delUser($this->php, "Bye."); } } - + public function loop() { - foreach($this->phpcache as $id => &$php) { - if(!$this->checkstate(&$php)) { + foreach($this->phpcache as $id => $php) { + if(!$this->checkstate($php)) { unset($this->phpcache[$id]); } } } - + function recive_privmsg($user, $channel, $message) { $opOnPHPChannel = false; $PHPChannel = P10_Channel::getChannelByName("#PHP"); @@ -82,7 +80,7 @@ class {$_NAME} extends Bot { $opOnPHPChannel = ($privs & P10_Channel::USERPRIV_OPED); } if(!$user->getModes()->hasMode('o') && !$opOnPHPChannel) return 0; - $exp=explode(" ",$message); + $exp=explode(" ", $message, 2); switch (strtolower($exp[0])) { case "~php": if(count($this->phpcache) > 5) { @@ -98,19 +96,31 @@ class {$_NAME} extends Bot { return; } $entry['time'] = time(); - fwrite($entry['pipes'][0], "<"."?php ".$exp[1]." ?".">"); + if(preg_match("#pastebin\.com/([a-zA-Z0-9]*)$#i", $exp[1])) { + $pasteid = explode("/", $exp[1]); + $pasteid = $pasteid[count($pasteid)-1]; + $codecontent = file_get_contents("http://pastebin.com/download.php?i=".$pasteid); + if(preg_match("#Unknown Paste ID!#i", $codecontent)) { + $this->uplink->notice($this->bot, $user, "Unknown Paste ID!"); + return; + } + $code = $codecontent; + } else { + $code = "<"."?php " . $exp[1] . " ?".">"; + }; + fwrite($entry['pipes'][0], $code); fclose($entry['pipes'][0]); $this->phpcache[] = $entry; break; } } - + function recive_quit($user, $reason) { - if($user === $this->modman) { + if($user === $this->php) { $this->load($this->uplink); } } - + function checkstate($php) { $data = proc_get_status($php['proc']); if(!$data['running']) { @@ -130,7 +140,7 @@ class {$_NAME} extends Bot { $i++; if($i>1000) { $this->uplink->privmsg($this->php, $php['channel'], "too many lines!"); - break; + break; } $this->uplink->privmsg($this->php, $php['channel'], $line); } @@ -141,9 +151,9 @@ class {$_NAME} extends Bot { $i=0; foreach($lines as $line) { $i++; - if($i>1000) { + if($i>1000) { $this->uplink->privmsg($this->php, $php['channel'], "too many lines!"); - break; + break; } $this->uplink->privmsg($this->php, $php['channel'], "4".$line.""); } @@ -166,13 +176,13 @@ class {$_NAME} extends Bot { } else { proc_terminate($php['proc']); $php['term']=true; - $this->uplink->privmsg($this->php, $php['channel'], "php timeout. (maximum of 10 seconds exceeded) sending SIGTERM"); + $this->uplink->privmsg($this->php, $php['channel'], "php timeout. (maximum of 10 seconds exceeded) sending SIGTERM"); return true; } } } } - + } ?> \ No newline at end of file