gitlab-org--gitlab-foss/app/controllers/projects_controller.rb

196 lines
5.1 KiB
Ruby
Raw Normal View History

class ProjectsController < ApplicationController
skip_before_filter :authenticate_user!, only: [:show]
before_filter :project, except: [:new, :create]
before_filter :repository, except: [:new, :create]
2011-10-08 17:36:38 -04:00
# Authorize
before_filter :authorize_read_project!, except: [:index, :new, :create]
before_filter :authorize_admin_project!, only: [:edit, :update, :destroy, :transfer, :archive, :unarchive, :retry_import]
before_filter :require_non_empty_project, only: [:blob, :tree, :graph]
2011-10-15 11:51:58 -04:00
2013-06-10 14:40:23 -04:00
layout 'navless', only: [:new, :create, :fork]
2013-06-07 10:31:12 -04:00
before_filter :set_title, only: [:new, :create]
2012-09-26 16:24:52 -04:00
2011-10-14 17:05:41 -04:00
def new
@project = Project.new
end
def edit
2013-06-19 15:44:57 -04:00
render 'edit', layout: "project_settings"
2011-10-14 17:05:41 -04:00
end
def create
@project = ::Projects::CreateService.new(current_user, params[:project]).execute
flash[:notice] = 'Project was successfully created.' if @project.saved?
2011-10-14 17:05:41 -04:00
respond_to do |format|
format.js
end
end
2011-10-08 17:36:38 -04:00
2011-10-14 17:05:41 -04:00
def update
status = ::Projects::UpdateService.new(@project, current_user, params).execute
2011-10-08 17:36:38 -04:00
respond_to do |format|
if status
flash[:notice] = 'Project was successfully updated.'
2013-05-24 17:07:19 -04:00
format.html { redirect_to edit_project_path(@project), notice: 'Project was successfully updated.' }
format.js
2011-10-14 17:05:41 -04:00
else
format.html { render "edit", layout: "project_settings" }
format.js
2011-10-14 17:05:41 -04:00
end
2011-10-08 17:36:38 -04:00
end
end
def transfer
::Projects::TransferService.new(project, current_user, params).execute
2011-10-08 17:36:38 -04:00
end
def show
if @project.import_in_progress?
redirect_to import_project_path(@project)
return
end
return authenticate_user! unless @project.public? || current_user
limit = (params[:limit] || 20).to_i
@events = @project.events.recent
@events = event_filter.apply_filter(@events)
@events = @events.limit(limit).offset(params[:offset] || 0)
2012-03-02 17:09:17 -05:00
respond_to do |format|
2012-06-01 02:42:02 -04:00
format.html do
if @project.empty_repo?
render "projects/empty", layout: user_layout
else
@last_push = current_user.recent_push(@project.id) if current_user
render :show, layout: user_layout
end
2012-03-02 17:09:17 -05:00
end
format.json { pager_json("events/_events", @events.count) }
2012-03-02 17:09:17 -05:00
end
end
def import
if project.import_finished?
redirect_to @project
return
end
end
def retry_import
unless @project.import_failed?
redirect_to import_project_path(@project)
end
@project.import_url = params[:project][:import_url]
if @project.save
@project.reload
@project.import_retry
end
redirect_to import_project_path(@project)
end
2011-10-08 17:36:38 -04:00
def destroy
2012-12-04 22:14:05 -05:00
return access_denied! unless can?(current_user, :remove_project, project)
2013-01-05 05:12:02 -05:00
project.team.truncate
2011-10-08 17:36:38 -04:00
project.destroy
respond_to do |format|
2012-06-22 15:39:03 -04:00
format.html { redirect_to root_path }
2011-10-08 17:36:38 -04:00
end
end
def fork
@forked_project = ::Projects::ForkService.new(project, current_user).execute
respond_to do |format|
format.html do
2013-06-10 14:40:23 -04:00
if @forked_project.saved? && @forked_project.forked?
redirect_to(@forked_project, notice: 'Project was successfully forked.')
else
2013-06-10 14:40:23 -04:00
@title = 'Fork project'
render "fork"
end
end
format.js
end
end
def autocomplete_sources
2014-03-25 07:40:49 -04:00
note_type = params['type']
note_id = params['type_id']
participating = if note_type && note_id
participants_in(note_type, note_id)
else
[]
end
2014-03-25 08:10:32 -04:00
team_members = sorted(@project.team.members)
2014-03-25 07:40:49 -04:00
participants = team_members + participating
@suggestions = {
2014-03-24 09:22:11 -04:00
emojis: Emoji.names.map { |e| { name: e, path: view_context.image_url("emoji/#{e}.png") } },
issues: @project.issues.select([:iid, :title, :description]),
mergerequests: @project.merge_requests.select([:iid, :title, :description]),
2014-03-25 09:00:43 -04:00
members: participants.uniq
}
respond_to do |format|
format.json { render :json => @suggestions }
end
end
2013-06-07 10:31:12 -04:00
def archive
return access_denied! unless can?(current_user, :archive_project, project)
project.archive!
respond_to do |format|
format.html { redirect_to @project }
end
end
def unarchive
return access_denied! unless can?(current_user, :archive_project, project)
project.unarchive!
respond_to do |format|
format.html { redirect_to @project }
end
end
2013-06-07 10:31:12 -04:00
private
def set_title
@title = 'New Project'
end
def user_layout
current_user ? "projects" : "public_projects"
end
2014-03-25 07:40:49 -04:00
def participants_in(type, id)
2014-03-25 08:10:32 -04:00
users = case type
when "Issue"
issue = @project.issues.find_by_iid(id)
issue ? issue.participants : []
when "MergeRequest"
merge_request = @project.merge_requests.find_by_iid(id)
merge_request ? merge_request.participants : []
when "Commit"
author_ids = Note.for_commit_id(id).pluck(:author_id).uniq
User.where(id: author_ids)
else
[]
end
2014-03-25 08:10:32 -04:00
sorted(users)
end
def sorted(users)
users.uniq.sort_by(&:username).map { |user| { username: user.username, name: user.name } }
2014-03-25 07:40:49 -04:00
end
2011-10-08 17:36:38 -04:00
end