Sha256: 397d8497188283f7425022e9a7b76da9a74f0e8353c9aaa8d644449143b2f5d8
Contents?: true
Size: 1.4 KB
Versions: 7
Compression:
Stored size: 1.4 KB
Contents
class UserCheckoutStat < ActiveRecord::Base attr_accessible :start_date, :end_date, :note include CalculateStat default_scope :order => 'user_checkout_stats.id DESC' scope :not_calculated, where(:state => 'pending') has_many :checkout_stat_has_users has_many :users, :through => :checkout_stat_has_users state_machine :initial => :pending do before_transition :pending => :completed, :do => :calculate_count event :calculate do transition :pending => :completed end end paginates_per 10 def calculate_count self.started_at = Time.zone.now User.find_each do |user| daily_count = user.checkouts.completed(self.start_date, self.end_date).size if daily_count > 0 self.users << user sql = ['UPDATE checkout_stat_has_users SET checkouts_count = ? WHERE user_checkout_stat_id = ? AND user_id = ?', daily_count, self.id, user.id] ActiveRecord::Base.connection.execute( self.class.send(:sanitize_sql_array, sql) ) end end self.completed_at = Time.zone.now end end # == Schema Information # # Table name: user_checkout_stats # # id :integer not null, primary key # start_date :datetime # end_date :datetime # note :text # state :string(255) # created_at :datetime not null # updated_at :datetime not null # started_at :datetime # completed_at :datetime #
Version data entries
7 entries across 7 versions & 1 rubygems