gitlabhq/app/models/project.rb

197 lines
5.2 KiB
Ruby
Raw Normal View History

2011-10-09 00:36:38 +03:00
require "grit"
class Project < ActiveRecord::Base
include Repository
include ProjectPush
include Authority
include Team
#
# Relations
#
2011-10-09 22:36:57 +03:00
belongs_to :owner, :class_name => "User"
has_many :users, :through => :users_projects
has_many :events, :dependent => :destroy
2011-11-28 09:39:43 +02:00
has_many :merge_requests, :dependent => :destroy
has_many :issues, :dependent => :destroy, :order => "closed, created_at DESC"
2012-04-09 00:28:58 +03:00
has_many :milestones, :dependent => :destroy
2011-10-09 00:36:38 +03:00
has_many :users_projects, :dependent => :destroy
has_many :notes, :dependent => :destroy
has_many :snippets, :dependent => :destroy
has_many :deploy_keys, :dependent => :destroy, :foreign_key => "project_id", :class_name => "Key"
has_many :hooks, :dependent => :destroy, :class_name => "ProjectHook"
has_many :wikis, :dependent => :destroy
has_many :protected_branches, :dependent => :destroy
2011-11-04 09:42:36 +02:00
attr_accessor :error_code
#
# Protected attributes
#
2011-10-09 04:05:31 -07:00
attr_protected :private_flag, :owner_id
2011-10-09 00:36:38 +03:00
#
# Scopes
#
2011-10-09 00:36:38 +03:00
scope :public_only, where(:private_flag => false)
2012-02-11 19:56:18 +02:00
scope :without_user, lambda { |user| where("id not in (:ids)", :ids => user.projects.map(&:id) ) }
2011-10-09 00:36:38 +03:00
def self.active
joins(:issues, :notes, :merge_requests).order("issues.created_at, notes.created_at, merge_requests.created_at DESC")
end
2012-03-16 01:14:39 +02:00
def self.search query
where("name like :query or code like :query or path like :query", :query => "%#{query}%")
end
def self.create_by_user(params, user)
project = Project.new params
Project.transaction do
project.owner = user
project.save!
# Add user as project master
project.users_projects.create!(:project_access => UsersProject::MASTER, :user => user)
# when project saved no team member exist so
# project repository should be updated after first user add
project.update_repository
end
project
rescue Gitlab::Gitolite::AccessDenied => ex
project.error_code = :gitolite
project
rescue => ex
project.error_code = :db
project.errors.add(:base, "Cant save project. Please try again later")
project
end
def git_error?
error_code == :gitolite
end
def saved?
id && valid?
end
#
# Validations
#
validates :name,
:uniqueness => true,
:presence => true,
:length => { :within => 0..255 }
validates :path,
:uniqueness => true,
:presence => true,
2012-06-28 00:47:12 +03:00
:format => { :with => /^[a-zA-Z][a-zA-Z0-9_\-\.]*$/,
:message => "only letters, digits & '_' '-' '.' allowed. Letter should be first" },
:length => { :within => 0..255 }
validates :description,
:length => { :within => 0..2000 }
validates :code,
:presence => true,
:uniqueness => true,
2012-06-28 00:47:12 +03:00
:format => { :with => /^[a-zA-Z][a-zA-Z0-9_\-\.]*$/,
:message => "only letters, digits & '_' '-' '.' allowed. Letter should be first" },
:length => { :within => 1..255 }
validates :owner, :presence => true
validate :check_limit
validate :repo_name
def check_limit
unless owner.can_create_project?
errors[:base] << ("Your own projects limit is #{owner.projects_limit}! Please contact administrator to increase it")
end
rescue
errors[:base] << ("Cant check your ability to create project")
2011-10-09 00:36:38 +03:00
end
def repo_name
if path == "gitolite-admin"
errors.add(:path, " like 'gitolite-admin' is not allowed")
end
end
2012-07-15 15:29:06 +03:00
def self.access_options
UsersProject.access_roles
end
def to_param
code
2011-11-06 22:38:08 +02:00
end
def web_url
[Gitlab.config.url, code].join("/")
2011-12-13 23:24:31 +02:00
end
2011-10-09 00:36:38 +03:00
def common_notes
2011-11-15 04:09:07 -05:00
notes.where(:noteable_type => ["", nil]).inc_author_project
2011-10-09 00:36:38 +03:00
end
def build_commit_note(commit)
notes.new(:noteable_id => commit.id, :noteable_type => "Commit")
2011-10-09 00:36:38 +03:00
end
def commit_notes(commit)
2012-01-10 22:08:46 +02:00
notes.where(:noteable_id => commit.id, :noteable_type => "Commit", :line_code => nil)
end
def commit_line_notes(commit)
2012-01-19 21:44:10 +02:00
notes.where(:noteable_id => commit.id, :noteable_type => "Commit").where("line_code is not null")
2011-10-09 00:36:38 +03:00
end
2011-10-09 00:36:38 +03:00
def public?
!private_flag
end
def private?
private_flag
end
2011-11-15 12:34:30 +04:00
def last_activity
events.last || nil
2011-10-31 22:57:16 +02:00
end
def last_activity_date
2012-03-01 20:40:32 +02:00
if events.last
events.last.created_at
else
2012-03-01 20:40:32 +02:00
updated_at
end
2012-03-01 20:40:32 +02:00
end
2012-03-06 00:26:40 +02:00
def project_id
self.id
end
2011-10-09 00:36:38 +03:00
end
2012-03-06 00:26:40 +02:00
2011-10-09 00:36:38 +03:00
# == Schema Information
#
# Table name: projects
#
2012-06-26 21:23:09 +03:00
# id :integer(4) not null, primary key
# name :string(255)
# path :string(255)
# description :text
2012-06-26 21:23:09 +03:00
# created_at :datetime not null
# updated_at :datetime not null
# private_flag :boolean(1) default(TRUE), not null
# code :string(255)
2012-06-26 21:23:09 +03:00
# owner_id :integer(4)
# default_branch :string(255) default("master"), not null
2012-06-26 21:23:09 +03:00
# issues_enabled :boolean(1) default(TRUE), not null
# wall_enabled :boolean(1) default(TRUE), not null
# merge_requests_enabled :boolean(1) default(TRUE), not null
# wiki_enabled :boolean(1) default(TRUE), not null
2011-10-09 00:36:38 +03:00
#