diff options
author | Vincent Petry <pvince81@owncloud.com> | 2016-05-11 12:39:22 +0200 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2016-05-20 17:56:02 +0200 |
commit | b5eb3d9e5a7edf61bfc3f4243533de9ca4afa8d4 (patch) | |
tree | a203c5b863b77a4de2c3db1f2b099268a8ffc712 /lib/private | |
parent | 3cd65fe25dc6f213dd7e4a1687616dc5e0960d4d (diff) | |
download | nextcloud-server-b5eb3d9e5a7edf61bfc3f4243533de9ca4afa8d4.tar.gz nextcloud-server-b5eb3d9e5a7edf61bfc3f4243533de9ca4afa8d4.zip |
Add system tag assignability check with groups
Whenever a user is not an admin, a tag is visible but not
user-assignable, check whether the user is a member of the allowed
groups.
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/SystemTag/SystemTagManager.php | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/private/SystemTag/SystemTagManager.php b/lib/private/SystemTag/SystemTagManager.php index 1c91ad1f578..832afc2a114 100644 --- a/lib/private/SystemTag/SystemTagManager.php +++ b/lib/private/SystemTag/SystemTagManager.php @@ -337,6 +337,7 @@ class SystemTagManager implements ISystemTagManager { * {@inheritdoc} */ public function canUserAssignTag(ISystemTag $tag, IUser $user) { + // early check to avoid unneeded group lookups if ($tag->isUserAssignable() && $tag->isUserVisible()) { return true; } @@ -345,6 +346,18 @@ class SystemTagManager implements ISystemTagManager { return true; } + if (!$tag->isUserVisible()) { + return false; + } + + $groupIds = $this->groupManager->getUserGroupIds($user->getUID()); + if (!empty($groupIds)) { + $matchingGroups = array_intersect($groupIds, $this->getTagGroups($tag)); + if (!empty($matchingGroups)) { + return true; + } + } + return false; } |