2012-10-02 19:42:15 +02:00
|
|
|
class GroupsController < ApplicationController
|
|
|
|
respond_to :html
|
|
|
|
layout 'group'
|
|
|
|
|
|
|
|
before_filter :group
|
|
|
|
before_filter :projects
|
|
|
|
|
2012-11-29 16:17:01 +01:00
|
|
|
# Authorize
|
|
|
|
before_filter :authorize_read_group!
|
|
|
|
|
2012-10-02 19:42:15 +02:00
|
|
|
def show
|
2012-10-09 21:09:46 +02:00
|
|
|
@events = Event.in_projects(project_ids).limit(20).offset(params[:offset] || 0)
|
2012-10-02 19:42:15 +02: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
|
2013-01-07 19:48:57 +01:00
|
|
|
@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 19:42:15 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
# Get only assigned issues
|
|
|
|
def issues
|
2013-01-07 19:48:57 +01:00
|
|
|
@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 19:42:15 +02:00
|
|
|
@issues = @issues.includes(:author, :project)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html
|
|
|
|
format.atom { render layout: false }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def search
|
2012-10-09 21:09:46 +02:00
|
|
|
result = SearchContext.new(project_ids, params).execute
|
2012-10-02 19:42:15 +02:00
|
|
|
|
2012-10-09 21:09:46 +02:00
|
|
|
@projects = result[:projects]
|
|
|
|
@merge_requests = result[:merge_requests]
|
|
|
|
@issues = result[:issues]
|
2013-01-07 19:48:57 +01:00
|
|
|
@wiki_pages = result[:wiki_pages]
|
2012-10-02 19:42:15 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def people
|
2012-11-29 18:14:05 +01:00
|
|
|
@project = group.projects.find(params[:project_id]) if params[:project_id]
|
|
|
|
@users = @project ? @project.users : group.users
|
2012-12-14 06:14:05 +01:00
|
|
|
@users.sort_by!(&:name)
|
2012-11-29 18:14:05 +01:00
|
|
|
|
|
|
|
if @project
|
|
|
|
@team_member = @project.users_projects.new
|
2012-12-25 23:52:49 +01:00
|
|
|
else
|
|
|
|
@team_member = UsersProject.new
|
2012-11-29 18:14:05 +01:00
|
|
|
end
|
2012-10-02 19:42:15 +02:00
|
|
|
end
|
|
|
|
|
2012-12-25 23:52:49 +01:00
|
|
|
def team_members
|
2012-12-26 17:30:11 +01:00
|
|
|
@group.add_users_to_project_teams(params[:user_ids], params[:project_access])
|
2012-12-25 23:52:49 +01:00
|
|
|
redirect_to people_group_path(@group), notice: 'Users was successfully added.'
|
|
|
|
end
|
|
|
|
|
2012-10-02 19:42:15 +02:00
|
|
|
protected
|
|
|
|
|
|
|
|
def group
|
2012-11-23 20:31:09 +01:00
|
|
|
@group ||= Group.find_by_path(params[:id])
|
2012-10-02 19:42:15 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def projects
|
2013-01-02 18:00:00 +01:00
|
|
|
@projects ||= current_user.authorized_projects.where(namespace_id: group.id).sorted_by_activity
|
2012-10-02 19:42:15 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def project_ids
|
|
|
|
projects.map(&:id)
|
|
|
|
end
|
2012-11-29 16:17:01 +01:00
|
|
|
|
|
|
|
# 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 19:42:15 +02:00
|
|
|
end
|