gitlabhq/app/controllers/projects_controller.rb

124 lines
3.1 KiB
Ruby
Raw Normal View History

2011-11-13 00:30:51 +02:00
require File.join(Rails.root, 'lib', 'graph_commit')
2011-10-09 00:36:38 +03:00
class ProjectsController < ApplicationController
before_filter :project, :except => [:index, :new, :create]
2011-10-28 15:07:58 +03:00
layout :determine_layout
2011-10-09 00:36:38 +03:00
# Authorize
before_filter :add_project_abilities
before_filter :authorize_read_project!, :except => [:index, :new, :create]
before_filter :authorize_admin_project!, :only => [:edit, :update, :destroy]
2011-12-04 22:34:39 +02:00
before_filter :require_non_empty_project, :only => [:blob, :tree, :graph]
2011-10-15 18:51:58 +03:00
2011-10-09 00:36:38 +03:00
def index
@limit, @offset = (params[:limit] || 16), (params[:offset] || 0)
2011-12-20 08:29:14 +02:00
@projects = current_user.projects.limit(@limit).offset(@offset)
2011-10-15 00:05:41 +03:00
end
def new
@project = Project.new
end
def edit
end
def create
@project = Project.new(params[:project])
@project.owner = current_user
Project.transaction do
2011-10-15 00:05:41 +03:00
@project.save!
2012-02-16 09:03:55 +02:00
@project.users_projects.create!(:project_access => UsersProject::MASTER, :user => current_user)
# when project saved no team member exist so
# project repository should be updated after first user add
@project.update_repository
2011-10-15 00:05:41 +03:00
end
respond_to do |format|
if @project.valid?
format.html { redirect_to @project, notice: 'Project was successfully created.' }
format.js
2011-10-15 00:05:41 +03:00
else
format.html { render action: "new" }
format.js
end
end
2011-12-05 09:43:53 +02:00
rescue Gitlabhq::Gitolite::AccessDenied
render :js => "location.href = '#{errors_githost_path}'" and return
2011-10-15 00:05:41 +03:00
rescue StandardError => ex
@project.errors.add(:base, "Cant save project. Please try again later")
respond_to do |format|
format.html { render action: "new" }
format.js
end
end
2011-10-09 00:36:38 +03:00
2011-10-15 00:05:41 +03:00
def update
2011-10-09 00:36:38 +03:00
respond_to do |format|
2011-10-15 00:05:41 +03:00
if project.update_attributes(params[:project])
format.html { redirect_to edit_project_path(project), :notice => 'Project was successfully updated.' }
format.js
2011-10-15 00:05:41 +03:00
else
format.html { render action: "edit" }
format.js
2011-10-15 00:05:41 +03:00
end
2011-10-09 00:36:38 +03:00
end
end
def show
2011-12-30 08:54:42 +02:00
return render "projects/empty" unless @project.repo_exists? && @project.has_commits?
2012-01-28 16:47:55 +02:00
limit = (params[:limit] || 10).to_i
@activities = @project.activities(limit)
end
def files
2011-12-30 21:56:34 +02:00
@notes = @project.notes.where("attachment != 'NULL'").order("created_at DESC").limit(100)
end
2011-10-15 00:05:41 +03:00
#
# Wall
#
2011-10-15 00:05:41 +03:00
def wall
return render_404 unless @project.wall_enabled
2011-10-15 00:05:41 +03:00
@note = Note.new
2011-10-21 14:25:42 +03:00
2011-11-15 12:34:30 +04:00
respond_to do |format|
2011-11-04 09:37:38 -04:00
format.html
end
2011-10-15 00:05:41 +03:00
end
2011-11-13 00:30:51 +02:00
def graph
2012-02-05 21:26:04 +02:00
render_full_content
2011-11-27 17:35:49 +02:00
@days_json, @commits_json = GraphCommit.to_graph(project)
2011-11-13 00:30:51 +02:00
end
2011-10-09 00:36:38 +03:00
def destroy
# Disable the UsersProject update_repository call, otherwise it will be
# called once for every person removed from the project
UsersProject.skip_callback(:destroy, :after, :update_repository)
2011-10-09 00:36:38 +03:00
project.destroy
UsersProject.set_callback(:destroy, :after, :update_repository)
2011-10-09 00:36:38 +03:00
respond_to do |format|
format.html { redirect_to projects_url }
end
end
protected
2011-10-09 00:36:38 +03:00
def project
2011-10-09 00:36:38 +03:00
@project ||= Project.find_by_code(params[:id])
@project || render_404
2011-10-09 00:36:38 +03:00
end
2011-10-28 15:07:58 +03:00
def determine_layout
if @project && !@project.new_record?
"project"
else
"application"
end
end
2011-10-09 00:36:38 +03:00
end