2014-03-26 11:09:39 +00:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: issues
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# title :string(255)
|
|
|
|
# status :integer
|
|
|
|
# assigned_id :integer
|
|
|
|
# category_id :integer
|
|
|
|
# text :text
|
|
|
|
# author_id :integer
|
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# solution :text
|
|
|
|
# text_parsed :text
|
|
|
|
#
|
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
class Issue < ActiveRecord::Base
|
2014-04-01 23:07:21 +00:00
|
|
|
include Extra
|
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
STATUS_OPEN = 0
|
|
|
|
STATUS_SOLVED = 1
|
|
|
|
STATUS_REJECTED = 2
|
|
|
|
|
2017-07-02 19:16:16 +00:00
|
|
|
CATEGORY_WEBSITE = 17
|
|
|
|
CATEGORY_NSLPLUGIN = 20
|
|
|
|
CATEGORY_LEAGUE = 22
|
2017-07-02 20:48:33 +00:00
|
|
|
CATEGORY_GATHER = 54
|
2017-07-02 19:16:16 +00:00
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
attr_accessor :assigned_name
|
|
|
|
attr_protected :id, :created_at, :updated_at
|
|
|
|
|
|
|
|
has_many :comments, :as => :commentable
|
|
|
|
belongs_to :category
|
|
|
|
belongs_to :author, :class_name => "User"
|
|
|
|
belongs_to :assigned, :class_name => "User"
|
|
|
|
|
|
|
|
scope :unread_by,
|
|
|
|
lambda { |user| {
|
|
|
|
:joins => "LEFT JOIN readings ON readable_type = 'Issue' AND readable_id = issues.id AND readings.user_id = #{user.id}",
|
|
|
|
:conditions => "readings.user_id IS NULL"} }
|
2019-10-10 19:12:17 +00:00
|
|
|
scope :with_status, -> (s) { where(status: s) }
|
2014-03-23 00:22:25 +00:00
|
|
|
|
|
|
|
validates_length_of :title, :in => 1..50
|
|
|
|
validates_length_of :text, :in => 1..65000
|
|
|
|
validate :validate_status
|
|
|
|
|
|
|
|
before_validation :init_variables, :if => Proc.new{|issue| issue.new_record?}
|
|
|
|
before_save :parse_text
|
|
|
|
after_save :remove_readings
|
|
|
|
|
|
|
|
acts_as_readable
|
|
|
|
|
|
|
|
def to_s
|
|
|
|
title
|
|
|
|
end
|
|
|
|
|
|
|
|
def status_s
|
|
|
|
statuses[status]
|
|
|
|
end
|
|
|
|
|
|
|
|
def statuses
|
|
|
|
{STATUS_OPEN => "Open", STATUS_SOLVED => "Solved", STATUS_REJECTED => "Rejected"}
|
|
|
|
end
|
|
|
|
|
|
|
|
def color
|
|
|
|
if status == STATUS_SOLVED
|
|
|
|
"green"
|
|
|
|
elsif status == STATUS_OPEN
|
|
|
|
"yellow"
|
|
|
|
elsif status == STATUS_REJECTED
|
|
|
|
"red"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def init_variables
|
|
|
|
self.assigned = User.find_by_username(assigned_name) if assigned_name
|
|
|
|
self.status = STATUS_OPEN unless status
|
|
|
|
end
|
|
|
|
|
|
|
|
def validate_status
|
|
|
|
errors.add :status, I18n.t(:invalid_status) unless statuses.include? status
|
|
|
|
end
|
|
|
|
|
|
|
|
def parse_text
|
2014-03-30 19:50:52 +00:00
|
|
|
if self.text
|
|
|
|
self.text_parsed = bbcode_to_html(self.text)
|
|
|
|
end
|
2014-03-23 00:22:25 +00:00
|
|
|
end
|
|
|
|
|
2014-04-05 00:37:52 +00:00
|
|
|
def solution_formatted
|
|
|
|
bbcode_to_html(solution)
|
|
|
|
end
|
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
def remove_readings
|
|
|
|
if status_changed? and status == STATUS_SOLVED
|
|
|
|
Reading.delete_all ["readable_type = 'Issue' AND readable_id = ?", self.id]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_show? cuser
|
2017-07-02 19:16:16 +00:00
|
|
|
return false unless cuser
|
|
|
|
return true if cuser.admin?
|
|
|
|
|
|
|
|
((author == cuser) or (Issue::allowed_categories(cuser).include?(self.category_id)))
|
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
end
|
|
|
|
|
2015-06-07 09:20:23 +00:00
|
|
|
def can_create? cuser
|
|
|
|
true
|
2014-03-23 00:22:25 +00:00
|
|
|
end
|
|
|
|
|
2017-06-24 18:43:42 +00:00
|
|
|
def can_update?(cuser, params = {})
|
2017-07-02 19:16:16 +00:00
|
|
|
return false unless cuser
|
|
|
|
return true if cuser.admin?
|
|
|
|
return false unless Issue::allowed_categories(cuser).include?(self.category_id)
|
|
|
|
!(params.member?(:category_id) && (self.category_id.to_s != params[:category_id]))
|
2014-03-23 00:22:25 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def can_destroy? cuser
|
|
|
|
cuser and cuser.admin?
|
|
|
|
end
|
2017-06-24 18:43:42 +00:00
|
|
|
|
|
|
|
# STATIC METHODS
|
|
|
|
|
|
|
|
def self.allowed_categories cuser
|
|
|
|
allowed = []
|
2017-07-02 19:16:16 +00:00
|
|
|
allowed << CATEGORY_GATHER if cuser.admin? || cuser.gather_moderator? # gather
|
|
|
|
allowed << CATEGORY_WEBSITE if cuser.admin? # website
|
|
|
|
allowed << CATEGORY_LEAGUE if cuser.admin? # league
|
|
|
|
allowed << CATEGORY_NSLPLUGIN if cuser.admin? # ensl plugin
|
2017-06-24 18:43:42 +00:00
|
|
|
allowed
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2014-03-23 00:22:25 +00:00
|
|
|
end
|