gitlabhq/app/models/project.rb

119 lines
3.2 KiB
Ruby
Raw Normal View History

2011-10-09 00:36:38 +03:00
require "grit"
class Project < ActiveRecord::Base
2011-10-09 22:36:57 +03:00
belongs_to :owner, :class_name => "User"
does "project/validations"
does "project/repository"
does "project/permissions"
does "project/hooks"
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 => "position"
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 :web_hooks, :dependent => :destroy
has_many :wikis, :dependent => :destroy
has_many :protected_branches, :dependent => :destroy
2011-11-04 09:42:36 +02:00
2011-10-09 04:05:31 -07:00
attr_protected :private_flag, :owner_id
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
def self.access_options
2012-02-16 09:03:55 +02:00
UsersProject.access_roles
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
2011-10-09 00:36:38 +03:00
def to_param
code
end
def web_url
[GIT_HOST['host'], code].join("/")
end
2011-11-06 22:38:08 +02:00
def team_member_by_name_or_email(email = nil, name = nil)
user = users.where("email like ? or name like ?", email, name).first
users_projects.find_by_user_id(user.id) if user
end
2011-12-13 23:24:31 +02:00
def team_member_by_id(user_id)
users_projects.find_by_user_id(user_id)
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
#
# id :integer not null, primary key
# name :string(255)
# path :string(255)
# description :text
# created_at :datetime
# updated_at :datetime
# private_flag :boolean default(TRUE), not null
# code :string(255)
# owner_id :integer
# default_branch :string(255) default("master"), not null
# issues_enabled :boolean default(TRUE), not null
# wall_enabled :boolean default(TRUE), not null
# merge_requests_enabled :boolean default(TRUE), not null
2012-02-28 15:09:23 +02:00
# wiki_enabled :boolean default(TRUE), not null
2011-10-09 00:36:38 +03:00
#