class Project < ApplicationRecord include Matchable include Publicable enum project_type: { mirror: 1, common: 0 } # common:开源托管项目, mirror:开源镜像项目 belongs_to :ignore, optional: true belongs_to :license, optional: true belongs_to :owner, class_name: 'User', foreign_key: :user_id belongs_to :project_category , :counter_cache => true belongs_to :project_language , :counter_cache => true has_many :commits has_many :members has_many :manager_members, -> { joins(:roles).where(roles: { name: 'Manager' }) }, class_name: 'Member' has_one :project_score, dependent: :destroy has_one :repository, dependent: :destroy has_many :issue_tags has_many :issue_statuses has_many :issues has_many :user_grades, dependent: :destroy has_many :attachments, as: :container, dependent: :destroy has_one :project_score, dependent: :destroy has_many :versions, -> { order("versions.effective_date DESC, versions.name DESC") }, dependent: :destroy has_many :praise_treads, as: :praise_tread_object, dependent: :destroy has_and_belongs_to_many :trackers, :order => "#{Tracker.table_name}.position" # 创建者 def creator User.find(user_id).full_name end def project_members self.members end def member?(user) members.exists?(user_id: user.id) end def members_user_infos members.joins("left join users on members.user_id = users.id").select("users.id", "users.login","users.firstname","users.lastname") .pluck("users.id", "users.login","users.lastname", "users.firstname") end def to_param self.identifier.parameterize end end