summaryrefslogtreecommitdiff
path: root/app/finders/joined_groups_finder.rb
diff options
context:
space:
mode:
authorAlfredo Sumaran <alfredo@gitlab.com>2016-03-22 11:13:27 -0500
committerAlfredo Sumaran <alfredo@gitlab.com>2016-03-22 11:13:27 -0500
commita42b2c388df5154eecefd8eb7d8a68373e794d6e (patch)
tree7cfcbca6f78d66fb05d56586f322067dcb4d9c92 /app/finders/joined_groups_finder.rb
parent647f28bd1d92eabe239a7f0f4a65eb100c0cda73 (diff)
parent18c049886e0f9ad2d094f02483aea272d0e029fb (diff)
downloadgitlab-ce-a42b2c388df5154eecefd8eb7d8a68373e794d6e.tar.gz
Merge branch 'master' into issue_7959
Diffstat (limited to 'app/finders/joined_groups_finder.rb')
-rw-r--r--app/finders/joined_groups_finder.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/app/finders/joined_groups_finder.rb b/app/finders/joined_groups_finder.rb
new file mode 100644
index 00000000000..47174980258
--- /dev/null
+++ b/app/finders/joined_groups_finder.rb
@@ -0,0 +1,24 @@
+class JoinedGroupsFinder < UnionFinder
+ def initialize(user)
+ @user = user
+ end
+
+ # Finds the groups of the source user, optionally limited to those visible to
+ # the current user.
+ def execute(current_user = nil)
+ segments = all_groups(current_user)
+
+ find_union(segments, Group).order_id_desc
+ end
+
+ private
+
+ def all_groups(current_user)
+ groups = []
+
+ groups << @user.authorized_groups.visible_to_user(current_user) if current_user
+ groups << @user.authorized_groups.public_to_user(current_user)
+
+ groups
+ end
+end