Sha256: b402bf16a54ef64e24658edd8d0c8135725d089d60167b8a42eafcc9cd4165ae
Contents?: true
Size: 1.97 KB
Versions: 6
Compression:
Stored size: 1.97 KB
Contents
class ManifestationReserveStat < ActiveRecord::Base include Statesman::Adapters::ActiveRecordQueries include CalculateStat default_scope {order('manifestation_reserve_stats.id DESC')} scope :not_calculated, -> {in_state(:pending)} has_many :reserve_stat_has_manifestations has_many :manifestations, through: :reserve_stat_has_manifestations belongs_to :user paginates_per 10 attr_accessor :mode has_many :manifestation_reserve_stat_transitions, autosave: false def state_machine ManifestationReserveStatStateMachine.new(self, transition_class: ManifestationReserveStatTransition) end delegate :can_transition_to?, :transition_to!, :transition_to, :current_state, to: :state_machine def calculate_count! self.started_at = Time.zone.now Manifestation.find_each do |manifestation| daily_count = manifestation.reserves.created(start_date.beginning_of_day, end_date.tomorrow.beginning_of_day).size # manifestation.update_attributes({daily_reserves_count: daily_count, total_count: manifestation.total_count + daily_count}) if daily_count > 0 manifestations << manifestation sql = ['UPDATE reserve_stat_has_manifestations SET reserves_count = ? WHERE manifestation_reserve_stat_id = ? AND manifestation_id = ?', daily_count, id, manifestation.id] ManifestationReserveStat.connection.execute( self.class.send(:sanitize_sql_array, sql) ) end end self.completed_at = Time.zone.now transition_to!(:completed) send_message end private def self.transition_class ManifestationReserveStatTransition end def self.initial_state :pending end end # == Schema Information # # Table name: manifestation_reserve_stats # # id :integer not null, primary key # start_date :datetime # end_date :datetime # note :text # created_at :datetime # updated_at :datetime # started_at :datetime # completed_at :datetime # user_id :integer #
Version data entries
6 entries across 6 versions & 1 rubygems