application_controller.rb 1.0 KB
Newer Older
V
Valery Sizov 已提交
1
class Groups::ApplicationController < ApplicationController
2 3
  include RoutableActions

4
  layout 'group'
D
Douwe Maan 已提交
5 6

  skip_before_action :authenticate_user!
7
  before_action :group
V
Valery Sizov 已提交
8 9

  private
10 11

  def group
D
Douwe Maan 已提交
12
    unless @group
13 14
      given_path = params[:group_id] || params[:id]
      @group = Group.find_by_full_path(given_path, follow_redirects: request.get?)
D
Douwe Maan 已提交
15

16 17 18
      if @group && can?(current_user, :read_group, @group)
        ensure_canonical_path(@group, given_path)
      else
D
Douwe Maan 已提交
19
        @group = nil
20

21
        route_not_found
22 23
      end
    end
D
Douwe Maan 已提交
24 25 26 27 28

    @group
  end

  def group_projects
29
    @projects ||= GroupProjectsFinder.new(group: group, current_user: current_user).execute
30
  end
31

32 33 34 35
  def group_merge_requests
    @group_merge_requests = MergeRequestsFinder.new(current_user, group_id: @group.id).execute
  end

V
Valery Sizov 已提交
36
  def authorize_admin_group!
37
    unless can?(current_user, :admin_group, group)
V
Valery Sizov 已提交
38 39 40
      return render_404
    end
  end
41

D
Douwe Maan 已提交
42 43 44 45 46
  def authorize_admin_group_member!
    unless can?(current_user, :admin_group_member, group)
      return render_403
    end
  end
V
Valery Sizov 已提交
47
end