Merge pull request #1506 from PEMapModder/master

Multiple permissions checked in Server::getInstance()
This commit is contained in:
Shoghi Cervantes 2014-06-17 16:15:39 +02:00
commit 552c934486

View File

@ -1476,20 +1476,23 @@ class Server{
/** /**
* @param string $message * @param string $message
* @param string $permission * @param string $permissions
* *
* @return int * @return int
*/ */
public function broadcast($message, $permission){ public function broadcast($message, $permissions){
$count = 0; $recipients = [];
foreach(explode(";", $permissions) as $permission){
foreach($this->pluginManager->getPermissionSubscriptions($permission) as $permissible){ foreach($this->pluginManager->getPermissionSubscriptions($permission) as $permissible){
if($permissible instanceof CommandSender and $permissible->hasPermission($permission)){ if($permissible instanceof CommandSender and $permissible->hasPermission($permission)){
$permissible->sendMessage($message); $recipients[spl_object_hash($permissible)] = $permissible; // do not send messages directly, or some might be repeated
++$count;
} }
} }
}
return $count; foreach($recipients as $recipient){
$recipient->sendMessage($message);
}
return count($recipients);
} }
/** /**