gitlabhq/app/models/project.rb

186 lines
5.5 KiB
Ruby
Raw Normal View History

2011-10-09 00:36:38 +03:00
require "grit"
class Project < ActiveRecord::Base
include Repository
2012-08-21 21:26:56 +03:00
include PushObserver
include Authority
include Team
attr_accessible :name, :path, :description, :code, :default_branch, :issues_enabled,
:wall_enabled, :merge_requests_enabled, :wiki_enabled
2012-09-26 23:20:36 -07:00
attr_accessor :error_code
# Relations
2012-10-02 18:17:12 +03:00
belongs_to :group
belongs_to :owner, class_name: "User"
has_many :users, through: :users_projects
has_many :events, dependent: :destroy
has_many :merge_requests, dependent: :destroy
has_many :issues, dependent: :destroy, order: "closed, created_at DESC"
has_many :milestones, dependent: :destroy
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
has_one :last_event, class_name: 'Event', order: 'events.created_at DESC', foreign_key: 'project_id'
2011-11-04 09:42:36 +02:00
delegate :name, to: :owner, allow_nil: true, prefix: true
2012-10-09 04:10:04 +04:00
# Validations
validates :owner, presence: true
validates :description, length: { within: 0..2000 }
validates :name, uniqueness: true, presence: true, length: { within: 0..255 }
validates :path, uniqueness: true, presence: true, length: { within: 0..255 },
format: { with: /\A[a-zA-Z][a-zA-Z0-9_\-\.]*\z/,
message: "only letters, digits & '_' '-' '.' allowed. Letter should be first" }
validates :code, presence: true, uniqueness: true, length: { within: 1..255 },
format: { with: /\A[a-zA-Z][a-zA-Z0-9_\-\.]*\z/,
message: "only letters, digits & '_' '-' '.' allowed. Letter should be first" }
validates :issues_enabled, :wall_enabled, :merge_requests_enabled,
:wiki_enabled, inclusion: { in: [true, false] }
validate :check_limit, :repo_name
# Scopes
scope :public_only, where(private_flag: false)
2012-10-03 14:26:37 +03:00
scope :without_user, ->(user) { where("id NOT IN (:ids)", ids: user.projects.map(&:id) ) }
scope :not_in_group, ->(group) { where("id NOT IN (:ids)", ids: group.project_ids ) }
2011-10-09 00:36:38 +03:00
2012-10-09 04:10:04 +04:00
class << self
def active
joins(:issues, :notes, :merge_requests).order("issues.created_at, notes.created_at, merge_requests.created_at DESC")
end
2012-10-09 04:10:04 +04:00
def search query
where("name LIKE :query OR code LIKE :query OR path LIKE :query", query: "%#{query}%")
end
2012-10-09 04:10:04 +04:00
def 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, "Can't save project. Please try again later")
project
end
2012-10-09 04:10:04 +04:00
def access_options
UsersProject.access_roles
end
end
def git_error?
error_code == :gitolite
end
def saved?
id && valid?
end
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
2012-08-10 19:47:54 -04:00
errors[:base] << ("Can't 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 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
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)
notes.where(noteable_id: commit.id, noteable_type: "Commit", line_code: nil)
2012-01-10 22:08:46 +02:00
end
def commit_line_notes(commit)
2012-10-04 13:40:40 +03: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
last_event
2011-10-31 22:57:16 +02:00
end
def last_activity_date
last_event.try(:created_at) || updated_at
2012-03-01 20:40:32 +02:00
end
def wiki_notes
2012-09-26 23:28:10 -07:00
Note.where(noteable_id: wikis.pluck(:id), noteable_type: 'Wiki', project_id: self.id)
end
2012-03-06 00:26:40 +02:00
def project_id
self.id
end
2012-10-09 20:39:06 +03:00
def issues_labels
issues.tag_counts_on(:labels)
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-09-26 22:36:31 -07:00
# id :integer 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
2012-09-26 22:36:31 -07:00
# private_flag :boolean default(TRUE), not null
# code :string(255)
2012-09-26 22:36:31 -07:00
# owner_id :integer
# default_branch :string(255)
2012-09-26 22:36:31 -07:00
# issues_enabled :boolean default(TRUE), not null
# wall_enabled :boolean default(TRUE), not null
# merge_requests_enabled :boolean default(TRUE), not null
# wiki_enabled :boolean default(TRUE), not null
2012-10-02 18:17:12 +03:00
# group_id :integer
2011-10-09 00:36:38 +03:00
#
2012-10-02 18:17:12 +03:00