case "OM":
$this->recv_mode($from, $arguments);
break;
+ case "AC":
+ $this->recv_account($from, $arguments);
+ break;
+ case "FA":
+ $this->recv_fakehost($from, $arguments);
+ break;
+ case "NFH":
+ $this->recv_newfakehost($from, $arguments);
+ break;
//default
default:
//unknown cmd
$channel->setCreateTime($create_time);
$modes = $channel->getModes();
$userstr = $args[count($args)-1];
- $modeparamcount = count($args)-3;
if($userstr[0] == "%") {
//ban list
$banlist = explode(" ", substr($userstr, 1));
//TODO: save bans
}
$userstr = $args[count($args)-2];
- $modeparamcount--;
}
if($userstr[0] == "+") { //MODE String
- $modeparamcount++;
$userstr = "";
}
$users = explode(",",$userstr);
if($user == "") continue;
$uexp = explode(":", $user);
if(strlen($uexp[0]) != 5) {
- trigger_error("burst parse error: '".$uexp[0]."' is not an user numeric.", E_USER_ERROR);
- return;
+ trigger_error("burst parse error: '".$uexp[0]."' is not an user numeric.", E_USER_WARNING);
+ break;
}
if(count($uexp) > 1) {
$isop = false;
if($this->eventHandler)
$this->eventHandler->event_join($user, $channel, true);
}
- $modes->parseModes(implode(" ", array_slice($args, 2, $modeparamcount)));
+ $modestr = array_slice($args, 2);
+ if($modestr[0] == "+")
+ $modes->parseModes(implode(" ", $modestr));
}
private function recv_join($from, $args) {
private function recv_mode($from, $args) {
$user = P10_User::getUserByNum($from);
- if($user == null) {
+ if($user == null && strlen($from) != 2) {
trigger_error("Server tries to send a modechange from an user that does not exist or was not found on recv_mode.", E_USER_ERROR);
return;
}
if($channel == null)
$channel = new P10_Channel($args[0]);
$channel->getModes()->setModes($modes);
- if($this->eventHandler)
+ if($this->eventHandler && strlen($from) != 2)
$this->eventHandler->event_chanmode($user, $channel, $modes);
} else {
$targetUser = P10_User::getUserByNick($args[0]);
$this->eventHandler->event_usermode($targetUser, $modes);
}
}
+
+ private function recv_account($from, $args) {
+ $user = P10_User::getUserByNum($args[0]);
+ if($user == null) {
+ trigger_error("Server tries to send an auth announce from an user that does not exist or was not found on recv_account.", E_USER_ERROR);
+ return;
+ }
+ $auth = $args[1];
+ $user->getModes()->setModes("+r ".$auth);
+ if($this->eventHandler)
+ $this->eventHandler->event_usermode($user, "+r ".$auth);
+ }
+
+ private function recv_fakehost($from, $args) {
+ $user = P10_User::getUserByNum($args[0]);
+ if($user == null) {
+ trigger_error("Server tries to send a fakehost change from an user that does not exist or was not found on recv_fakehost.", E_USER_ERROR);
+ return;
+ }
+ $fakehost = $args[1];
+ $user->getModes()->setModes("+f ".$fakehost);
+ if($this->eventHandler)
+ $this->eventHandler->event_usermode($user, "+f ".$fakehost);
+ }
+
+ private function recv_newfakehost($from, $args) {
+ $user = P10_User::getUserByNum($args[0]);
+ if($user == null) {
+ trigger_error("Server tries to send a fakehost change from an user that does not exist or was not found on recv_fakehost.", E_USER_ERROR);
+ return;
+ }
+ $fakeident = $args[1];
+ $fakehost = $args[2];
+ $user->setIdent($fakeident);
+ $user->getModes()->setModes("+f ".$fakehost);
+ if($this->eventHandler)
+ $this->eventHandler->event_usermode($user, "+f ".$fakehost);
+ }
/********************************************************************************************
* SERVER FUNCTIONS *