X-Git-Url: http://git.pk910.de/?p=PHP-P10.git;a=blobdiff_plain;f=Uplink%2FP10_ModeSets.class.php;h=2515984924327babca14a522a77257a370b95b01;hp=264a53f94d7c86f711b25f6be3f80a37810937fa;hb=811bc0c7a1f583fb624a0f8c3601146e063c5a25;hpb=455040407c031d33129808462d42414c577863b4 diff --git a/Uplink/P10_ModeSets.class.php b/Uplink/P10_ModeSets.class.php index 264a53f..2515984 100644 --- a/Uplink/P10_ModeSets.class.php +++ b/Uplink/P10_ModeSets.class.php @@ -1,22 +1,19 @@ . * * * ************************************************************************ * @@ -70,9 +67,11 @@ class P10_ChannelModeSet { "d" => self::MODE_TYPE_D, "R" => self::MODE_TYPE_D, "z" => self::MODE_TYPE_D, + "S" => self::MODE_TYPE_D, //special behavior "o" => self::MODE_TYPE_B, + "h" => self::MODE_TYPE_B, "v" => self::MODE_TYPE_B ); private static $modevalues = null; @@ -108,9 +107,9 @@ class P10_ChannelModeSet { continue; } $flag = self::$modevalues[$mode]; - if(self::$modevalues[$mode] == self::MODE_TYPE_A) continue; //we shouldn't get such a mode on parseModes + if(self::$modes[$mode] == self::MODE_TYPE_A) continue; //we shouldn't get such a mode on parseModes $this->modeflags |= $flag; - if(self::$modevalues[$mode] == self::MODE_TYPE_B || self::$modevalues[$mode] == self::MODE_TYPE_C) { + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { $this->modeparams[$mode] = $args[$c++]; } } @@ -139,7 +138,7 @@ class P10_ChannelModeSet { trigger_error("unknown mode (".$mode.") on setModes (".$modes.").", E_USER_WARNING); continue; } - if($mode == "o" || $mode == "v") { + if($mode == "o" || $mode == "h" || $mode == "v") { if($this->setPrivs($add, $mode, $args[$c++])) { if($returndiff && $add) { $modestradd .= $mode; @@ -150,31 +149,42 @@ class P10_ChannelModeSet { } } continue; + } else if($mode == "b") { + if($this->handleBan($add, $mode, $args[$c++])) { + if($returndiff && $add) { + $modestradd .= $mode; + $paramstradd .= " ".$args[$c-1]; + } else if($returndiff && !$add) { + $modestrdel .= $mode; + $paramstrdel .= " ".$args[$c-1]; + } + } + continue; } $flag = self::$modevalues[$mode]; if($add) { if($returndiff && !($this->modeflags & $flag)) { $modestradd .= $mode; - if(self::$modevalues[$mode] == self::MODE_TYPE_B || self::$modevalues[$mode] == self::MODE_TYPE_C) { + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { $paramstradd .= " ".$args[$c]; } } $this->modeflags |= $flag; - if(self::$modevalues[$mode] == self::MODE_TYPE_B || self::$modevalues[$mode] == self::MODE_TYPE_C) { + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { $this->modeparams[$mode] = $args[$c++]; } } else { if($returndiff && ($this->modeflags & $flag)) { $modestrdel .= $mode; - if(self::$modevalues[$mode] == self::MODE_TYPE_C) { + if(self::$modes[$mode] == self::MODE_TYPE_C) { $paramstrdel .= " ".$args[$c]; } } $this->modeflags &= ~$flag; - if(self::$modevalues[$mode] == self::MODE_TYPE_B || self::$modevalues[$mode] == self::MODE_TYPE_C) { + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { unset($this->modeparams[$mode]); } - if(self::$modevalues[$mode] == self::MODE_TYPE_C) $c++; + if(self::$modes[$mode] == self::MODE_TYPE_C) $c++; } } if($returndiff) { @@ -185,6 +195,11 @@ class P10_ChannelModeSet { } } + private function handleBan($add, $mode, $mask) { + //no ban management right now... + return true; + } + private function setPrivs($add, $mode, $user) { $user = P10_User::getUserByNum($user); if($user == null) { @@ -194,6 +209,7 @@ class P10_ChannelModeSet { $privs = $this->channel->getUserPrivs($user); $privFlag = 0; if($mode == "o") $privFlag = P10_Channel::USERPRIV_OPED; + if($mode == "h") $privFlag = P10_Channel::USERPRIV_HALFOP; if($mode == "v") $privFlag = P10_Channel::USERPRIV_VOICE; if(!($add xor ($privs & $privFlag))) return false; @@ -210,7 +226,7 @@ class P10_ChannelModeSet { foreach(self::$modevalues as $mode => $flag) { if(($this->modeflags & $flag)) { $modestr .= $mode; - if(self::$modevalues[$mode] == self::MODE_WITH_PARAMETER) { + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { $paramstr .= " ".$this->modeparams[$mode]; } } @@ -218,6 +234,18 @@ class P10_ChannelModeSet { return $modestr.$paramstr; } + public function hasMode($mode) { + if(!array_key_exists($mode, self::$modevalues)) { + trigger_error("unknown mode (".$mode.") on setModes (".$modes.").", E_USER_WARNING); + continue; + } + $flag = self::$modevalues[$mode]; + if(self::$modes[$mode] == self::MODE_TYPE_B || self::$modes[$mode] == self::MODE_TYPE_C) { + return (($this->modeflags & $flag) ? $this->modeparams[$mode] : false); + } else + return ($this->modeflags & $flag); + } + } class P10_UserModeSet { @@ -230,7 +258,7 @@ class P10_UserModeSet { "s" => self::MODE_WITHOUT_PARAMETER, "d" => self::MODE_WITHOUT_PARAMETER, "k" => self::MODE_WITHOUT_PARAMETER, - "g" => self::MODE_WITH_PARAMETER, + "g" => self::MODE_WITHOUT_PARAMETER, "r" => self::MODE_WITH_PARAMETER, "f" => self::MODE_WITH_PARAMETER, "n" => self::MODE_WITHOUT_PARAMETER, @@ -277,7 +305,7 @@ class P10_UserModeSet { } $flag = self::$modevalues[$mode]; $this->modeflags |= $flag; - if(self::$modevalues[$mode] == self::MODE_WITH_PARAMETER) { + if(self::$modes[$mode] == self::MODE_WITH_PARAMETER) { $this->modeparams[$mode] = $args[$c++]; } } @@ -308,12 +336,12 @@ class P10_UserModeSet { if($add) { if($returndiff && !($this->modeflags & $flag)) { $modestradd .= $mode; - if(self::$modevalues[$mode] == self::MODE_WITH_PARAMETER) { + if(self::$modes[$mode] == self::MODE_WITH_PARAMETER) { $paramstradd .= " ".$args[$c]; } } $this->modeflags |= $flag; - if(self::$modevalues[$mode] == self::MODE_WITH_PARAMETER) { + if(self::$modes[$mode] == self::MODE_WITH_PARAMETER) { $this->modeparams[$mode] = $args[$c++]; } } else { @@ -337,7 +365,7 @@ class P10_UserModeSet { foreach(self::$modevalues as $mode => $flag) { if(($this->modeflags & $flag)) { $modestr .= $mode; - if(self::$modevalues[$mode] == self::MODE_WITH_PARAMETER) { + if(self::$modes[$mode] == self::MODE_WITH_PARAMETER) { $paramstr .= " ".$this->modeparams[$mode]; } } @@ -345,6 +373,18 @@ class P10_UserModeSet { return $modestr.$paramstr; } + public function hasMode($mode) { + if(!array_key_exists($mode, self::$modevalues)) { + trigger_error("unknown mode (".$mode.") on setModes (".$modes.").", E_USER_WARNING); + continue; + } + $flag = self::$modevalues[$mode]; + if(self::$modes[$mode] == self::MODE_WITH_PARAMETER) { + return (($this->modeflags & $flag) ? $this->modeparams[$mode] : false); + } else + return ($this->modeflags & $flag); + } + } ?> \ No newline at end of file