gitlabhq/app/controllers/groups_controller.rb

89 lines
2.2 KiB
Ruby
Raw Normal View History

2012-10-02 20:42:15 +03:00
class GroupsController < ApplicationController
respond_to :html
layout 'group'
before_filter :group
before_filter :projects
# Authorize
before_filter :authorize_read_group!
2012-10-02 20:42:15 +03:00
def show
@events = Event.in_projects(project_ids).limit(20).offset(params[:offset] || 0)
2012-10-02 20:42:15 +03:00
@last_push = current_user.recent_push
respond_to do |format|
format.html
format.js
format.atom { render layout: false }
end
end
# Get authored or assigned open merge requests
def merge_requests
@merge_requests = current_user.cared_merge_requests.of_group(@group)
@merge_requests = FilterContext.new(@merge_requests, params).execute
@merge_requests = @merge_requests.recent.page(params[:page]).per(20)
2012-10-02 20:42:15 +03:00
end
# Get only assigned issues
def issues
@issues = current_user.assigned_issues.of_group(@group)
@issues = FilterContext.new(@issues, params).execute
@issues = @issues.recent.page(params[:page]).per(20)
2012-10-02 20:42:15 +03:00
@issues = @issues.includes(:author, :project)
respond_to do |format|
format.html
format.atom { render layout: false }
end
end
def search
result = SearchContext.new(project_ids, params).execute
2012-10-02 20:42:15 +03:00
@projects = result[:projects]
@merge_requests = result[:merge_requests]
@issues = result[:issues]
@wiki_pages = result[:wiki_pages]
2012-10-02 20:42:15 +03:00
end
def people
2012-11-29 20:14:05 +03:00
@project = group.projects.find(params[:project_id]) if params[:project_id]
@users = @project ? @project.users : group.users
@users.sort_by!(&:name)
2012-11-29 20:14:05 +03:00
if @project
@team_member = @project.users_projects.new
2012-12-26 02:52:49 +04:00
else
@team_member = UsersProject.new
2012-11-29 20:14:05 +03:00
end
2012-10-02 20:42:15 +03:00
end
2012-12-26 02:52:49 +04:00
def team_members
@group.add_users_to_project_teams(params[:user_ids], params[:project_access])
2012-12-26 02:52:49 +04:00
redirect_to people_group_path(@group), notice: 'Users was successfully added.'
end
2012-10-02 20:42:15 +03:00
protected
def group
2012-11-23 22:31:09 +03:00
@group ||= Group.find_by_path(params[:id])
2012-10-02 20:42:15 +03:00
end
def projects
@projects ||= current_user.authorized_projects.where(namespace_id: group.id).sorted_by_activity
2012-10-02 20:42:15 +03:00
end
def project_ids
projects.map(&:id)
end
# Dont allow unauthorized access to group
def authorize_read_group!
unless projects.present? or can?(current_user, :manage_group, @group)
return render_404
end
end
2012-10-02 20:42:15 +03:00
end