diff --git a/apps/dav/lib/connector/sabre/principal.php b/apps/dav/lib/connector/sabre/principal.php
index 4f26390e3cc5f5f8974f9e8198c59dc8092f8ed1..a573124007d831eea97da072be25a35f379afa27 100644
--- a/apps/dav/lib/connector/sabre/principal.php
+++ b/apps/dav/lib/connector/sabre/principal.php
@@ -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 [];
 	}
diff --git a/apps/dav/tests/unit/connector/sabre/principal.php b/apps/dav/tests/unit/connector/sabre/principal.php
index 07bfd5d263b985b2f77f5db76002d72320bc59fe..1747885240ab48314dc3b16dcc8978ec54d7349e 100644
--- a/apps/dav/tests/unit/connector/sabre/principal.php
+++ b/apps/dav/tests/unit/connector/sabre/principal.php
@@ -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);
 	}