mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-07 13:41:42 +08:00
init project
This commit is contained in:
81
app/models/project.rb
Normal file
81
app/models/project.rb
Normal file
@@ -0,0 +1,81 @@
|
||||
class Project < ApplicationRecord
|
||||
include Matchable
|
||||
include Publicable
|
||||
include Watchable
|
||||
include ProjectOperable
|
||||
|
||||
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 :project_trends, dependent: :destroy
|
||||
|
||||
has_many :commits, dependent: :destroy
|
||||
|
||||
has_one :project_score, dependent: :destroy
|
||||
has_one :repository, dependent: :destroy
|
||||
has_many :issue_tags, dependent: :destroy
|
||||
has_many :issue_statuses, dependent: :destroy
|
||||
has_many :pull_requests, dependent: :destroy
|
||||
|
||||
has_many :issues, dependent: :destroy
|
||||
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"
|
||||
|
||||
after_save :check_project_members
|
||||
scope :project_statics_select, -> {select(:id,:name, :is_public, :identifier, :status, :project_type, :user_id, :forked_count, :visits, :project_category_id, :project_language_id, :license_id, :ignore_id, :watchers_count, :created_on)}
|
||||
|
||||
|
||||
# 创建者
|
||||
def creator
|
||||
User.find(user_id).full_name
|
||||
end
|
||||
|
||||
def members_user_infos
|
||||
members.joins("left join users on members.user_id = users.id").includes(:user)
|
||||
# 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
|
||||
|
||||
def get_issues_count(status_id)
|
||||
if status_id.present?
|
||||
self&.issues.issue_issue.select(:id, :status_id).where(status_id: status_id)&.pluck(:id).size
|
||||
else
|
||||
self&.issues.issue_issue.select(:id)&.pluck(:id).size
|
||||
end
|
||||
end
|
||||
|
||||
def get_pull_requests_count(status_id)
|
||||
if status_id.present?
|
||||
self&.pull_requests.select(:id, :status).where(status: status_id)&.pluck(:id).size
|
||||
else
|
||||
self&.pull_requests.select(:id)&.pluck(:id).size
|
||||
end
|
||||
end
|
||||
|
||||
#创建项目管理员
|
||||
def check_project_members
|
||||
unless members.present? && members.exists?(user_id: self.user_id)
|
||||
member_params = {
|
||||
user_id: self.user_id,
|
||||
project_id: self.id
|
||||
}
|
||||
user_member = Member.new(member_params)
|
||||
if user_member.save
|
||||
MemberRole.create(member_id: user_member.id ,role_id: 3)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
Reference in New Issue
Block a user