} elseif ( $params['rights'] ) {
$excludeGroups = false;
foreach ( $params['rights'] as $r ) {
- $limitGroups = array_merge( $limitGroups, User::getGroupsWithPermission( $r ) );
+ $limitGroups = array_merge( $limitGroups, $this->getPermissionManager()
+ ->getGroupsWithPermission( $r ) );
}
// If no group has the rights requested, no need to query
} elseif ( $params['excluderights'] ) {
$excludeGroups = true;
foreach ( $params['excluderights'] as $r ) {
- $limitGroups = array_merge( $limitGroups, User::getGroupsWithPermission( $r ) );
+ $limitGroups = array_merge( $limitGroups, $this->getPermissionManager()
+ ->getGroupsWithPermission( $r ) );
}
}
$limitGroups = array_unique( $limitGroups );
$this->addTables( 'user_groups' );
$this->addJoinConds( [ 'user_groups' => [
- $excludeGroups ? 'LEFT OUTER JOIN' : 'INNER JOIN',
+ $excludeGroups ? 'LEFT JOIN' : 'JOIN',
[
'ug_user=' . $revQuery['fields']['rev_user'],
'ug_group' => $limitGroups,
public function getAllowedParams() {
$userGroups = User::getAllGroups();
- $userRights = User::getAllRights();
+ $userRights = $this->getPermissionManager()->getAllPermissions();
return [
'group' => [