X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=ModCMD%2FBinding.class.php;h=ed980c0219e8997b1388e80e1b1eca17a174ad16;hb=56db0f2b9479259c23ef03661d10ab8b18c5ea41;hp=7dc0d79567d82eb96b4b91f6b20bb7734c9ba248;hpb=0f30e96ae37491aee19e72b89cc54a6798d1f254;p=PHP-P10.git diff --git a/ModCMD/Binding.class.php b/ModCMD/Binding.class.php index 7dc0d79..ed980c0 100644 --- a/ModCMD/Binding.class.php +++ b/ModCMD/Binding.class.php @@ -26,20 +26,31 @@ class Binding { private $bot; private $method; + private $filter; - public function __construct($bot, $method) { + public function __construct($bot, $method, $filter) { $this->bot = $bot; $this->method = $method; + $this->filter = $filter; } public function trigger($params) { call_user_func_array(array($this->bot, $this->method), $params); } - public function match($bot, $method) { - return ($bot === $this->bot && strtolower($this->method) == strtolower($method)); + public function match($bot, $method, $filter) { + return ($bot === $this->bot && (!$method || strtolower($this->method) == strtolower($method)) && (!$filter || $this->match_filter($filter, false))); } + public function match_filter($filter, $preg = true) { + if(!$this->filter) return true; + if(is_object($filter) || is_object($this->filter)) { + return $filter === $this->filter; + } else if($preg && is_string($filter && is_string($this->filter))) { + return preg_match($this->filter, $filter); + } else + return $filter == $this->filter; + } } ?> \ No newline at end of file