Fix group principal

This commit is contained in:
Thomas Müller 2016-02-10 10:43:32 +01:00
parent 2982017682
commit 2e94d34dfd
2 changed files with 24 additions and 8 deletions

View File

@ -49,6 +49,9 @@ class Principal implements BackendInterface {
/** @var string */
private $principalPrefix;
/** @var bool */
private $hasGroups;
/**
* @param IUserManager $userManager
* @param IGroupManager $groupManager
@ -60,6 +63,7 @@ class Principal implements BackendInterface {
$this->userManager = $userManager;
$this->groupManager = $groupManager;
$this->principalPrefix = trim($principalPrefix, '/');
$this->hasGroups = ($principalPrefix === 'principals/users/');
}
/**
@ -141,13 +145,15 @@ class Principal implements BackendInterface {
throw new Exception('Principal not found');
}
$groups = $this->groupManager->getUserGroups($user);
$groups = array_map(function($group) {
/** @var IGroup $group */
return $this->principalPrefix . '/' . $group->getGID();
}, $groups);
if ($this->hasGroups) {
$groups = $this->groupManager->getUserGroups($user);
$groups = array_map(function($group) {
/** @var IGroup $group */
return 'principals/groups/' . $group->getGID();
}, $groups);
return $groups;
return $groups;
}
}
return [];
}

View File

@ -202,16 +202,26 @@ class Principal extends TestCase {
public function testGetGroupMembership() {
$fooUser = $this->getMockBuilder('\OC\User\User')
->disableOriginalConstructor()->getMock();
$group = $this->getMockBuilder('\OCP\IGroup')
->disableOriginalConstructor()->getMock();
$group->expects($this->once())
->method('getGID')
->willReturn('group1');
$this->userManager
->expects($this->once())
->method('get')
->with('foo')
->willReturn($fooUser);
$this->groupManager
->expects($this->once())
->method('getUserGroups')
->willReturn([]);
->willReturn([
$group
]);
$expectedResponse = [];
$expectedResponse = [
'principals/groups/group1'
];
$response = $this->connector->getGroupMembership('principals/users/foo');
$this->assertSame($expectedResponse, $response);
}