gitlabhq/app/models/event.rb

129 lines
2.4 KiB
Ruby
Raw Normal View History

2012-02-28 15:09:23 +02:00
class Event < ActiveRecord::Base
include PushEvent
default_scope where("author_id IS NOT NULL")
Created = 1
Updated = 2
Closed = 3
Reopened = 4
Pushed = 5
Commented = 6
Merged = 7
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?
push? || issue? || merge_request?
2012-03-01 20:47:57 +02:00
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
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"
else
"opened"
end
end
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-02-28 15:09:23 +02:00
end
# == Schema Information
#
# Table name: events
#
2012-06-26 21:23:09 +03:00
# id :integer(4) not null, primary key
# target_type :string(255)
2012-06-26 21:23:09 +03:00
# target_id :integer(4)
# title :string(255)
# data :text
2012-06-26 21:23:09 +03:00
# project_id :integer(4)
# created_at :datetime not null
# updated_at :datetime not null
2012-06-26 21:23:09 +03:00
# action :integer(4)
# author_id :integer(4)
2012-02-28 15:09:23 +02:00
#