gitlabhq/app/models/event.rb

159 lines
2.9 KiB
Ruby
Raw Normal View History

2012-02-28 15:09:23 +02:00
class Event < ActiveRecord::Base
include PushEvent
attr_accessible :project, :action, :data, :author_id, :project_id,
:target_id, :target_type
default_scope where("author_id IS NOT NULL")
Created = 1
Updated = 2
Closed = 3
Reopened = 4
Pushed = 5
Commented = 6
Merged = 7
2012-09-09 23:18:28 +03:00
Joined = 8 # User joined project
2012-09-10 00:27:47 +03:00
Left = 9 # User left project
2012-09-26 23:20:36 -07:00
delegate :name, :email, to: :author, prefix: true, allow_nil: true
delegate :title, to: :issue, prefix: true, allow_nil: true
delegate :title, to: :merge_request, prefix: true, allow_nil: true
2012-09-27 23:23:11 +03:00
belongs_to :author, class_name: "User"
2012-02-28 15:09:23 +02:00
belongs_to :project
belongs_to :target, polymorphic: true
2012-04-04 02:49:58 +03:00
# For Hash only
serialize :data
scope :recent, order("created_at DESC")
scope :code_push, where(action: Pushed)
def self.determine_action(record)
if [Issue, MergeRequest].include? record.class
Event::Created
elsif record.kind_of? Note
Event::Commented
end
end
def self.recent_for_user user
where(project_id: user.projects.map(&:id)).recent
end
# Next events currently enabled for system
# - push
# - new issue
# - merge request
2012-03-01 20:47:57 +02:00
def allowed?
2012-09-10 00:27:47 +03:00
push? || issue? || merge_request? || membership_changed?
2012-03-01 20:47:57 +02:00
end
def project_name
if project
project.name
else
"(deleted)"
end
end
def push?
action == self.class::Pushed && valid_push?
end
def merged?
action == self.class::Merged
end
def closed?
action == self.class::Closed
end
def reopened?
action == self.class::Reopened
end
def issue?
target_type == "Issue"
end
def merge_request?
target_type == "MergeRequest"
2012-03-06 00:29:40 +02:00
end
def new_issue?
target_type == "Issue" &&
action == Created
end
def new_merge_request?
target_type == "MergeRequest" &&
action == Created
end
def changed_merge_request?
target_type == "MergeRequest" &&
[Closed, Reopened].include?(action)
end
def changed_issue?
target_type == "Issue" &&
[Closed, Reopened].include?(action)
end
2012-09-09 23:18:28 +03:00
def joined?
2012-09-10 00:27:47 +03:00
action == Joined
end
def left?
action == Left
end
def membership_changed?
joined? || left?
2012-09-09 23:18:28 +03:00
end
def issue
target if target_type == "Issue"
end
def merge_request
target if target_type == "MergeRequest"
end
def author
@author ||= User.find(author_id)
end
def action_name
if closed?
"closed"
elsif merged?
"merged"
2012-09-09 23:18:28 +03:00
elsif joined?
'joined'
2012-09-10 00:27:47 +03:00
elsif left?
'left'
else
"opened"
end
end
2012-02-28 15:09:23 +02:00
end
2012-09-26 23:20:36 -07:00
2012-02-28 15:09:23 +02:00
# == Schema Information
#
# Table name: events
#
2012-09-26 22:36:31 -07:00
# id :integer not null, primary key
# target_type :string(255)
2012-09-26 22:36:31 -07:00
# target_id :integer
# title :string(255)
# data :text
2012-09-26 22:36:31 -07:00
# project_id :integer
# created_at :datetime not null
# updated_at :datetime not null
2012-09-26 22:36:31 -07:00
# action :integer
# author_id :integer
2012-02-28 15:09:23 +02:00
#