summaryrefslogtreecommitdiff
path: root/app/Model/ProjectGroupRole.php
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2016-01-18 21:20:35 -0500
committerFrederic Guillot <fred@kanboard.net>2016-01-18 21:20:35 -0500
commitddb73063a7889c8dad79dd7148c01c9bc845d9f0 (patch)
tree89fcc0a11721b75c6ac823f6229ef2e836917e90 /app/Model/ProjectGroupRole.php
parentbcbb3297860a8fe106094fefc04f74af4e30aed2 (diff)
Return the highest role for a project when a user is member of multiple groups
Diffstat (limited to 'app/Model/ProjectGroupRole.php')
-rw-r--r--app/Model/ProjectGroupRole.php6
1 files changed, 4 insertions, 2 deletions
diff --git a/app/Model/ProjectGroupRole.php b/app/Model/ProjectGroupRole.php
index 2fe22ca6..ee6ee7cb 100644
--- a/app/Model/ProjectGroupRole.php
+++ b/app/Model/ProjectGroupRole.php
@@ -48,11 +48,13 @@ class ProjectGroupRole extends Base
*/
public function getUserRole($project_id, $user_id)
{
- return $this->db->table(self::TABLE)
+ $roles = $this->db->table(self::TABLE)
->join(GroupMember::TABLE, 'group_id', 'group_id', self::TABLE)
->eq(GroupMember::TABLE.'.user_id', $user_id)
->eq(self::TABLE.'.project_id', $project_id)
- ->findOneColumn('role');
+ ->findAllByColumn('role');
+
+ return $this->projectAccessMap->getHighestRole($roles);
}
/**