teams_controller.rb 2.68 KB
class TeamsController < ApplicationController
  respond_to :html
  layout 'user_team',       only: [:show, :edit, :update, :destroy, :issues, :merge_requests, :search]

  before_filter :user_team, only: [:show, :edit, :update, :destroy, :issues, :merge_requests, :search]
  before_filter :projects,  only: [:show, :edit, :update, :destroy, :issues, :merge_requests, :search]

  # Authorize
  before_filter :authorize_manage_user_team!, only: [:edit, :update]
  before_filter :authorize_admin_user_team!, only: [:destroy]

  def index
    @teams = UserTeam.all
  end

  def show
    @events = Event.in_projects(project_ids).limit(20).offset(params[:offset] || 0)

    respond_to do |format|
      format.html
      format.js
      format.atom { render layout: false }
    end
  end

  def edit

  end

  def update
    if user_team.update_attributes(params[:user_team])
      redirect_to team_path(user_team)
    else
      render action: :edit
    end
  end

  def destroy
    user_team.destroy
    redirect_to teams_path
  end

  def new
    @team = UserTeam.new
  end

  def create
    @team = UserTeam.new(params[:user_team])
    @team.owner = current_user unless params[:owner]
    @team.path = @team.name.dup.parameterize if @team.name

    if @team.save
      redirect_to team_path(@team)
    else
      render action: :new
    end
  end

  # Get authored or assigned open merge requests
  def merge_requests
    @merge_requests = MergeRequest.of_user_team(@user_team)
    @merge_requests = FilterContext.new(@merge_requests, params).execute
    @merge_requests = @merge_requests.recent.page(params[:page]).per(20)
  end

  # Get only assigned issues
  def issues
    @issues = Issue.of_user_team(@user_team)
    @issues = FilterContext.new(@issues, params).execute
    @issues = @issues.recent.page(params[:page]).per(20)
    @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

    @projects       = result[:projects]
    @merge_requests = result[:merge_requests]
    @issues         = result[:issues]
    @wiki_pages     = result[:wiki_pages]
  end

  protected

  def user_team
    @user_team ||= UserTeam.find_by_path(params[:id])
  end

  def projects
    @projects ||= user_team.projects.sorted_by_activity
  end

  def project_ids
    projects.map(&:id)
  end

  def authorize_manage_user_team!
    unless user_team.present? or can?(current_user, :manage_user_team, user_team)
      return render_404
    end
  end

  def authorize_admin_user_team!
    unless user_team.owner == current_user || current_user.admin?
      return render_404
    end
  end
end