Sha256: 6bfa85bccd2a1d4ea37eec2c1be7223cbf49ae6224a4f3fdb082bbc923b123bc
Contents?: true
Size: 1.97 KB
Versions: 7
Compression:
Stored size: 1.97 KB
Contents
module Effective class Log < ActiveRecord::Base self.table_name = EffectiveLogging.logs_table_name.to_s # These 3 attr_accessors are set on the controller #show actions attr_accessor :datatable attr_accessor :next_log attr_accessor :prev_log # Self-Referencing relationship belongs_to :parent, :class_name => 'Effective::Log', :counter_cache => true has_many :logs, :dependent => :destroy, :class_name => 'Effective::Log', :foreign_key => :parent_id # The user this log item is referring to # An associated object, if we wanna add anything extra belongs_to :user belongs_to :associated, :polymorphic => true serialize :details, Hash # structure do # logs_count :integer # Rails Counter Cache # message :string, :validates => [:presence] # details :text # status :string, :validates => [:presence, :inclusion => {:in => EffectiveLogging.statuses }] # timestamps # end validates_presence_of :message, :status validates_inclusion_of :status, in: EffectiveLogging.statuses default_scope -> { order("#{EffectiveLogging.logs_table_name.to_s}.updated_at DESC") } def log(message, status = EffectiveLogging.statuses.first, options = {}) EffectiveLogger.log(message, status, (options || {}).merge({:parent => self})) end def details ((self[:details] ||= {}) rescue {}) end # def next_log # @next_log ||= Log.unscoped.order(:id).where(:parent_id => self.parent_id).where('id > ?', self.id).first # end # def prev_log # @prev_log ||= Log.unscoped.order(:id).where(:parent_id => self.parent_id).where('id < ?', self.id).last # end # Dynamically add logging methods based on the defined statuses # EffectiveLogging.info 'my message' (EffectiveLogging.statuses || []).each do |status| send(:define_method, status) { |message, options={}| log(message, status, options) } end end end
Version data entries
7 entries across 7 versions & 1 rubygems